data:image/s3,"s3://crabby-images/eba3a/eba3a4158df7fa27ce1156656b618e1ce911c397" alt=""
Why E2E tests and why Cypress
Advantages and Strengths of Cypress in E2E Testing
data:image/s3,"s3://crabby-images/a1693/a1693ff633fbe2a8041b00d38d84ea5fa1a5047c" alt=""
e2e tests are not a silver bullet
E2E
Integration
Unit
E2E
Integration
Unit
E2E
Integration
Unit
data:image/s3,"s3://crabby-images/dd5ca/dd5ca78f7c40604a16a929e4b3966109c8ffb4f7" alt=""
data:image/s3,"s3://crabby-images/c2751/c2751d73f3de875fe620e5782a1cc2836f8b9a99" alt=""
$$$
$
Cypress
data:image/s3,"s3://crabby-images/b204c/b204c57e39b0e61705a3dc3ae3f7c889dbcc4c17" alt=""
data:image/s3,"s3://crabby-images/89db9/89db918767e05b2099a513e444b99eda17bcec46" alt=""
Why Cypress?
-
Free and open source
-
Test modern apps directly in the browser
-
Write your first passing test in minutes
-
npm install --save-dev cypress
-
npx cypress open # generates cypress project
-
-
Debug failures directly in the browser:
-
Time Travel
-
Screenshots and Videos
-
Live Reload
-
data:image/s3,"s3://crabby-images/a0485/a04850e428c813494879a81513b4a70d6e0e7b85" alt=""
How to keep project healthy
Leveraging Regular Cypress E2E Test Execution with GitHub
data:image/s3,"s3://crabby-images/85785/8578594215a6f917acf9b32213682e901f1e309c" alt=""
Test execution
data:image/s3,"s3://crabby-images/539c8/539c83af8b76f88167cff45b45706d9fbf8062d2" alt=""
For every commit on:
-
prod/main/dev branches
-
Pull Request
- ?
Locally:
-
pre-commit - probably not
-
pre-push - well... probably nothing more than smoke tests
data:image/s3,"s3://crabby-images/76150/7615042388fdc94323b81936a3175cfd89fe59e7" alt=""
Cypress & Github configuration
Leveraging Regular Cypress E2E Test Execution with GitHub
data:image/s3,"s3://crabby-images/bce5e/bce5e58c61541f6bf517252eb497aaa3d86bcfbb" alt=""
GOAL: Cypress checks
data:image/s3,"s3://crabby-images/ec9bc/ec9bcb43d1f213252afc1efca26836209de25e5d" alt=""
data:image/s3,"s3://crabby-images/13edd/13edd4a495ba8bf98135743ddd32c8d4a0b4a36a" alt=""
Simple github Action
name: End-to-end tests
on: push
jobs:
cypress-run:
runs-on: ubuntu-22.04
steps:
- name: Checkout
uses: actions/checkout@v3
# build your dedicated instance here
- name: Cypress run
uses: cypress-io/github-action@v5
goal: videos & screenshots
data:image/s3,"s3://crabby-images/63d39/63d3900ea0ae06bb5144ed4360a5b87a13099500" alt=""
Storing Artifacts
name: Artifacts
on: push
jobs:
cypress-run:
runs-on: ubuntu-22.04
name: Artifacts
steps:
- uses: actions/checkout@v3
- uses: cypress-io/github-action@v5
- uses: actions/upload-artifact@v3
if: failure()
with:
name: cypress-screenshots
path: cypress/screenshots
- uses: actions/upload-artifact@v3
if: always()
with:
name: cypress-videos
path: cypress/videos
GOAL: Inline comments
data:image/s3,"s3://crabby-images/f84b1/f84b136d6d9958c7e231b94e75d3de7b93165e67" alt=""
data:image/s3,"s3://crabby-images/3b004/3b004e1071741ba3a4412bb4d25611f57134dd50" alt=""
data:image/s3,"s3://crabby-images/16d86/16d86d8eabb4b9d98dbe65e0933734e9daa209c3" alt=""
Cypress Cloud setup
cypress config file
data:image/s3,"s3://crabby-images/8e79f/8e79f4c4ea28d612fda8de6a1c8d91eea9d3a3bf" alt=""
data:image/s3,"s3://crabby-images/e64ae/e64ae115c940a383623654a052509f28efc7dccb" alt=""
GitHUB ACTIONs
data:image/s3,"s3://crabby-images/d3d19/d3d19dd890e34f7f729eaefa6c0ea41ea7057f48" alt=""
data:image/s3,"s3://crabby-images/52ad4/52ad457a8aaf13e998439b0785c4453bdfdce1b1" alt=""
data:image/s3,"s3://crabby-images/85a41/85a41340f8934db44806b7ba76b2a4455dc0400f" alt=""
data:image/s3,"s3://crabby-images/4dad1/4dad119a02a0c97cc5d49dcacd699443938fa878" alt=""
GitHUB integration
data:image/s3,"s3://crabby-images/ea844/ea844e4d8fdfa573accdf9965a092cc548e576f6" alt=""
DASHBOARD VIEW
data:image/s3,"s3://crabby-images/27cc5/27cc5713227de51fc3b120df7be9051fd3ab141e" alt=""
failed test video
data:image/s3,"s3://crabby-images/bbed3/bbed358fd9496392eb1b0d7697f304370b52383b" alt=""
Cypress Dashboards
Cypress Cloud vs. Alternative Solutions
data:image/s3,"s3://crabby-images/6a2c7/6a2c7604056ddfb129201659dae284004e316515" alt=""
Cypress vs. Currents vs. Sorry Cypress
data:image/s3,"s3://crabby-images/49805/49805cf30e53f39acbd52369fe7a08df01bd2be7" alt=""
data:image/s3,"s3://crabby-images/2a5fc/2a5fccf65fc1bc2e8a7e23afa508f236e0d5df0a" alt=""
data:image/s3,"s3://crabby-images/f7ee4/f7ee48a9694fc8000d60628e900258348d209e2b" alt=""
cypress.io/cloud
currents.dev
pricing
data:image/s3,"s3://crabby-images/ff870/ff870cf3baf422d41619cdeddfe5ae6977145014" alt=""
data:image/s3,"s3://crabby-images/fc2e3/fc2e3e4a61270f3d47d3d592f0060b09dc1ec29b" alt=""
data:image/s3,"s3://crabby-images/a1e26/a1e2658785bdb45ab5f1969d0ff47cabc3f01a81" alt=""
currents.dev
Cypress checks
data:image/s3,"s3://crabby-images/8ac9b/8ac9b47c2f09bc75c28f8ee700381537a7fa4350" alt=""
data:image/s3,"s3://crabby-images/292cb/292cb4622eb6ca4053b542fef9c844946ef33602" alt=""
inline comments
data:image/s3,"s3://crabby-images/3e1b0/3e1b05a067251fd92e8ddde557da3453a04a786f" alt=""
data:image/s3,"s3://crabby-images/80fbc/80fbcc1ce5898ad0726ce317f6b45ee90ceef752" alt=""
dashboard view
data:image/s3,"s3://crabby-images/04c86/04c86edcdb94112a31320af9dc21d972ddd7751e" alt=""
failed test video
data:image/s3,"s3://crabby-images/21db2/21db2f0edbfe9886826d82d962429cb6c31f0d34" alt=""
installation
data:image/s3,"s3://crabby-images/9f1e2/9f1e24859ffe197048f4c2aae3184c425ce37497" alt=""
data:image/s3,"s3://crabby-images/175ce/175cef358d0bf7883f9715ee1c7648b360919add" alt=""
data:image/s3,"s3://crabby-images/66efb/66efb449ad20499960d492eb3550404143f624e3" alt=""
installation
data:image/s3,"s3://crabby-images/0e2f5/0e2f50e3b07ac6973263ac4207fe59ebe3881d29" alt=""
github actions
data:image/s3,"s3://crabby-images/1f661/1f661522a6a75b040a57497d718751658725cfa9" alt=""
data:image/s3,"s3://crabby-images/f4d41/f4d4147c740d52a786b5ad4251fa1127fde16567" alt=""
workflow config file
data:image/s3,"s3://crabby-images/2840c/2840cfff47da59db30b33610ebea852d3f7c4a3c" alt=""
Self Hosted
Sorry Cypress Setup
git clone git@github.com:sorry-cypress/sorry-cypress.git
cd sorry-cypress
docker-compose -f docker-compose.full.yml up
// currents.config.js
module.exports = {
projectId: "kj29s",
cloudServiceUrl: "http://localhost:1234", # ADD THIS
};
data:image/s3,"s3://crabby-images/91102/911021d742a83ab464479cdbfce9f3e093f71610" alt=""
localhost:8080
Quick Summary
Cypress, GitHub & Cloud
data:image/s3,"s3://crabby-images/1b25b/1b25bf5620876fafdb824e059f7f3a7ae9c5c8e4" alt=""
Cypress & Github
-
Workflow files ✅
-
Status checks
-
Test artifacts in status checks summary
-
-
Cypress Cloud 💰
-
Status checks + inline comments with linked artifacts
-
The official companion to the Cypress app
-
The free plan (with limited functions)
-
-
Currents.Dev 🤔
-
Status checks + inline comments with linked artifacts
-
Cheaper than Cypress Cloud
-
All features from the start
-
-
Sorry-Cypress 💪
- Free & self-hosted
- Takes time to set up (with limited features)
You NEED e2e Tests?
HIRE ME
Cypress & GitHub
By Marek Szumny
Cypress & GitHub
Efficient Setup for Pull Requests with Cypress Cloud and Alternatives
- 552