Simple basic demo project written with TypeScript, Playwright, Synpress, and Ethers for testing Web3 app with Metamask wallet
- TypeScript
- Playwright - UI tests
- Ethers - encryption and decryption methods
- Synpress - e2e testing framework based on Cypress.io and Playwright with Metamask support. In my case I use Playwright integration.
I am confident that there is no need to create custom integration solutions to work with Metamask.
Rather, it's better to use out-of-the-box solutions.
I have tested several frameworks for integrating interaction with Metamask. I chose Synpress.
Considering that the automation project is a single-page application, this project is a demonstration of the approach to building test automation. It is not intended to show all the possible approaches to building such projects. The minimum necessary for the work was used. In particular:
- Page Object pattern
- Page Component pattern
- Test fixtures
- Step methods
- Logic hided from test. Test call only steps
That's it.
This can be further expanded by using the following:
-
Different test suits: sanity, smoke, regression test suits. Or other, depending on project needs.
-
Test actions. Combining test steps into larger actions.
For example: "Establish Metamask connection" action will contain next steps: opening a page, connecting a wallet, and checking that the page is ready to use. In this case, the HTML report will have a nice concise look and will have a number of high-level user-friendly actions. Single action can be expanded and included steps can be accessed. -
Helper class for Ether methods and additional helper-methods
-
Docker containers. Currently, tests run locally and sequentially due to Playwright's limitations over Chrome extensions. But this does not matter when running tests in Docker containers. These limitations are being dropped. Test can be run in parallel and in headless mode if needed.
Couple examples how to run tests in Docker containers:
- Aerokube Moon. Free up to 4 parallel sessions. Best option if K8 available on the project. Ready to use solution with minimum adjustment actions
- Selenium grid docker
- Lambda test. Quite expensive to use on a small-scale project.
-
Add tests to CI pipelines and create quality gates
-
Attaching HTML report to each run on CI
Tests cover the main functions of the application. The goal was not to cover all possible scenarios. This is a demo.
- playwright.config.ts Playwright config file. Two projects were configured. One depends on the other.
- connect.metamask.ts - This is initial test. Goal - verify if Metamask connection can be established. If this test fails, all the others will not run because connection failed.
- vtvl.spec.ts - dependant tests. Cover main function of the app.
- A new browser session is started for each test. Tests are independent on each other.
-
Sign the message
- Set wallet address
- Set message
- Sign the message
- Verify signature string
-
Verify valid signature
- Set wallet address
- Set message
- Sign the message
- Verify valid signature pop-up
-
Verify invalid signature pop-up for invalid message text
- Set wallet address
- Set message1
- Sign the message
- Verify signature string
- Set message2
- Click Verify the signature button
- Verify invalid signature pop-up with "ethers" lib
-
Verify invalid signature pop-up for invalid Wallet address
- Set valid wallet address
- Set message
- Sign the message
- Set invalid wallet address
- Click Verify the signature button
- Verify invalid signature pop-up with "ethers" lib
Copy .env file:
cp .env.example .env
Add to .env file required fields: ADDRESS, SEED_PHRASE, PASSWORD
Install dependencies:
with yarn
yarn install
with npm
npm install
Install chromium browser:
npx playwright install chromium
Run tests:
with yarn
yarn run test
with npm
npm run test
After tests are passed, HTML report should open automatically in the browser. But this action can be triggered manually:
yarn run show-report
P.S.: You may notice that the HTML report contains a lot of method calls from Playwright. I've already reported an issue. It's related to Synpress and Metamask integration. I hope it will be fixed soon.