OpenProject uses automated tests throughout the stack.
To run JavaScript frontend tests, first ensure you have all necessary
dependencies installed via npm (i.e. npm install
).
You can run all frontend tests with the standard npm command:
npm test
If you want a single test run, you can use npm run
:
npm run karma
By default tests will be run with PhantomJS and Firefox. To start a server or for more options, such as another browser, invoke the karma executable directly:
./node_modules/karma/bin/karma start
./node_modules/karma/bin/karma start --browsers Chrome,Firefox
If you want to run all tests with Protractor, you can use npm run
:
npm run protractor
This is a wrapper around a Gulp task. You can also:
gulp tests:protractor
The task takes care of:
- bundling assets using Webpack.
- running an Express server that serves the frontend application, in addition to mock API endpoints.
- running a Selenium Webdriver server.
If you want to follow these steps manually for any reason:
-
Ensure you have the the latest Selenium WebDriver:
npm install -g protractor webdriver-manager update
-
You can start the frontend application
gulp express
-
You can then proceed to start both the Selenium server and Protractor:
webdriver-manager start ./node_modules/protractor/bin/protractor protractor/conf.js
You can run the specs with the following commands:
bundle exec rake spec
Run all core specs with a random seedSPEC_OPTS="--seed 12935" bundle exec rake spec
Run the core specs with the seed 12935
TODO: how to run plugins specs.
The cucumber features can be run using rake. You can run the following
rake tasks using the command bundle exec rake <task>
.
-
cucumber
Run core features -
cucumber:plugins
Run plugin features -
cucumber:all
Run core and plugin features -
cucumber:custom[features]
: Run single features or folders of featuresExample:
cucumber:custom[features/issues/issue.feature]
-
When providing multiple features, the task name and arguments must be enclosed in quotation marks.
Example:
bundle exec rake "cucumber:custom[features/issues features/projects]"
-
cucumber:plugins
and cucumber:all
accept an optional parameter which
allows specifying custom options to cucumber. This can be used for
executing scenarios by name, e.g. "cucumber:all[-n 'Adding an issue link']"
.
Like with spaces in cucumber:custom
arguments, task name and arguments
have to be enclosed in quotation marks.
Here are two bash functions which allow using shorter commands for running cucumber features:
# Run OpenProject cucumber features (like arguments to the cucumber command)
# Example: cuke features/issues/issue.feature
cuke() { RAILS_ENV=test bundle exec rake "cucumber:custom[$*]"; }
# Run OpenProject cucumber scenarios by name
# Example: cuken Adding an issue link
cuken() { RAILS_ENV=test bundle exec rake "cucumber:all[-n '$*']"; }
Setting RAILS_ENV=test
allows the cucumber rake tasks to run the features
directly in the same process, so this reduces the time until the features are
running a bit (5-10 seconds) due to the Rails environment only being loaded
once.
To activate selenium as test driver to test javascript on web pages, you can add @javascript above the scenario like the following example shows:
@javascript
Scenario: Testing something with Javascript
When I ...
You can always start a debugger using the step "And I start debugging". If you need Firebug and Firepath while debugging a scenario, just replace @javascript with @firebug.
You can run a single test with the following command:
rake test:units TEST=path/to/test.rb TESTOPTS="--name=test_name_of_test_to_run"
You let test unit display test names instead of anonymous dots with the following command:
rake test:units TESTOPTS="--verbose=verbose"
- We are testing on travis-ci. Look there for your pull requests.
https://travis-ci.org/opf/openproject - If you have enabled the terminal bell, add
; echo -e "\a"
to the end of your test command. The terminal bell will then tell you when your tests finished.
- Sometimes you want to test things manually. Always remember: If you test something more than once, write an automated test for it.
- Assuming you do not have a version of Internet Explorer already installed on your computer, you can grab a VM with preinstalled IE's directly from Microsoft: http://www.modern.ie/en-us/virtualization-tools#downloads