#GUIDE
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? |
##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
- Update your local configuration
Inside /Behat/behat.local.yml
, update:
- the
base_url
to your local site url - the
drupal_root
value to the path to your local drupal installation.
- Configure Chrome - Optional Step
This is only required if you want to run tests on Chrome.
(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:
/Behat
Execute the following:
./run-behat.sh setup firefox
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
- Update your local configuration
Inside /Behat/behat.local.yml
, update:
- the
base_url
to your local site url - the
drupal_root
value to the path to your local drupal installation.
- Configure Chrome - Optional Step
This is only required if you want to run tests on Chrome.
(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:
/Behat
Execute the following:
./run-behat.sh setup firefox
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
##Test Execution
Navigate to:
/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.
@todo: Please add section detailing the tagging process.
- If you get API rate limit messages during the
./bootstrap.sh
step, please see:
- 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"