redbadger/website-honestly

View on GitHub
cypress/support/commands.js

Summary

Maintainability
A
0 mins
Test Coverage
// ***********************************************
// This example commands.js shows you how to
// create various custom commands and overwrite
// existing commands.
//
// For more comprehensive examples of custom
// commands please read more here:
// https://on.cypress.io/custom-commands
// ***********************************************
//
//
// -- This is a parent command --
// Cypress.Commands.add("login", (email, password) => { ... })
//
//
// -- This is a child command --
// Cypress.Commands.add("drag", { prevSubject: 'element'}, (subject, options) => { ... })
//
//
// -- This is a dual command --
// Cypress.Commands.add("dismiss", { prevSubject: 'optional'}, (subject, options) => { ... })
//
//
// -- This will overwrite an existing command --
// Cypress.Commands.overwrite("visit", (originalFn, url, options) => { ... })

/* eslint import/no-extraneous-dependencies: ["error", {"peerDependencies": false}] */
import { addMatchImageSnapshotCommand } from 'cypress-image-snapshot/command';

Cypress.Commands.overwrite('visit', (originalFn, url, options) => {
  // eslint-disable-next-line no-param-reassign
  const opts = Object.assign({}, (options = {}), {
    // eslint-disable-next-line no-param-reassign
    onBeforeLoad: (window, ...args) => {
      // eslint-disable-next-line no-param-reassign
      window.fetch = null;
      if (options.onBeforeLoad) {
        return options.onBeforeLoad(window, ...args);
      }
    },
  });
  return originalFn(url, opts);
});

addMatchImageSnapshotCommand();