Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dollarshaveclub/e2e
Make End-to-End Testing Great For Once
https://github.com/dollarshaveclub/e2e
Last synced: 3 months ago
JSON representation
Make End-to-End Testing Great For Once
- Host: GitHub
- URL: https://github.com/dollarshaveclub/e2e
- Owner: dollarshaveclub
- License: mit
- Created: 2017-11-11T18:38:58.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2020-01-02T23:16:08.000Z (about 5 years ago)
- Last Synced: 2024-11-05T03:37:31.972Z (3 months ago)
- Language: JavaScript
- Homepage:
- Size: 241 KB
- Stars: 32
- Watchers: 23
- Forks: 3
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: CODEOWNERS
Awesome Lists containing this project
- awesome-puppeteer - e2e - End-to-end testing. (Testing)
- awesome-puppeteer-zh - e2e - 端到端测试. (测试 / 贡献)
README
# @dollarshaveclub/e2e
[![CircleCI](https://circleci.com/gh/dollarshaveclub/e2e/tree/master.svg?style=svg&circle-token=3c62580973ef5525cd6a68b7e57bd8d9e603a91e)](https://circleci.com/gh/dollarshaveclub/e2e/tree/master)
[![codecov](https://codecov.io/gh/dollarshaveclub/e2e/branch/master/graph/badge.svg?token=RL1k07t3tS)](https://codecov.io/gh/dollarshaveclub/e2e)
[![Greenkeeper badge](https://badges.greenkeeper.io/dollarshaveclub/e2e.svg?token=53420725e4efa55047668b13f8221d19e6c294e7783481a4300c63fbed4ba71c&ts=1510792360361)](https://greenkeeper.io/)A end-to-end test runner currently built for:
- Official Selenium Webdriver JS SDK - http://seleniumhq.github.io/selenium/docs/api/javascript/
- Google Chrome's Puppeteer - https://github.com/GoogleChrome/puppeteer
- Sauce LabsThis test runner mitigates test flakiness and maximizes test speed:
- Retry support - retry a test as many times as you'd like
- Retry local tests on Sauce Labs - if a local Selenium test keeps failing, retry it on Sauce Labs the logs, video, and screenshots
- Parallelism and concurrency - run local and remote tests with separate, configurable concurrencies
- Per-step timeouts - helps debug your E2E tests when your `await`s hang, which is the correct way to write Selenium testsIt also has features to make writing and running tests easier:
- Automatically setup and destroy your `selenium` or `puppeteer` driver so you don't have to
- Filter tests by browsers
- Filter tests by local or remote (Sauce Labs) tests
- Unwinding - easily run your tests multiple times with different parameters and clientsSee our [example tests](tests/).
## Installation
Install Selenium:
```bash
brew tap homebrew/cask
brew cask install chromedriver
brew install selenium-server-standalone geckodriver
```Start the Selenium server:
```bash
brew services start selenium-server-standalone
```Install node@8+:
```bash
nvm install 8
```## API
### Running Tests
Install this package:
```bash
npm install @dollarshaveclub/e2e
```Run the executable:
```bash
./node_modules/.bin/dsc-e2e -h
```### Tests
You can define multiple `clients` and multiple `parameters` per test.
If you have 5 clients and 5 parameters, your tests will run 5x5 = 25 times.
Keep this in mind as you add `clients` and `parameters`.#### exports.options\
Options for running the test.
Options are:
- `stepTimeout='30s'` - the default timeout for each `step`
- `stepSlowThreshold='5s'` - after this threshold is met for each `step`, the color of the step is `yellow`
- `retries=1` - number of times to retry a test
- `retryWithSauceLabs=true` - whether to retry failing tests on Sauce Labs when ran with Sauce Labs enabled
- `clients=[]` - an array of clients to test with.
- `browser='chrome'`
- `width=1280`
- `height=960`
- `platform={}` - the platform to run on, specifically on Sauce Labs
- `width=1280`
- `height=960`
- `driver='selenium'` - which driver to use.
- Valid values: `selenium`, `puppeteer`#### exports.parameters\
Various parameters to run your test.
Passed to your `.test` function and is intended to be used within it.
If your parameters is an array, your test will run for each value in the array.#### exports.test\({ step, parameters, ... })
Define your actual test in this function.
- `step` - define your tests in `step`s
- `parameters` - the parameters defined for your test via `exports.parameters`##### Selenium Options
- `driver` - the Selenium SDK driver instance
##### Puppeteer Options
- `browser` - Puppeteer browser instance
- `page` - a Puppeteer page instance#### step(name\, fn\, options\)
A step in your test. Think of this as a `test()` or `it()` from `mocha` or `jest`.
As this runner is designed for end-to-end tests, calling each code block `step`s
makes more sense than calling it `test()` or `it()`.
Unlike other frameworks, there is no nesting of `step()`s.For example, if are testing the end-to-end flow of a conversion funnel,
each action a user takes would be a `step`.
Practically, however, you should write each `await` within its own `step`.
The reason is many `await`s wait for a condition to occur, and the only way
to test that it does not occur is to timeout.Thus, the options for each `step` are:
- `timeout` - the timeout for this step
- `slowThreshold` - when this step is considered slow#### step.skip()
Same as `step()`, but is not actually ran.
#### exports.description
Description of your test.