Skip to content

Commit

Permalink
test(cat-voices): playwright refactoring
Browse files Browse the repository at this point in the history
  • Loading branch information
emiride committed Dec 4, 2024
1 parent 13968b4 commit a6194e2
Show file tree
Hide file tree
Showing 17 changed files with 536 additions and 254 deletions.
2 changes: 2 additions & 0 deletions .config/dictionaries/project.dic
Original file line number Diff line number Diff line change
Expand Up @@ -275,6 +275,7 @@ tablestats
tacho
testcov
testdocs
testid
testplan
testunit
thiserror
Expand All @@ -284,6 +285,7 @@ Toastify
todos
toggleable
tojunit
tomjs
Traceback
traefik
trailings
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,11 @@ src:
COPY --dir utils ./utils
COPY playwright.config.ts .
COPY test-fixtures.ts .
COPY setup.ts .

package-test:
FROM +src
ENV APP_URL http://test-app:80
ENV APP_URL http://test-app:80
RUN mkdir /results
VOLUME /results
ENTRYPOINT ["/bin/sh", "-c", "/usr/bin/xvfb-run --auto-servernum npm test", ""]
Expand All @@ -31,19 +31,21 @@ package-test:

builder:
DO flutter-ci+SETUP
COPY ../../../../+repo-catalyst-voices-all/repo .
COPY ../../../../../+repo-catalyst-voices/repo .
DO flutter-ci+BOOTSTRAP

build-web:
FROM +builder
ARG WORKDIR=/frontend/catalyst_voices_packages/catalyst_cardano/catalyst_cardano/example
ARG WORKDIR=/frontend/packages/libs/catalyst_cardano/catalyst_cardano/example
DO flutter-ci+BUILD_WEB --TARGET=lib/main.dart --WORKDIR=$WORKDIR
SAVE ARTIFACT web

package-app:
FROM nginx:alpine3.20-slim
ARG tag='latest'
COPY +build-web/web /usr/share/nginx/html/
COPY +build-web/web /app
COPY ./nginx.conf /etc/nginx/nginx.conf
EXPOSE 80
SAVE IMAGE test-app:$tag

nightly-test:
Expand All @@ -55,10 +57,8 @@ nightly-test:
--load test:latest=(+package-test)

RUN docker run --network=default_default --name=test test:latest ; \
docker cp test:/results/cardano-wallet.junit-report.xml cardano-wallet.junit-report.xml ; \
docker cp test:/results/ /playwright-report
docker cp test:/results/cardano-wallet.junit-report.xml cardano-wallet.junit-report.xml ;
END
WAIT
SAVE ARTIFACT cardano-wallet.junit-report.xml AS LOCAL cardano-wallet.junit-report.xml
SAVE ARTIFACT ./playwright-report/* AS LOCAL ./playwright-report/
END
Original file line number Diff line number Diff line change
@@ -1,44 +1,49 @@
# Wallet Automation

Welcome to wallet automation, a testing package in Playwright that tests wallet integration for Catalyst Voices.

## Introduction

Wallet automation is a testing package in Playwright that automates the wallet creation process for the Catalyst project.
Wallet automation is a testing package in Playwright that automates the wallet creation process for the Catalyst project.
It is a part of the Catalyst Voices ecosystem.

## Getting Started

1. Clone this repository:

```sh
git clone
cd catalyst-voices
```
```sh
git clone
cd catalyst-voices
```

2. Install Flutter and Dart:

```sh
brew install flutter
```
```sh
brew install flutter
```

3. Bootstrap the project:

```sh
melos bootstrap
```
```sh
melos bootstrap
```

4. Execute earthly command from this directory:

```sh
earthly +package-app
```
```sh
earthly +package-app
```

5. Use docker compose to run the app:

```sh
docker compose up
```
The app should be running on `localhost:8000`.
```sh
docker compose up
```

The app should be running on `localhost:8000`.

6. You can now run tests with the following command:

```sh
npx playwright test
```
```sh
npx playwright test
```
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
user nginx;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name localhost;

# https://cjycode.com/flutter_rust_bridge/manual/miscellaneous/web-cross-origin#background
add_header Cross-Origin-Opener-Policy "same-origin";
add_header Cross-Origin-Embedder-Policy "require-corp";

location / {
root /app;
index index.html;
try_files $uri $uri/ /index.html;
}
# Ensure that /m4 (and any other SPA path) serves index.html
location /m4 {
root /app;
try_files $uri $uri/ /index.html;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}
}
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { Page, Locator, expect } from '@playwright/test';
import { BrowserExtensionName } from '../utils/extensions';
import { Modal, ModalName } from './modal';
import { WalletConfig } from '../utils/wallets/walletUtils';

export interface UTxO {
tx: string;
Expand All @@ -10,7 +10,7 @@ export interface UTxO {

export interface WalletCipData {
balance: number;
extensions: string;
extensions: string[];
networkId: string;
changeAddress: string;
rewardAddresses: string[];
Expand Down Expand Up @@ -61,7 +61,7 @@ export class HomePage {
async getWalletCipData() {
const walletCipData: WalletCipData = {
balance: 0,
extensions: '',
extensions: [],
networkId: '',
changeAddress: '',
rewardAddresses: [],
Expand Down Expand Up @@ -106,15 +106,16 @@ export class HomePage {
}
}

async getExtensions(): Promise<string> {
async getExtensions(): Promise<string[]> {
const isVisible = await this.extensionsLabel.isVisible();
if (!isVisible) {
throw new Error('Extensions label is not visible');
}
const extensionsText = await this.extensionsLabel.textContent();
const match = extensionsText?.trim().match(/^Extensions:\s*(.+)$/);
if (match && match[1]) {
return match[1].trim();
const trimmedText = match[1].trim();
return trimmedText.split(',').map(ext => ext.trim()).filter(ext => ext.length > 0);
} else {
throw new Error(`Unable to extract extensions from text: ${extensionsText}`);
}
Expand Down Expand Up @@ -272,9 +273,9 @@ export class HomePage {
}
}

async assertBasicWalletCipData(actualWalletCipData: WalletCipData, extensionName: BrowserExtensionName) {
async assertBasicWalletCipData(actualWalletCipData: WalletCipData, walletConfig: WalletConfig) {
expect(actualWalletCipData.balance).toBeGreaterThan(500000000);
expect(actualWalletCipData.extensions).toBe(extensionName === BrowserExtensionName.Typhon ? 'cip-30' : 'cip-95');
await this.assertExtensions(actualWalletCipData.extensions, walletConfig.cipBridge);
expect(actualWalletCipData.networkId).not.toBeNaN();
expect(actualWalletCipData.changeAddress).not.toBeNaN();
expect(actualWalletCipData.rewardAddresses.length).toBeGreaterThan(0);
Expand All @@ -283,6 +284,12 @@ export class HomePage {
expect(actualWalletCipData.utxos.length).toBeGreaterThan(0);
expect(actualWalletCipData.publicDRepKey).not.toBeNaN();
expect(actualWalletCipData.registeredPublicStakeKeys).not.toBeNaN();

}

//Check if expected extensions are present in actual extensions
async assertExtensions(actualExtensions: string[], expectedExtensions: string[]) {
for (const ext of expectedExtensions) {
expect(actualExtensions).toContain(ext);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ export enum ModalName {
SignData = 'SignData',
SignAndSubmitTx = 'SignAndSubmitTx',
SignAndSubmitRBACTx = 'SignAndSubmitRBACTx',
SignDataUserDeclined = 'UserDeclined',
SignTxUserDeclined = 'SignTxUserDeclined',
SignRBACTxUserDeclined = 'SignRBACTxUserDeclined',
}

export interface ModalContent {
Expand All @@ -24,6 +27,18 @@ export const modalContents: { [key in ModalName]: ModalContent } = {
header: 'Sign & submit RBAC tx',
unchangingText: 'Tx hash:',
},
[ModalName.SignDataUserDeclined]: {
header: 'Sign data',
unchangingText: 'user declined sign data',
},
[ModalName.SignTxUserDeclined]: {
header: 'Sign & submit tx',
unchangingText: 'user declined sign tx',
},
[ModalName.SignRBACTxUserDeclined]: {
header: 'Sign & submit RBAC tx',
unchangingText: 'user declined sign tx',
},
};

export class Modal {
Expand All @@ -35,8 +50,8 @@ export class Modal {
constructor(page: Page, modalName: ModalName) {
this.page = page;
this.content = modalContents[modalName];
this.modalHeader = this.page.getByText(this.content.header)
this.modalBody = this.page.getByText(this.content.unchangingText)
this.modalHeader = this.page.getByText(this.content.header, { exact: true });
this.modalBody = this.page.getByText(this.content.unchangingText)
}

async assertModalIsVisible() {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import { Locator, Page } from '@playwright/test';
import { BrowserExtensionName } from '../utils/extensions';


export class WalletListPage {
readonly page: Page;

constructor(page: Page) {
this.page = page;
}
async clickEnableWallet(walletName: BrowserExtensionName): Promise<void> {
const enableButton = (walletName: BrowserExtensionName) => this.page.locator(
`flt-semantics:has(flt-semantics-img[aria-label*="Name: ${walletName.toLowerCase()}"]) ` +
`flt-semantics[role="button"]:has-text("Enable wallet")`
);
await enableButton(walletName).click();
}
}
Original file line number Diff line number Diff line change
@@ -1,30 +1,37 @@
import { defineConfig, devices } from '@playwright/test';
import dotenv from 'dotenv';
import path from 'path';
import { defineConfig, devices } from "@playwright/test";
import dotenv from "dotenv";
import path from "path";

dotenv.config({ path: path.resolve(__dirname, '.env') });
dotenv.config({ path: path.resolve(__dirname, ".env") });

export default defineConfig({
testDir: './tests',
testDir: "./tests",
fullyParallel: false,
forbidOnly: !!process.env.CI,
retries: process.env.CI ? 2 : 1,
workers: process.env.CI ? 1 : 1,
use: {
baseURL: process.env.APP_URL || 'http://localhost:8000',
screenshot: 'only-on-failure',
trace: 'on',
video: 'on',

baseURL: process.env.APP_URL || "http://localhost:8000",
ignoreHTTPSErrors: true,
screenshot: "only-on-failure",
trace: "on",
video: "on",
},
reporter: [
['html', { open: 'never', outputFolder: '/results' }],
['junit', { outputFile: '/results/cardano-wallet.junit-report.xml' }]],
timeout: 120 * 1000,
["junit", { outputFile: "/results/cardano-wallet.junit-report.xml" }],
],
timeout: 60 * 1000,
projects: [
{
name: 'chromium',
use: { ...devices['Desktop Chrome'] },
name: "chromium",
use: {
...devices["Desktop Chrome"],
launchOptions: {
args: [
"--unsafely-treat-insecure-origin-as-secure=http://test-app:80",
],
},
},
},
]
],
});
Loading

0 comments on commit a6194e2

Please sign in to comment.