Full-stack testing PHP framework
Failed to load latest commit information.
docs Document high_limiy and low_limit for codecoverage. Closes #3880 Jan 20, 2017
ext updated docs, added Codeception\Module reference and build script for it Dec 5, 2016
package added config:validate for phar builds Dec 5, 2016
src/Codeception version bump, year updated Jan 20, 2017
tests added test for #3865 Jan 20, 2017
.gitattributes added .gitattributes Jan 24, 2015
.gitignore merged with 2.1 Jun 7, 2016
.travis.yml [Travis] Run tests on PHP 7.1 (#3913) Jan 18, 2017
CHANGELOG.md added test for #3865 Jan 20, 2017
CONTRIBUTING.md Updated CONTRIBUTING.md (#3751) Nov 17, 2016
Dockerfile Feature/docker support (#3067) May 25, 2016
LICENSE Fixes #2207: added license file Jul 23, 2015
RoboFile.php updated docs Jan 17, 2017
appveyor.yml Added the actual cache to appveyor Sep 27, 2016
autoload.php Fixed redeclaring functions in autoload (#3575) Oct 6, 2016
codecept Added validate:config command (#3784) Nov 30, 2016
codecept.bat fix to #8 Feb 28, 2012
codeception.yml Moved HHVM builds to Wercker CI (#3809) Jan 17, 2017
composer.json Changed package name to codeception/codeception (#3885) Jan 11, 2017
nitpick.json added nitpick ignores Mar 22, 2016
readme.md version bump, year updated Jan 20, 2017
ruleset.xml PSR-2 compliance (#3105) May 16, 2016
shim.php shim to be autoloaded only for PHPUnit 5.4+ Jun 3, 2016
wercker.yml Moved HHVM builds to Wercker CI (#3809) Jan 17, 2017



Latest Stable Total Downloads Daily Downloads Gitter PHP 7 ready Scrutinizer Code Quality

Modern PHP Testing for everyone

Codeception is a modern full-stack testing framework for PHP. Inspired by BDD, it provides you an absolutely new way of writing acceptance, functional and even unit tests. Powered by PHPUnit.

General Windows Webdriver Facebook HHVM
Build Status Build status Build Status Facebook Status for Codeception/Codeception wercker status


At Codeception we are glad to receive contributions from the community. If you want to send additions or fixes to the code or the documentation please check the Contributing guide.

At a Glance

Describe what you test and how you test it. Use PHP to write descriptions faster.

Run tests and see what actions were taken and what results were seen.

Sample acceptance test


$I = new FunctionalTester($scenario);
$I->wantTo('create wiki page');
$I->see('New Page');
$I->submitForm('form#new_page', array('title' => 'Tree of Life Movie Review','body' => "Next time don't let Hollywood create art-house!"));
$I->see('page created'); // notice generated
$I->see('Tree of Life Movie Review','h1'); // head of page of is our title
$I->seeInCurrentUrl('pages/tree-of-life-movie-review'); // slug is generated
$I->seeInDatabase('pages', array('title' => 'Tree of Life Movie Review')); // data is stored in database

For unit testing you can stay on classic PHPUnit tests, as Codeception can run them too.


Documentation on Github

Documentation is currently included within the project. Look for it in the 'docs' directory.



Download codecept.phar

Copy it into your project.

You can also make Codeception an executable and it put it into your $PATH, for instance:

wget http://codeception.com/codecept.phar

chmod +x codecept.phar

sudo mv codecept.phar /usr/local/bin/codecept

You can then run Codecept in the command line using: codecept bootstrap, codecept run, etc

Run CLI utility:

php codecept.phar


php composer.phar require "codeception/codeception"

Read Also Installation | QuickStart

Getting Started

If you successfully installed Codeception, run this command:

codecept bootstrap

this will create a default directory structure and default test suites

See Documentation for more information.



(c) Michael Bodnarchuk "Davert" 2011-2017