cw / behat_test
Installs: 874
Dependents: 0
Suggesters: 0
Security: 0
Stars: 9
Watchers: 7
Forks: 6
Open Issues: 2
pkg:composer/cw/behat_test
Requires
- drupal/drupal-extension: 3.2.2
- emuse/behat-html-formatter: 0.1.0
- phpunit/phpunit: *
- dev-master
- v1.3.3.8
- v1.3.3.7
- v1.3.3.6
- v1.3.3.5
- v1.3.3.4
- v1.3.3.3
- v1.3.3.2
- v1.3.3.1
- v1.3.3
- v1.3.2
- v1.3.1
- v1.3.0
- v1.2.9
- v1.2.8
- v1.2.7
- v1.2.6
- v1.2.5
- v1.2.4
- v1.2.3
- v1.2.2
- v1.2.1
- v1.2.0
- v1.1.9
- v1.1.8
- v1.1.7
- v1.1.6
- v1.1.5
- v1.1.4
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.13
- v1.0.12
- v1.0.11
- v1.0.10
- v1.0.9
- v1.0.8
- v1.0.7
- v1.0.6
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- dev-Amend-Article-tags
- dev-Update-HTML-reporting-paths
- dev-Remove-Page_Utils-directory
- dev-Updates_to_the_behat_yml
- dev-Updates_to_the_composer_json
- dev-7.x-1.x
- dev-8.x-1.x
- dev-develop
This package is not auto-updated.
Last update: 2025-10-26 01:22:18 UTC
README
| Link | What do you want to do? | 
|---|---|
| Initial Set-up | If you are the first person on the project to install this framework, please complete the initial set-up steps | 
| Onbording to a project | If the framework is already part of your project repo, please complete the onboarding steps | 
| Ongoing Update | If you are only updating the framework, please complete the ongoing update steps | 
| Test Execution | How to run tests? | 
| Test Results | Where to find the test results? | 
| Behat test writing process | How to write new tests? | 
Dependenices
Composer
This command will download and install Composer as a system-wide command named composer, under /usr/local/bin.
curl -sS https://getcomposer.org/installer | sudo php -- --install-dir=/usr/local/bin --filename=composer
Java
Java v1.7 is required.
INITIAL SET-UP
- Select a location for the framework
Create a folder, ideally in a Test folder in your project, outside your Drupal webroot.
- Create a composer JSON file Composer
Create a composer.json file in the test folder root.
{
  "require": {
    "cw/behat_test": "*"
  },
  "config": {
    "bin-dir": "bin/"
  },
  "autoload": {
    "psr-4": {
      "CWTest\\": "src/"
    }
  }
}
- Install via Composer
From the Test folder created st step 1, run:
composer install
- Create the Behat folder structure
Run the bootstrap shell script:
cd bin && ./cwtest-bootstrap.sh
cd ..
- Update your local configuration
In your Test folder, edit Behat/behat.local.yml. Update:
- the base_urlto your local site url
- the drupal_rootvalue to the path to your local drupal installation.
- Configure Chrome - Optional Step
This is only required if you want to run tests on Chrome. Skip to step 7 if you don't.
(By default, Firefox works out-of-the-box.)
- 
Download chromedriver from http://chromedriver.storage.googleapis.com/index.html?path=2.17/
- 
Save it to /usr/local/bin
- 
Verify Setup Successful 
Navigate to the Behat folder inside your Test folder:
cd Behat
Execute the following:
./run-behat.sh setup firefox
Selenium will launch and run a test. You should see 1 scenarios (1 passed) in the terminal window after 15-20 seconds.
ONBOARDING TO A PROJECT
- Install via Composer
From the project Test folder, run:
composer install
- Create the Behat folder structure
Run the bootstrap shell script:
cd bin && ./cwtest-bootstrap.sh
cd ..
- Update your local configuration
In your Test folder, edit Behat/behat.local.yml. Update:
- the base_urlto your local site url
- the drupal_rootvalue to the path to your local drupal installation.
- Configure Chrome - Optional Step
This is only required if you want to run tests on Chrome. Skip to step 7 if you don't.
(By default, Firefox works out-of-the-box.)
- 
Download chromedriver from http://chromedriver.storage.googleapis.com/index.html?path=2.17/
- 
Save it to /usr/local/bin
- 
Verify Setup Successful 
Navigate to the Behat folder inside your Test folder:
cd Behat
Execute the following:
./run-behat.sh setup firefox
Selenium will launch and run a test. You should see 1 scenarios (1 passed) in the terminal window after 15-20 seconds.
ONGOING UPDATE
- Update via Composer
From the project Test folder, run:
composer update
- Update the Behat folder structure
Run the bootstrap shell script:
cd bin && ./cwtest-bootstrap.sh
cd ..
Test Execution
Navigate to the Behat folder inside your Test folder:
cd Behat
To execute all of the tests, select one of the following options based on the format ./run-behat.sh [tag] [profile]:
./run-behat.sh regression firefox
or
./run-behat.sh regression chrome
Test Results
The results of all tests will be stored in /Results/Behat/Twig_***.html
Behat test writing process
It is a good idea to read through the LOGIN feature, page, and context files while reading through the following descriptions.
In the following, XXXX is the name of the page being tested, e.g. Basic, Article, Login, etc.
"ACTION" indicates a step that you have to do.
The basic process for writing any test would be:
1. SCENARIOS
Decide on a business scenario that you would like to automate.
This often comes from a User Story or piece of functionality that you'd like to test.
For the rest of the following, let's think of a login scenario where a user is going:
- open the login page
- enter a username and password.
- click the login button.
2. FEATURE file
This file contains the high-level test scenarios written in a Gherkin syntax.
These files are located in Behat/features/.
They all follow the naming convention XXXX.feature.
For example, in the LoginPage.feature, there are tests to ensure a valid login is successful.
ACTION: Create a .feature file, using the template provided, and write your scenario into the .feature file.
Follow the syntax used in other tests.
Where possible, re-use existing sentences from the .feature file as these will already have been automated.
If you are creating a new sentence, keep it short but descriptive.
- template - /Sample_Files/Behat/features/LoginPage.feature
- reference - Gherkin
3. PAGE.php file
This file contains the path, page objects, and getters/setters for all the fields on the page XXXX.
These files are located in src/Util/.
They all follow the naming convention XXXXPage.php.
For example, in the LoginPage.php, there are the username, password, and login button objects detailed.
ACTION: Create a Page.php file, and add the objects  to it.
For Create/Edit/View content types, you generally want to add every object that an end-user would use to the XXXXPage.php file.
Using the template provided, create your XXXXPage.php file.
Take care to separate textfields, buttons, frames, etc, and follow the syntax and naming conventions from other PAGE files.
Where possible, always use IDs for your objects. If IDs are not available, consider using name, data-drupal-selector, or xpath.
- template - /Sample_Files/src/Util/ArticlePage.php
4. CONTEXT.php file
This file contains all of the functions that are specific to the XXXX page.
These files are located in src/Context.
They all follow the naming convention XXXXContext.php.
For example, in the LoginContext.php, there are functions to fill in the username and password fields, and press the login button.
ACTION: Create a XXXXContext.php file, and add the relevant functions to interact with the objects from the Page.php file.
This file will detail function for interacting with your objects.
The number of functions you write will vary from context to context - typically, the more complicated a UI is, the more functions will be required.
Follow the syntax and naming conventions from other CONTEXT files.
Keep all functions as short as possible, ideally doing one thing each, like filling in a text field.
- template - /Sample_Files/src/Context/ArticleContext.php
- reference - Step definitions
- reference - Hooks
- reference - Contexts
5. behat.yml file
This file contains most of the configuration settings that are required for behat to run.
Every new feature file that gets created will require that a new entry is made to this file.
ACTION: Follow the example of the login from lines 3-15. Copy and paste this inside the default profile, and update the login values with the correct values.
TAGS
@todo: Please add section detailing the tagging process.
TROUBLESHOOTING
- 
If you get API rate limit messages during the ./bootstrap.shstep, please see: API rate limit and OAuth tokens.
- 
If you get the folowing when running the tests, please upgrade your version of java: Exception in thread "main" java.lang.UnsupportedClassVersionError: org/openqa/grid/selenium/GridLauncher : Unsupported major.minor version 51.0
- 
If you get errors related to timezone settings, add the following to your path profile (with the appropriate version of PHP): export PATH="/Applications/MAMP/bin/php/php5.6.7/bin:$PATH"
CREDITS
This work is sponsored and supported by Cameron & Wilding, a London Drupal Agency.