# Codeception [![Latest Stable](https://poser.pugx.org/Codeception/Codeception/version.png)](https://packagist.org/packages/Codeception/Codeception) [![Total Downloads](https://poser.pugx.org/codeception/codeception/downloads.png)](https://packagist.org/packages/codeception/codeception) [![Daily Downloads](https://img.shields.io/packagist/dd/codeception/codeception.svg)](https://packagist.org/packages/codeception/codeception) [![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/Codeception/Codeception?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) [![PHP 7 ready](http://php7ready.timesplinter.ch/Codeception/Codeception/badge.svg)](https://travis-ci.org/Codeception/Codeception) [![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/Codeception/Codeception/badges/quality-score.png?b=2.2)](https://scrutinizer-ci.com/g/Codeception/Codeception/?branch=2.2) **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](https://secure.travis-ci.org/Codeception/Codeception.png?branch=2.2)](http://travis-ci.org/Codeception/Codeception) | [![Build status](https://ci.appveyor.com/api/projects/status/ntjj9i4y67d1rb7y?svg=true)](https://ci.appveyor.com/project/DavertMik/codeception/branch/2.2) | [![Build Status](https://semaphoreci.com/api/v1/codeception/codeception/branches/master/shields_badge.svg)](https://semaphoreci.com/codeception/codeception) | [ ![Facebook Status for Codeception/Codeception](https://codeship.com/projects/e4bc90d0-1ed5-0134-566c-1ed679ae6c9d/status?branch=2.2)](https://codeship.com/projects/160201) | [![wercker status](https://app.wercker.com/status/b4eecd0596bedb65333ff7ab7836bc7f/s/ "wercker status")](https://app.wercker.com/project/byKey/b4eecd0596bedb65333ff7ab7836bc7f) | #### Contributions 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](https://github.com/Codeception/Codeception/blob/2.0/CONTRIBUTING.md). ### 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 ``` php wantTo('create wiki page'); $I->amOnPage('/'); $I->click('Pages'); $I->click('New'); $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 [Documentation on Github](https://github.com/Codeception/Codeception/tree/master/docs) Documentation is currently included within the project. Look for it in the 'docs' directory. ## Installation ### Phar Download [codecept.phar](http://codeception.com/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 ``` ### Composer ``` php composer.phar require "codeception/codeception" ``` Read Also [Installation](http://codeception.com/install) | **[QuickStart](http://codeception.com/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. ### License MIT (c) Michael Bodnarchuk "Davert" 2011-2017