Filesystem
Module for testing local filesystem.
Fork it to extend the module for FTP, Amazon S3, others.
Status
Module was developed to test Codeception itself.
Actions
amInPath
Enters a directory In local filesystem.
Project root directory is used by default
cleanDir
Erases directory contents
<?php
$I->cleanDir('logs');
?>
copyDir
Copies directory with all contents
<?php
$I->copyDir('vendor','old_vendor');
?>
param string
$src
param string
$dst
deleteDir
Deletes directory with all subdirectories
<?php
$I->deleteDir('vendor');
?>
deleteFile
Deletes a file
<?php
$I->deleteFile('composer.lock');
?>
deleteThisFile
Deletes a file
dontSeeFileFound
Checks if file does not exist in path
param string
$filename
param string
$path
dontSeeInThisFile
Checks If opened file doesn’t contain text
in it
<?php
$I->openFile('composer.json');
$I->dontSeeInThisFile('codeception/codeception');
?>
openFile
Opens a file and stores it’s content.
Usage:
<?php
$I->openFile('composer.json');
$I->seeInThisFile('codeception/codeception');
?>
seeFileContentsEqual
Checks the strict matching of file contents.
Unlike seeInThisFile
will fail if file has something more than expected lines.
Better to use with HEREDOC strings.
Matching is done after removing “\r” chars from file content.
<?php
$I->openFile('process.pid');
$I->seeFileContentsEqual('3192');
?>
seeFileFound
Checks if file exists in path.
Opens a file when it’s exists
<?php
$I->seeFileFound('UserModel.php','app/models');
?>
param string
$filename
param string
$path
seeInThisFile
Checks If opened file has text
in it.
Usage:
<?php
$I->openFile('composer.json');
$I->seeInThisFile('codeception/codeception');
?>
seeNumberNewLines
Checks If opened file has the number
of new lines.
Usage:
<?php
$I->openFile('composer.json');
$I->seeNumberNewLines(5);
?>
param int
$number New lines
seeThisFileMatches
Checks that contents of currently opened file matches $regex
writeToFile
Saves contents to file
param string
$filename
param string
$contents