CI Workflows

Upload strategies

When you run tests and create recordings, they are stored locally. You can opt to upload them automatically or define your own uploading strategy. All uploaded recordings become accessible in the Replay App.


While uploading just failed test 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

Use the advanced upload options to upload only the failed recordings:

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

Use the advanced upload options to upload failed and flaky test recordings:

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.

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 Playwright config, e.g.:

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. (Two recordings will be uploaded for a flaky 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
},
},
})

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
},
},
})