2014-08-15 03:30:47 +04:00
This directory contains various tests for the basic application.
Tests in `codeception` directory are developed with [Codeception PHP Testing Framework ](http://codeception.com/ ).
2013-11-14 11:05:09 -05:00
2013-12-28 15:04:08 -05:00
After creating the basic application, follow these steps to prepare for the tests:
2013-11-14 11:05:09 -05:00
2014-08-15 03:30:47 +04:00
1. Install Codeception if it's not yet installed:
2015-05-10 01:01:36 +02:00
```
composer global require "codeception/codeception=2.0.*"
composer global require "codeception/specify=*"
composer global require "codeception/verify=*"
```
2014-08-15 03:30:47 +04:00
2015-05-10 01:01:36 +02:00
If you've never used Composer for global packages run `composer global status` . It should output:
2014-08-15 03:30:47 +04:00
2015-05-10 01:01:36 +02:00
```
Changed current directory to < directory >
```
2014-02-07 19:36:20 +04:00
2015-05-10 01:01:36 +02:00
Then add `<directory>/vendor/bin` to you `PATH` environment variable. Now we're able to use `codecept` from command
line globally.
2013-12-17 17:24:23 +01:00
2014-08-24 15:26:57 +04:00
2. Install faker extension by running the following from template root directory where `composer.json` is:
2015-05-10 01:01:36 +02:00
```
2015-10-21 18:06:24 -07:00
composer require --dev "yiisoft/yii2-faker:*"
2015-05-10 01:01:36 +02:00
```
2014-08-24 15:26:57 +04:00
2015-05-10 01:17:26 +02:00
3. Create `yii2_basic_tests` database and update it by applying migrations (you may skip this step if you do not have created any migrations yet):
2014-08-24 15:26:57 +04:00
2015-05-10 01:01:36 +02:00
```
2016-07-05 01:17:16 +03:00
cd tests
2015-05-10 01:01:36 +02:00
codeception/bin/yii migrate
```
2014-08-24 15:26:57 +04:00
2015-08-06 00:21:54 +02:00
The command needs to be run in the `tests` directory.
The database configuration can be found at `tests/codeception/config/config.php` .
2014-08-24 15:26:57 +04:00
4. Build the test suites:
2014-08-15 03:30:47 +04:00
2015-05-10 01:01:36 +02:00
```
codecept build
```
2014-08-15 03:30:47 +04:00
2016-07-02 20:22:42 +03:00
5. In order to be able to run acceptance tests you need to start a webserver. The simplest way is to use built-in Yii
command:
2014-08-15 03:30:47 +04:00
2015-05-10 01:01:36 +02:00
```
2016-07-02 20:22:42 +03:00
./yii serve
2015-05-10 01:01:36 +02:00
```
2013-11-14 11:11:51 -05:00
2014-08-24 15:26:57 +04:00
6. Now you can run the tests with the following commands:
2013-12-28 15:04:08 -05:00
2015-05-10 01:01:36 +02:00
```
# run all available tests
codecept run
# run acceptance tests
codecept run acceptance
# run functional tests
codecept run functional
# run unit tests
codecept run unit
```
2013-12-28 15:04:08 -05:00
2015-10-21 03:07:07 +02:00
Fixtures Default Configuration
------------------------------
The `fixture` commands refer to the following `ActiveFixture` configuration by default:
- Fixtures path: `@tests/unit/fixtures`
- Fixtures data path: `@tests/unit/fixtures/data`
- Template files path: `@tests/unit/templates/fixtures`
- Namespace: `tests\unit\fixtures`
Where `@tests` refers to `@app/tests/codeception` .
2014-12-10 22:44:27 +04:00
Code coverage support
---------------------
2014-12-10 23:01:08 +04:00
By default, code coverage is disabled in `codeception.yml` configuration file, you should uncomment needed rows to be able
2014-12-10 22:44:27 +04:00
to collect code coverage. You can run your tests and collect coverage with the following command:
```
#collect coverage for all tests
codecept run --coverage-html --coverage-xml
#collect coverage only for unit tests
codecept run unit --coverage-html --coverage-xml
#collect coverage for unit and functional tests
codecept run functional,unit --coverage-html --coverage-xml
```
You can see code coverage output under the `tests/_output` directory.
###Remote code coverage
When you run your tests not in the same process where code coverage is collected, then you should uncomment `remote` option and its
related options, to be able to collect code coverage correctly. To setup remote code coverage you should follow [instructions ](http://codeception.com/docs/11-Codecoverage )
from codeception site.
2014-12-10 22:46:53 +04:00
1. install `Codeception c3` remote support `composer require "codeception/c3:*"` ;
2014-12-10 22:44:27 +04:00
2014-12-10 22:46:53 +04:00
2. copy `c3.php` file under your `web` directory;
2014-12-10 22:44:27 +04:00
3. include `c3.php` file in your `index-test.php` file before application run, so it can catch needed requests.
2015-08-04 10:49:22 +02:00
4. edit `c3.php` to update config file path (~ line 55) with `$config_file = realpath(__DIR__ . '/../tests/codeception.yml');`
2015-08-04 10:18:35 +02:00
2014-12-10 22:44:27 +04:00
Configuration options that are used by remote code coverage:
- c3_url: url pointing to entry script that includes `c3.php` file, so `Codeception` will be able to produce code coverage;
- remote: whether to enable remote code coverage or not;
2014-12-10 23:01:08 +04:00
- remote_config: path to the `codeception.yml` configuration file, from the directory where `c3.php` file is located. This is needed
2014-12-10 22:44:27 +04:00
so that `Codeception` can create itself instance and collect code coverage correctly.
By default `c3_url` and `remote_config` setup correctly, you only need to copy and include `c3.php` file in your `index-test.php`
After that you should be able to collect code coverage from tests that run through `PhpBrowser` or `WebDriver` with same command
as for other tests:
```
#collect coverage from remote
codecept run acceptance --coverage-html --coverage-xml
```
2013-11-14 11:11:51 -05:00
Please refer to [Codeception tutorial ](http://codeception.com/docs/01-Introduction ) for
2013-12-28 15:04:08 -05:00
more details about writing and running acceptance, functional and unit tests.