This extension requires:
- Behat 2.4+
- Set dependencies in your composer.json:
{
"require": {
...
"shvetsgroup/parallelrunner": "dev-master"
}
}
- Install/update your vendors:
$ curl http://getcomposer.org/installer | php
$ php composer.phar install
As a bare minimum requirement, activate extension in your behat.yml:
default:
extensions:
shvetsgroup\ParallelRunner\Extension: ~
In certain cases, it's useful to run testing processes in separate environments (e.g. if test results of one test could break other test's data). For this purpose, you should define behat profiles in your configuration file and pass their names to "profile" parameter of the extension like this:
default:
extensions:
shvetsgroup\ParallelRunner\Extension:
profiles:
- environment1
- environment2
...
environment1:
some_data: ...
environment2:
some_data: ...
Now, let's say you've run the test with 4 parallel processes. The first process will be launched with "environment1" profile, second with "environment2", and the rest with the default profile (or profile, which was passed in --config option).
If you want all of your tests to run in parallel, just specify default number of parallel processes in your configuration file. Note: this number can be overridden by --parallel option.
default:
extensions:
shvetsgroup\ParallelRunner\Extension:
process_count: 4
Use "--parallel" or "-l" parameter to specify number of concurrent test processes. For example:
$ bin/behat -l 4
-
If you're using Selenium, make sure it's launched in Hub mode to get all the benefits of parallelism (http://selenium-grid.seleniumhq.org/run_the_demo.html).
-
This extension does not work with features which have closures as definitions (you'll get "Serialization of 'Closure' is not allowed" errors most likely).