Docs about commands and testing dependencies

This commit is contained in:
Ingo Schommer 2012-11-09 20:30:56 +01:00
parent 599ac8a7fc
commit 66a07442cf
2 changed files with 38 additions and 6 deletions

View File

@ -18,10 +18,12 @@ It provides the following helpers:
* Provide access to SilverStripe classes in your Behat contexts * Provide access to SilverStripe classes in your Behat contexts
* Set up a temporary database automatically * Set up a temporary database automatically
* Reset the database content on every scenario * Reset the database content on every scenario
* Prebuilt Contexts for SilverStripe login * Prebuilt Contexts for SilverStripe's login forms and other common tasks
* Creating of member fixtures with predefined permissions * Creating of member fixtures with predefined permissions
* YML fixture definitions inside your Behat scenarios * YML fixture definitions inside your Behat scenarios
* Waiting for jQuery Ajax responses (rather than fixed wait timers) * Waiting for jQuery Ajax responses (rather than fixed wait timers)
* Captures JavaScript errors and logs them through Selenium
* Saves screenshots to filesystem whenever an assertion error is detected
In order to achieve this, the extension makes on basic assumption: In order to achieve this, the extension makes on basic assumption:
Your Behat tests are run from the same application as the tested Your Behat tests are run from the same application as the tested
@ -184,6 +186,20 @@ Selenium will also try to use chrome browser. Refer to `behat.yml` for details.
# This will run all feature tests using chrome profile # This will run all feature tests using chrome profile
vendor/behat --config mymodule/tests/behat/behat.yml --profile=chrome vendor/behat --config mymodule/tests/behat/behat.yml --profile=chrome
# This will run a specific feature test
vendor/behat --config mymodule/tests/behat/behat.yml mymodule/tests/behat/features/my-steps.feature
### Available Step Definitions
The extension comes with several `BehatContext` subclasses come with some extra step defintions.
Some of them are just helpful in general website testing, other's are specific to SilverStripe.
To find out all available steps (and the files they are defined in), run the following:
vendor/bin/behat --config mymodule/tests/behat/behat.yml --definitions=i
Note: There are more specific step definitions in the SilverStripe `framework` module
for interacting with the CMS interfaces (see `framework/tests/behat/features/bootstrap`).
### Fixtures ### Fixtures
Fixtures should be provided in YAML format (standard SilverStripe fixture format) Fixtures should be provided in YAML format (standard SilverStripe fixture format)
@ -256,6 +272,21 @@ It also populates this temporary database with the default records if necessary.
It is possible to include your own fixtures, it is explained further. It is possible to include your own fixtures, it is explained further.
### Why do tests pass in a fresh installation, but fail in my own project?
Because we're testing the interface directly, any changes to the
viewed elements have the potential to disrupt testing.
By building a test database from scratch, we're trying to minimize this impact.
Some examples where things can go wrong nevertheless:
* Thirdparty SilverStripe modules which install default data
* Changes to the default interface language
* Configurations which remove admin areas or specific fields
Currently there's no way to exclude offending modules from a test run.
You either have to adjust the tests to work around these changes,
or run tests on a "sandbox" projects without these modules.
### How do I debug when something goes wrong? ### How do I debug when something goes wrong?
First, read the console output. Behat will tell you which steps have failed. First, read the console output. Behat will tell you which steps have failed.

View File

@ -171,6 +171,7 @@ JS;
public function handleAjaxTimeout() public function handleAjaxTimeout()
{ {
// Wait for an ajax request to complete, but only for a maximum of 5 seconds to avoid deadlocks
$this->getSession()->wait(5000, $this->getSession()->wait(5000,
"(typeof window.__ajaxStatus !== 'undefined' ? window.__ajaxStatus() : 'no ajax') !== 'waiting'" "(typeof window.__ajaxStatus !== 'undefined' ? window.__ajaxStatus() : 'no ajax') !== 'waiting'"
); );
@ -252,17 +253,17 @@ JS;
} }
/** /**
* @Given /^I wait for "(\d+)"$/ * @Given /^I wait for ([\d\.]+) seconds$/
*/ */
public function stepIWaitFor($ms) public function stepIWaitFor($secs)
{ {
$this->getSession()->wait($ms); $this->getSession()->wait((float)$secs*1000);
} }
/** /**
* @Given /^I press "([^"]*)" button$/ * @Given /^I press the "([^"]*)" button$/
*/ */
public function stepIPressButton($button) public function stepIPressTheButton($button)
{ {
$page = $this->getSession()->getPage(); $page = $this->getSession()->getPage();