diff --git a/.eslintrc.js b/.eslintrc.js index 35d2c73..da2f17b 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -1,38 +1,31 @@ module.exports = { root: true, - plugins: [ - '@typescript-eslint', - 'eslint-comments', - "cypress" - ], + plugins: ["@typescript-eslint", "eslint-comments", "cypress"], env: { es6: true, node: true, - 'cypress/globals': true + "cypress/globals": true, }, extends: [ - 'eslint:recommended', - 'plugin:@typescript-eslint/recommended', - 'plugin:eslint-comments/recommended', - 'prettier' + "eslint:recommended", + "plugin:@typescript-eslint/recommended", + "plugin:eslint-comments/recommended", + "prettier", ], overrides: [ { - files: ['**.ts'], - parser: '@typescript-eslint/parser', + files: ["**.ts"], + parser: "@typescript-eslint/parser", parserOptions: { - sourceType: 'module', - project: [ - './tsconfig.json', - './packages/*/tsconfig.json', - ], + sourceType: "module", + project: ["./tsconfig.json", "./example/tsconfig.json"], tsconfigRootDir: __dirname, warnOnUnsupportedTypeScriptVersion: false, EXPERIMENTAL_useSourceOfProjectReferenceRedirect: true, }, rules: { - '@typescript-eslint/explicit-module-boundary-types': 'off' - } + "@typescript-eslint/explicit-module-boundary-types": "off", + }, }, ], }; diff --git a/.github/FUNDING.yml b/.github/FUNDING.yml index ef480f9..da27516 100644 --- a/.github/FUNDING.yml +++ b/.github/FUNDING.yml @@ -2,4 +2,4 @@ github: [FRSOURCE] patreon: frsource -custom: ['https://www.buymeacoffee.com/FRSOURCE'] +custom: ["https://www.buymeacoffee.com/FRSOURCE"] diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md index e784ecb..d849256 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.md +++ b/.github/ISSUE_TEMPLATE/bug_report.md @@ -1,10 +1,9 @@ --- name: Bug report about: Create a report to help us improve -title: '' +title: "" labels: bug -assignees: '' - +assignees: "" --- **Describe the bug** @@ -12,6 +11,7 @@ A clear and concise description of what the bug is. **To Reproduce** Steps to reproduce the behavior: + 1. Go to '...' 2. Click on '....' 3. Scroll down to '....' @@ -24,9 +24,10 @@ A clear and concise description of what you expected to happen. If applicable, add screenshots to help explain your problem. **Please complete the following information:** - - OS and version: [e.g. Windows 10 build. 19043.1319] - - Browser and version [e.g. chrome 22] - - Cypress version [e.g. 8.6.0] + +- OS and version: [e.g. Windows 10 build. 19043.1319] +- Browser and version [e.g. chrome 22] +- Cypress version [e.g. 8.6.0] **Additional context** Add any other context about the problem here. diff --git a/.github/ISSUE_TEMPLATE/feature_request.md b/.github/ISSUE_TEMPLATE/feature_request.md index 11fc491..d883b8f 100644 --- a/.github/ISSUE_TEMPLATE/feature_request.md +++ b/.github/ISSUE_TEMPLATE/feature_request.md @@ -1,10 +1,9 @@ --- name: Feature request about: Suggest an idea for this project -title: '' +title: "" labels: enhancement -assignees: '' - +assignees: "" --- **Is your feature request related to a problem? Please describe.** diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 192c7e2..188f107 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -1,4 +1,4 @@ -name: CI +name: CI on: pull_request_target: branches: @@ -17,7 +17,7 @@ jobs: - uses: actions/checkout@v3 - uses: actions/setup-node@v3 with: - node-version: '16.x' + node-version: "16.x" - name: Remove git auth run: git config --unset http.https://github.com/.extraheader - name: Generate yarn cache-key @@ -52,7 +52,7 @@ jobs: - uses: actions/checkout@v3 - uses: actions/setup-node@v3 with: - node-version: '16.x' + node-version: "16.x" - name: remove git auth run: git config --unset http.https://github.com/.extraheader - name: Configure Yarn cache @@ -79,7 +79,7 @@ jobs: - uses: actions/checkout@v3 - uses: actions/setup-node@v3 with: - node-version: '16.x' + node-version: "16.x" - name: remove git auth run: git config --unset http.https://github.com/.extraheader - name: Configure Yarn cache @@ -110,7 +110,7 @@ jobs: - uses: actions/checkout@v3 - uses: actions/setup-node@v3 with: - node-version: '16.x' + node-version: "16.x" - name: remove git auth run: git config --unset http.https://github.com/.extraheader - name: Configure Yarn cache @@ -149,7 +149,7 @@ jobs: git config --global user.email "$(git --no-pager log --format=format:'%ae' -n 1)" - uses: actions/setup-node@v3 with: - node-version: '16.x' + node-version: "16.x" - name: remove git auth run: git config --unset http.https://github.com/.extraheader - name: Configure Yarn cache diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 0000000..518f78b --- /dev/null +++ b/.prettierignore @@ -0,0 +1,7 @@ +node_modules +dist +coverage +CHANGELOG.md +.yarnrc.yml +example/.yarnrc.yml +.yarn diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index a3c13ab..a71aa48 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -29,6 +29,7 @@ Don’t hesitate to ask a question directly on the [discussions board](https://g - We have no preference about number of commits on the PR - they will be all squashed by GitHub while merging - When creating a new feature/plugin/integration: + - Make sure the feature is covered by tests - Provide a meaningful description. In most cases it would make sens to first open a issue with a suggestion, discuss about it and have it approved before working on it @@ -40,12 +41,14 @@ Don’t hesitate to ask a question directly on the [discussions board](https://g ## Development Setup + You will need [Node.js](https://nodejs.org/en/) **version 16+** and [yarn](https://yarnpkg.com/getting-started/install). + After cloning the repository, run: -``` bash +```bash yarn i # installs the project dependencies cd example && yarn i # install dependencies for example project (useful for testing) ``` @@ -58,7 +61,7 @@ Commit messages should follow the [conventional commits v1.0.0](https://www.conv When fired in the project root they will run corresponding actions in every nested package at once. -``` bash +```bash # build the project for NPM and example usage $ yarn build diff --git a/README.md b/README.md index 68060a6..96acb78 100644 --- a/README.md +++ b/README.md @@ -71,54 +71,63 @@ npm install --save-dev @frsource/cypress-plugin-visual-regression-diff Next, you need to import the library: - first, in your support file (located by default in `cypress/support/index.js`): + ```ts // typescript / ES6 -import '@frsource/cypress-plugin-visual-regression-diff'; +import "@frsource/cypress-plugin-visual-regression-diff"; // javascript -require('@frsource/cypress-plugin-visual-regression-diff'); +require("@frsource/cypress-plugin-visual-regression-diff"); ``` - secondly: - (for Cypress 10.0+) in `cypress.config.js` (or `cypress.config.ts`): + ```ts // typescript / ES6 -import { defineConfig } from 'cypress'; -import { initPlugin } from '@frsource/cypress-plugin-visual-regression-diff/plugins'; +import { defineConfig } from "cypress"; +import { initPlugin } from "@frsource/cypress-plugin-visual-regression-diff/plugins"; export default defineConfig({ // initPlugin must be called in the section where it is used: e2e or component e2e: { setupNodeEvents(on, config) { initPlugin(on, config); - } + }, }, component: { setupNodeEvents(on, config) { initPlugin(on, config); - } - } + }, + }, }); ``` - - (for Cypress <10.0) in your plugins file (located by default in `cypress/plugins/index.js`): + +- (for Cypress <10.0) in your plugins file (located by default in `cypress/plugins/index.js`): + ```ts // typescript / ES6 -import { initPlugin } from '@frsource/cypress-plugin-visual-regression-diff/plugins'; +import { initPlugin } from "@frsource/cypress-plugin-visual-regression-diff/plugins"; -export default function (on: Cypress.PluginEvents, config: Cypress.PluginConfigOptions) { +export default function ( + on: Cypress.PluginEvents, + config: Cypress.PluginConfigOptions +) { initPlugin(on, config); return config; -}; +} // javascript -const { initPlugin } = require('@frsource/cypress-plugin-visual-regression-diff/plugins'); +const { + initPlugin, +} = require("@frsource/cypress-plugin-visual-regression-diff/plugins"); module.exports = function (on, config) { initPlugin(on, config); return config; -} +}; ``` That's it - now let's see how to use the library in [usage section](#usage). @@ -128,7 +137,7 @@ That's it - now let's see how to use the library in [usage section](#usage). Once installed, the library might be used by writing in your test: ```ts -cy.get('.an-element-of-your-choice').matchImage(); +cy.get(".an-element-of-your-choice").matchImage(); ``` Or, if you would like to make a screenshot of whole document: @@ -184,7 +193,7 @@ cy.matchImage({ // maximum threshold above which the test should fail // default: 0.01 maxDiffThreshold: 0.1, - // forces scale factor to be set as value "1" + // forces scale factor to be set as value "1" // helps with screenshots being scaled 2x on high-density screens like Mac Retina // default: true forceDeviceScaleFactor: false, @@ -206,16 +215,15 @@ npx cypress run --env "pluginVisualRegressionUpdateImages=true,pluginVisualRegre ```ts // cypress.config.ts -import { defineConfig } from 'cypress'; +import { defineConfig } from "cypress"; export default defineConfig({ env: { pluginVisualRegressionUpdateImages: true, - pluginVisualRegressionDiffConfig: { threshold: 0.01 } - } -}) + pluginVisualRegressionDiffConfig: { threshold: 0.01 }, + }, +}); { - } ``` @@ -235,8 +243,8 @@ For more ways of setting environment variables [take a look here](https://docs.c Screenshots in Cypress do not scale to the viewport size by default. You can change this behavior: -* globally, by changing default screenshot configuration: Cypress.Screenshot.defaults({ capture: 'viewport' }); -* locally, by passing screenshot configuration directly to the .matchImage command: cy.matchImage({ screenshotConfig: { capture: 'viewport' } }); +- globally, by changing default screenshot configuration: Cypress.Screenshot.defaults({ capture: 'viewport' }); +- locally, by passing screenshot configuration directly to the .matchImage command: cy.matchImage({ screenshotConfig: { capture: 'viewport' } }); diff --git a/__tests__/fixtures/prepare-screenshot-for-cleanup.spec.cy.js b/__tests__/fixtures/prepare-screenshot-for-cleanup.spec.cy.js index a6d416e..63455cd 100644 --- a/__tests__/fixtures/prepare-screenshot-for-cleanup.spec.cy.js +++ b/__tests__/fixtures/prepare-screenshot-for-cleanup.spec.cy.js @@ -1,6 +1,6 @@ -describe('Cleanup test', () => { - it('Create screenshot to be removed', () => { - cy.visit('/'); +describe("Cleanup test", () => { + it("Create screenshot to be removed", () => { + cy.visit("/"); cy.get('[data-testid="description"]').matchImage(); }); }); diff --git a/example/cypress.config.js b/example/cypress.config.js deleted file mode 100644 index 89ee51b..0000000 --- a/example/cypress.config.js +++ /dev/null @@ -1,24 +0,0 @@ -// eslint-disable-next-line @typescript-eslint/no-var-requires -const { defineConfig } = require("cypress"); -// eslint-disable-next-line @typescript-eslint/no-var-requires -const { initPlugin } = require("@frsource/cypress-plugin-visual-regression-diff/dist/plugins"); - -module.exports = defineConfig({ - video: false, - e2e: { - setupNodeEvents(on, config) { - initPlugin(on, config); - }, - specPattern: "cypress/e2e/**/*.cy.{js,jsx,ts,tsx}" - }, - - component: { - setupNodeEvents(on, config) { - initPlugin(on, config); - }, - devServer: { - framework: "vue-cli", - bundler: "webpack", - }, - }, -}); diff --git a/example/cypress.config.ts b/example/cypress.config.ts new file mode 100644 index 0000000..c3f8c96 --- /dev/null +++ b/example/cypress.config.ts @@ -0,0 +1,22 @@ +import { defineConfig } from "cypress"; +import { initPlugin } from "@frsource/cypress-plugin-visual-regression-diff/plugins"; + +module.exports = defineConfig({ + video: false, + e2e: { + setupNodeEvents(on, config) { + initPlugin(on, config); + }, + specPattern: "cypress/e2e/**/*.cy.{js,jsx,ts,tsx}", + }, + + component: { + setupNodeEvents(on, config) { + initPlugin(on, config); + }, + devServer: { + framework: "vue-cli", + bundler: "webpack", + }, + }, +}); diff --git a/example/cypress/component/HelloWorld.cy.js b/example/cypress/component/HelloWorld.cy.js deleted file mode 100644 index e4c3eac..0000000 --- a/example/cypress/component/HelloWorld.cy.js +++ /dev/null @@ -1,16 +0,0 @@ -import HelloWorld from '../../src/components/HelloWorld.vue'; - -const msg = 'Some random test message'; - -describe('HelloWorld.cy.js', () => { - it('playground', () => { - cy.mount(HelloWorld, { - propsData: { msg }, - }) - .then(() => { - cy.contains('h1', msg); - cy.matchImage(); - cy.get('[data-testid="description"]').matchImage(); - }) - }) -}) diff --git a/example/cypress/component/HelloWorld.cy.ts b/example/cypress/component/HelloWorld.cy.ts new file mode 100644 index 0000000..ed8d5cf --- /dev/null +++ b/example/cypress/component/HelloWorld.cy.ts @@ -0,0 +1,16 @@ +import { mount } from "cypress/vue"; +import HelloWorld from "../../src/components/HelloWorld.vue"; + +const msg = "Some random test message"; + +describe("HelloWorld.cy.js", () => { + it("playground", () => { + mount(HelloWorld, { + propsData: { msg }, + }).then(() => { + cy.contains("h1", msg); + cy.matchImage(); + cy.get('[data-testid="description"]').matchImage(); + }); + }); +}); diff --git a/example/cypress/e2e/spec.cy.js b/example/cypress/e2e/spec.cy.js deleted file mode 100644 index 4671caf..0000000 --- a/example/cypress/e2e/spec.cy.js +++ /dev/null @@ -1,11 +0,0 @@ -describe('My First Test', () => { - it('Visits the app root url', () => { - cy.visit('/') - cy.contains('h1', 'Welcome to Your Vue.js App') - cy.matchImage() - .then(({ imgNewPath }) => { - // match against image from custom path - cy.matchImage({ matchAgainstPath: imgNewPath }); - }) - }) -}) diff --git a/example/cypress/e2e/spec.cy.ts b/example/cypress/e2e/spec.cy.ts new file mode 100644 index 0000000..c6555cd --- /dev/null +++ b/example/cypress/e2e/spec.cy.ts @@ -0,0 +1,10 @@ +describe("My First Test", () => { + it("Visits the app root url", () => { + cy.visit("/"); + cy.contains("h1", "Welcome to Your Vue.js App"); + cy.matchImage().then(({ imgNewPath }) => { + // match against image from custom path + cy.matchImage({ matchAgainstPath: imgNewPath }); + }); + }); +}); diff --git a/example/cypress/support/commands.js b/example/cypress/support/commands.ts similarity index 92% rename from example/cypress/support/commands.js rename to example/cypress/support/commands.ts index 6344a6d..ee5f416 100644 --- a/example/cypress/support/commands.js +++ b/example/cypress/support/commands.ts @@ -24,4 +24,4 @@ // -- This will overwrite an existing command -- // Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... }) -import '@frsource/cypress-plugin-visual-regression-diff/dist/support'; +import "@frsource/cypress-plugin-visual-regression-diff/dist/support"; diff --git a/example/cypress/support/component-index.html b/example/cypress/support/component-index.html index ac6e79f..e39ba42 100644 --- a/example/cypress/support/component-index.html +++ b/example/cypress/support/component-index.html @@ -1,12 +1,12 @@ - - - + + + Components App
- \ No newline at end of file + diff --git a/example/cypress/support/e2e.js b/example/cypress/support/component.ts similarity index 96% rename from example/cypress/support/e2e.js rename to example/cypress/support/component.ts index 5e450a7..4d17a4a 100644 --- a/example/cypress/support/e2e.js +++ b/example/cypress/support/component.ts @@ -14,7 +14,7 @@ // *********************************************************** // Import commands.js using ES2015 syntax: -import './commands' +import "./commands"; // Alternatively you can use CommonJS syntax: // require('./commands') diff --git a/example/cypress/support/component.js b/example/cypress/support/e2e.ts similarity index 82% rename from example/cypress/support/component.js rename to example/cypress/support/e2e.ts index 0474d1b..4d17a4a 100644 --- a/example/cypress/support/component.js +++ b/example/cypress/support/e2e.ts @@ -14,14 +14,7 @@ // *********************************************************** // Import commands.js using ES2015 syntax: -import './commands' +import "./commands"; // Alternatively you can use CommonJS syntax: // require('./commands') - -import { mount } from 'cypress/vue' - -Cypress.Commands.add('mount', mount); - -// Example use: -// cy.mount(MyComponent) diff --git a/example/package.json b/example/package.json index d1e21f0..d3b61a3 100644 --- a/example/package.json +++ b/example/package.json @@ -19,6 +19,7 @@ "@frsource/cypress-plugin-visual-regression-diff": "portal:..", "@vue/cli-plugin-e2e-cypress": "5.0.8", "@vue/cli-service": "5.0.8", - "cypress": "10.11.0" + "cypress": "10.11.0", + "typescript": "^4.8.4" } } diff --git a/example/public/index.html b/example/public/index.html index 3e5a139..5f1393c 100644 --- a/example/public/index.html +++ b/example/public/index.html @@ -1,15 +1,19 @@ - - - - + + + + <%= htmlWebpackPlugin.options.title %>
diff --git a/example/src/App.vue b/example/src/App.vue index 591a031..57791b0 100644 --- a/example/src/App.vue +++ b/example/src/App.vue @@ -1,17 +1,17 @@