CI Workflows
Upload strategies
When you run tests and create recordings, they are stored locally. You can choose which recordings get uploaded to Replay. All uploaded recordings become accessible in the Replay App.
While uploading just failed tests is good for saving resources, our recommendation is to upload both failed and passed tests so that you can compare them. This can be really useful for debugging purposes.
Upload all tests
To upload all test replays no matter the result, set the upload
option to true.
cypress.config.js
export default defineConfig({e2e: {setupNodeEvents(cyOn, config) {const on = wrapOn(cyOn)replayPlugin(on, config, {apiKey: process.env.REPLAY_API_KEY,upload: true,})return config},},})
Upload failed tests only
To upload recordings only for failed tests use statusThreshold
option:
cypress.config.js
export default defineConfig({e2e: {setupNodeEvents(cyOn, config) {const on = wrapOn(cyOn)replayPlugin(on, config, {apiKey: process.env.REPLAY_API_KEY,upload: {statusThreshold: 'failed',},})return config},},})
Upload failed and flaky tests
To upload recordings for failed and flaky tests use statusThreshold
option:
cypress.config.js
export default defineConfig({e2e: {setupNodeEvents(cyOn, config) {const on = wrapOn(cyOn)replayPlugin(on, config, {apiKey: process.env.REPLAY_API_KEY,upload: {statusThreshold: 'failed-and-flaky',},})return config},},})
Upload only for the primary branch
Many CI providers provide an environment variable that references the current branch name.
- CircleCI:
$CIRCLE_BRANCH
- GitLab:
$CI_COMMIT_REF_NAME
- Semaphore:
$SEMAPHORE_GIT_BRANCH
- Travis:
$TRAVIS_BRANCH
GitHub stores this value in a default variable named GITHUB_BASE_REF
that can be passed along as part of a Workflow and then referenced in the test config like so:
cypress.config.js
export default defineConfig({e2e: {setupNodeEvents(cyOn, config) {const on = wrapOn(cyOn)replayPlugin(on, config, {apiKey: process.env.REPLAY_API_KEY,upload: process.env.BRANCH_NAME === 'main',})return config},},})
Reducing the number of uploaded recordings
Use the advanced upload options to reduce the number of recordings that are uploaded. When this option is enabled, only one recording will be uploaded for any passing or failing test.
cypress.config.js
export default defineConfig({e2e: {setupNodeEvents(cyOn, config) {const on = wrapOn(cyOn)replayPlugin(on, config, {apiKey: process.env.REPLAY_API_KEY,upload: {minimizeUploads: true,},})return config},},})
Note that for flaky tests, two recordings will be uploaded– the passing test and one of the failed attempts.
Combining options
You can combine advanced upload options to e.g. only upload a single recording and only for a failing test.
cypress.config.js
export default defineConfig({e2e: {setupNodeEvents(cyOn, config) {const on = wrapOn(cyOn)replayPlugin(on, config, {apiKey: process.env.REPLAY_API_KEY,upload: {minimizeUploads: true,statusThreshold: 'failed',},})return config},},})