Introducing Socket Firewall: Free, Proactive Protection for Your Software Supply Chain.Learn More
Socket
Book a DemoInstallSign in
Socket

cypress-mochawesome-reporter

Package Overview
Dependencies
Maintainers
1
Versions
41
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

cypress-mochawesome-reporter

Zero config Mochawesome reporter for Cypress with screenshots

latest
Source
npmnpm
Version
4.0.2
Version published
Weekly downloads
350K
4.07%
Maintainers
1
Weekly downloads
 
Created
Source

cypress-mochawesome-reporter

npm node npm npm

Zero config Mochawesome reporter for Cypress with screenshots attached to tests.

Example report

Mochawesome report with fail test screenshot

Cypress compatibility

reporter versioncypress versionreporter branch
v4node >= 22
>= 6.7.0
>= 6.2.0 with experimentalRunEvents: true
main
v3node >= 14
>= 6.7.0
>= 6.2.0 with experimentalRunEvents: true
v3
v2>= 6.7.0
>= 6.2.0 with experimentalRunEvents: true
v2
v1>= 4.0.0v1

migration guide from v1 to v2

Setup

This setup tutorial works with Cypress >= v10, looking for older version setup? here

  • install cypress-mochawesome-reporter

    npm i --save-dev cypress-mochawesome-reporter
    

    or

    yarn add -D cypress-mochawesome-reporter
    
  • Change cypress reporter & setup hooks

    Edit config file (cypress.config.js by default)

    const { defineConfig } = require('cypress');
    
    module.exports = defineConfig({
      reporter: 'cypress-mochawesome-reporter',
      e2e: {
        setupNodeEvents(on, config) {
          require('cypress-mochawesome-reporter/plugin')(on);
        },
      },
    });
    

    If you are override before:run or after:run hooks, use this:

    const { defineConfig } = require('cypress');
    const { beforeRunHook, afterRunHook } = require('cypress-mochawesome-reporter/lib');
    
    module.exports = defineConfig({
      reporter: 'cypress-mochawesome-reporter',
      e2e: {
        setupNodeEvents(on, config) {
          on('before:run', async (details) => {
            console.log('override before:run');
            await beforeRunHook(details);
          });
    
          on('after:run', async () => {
            console.log('override after:run');
            await afterRunHook();
          });
        },
      },
    });
    
  • Add to cypress/support/e2e.js

    import 'cypress-mochawesome-reporter/register';
    
  • (optional, if your are using cypress-cucumber-preprocessor) Add to cypress/support/step_definitions/index.js

    import 'cypress-mochawesome-reporter/cucumberSupport';
    

    ⚠️ cypress-cucumber-preprocessor uses the same hooks as cypress-mochawesome-reporter, you also need to install cypress-on-fix. Full example of using cypress-mochawesome-reporter with cypress-cucumber-preprocessor can be found here.

  • run cypress

Custom options

If you want to customize your HTML report with mochawesome-report-generator flags just add the flags you want to reporterOptions

const { defineConfig } = require('cypress');

module.exports = defineConfig({
  reporter: 'cypress-mochawesome-reporter',
  reporterOptions: {
    charts: true,
    reportPageTitle: 'custom-title',
    embeddedScreenshots: true,
    inlineAssets: true,
    saveAllAttempts: false,
  },
  e2e: {
    setupNodeEvents(on, config) {
      require('cypress-mochawesome-reporter/plugin')(on);
    },
  },
});

Additional reporter options:

nametypedefaultdescription
embeddedScreenshotsbooleanfalseEmbedded external screenshots into HTML using base64, use with inlineAssets option to produce a single HTML file
ignoreVideosbooleanfalseWill not copy videos recorded by Cypress nor show them in the mochawesome report. Requires that Cypress config option video is set to true for the option to have any effect
Because mochawesome doesn't support context per spec file, each test will have the whole spec file video. More info can be found here
videoOnFailOnlybooleanfalseIf Videos are recorded and added to the report, setting this to true will add the videos only to tests with failures.
Do note that this will NOT cause video's to only record failed tests, just they not be added to passed tests in the mochawesome report
quietbooleanfalseSilence console messages
saveAllAttemptsbooleantrueSave screenshots of all test attempts, set to false to save only the last attempt
debugbooleanfalseCreates log file with debug data
saveJsonbooleanfalseKeeps the json file used to create html report

Add extra information to report

Add extra information to the report manually by using cy.addTestContext() as seen in the simple-typescript example test 2

Mochawesome report with fail test screenshot

Examples

Run npm i in root directory then:

cd examples/<example-project>

npm i
npm test

Keywords

cypress

FAQs

Package last updated on 21 Aug 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts