Automated UI tests for the dashboard.
This is the best option for rapid iteration while writing a new test. ChromeDriver will run your tests in a new window on your machine.
cd
to the directory of this README.- if this is your first time running tests via chromedriver, run
bundle install
and thenrbenv rehash
./runner.rb -l
-l
makes it use the chromedriver, and specifies local dashboard and pegasus domains- By default, the tests run in "headless" mode, meaning with no visible chrome window.
- If you need to see what's happening, add the
--headed
flag. A chrome window will pop up in the background in which you can watch the tests happen
- In a separate window, run
tail -f *.log
from thelog
subdirectory to watch the results of your tests
-f
streams the log in your shell, so it will be updated as new lines are written
- To run a single ui test, you can simply run
rake test:ui feature=path/to/test.feature
If you get the error unknown error: cannot get automation extension
, follow the chromedriver-helper instructions to upgrade to latest chromedriver.
Running tests remotely on Saucelabs lets you review results, view visual logs of test runs and even watch live video of your tests running on different browsers in real-time.
We currently have 120 available browsers, and the automated ui tests attempt to run 110.
Saucelabs requires credentials to be set in locals.yml first.
# code-dot-org/locals.yml
saucelabs_username: 'yourusername'
saucelabs_authkey: 'xxxxxx-xxxx-xxxx-xxx-xxxxxxxxx'
You can find the values for these settings in your saucelabs account settings (https://app.saucelabs.com/users/:username
) The key you need, saucelabs_authkey
, will be under the "Access Key" header.
If you want to run tests on saucelabs against localhost you need to set up your tunnel:
- Login to Saucelabs and download the tunnel
- Start the tunnel via
~/bin/sc/ -u $SAUCELABS_USERNAME -k SAUCELABS_ACCESS_KEY
. Notes: The link above has an example command line with your credentials that you can copy.~/bin/sc/
should be replaced with the path that points to the tunnel software downloaded in step 1. - In a separate terminal window,
./runner.rb -d localhost-studio.code.org:3000 <whatever other arguments you want>
You can now watch your tests run at the saucelabs dashboard
Here are some example command line options. Run ./runner.rb --help
for a full list.
Run all UI tests on all browsers against your local host (by default, tests point to staging.code.org). Takes some around 45 minutes to run depending on your setup. If you are testing browsers against your localhost other than Chrome, you need to setup SauceConnect - instructions are here https://wiki.saucelabs.com/display/DOCS/Setting+Up+Sauce+Connect.
./runner.rb -d localhost-studio.code.org:3000
Alternatively, ./runner.rb -d localhost-studio.code.org:3000 -n <some number>
will run "some number" of tests in parallel - it might be faster though too high a number will overwhelm your host. 5 seems to work well.
Run all UI tests using the local chromedriver against your localhost. Faster than running through Saucelabs.
./runner.rb -l
Run all UI tests for a given browser/os combination - full list of combinations is in browsers.json
./runner.rb --config ChromeLatestWin7
Run all UI tests for a given browser
./runner.rb --browser Chrome
Run all tests in a given feature file for all browser/os combinations
./runner.rb --feature features/awesome_stuff.feature
Run exactly one UI test in a given feature file for all browser/os combinations
./runner.rb --feature features/awesome_stuff.feature:40
will run the feature on line 40
Run one feature using chromedriver against your local machine with html output
./runner.rb -l -f features/big_game_remix.feature --html
Run one feature in one saucelabs browser against your local machine with html output (requires SauceConnect, described earlier)
./runner.rb -l -f features/big_game_remix.feature -c ChromeLatestWin7 --html
Run eyes tests on one feature in one saucelabs browser against your local machine with html output (requires SauceConnect, described earlier)
./runner.rb -l -f features/angle_helper.feature -c ChromeLatestWin7 --html --eyes
- If you're new to Cucumber, read about Cucumber scenarios, especially the keywords Given When Then.
- When debugging test scripts, it can be helpful to add pauses, such as:
And I wait for 5 seconds
.