description | coverY |
---|---|
Synpress can be used as a Cypress plugin. You can continue to write your regular Cypress logic but will need Synpress when you are interacting with MetaMask. |
0 |
Synpress can be used as a plugin for Cypress. In this tutorial, We will address the following
- How to start testing a new project with Synpress & Cypress
- Add Synpress to an existing Cypress setup
- General knowledge of the notion of E2E testing
- Basic knowledge in Cypress — Write your first test with Cypress
Add Synpress to your project dependencies.
yarn add -D @synthetixio/synpress
At the root of your project, create cypress/e2e/example.cy.[js,ts]
and cypress/support/e2e.[js,ts]
{% tabs %} {% tab title="JavaScript" %}
/cypress/e2e/example.cy.js
/cypress/support/e2e.js
{% tab title="TypeScript" %}
/cypress/e2e/example.cy.ts
/cypress/support/e2e.ts
cypress/e2e/*
-> Where all of your E2E tests will live.cypress/support/e2e.[js,ts]
-> Where you will import Synpress plugins.
{% tabs %} {% tab title="JavaScript" %}
// cypress/support/e2e.js
/// <reference types="Cypress" />
import "@synthetixio/synpress/support/index";
{% endtab %}
{% tab title="TypeScript" %}
// cypress/support/e2e.ts
/// <reference types="Cypress" />
import "@synthetixio/synpress/support/index";
{% endtab %} {% endtabs %}
For more information about writing and organizing tests in Cypress read this guide
Synpress config file is exactly the same as Cypress config file with some modifications. Add the config file to the project root directory.
// synpress.config.js
const { defineConfig } = require("cypress");
// import synpress node events
const setupNodeEvents = require("@synthetixio/synpress/plugins/index");
// Set timeout (in milliseconds) for Cypress & Synpress to wait before failing.
// Note: big timeout can slow the tests down. Slow timeouts can cause the test to fail.
// Read more about timeouts: https://docs.cypress.io/guides/references/configuration#Timeouts
const timeout = process.env.SYNDEBUG ? 9999999 : 30000;
module.exports = defineConfig({
userAgent: "synpress",
retries: {
runMode: process.env.CI ? 1 : 0,
openMode: 0,
},
fixturesFolder: "@synthetixio/synpress/fixtures",
chromeWebSecurity: true,
viewportWidth: 1920,
viewportHeight: 1080,
video: false,
env: {
coverage: false,
},
defaultCommandTimeout: timeout,
pageLoadTimeout: timeout,
requestTimeout: timeout,
e2e: {
testIsolation: false,
setupNodeEvents,
// Url for the test dApp
baseUrl: "http://127.0.0.1:8080/",
// Where all tests can be found.
specPattern: "cypress/e2e/**/*.{js,jsx,ts,tsx}",
// Path for your support file your setup early
supportFile: "cypress/support/e2e.ts",
},
});
All Cypress configs are still valid in Synpress config file. If you want to know the rest of the options, feel free to go through the configuration guide in Cypress docs.
Tip: It is recommended to keep all E2E test environment variables in their own .env
file to avoid name collision and for separation of concerns. This is easily achievable using env-cmd.
{% embed url="https://www.npmjs.com/package/env-cmd" %} A simple node program for executing commands using an environment from an env file. {% endembed %}
# .env.e2e
# The recovery phrase for the wallet that will be restored while preparing Metamask
# Will be the selected wallet by default when connecting to the dApp
SECRET_WORDS='battle raccoon helmet please deliver keep kiss round orphan frame update message'
# Network info at which the tests will run.
NETWORK_NAME='Mumbai'
CHAIN_ID=80001
RPC_URL='https://matic-mumbai.chainstacklabs.com'
SYMBOL="MATIC"
IS_TESTNET=true
If you want to know the rest of the available environment variables, feel free to go through it here.
Synpress has Command Line Interface (CLI) to help in launching & managing tests from the terminal. Get to know Synpress CLI here.
Below we are adding a new script to package.json
.
// package.json
"synpress:run": "env-cmd -f .env.e2e synpress run --configFile synpress.config.js",
"test:e2e": "start-server-and-test 'yarn start' http://localhost:8080 'yarn synpress:run'"
- Notice how loading the required environment variables from
.env.e2e
file using `env-cmd` packageenv-cmd -f .env.e2e
. - Get to know all the available environment variables and their usage here.
- Notice how are passing the path to the synpress config file we created earlier
--configFile synpress.config.js
. - Note: you will need to have your dApp running in the background or you can use
start-server-and-test
(mostly needed in the CI/CD). \
{% embed url="https://www.npmjs.com/package/start-server-and-test" %} Starts server, waits for URL, then runs test command; when the tests end, shuts down server {% endembed %}
Below is a simple dApp (synpress-demo) written in React + WAGMI that I created on GitLab. Feel free to clone the repo and play around with it (don't forget to add the environment variables!!).
Synpress Demo
Below is a test case example for connecting dApp to MetaMask. Note that almost all of the logic is regular Cypress! Synpress comes to play when the dApp is interacting with Metamask (e.g. connect, send Tx, signing...)
{% tabs %} {% tab title="JavaScript" %}
// cypress/e2e/example.cy.js
describe("Synpress Demo", () => {
it("should connect to MetaMask and display wallet address", () => {
cy.visit("http://localhost:8080/");
cy.get("#address").contains("??");
cy.get("#connected").contains("NO");
cy.get("#connect-btn").click();
cy.acceptMetamaskAccess(); // <------ Synpress API
cy.get("#address").contains("0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266");
cy.get("#connected").contains("YES");
cy.get("#disconnect-btn").click();
cy.get("#address").contains("??");
cy.get("#connected").contains("NO");
});
});
{% endtab %}
{% tab title="TypeScript" %}
describe("Synpress Demo", () => {
it("should connect to MetaMask and display wallet address", () => {
cy.visit("http://localhost:8080/");
cy.get("#address").contains("??");
cy.get("#connected").contains("NO");
cy.get("#connect-btn").click();
cy.acceptMetamaskAccess(); // <------ Synpress API
cy.get("#address").contains("0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266");
cy.get("#connected").contains("YES");
cy.get("#disconnect-btn").click();
cy.get("#address").contains("??");
cy.get("#connected").contains("NO");
});
});
{% endtab %} {% endtabs %}
Get to know all that Synpress has to offer throughout the Synpress API
Add Synpress to your project dependencies.
yarn add -D @synthetixio/synpress
import "@synthetixio/synpress/support/index";
You can simply import the Synpress plugin into cypress.config.js
file as stated below.
+ const setupNodeEvents = require("@synthetixio/synpress/plugins/index");
module.exports = defineConfig({
+ userAgent: "synpress",
e2e: {
+ setupNodeEvents,
},
});