You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

55 lines
1.6 KiB
Markdown

# Full E2E test suite with Cypress.io (for site:http://angularjs.realworld.io/) [WIP]
Goals:
- keep it simple - no abstractions/functions/utils/helpers
- tests are easily readable
- project is easily understandable even to people without previous JS or Cypress knowledge
![image](https://user-images.githubusercontent.com/48861601/110022516-af6f2400-7d34-11eb-8b13-f21789331cb3.png)
# 1. Setup
`npm install`
# 2. Run tests
cypress test runner (cypress __open__):
`npm run cypress open --env device=mob`
`npm run cypress open --env device=web`
cypress __headless mode__ (cypress run):
`npm run cypress run --env device=mob`
`npm run cypress run --env device=web`
# Information
Tests are located in `cypress/integration` folder
Configuration files:
1. `cypress.json`
2. `plugins/index.js`
Custom commands (shortcuts) are located in `cypress/support` folder (`.cmd.js` suffix)
Selectors are located in `cypress/selectors` folder [only difference from cypress default project structure]
- __not__ using page objects pattern but keeping selectors (only selectors) separately as they are not easily readable
# Q&A
1. Why mobile view is in config and not in test (like cy.viewport())?
- we can't change userAgent in the middle of the test:
https://github.com/cypress-io/cypress/issues/2100
So it seems more correct to launch the tests with the correct config (--env device=mob/web)
# __Following best practices__
1. https://www.youtube.com/watch?v=5XQOK0v_YRE&ab_channel=OKG%21
2. https://docs.cypress.io/guides/references/best-practices.html
3. https://docs.cypress.io/api/cypress-api/custom-commands.html#Best-Practices