Skip to content

saucelabs/cypress-junit-plugin

Repository files navigation

@saucelabs/cypress-junit-plugin

@saucelabs/cypress-junit-plugin is a third-party plugin designed to enhance your Cypress testing workflow by generating comprehensive JUnit test reports.

Please be aware that this plugin is not an official product of Sauce Labs.

Unique Features

Unlike Cypress' built-in junit reporter, this plugin generates a single, consolidated JUnit file for the entire test run, rather than individual files per spec that then need to be merged.

Prerequisites

Cypress Version: This plugin is compatible with Cypress version 13 and above. Make sure your project is updated to meet this version requirement.

Installation

To install the plugin, run the following command in your project directory:

npm install @saucelabs/cypress-junit-plugin --save-dev

Configuration

After installation, configure the plugin to work with your Cypress setup.

cypress.config.mjs Example:

import { defineConfig } from 'cypress';
import { setupJUnitPlugin } from '@saucelabs/cypress-junit-plugin';

export default defineConfig({
  e2e: {
    setupNodeEvents(on, config) {
      setupJUnitPlugin(on, config, { filename: "path/to/my_junit.xml" });
      return config;
    }
  },
});

cypress.config.cjs Example:

const { defineConfig } = require('cypress');
const { setupJUnitPlugin } = require('@saucelabs/cypress-junit-plugin');

module.exports = defineConfig({
  e2e: {
    setupNodeEvents(on, config) {
      setupJUnitPlugin(on, config, { filename: 'path/to/my_junit.xml' });
      return config;
    },
  },
});

Usage

Simply run your Cypress tests as usual. The plugin will automatically generate a JUnit report at the specified location (default: junit.xml) after the test run is complete.

cypress run

API Usage

If you are using the Cypress module API, you can pass the Cypress results to the plugin directly:

const cypress = require('cypress')
const {createJUnitReport} = require('@saucelabs/cypress-junit-plugin')

cypress.run({
  reporter: 'spec',
  browser: 'chrome',
}).then(r => {
  createJUnitReport(r, { filename: 'path/to/my_junit.xml' });
})

Contributing

Contributions to the @saucelabs/cypress-junit-plugin are welcome! Check out our contributing guidelines for more information on how to participate.

Support

If you run into any issues or have questions about the plugin, feel free to open an issue on our GitHub repository.

License

This plugin is released under the MIT License.

About

No description, website, or topics provided.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •