-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #57 from Agoric/ui-test
test(ui): ensure title and connect wallet button render
- Loading branch information
Showing
8 changed files
with
1,313 additions
and
43 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -22,3 +22,5 @@ jobs: | |
run: yarn build | ||
- name: yarn test | ||
run: yarn test | ||
- name: yarn test:e2e | ||
run: yarn test:e2e |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
import './installSesLockdown'; | ||
import { render, screen } from '@testing-library/react'; | ||
import App from './App'; | ||
|
||
describe('App.tsx', () => { | ||
it('renders app title', async () => { | ||
render(<App />); | ||
|
||
const titleElement = await screen.findByText('Items Listed on Offer Up', { | ||
selector: 'h1', | ||
}); | ||
expect(titleElement).toBeTruthy(); | ||
}); | ||
|
||
it('renders the wallet connection button', async () => { | ||
render(<App />); | ||
const buttonEl = await screen.findByRole('button', { | ||
name: 'Connect Wallet', | ||
}); | ||
expect(buttonEl).toBeTruthy(); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
import puppeteer from 'puppeteer'; | ||
import { execSync, spawn } from 'node:child_process'; | ||
|
||
describe('Puppeteer E2E test', () => { | ||
it('should load the webpage', async () => { | ||
execSync('yarn build'); | ||
const previewServer = spawn('yarn', ['preview'], { | ||
detached: true, | ||
stdio: 'ignore', | ||
}); | ||
// delay for preview server to start | ||
await new Promise(resolve => setTimeout(resolve, 2000)); | ||
|
||
try { | ||
const browser = await puppeteer.launch(); | ||
const page = await browser.newPage(); | ||
await page.goto('http://localhost:4173'); | ||
|
||
const buttonText = await page.$eval('button', el => el.textContent); | ||
expect(buttonText).toBe('Connect Wallet'); | ||
|
||
await browser.close(); | ||
previewServer.kill(); | ||
} catch (_) { | ||
previewServer.kill(); | ||
} | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,16 @@ | ||
/// <reference types="vitest" /> | ||
|
||
import { defineConfig } from 'vite'; | ||
import react from '@vitejs/plugin-react'; | ||
|
||
// https://vitejs.dev/config/ | ||
export default defineConfig({ | ||
plugins: [react()], | ||
test: { | ||
globals: true, | ||
environment: 'happy-dom', | ||
testTimeout: 20000, // 20 seconds for puppeteer CI | ||
// modified import('vitest/dist/config.js').defaultInclude | ||
include: '**/*.{spec,e2e}.?(c|m)[jt]s?(x)', | ||
}, | ||
}); |
Oops, something went wrong.