mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
Added Playwright tests to Signup Form
refs https://github.com/TryGhost/Team/issues/3298
This commit is contained in:
parent
dd6559b3c8
commit
fd3393c562
8 changed files with 210 additions and 72 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -133,6 +133,9 @@ Caddyfile
|
||||||
# Signup Form and local environments
|
# Signup Form and local environments
|
||||||
/ghost/signup-form/umd
|
/ghost/signup-form/umd
|
||||||
/ghost/signup-form/.env*.local
|
/ghost/signup-form/.env*.local
|
||||||
|
/ghost/signup-form/test-results/
|
||||||
|
/ghost/signup-form/playwright-report/
|
||||||
|
/ghost/signup-form/playwright/.cache/
|
||||||
|
|
||||||
# Announcement-Bar
|
# Announcement-Bar
|
||||||
/ghost/announcement-bar/umd
|
/ghost/announcement-bar/umd
|
||||||
|
|
|
@ -34,3 +34,6 @@ Follow the instructions for the top-level repo.
|
||||||
|
|
||||||
- `yarn lint` run just eslint
|
- `yarn lint` run just eslint
|
||||||
- `yarn test` run lint and tests
|
- `yarn test` run lint and tests
|
||||||
|
- `yarn test:e2e` run e2e tests on Chromium
|
||||||
|
- `yarn test:slowmo` run e2e tests visually (headed) and slower on Chromium
|
||||||
|
- `yarn test:e2e:full` run e2e tests on all browsers
|
||||||
|
|
|
@ -1,73 +1,78 @@
|
||||||
{
|
{
|
||||||
"name": "@tryghost/signup-form",
|
"name": "@tryghost/signup-form",
|
||||||
"version": "0.0.0",
|
"version": "0.0.0",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/TryGhost/Ghost/tree/main/packages/signup-form"
|
"url": "https://github.com/TryGhost/Ghost/tree/main/packages/signup-form"
|
||||||
},
|
},
|
||||||
"author": "Ghost Foundation",
|
"author": "Ghost Foundation",
|
||||||
"files": [
|
"files": [
|
||||||
"LICENSE",
|
"LICENSE",
|
||||||
"README.md",
|
"README.md",
|
||||||
"umd/"
|
"umd/"
|
||||||
],
|
],
|
||||||
"publishConfig": {
|
"publishConfig": {
|
||||||
"access": "public",
|
"access": "public",
|
||||||
"registry": "https://registry.npmjs.org/"
|
"registry": "https://registry.npmjs.org/"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "concurrently \"vite --port 6173\" \"vite preview -l silent\" \"vite build --watch\"",
|
"dev": "concurrently \"vite --port 6173\" \"vite preview -l silent\" \"vite build --watch\"",
|
||||||
"build": "tsc && vite build",
|
"dev:test": "vite build && vite preview --port 6175",
|
||||||
"lint": "yarn run lint:js",
|
"build": "tsc && vite build",
|
||||||
"lint:js": "eslint --ext .js,.ts,.cjs,.tsx --cache src test",
|
"lint": "yarn run lint:js",
|
||||||
"test:unit": "yarn build",
|
"lint:js": "eslint --ext .js,.ts,.cjs,.tsx --cache src test",
|
||||||
"preview": "vite preview",
|
"test:unit": "yarn build",
|
||||||
"storybook": "storybook dev -p 6006",
|
"test:e2e": "NODE_OPTIONS='--experimental-specifier-resolution=node --no-warnings' VITE_TEST=true playwright test",
|
||||||
"build-storybook": "storybook build",
|
"test:slowmo": "TIMEOUT=100000 PLAYWRIGHT_SLOWMO=100 yarn test:e2e --headed",
|
||||||
"preship": "yarn lint",
|
"test:e2e:full": "ALL_BROWSERS=1 yarn test:e2e",
|
||||||
"ship": "STATUS=$(git status --porcelain); echo $STATUS; if [ -z \"$STATUS\" ]; then yarn version; fi",
|
"preview": "vite preview",
|
||||||
"postship": "git push ${GHOST_UPSTREAM:-origin} --follow-tags && npm publish",
|
"storybook": "storybook dev -p 6006",
|
||||||
"prepublishOnly": "yarn build"
|
"build-storybook": "storybook build",
|
||||||
},
|
"preship": "yarn lint",
|
||||||
"dependencies": {
|
"ship": "STATUS=$(git status --porcelain); echo $STATUS; if [ -z \"$STATUS\" ]; then yarn version; fi",
|
||||||
"react": "^18.2.0",
|
"postship": "git push ${GHOST_UPSTREAM:-origin} --follow-tags && npm publish",
|
||||||
"react-dom": "^18.2.0"
|
"prepublishOnly": "yarn build"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"dependencies": {
|
||||||
"@storybook/addon-essentials": "7.0.15",
|
"react": "^18.2.0",
|
||||||
"@storybook/addon-interactions": "7.0.15",
|
"react-dom": "^18.2.0"
|
||||||
"@storybook/addon-links": "7.0.15",
|
},
|
||||||
"@storybook/addon-styling": "1.0.6",
|
"devDependencies": {
|
||||||
"@storybook/blocks": "7.0.15",
|
"@playwright/test": "1.34.2",
|
||||||
"@storybook/react": "7.0.15",
|
"@storybook/addon-essentials": "7.0.15",
|
||||||
"@storybook/react-vite": "7.0.15",
|
"@storybook/addon-interactions": "7.0.15",
|
||||||
"@storybook/testing-library": "0.1.0",
|
"@storybook/addon-links": "7.0.15",
|
||||||
"@tailwindcss/line-clamp": "0.4.4",
|
"@storybook/addon-styling": "1.0.6",
|
||||||
"@types/react": "18.0.28",
|
"@storybook/blocks": "7.0.15",
|
||||||
"@types/react-dom": "18.0.11",
|
"@storybook/react": "7.0.15",
|
||||||
"@typescript-eslint/eslint-plugin": "5.57.1",
|
"@storybook/react-vite": "7.0.15",
|
||||||
"@typescript-eslint/parser": "5.57.1",
|
"@storybook/testing-library": "0.1.0",
|
||||||
"@vitejs/plugin-react": "4.0.0",
|
"@tailwindcss/line-clamp": "0.4.4",
|
||||||
"autoprefixer": "10.4.14",
|
"@types/react": "18.0.28",
|
||||||
"concurrently": "8.0.1",
|
"@types/react-dom": "18.0.11",
|
||||||
"eslint": "8.38.0",
|
"@typescript-eslint/eslint-plugin": "5.57.1",
|
||||||
"eslint-config-react-app": "7.0.1",
|
"@typescript-eslint/parser": "5.57.1",
|
||||||
"eslint-plugin-ghost": "2.18.0",
|
"@vitejs/plugin-react": "4.0.0",
|
||||||
"eslint-plugin-react": "7.32.2",
|
"autoprefixer": "10.4.14",
|
||||||
"eslint-plugin-react-hooks": "4.6.0",
|
"concurrently": "8.0.1",
|
||||||
"eslint-plugin-react-refresh": "0.3.4",
|
"eslint": "8.38.0",
|
||||||
"eslint-plugin-tailwindcss": "3.11.0",
|
"eslint-config-react-app": "7.0.1",
|
||||||
"postcss": "8.4.23",
|
"eslint-plugin-ghost": "2.18.0",
|
||||||
"postcss-import": "^15.1.0",
|
"eslint-plugin-react": "7.32.2",
|
||||||
"prop-types": "15.8.1",
|
"eslint-plugin-react-hooks": "4.6.0",
|
||||||
"rollup-plugin-node-builtins": "2.1.2",
|
"eslint-plugin-react-refresh": "0.3.4",
|
||||||
"storybook": "7.0.15",
|
"eslint-plugin-tailwindcss": "3.11.0",
|
||||||
"stylelint": "15.6.1",
|
"postcss": "8.4.23",
|
||||||
"tailwindcss": "3.3.2",
|
"postcss-import": "^15.1.0",
|
||||||
"typescript": "5.0.4",
|
"prop-types": "15.8.1",
|
||||||
"vite": "4.3.8",
|
"rollup-plugin-node-builtins": "2.1.2",
|
||||||
"vite-plugin-svgr": "3.2.0",
|
"storybook": "7.0.15",
|
||||||
"vitest": "0.31.1"
|
"stylelint": "15.6.1",
|
||||||
}
|
"tailwindcss": "3.3.2",
|
||||||
|
"typescript": "5.0.4",
|
||||||
|
"vite": "4.3.8",
|
||||||
|
"vite-plugin-svgr": "3.2.0",
|
||||||
|
"vitest": "0.31.1"
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
57
ghost/signup-form/playwright.config.ts
Normal file
57
ghost/signup-form/playwright.config.ts
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
import {defineConfig, devices} from '@playwright/test';
|
||||||
|
|
||||||
|
export const E2E_PORT = 6175;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* See https://playwright.dev/docs/test-configuration.
|
||||||
|
*/
|
||||||
|
export default defineConfig({
|
||||||
|
testDir: './test/e2e',
|
||||||
|
/* Run tests in files in parallel */
|
||||||
|
fullyParallel: true,
|
||||||
|
/* Fail the build on CI if you accidentally left test.only in the source code. */
|
||||||
|
forbidOnly: !!process.env.CI,
|
||||||
|
/* Retry on CI only */
|
||||||
|
retries: process.env.CI ? 2 : 0,
|
||||||
|
/* Opt out of parallel tests on CI. */
|
||||||
|
workers: process.env.CI ? 1 : undefined,
|
||||||
|
/* Reporter to use. See https://playwright.dev/docs/test-reporters */
|
||||||
|
reporter: 'html',
|
||||||
|
/* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */
|
||||||
|
use: {
|
||||||
|
/* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */
|
||||||
|
trace: 'on-first-retry',
|
||||||
|
launchOptions: {
|
||||||
|
slowMo: parseInt(process.env.PLAYWRIGHT_SLOWMO ?? '') || 0,
|
||||||
|
// force GPU hardware acceleration
|
||||||
|
// (even in headless mode)
|
||||||
|
args: ['--use-gl=egl']
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
/* Configure projects for major browsers */
|
||||||
|
projects: [
|
||||||
|
{
|
||||||
|
name: 'chromium',
|
||||||
|
use: {...devices['Desktop Chrome']}
|
||||||
|
},
|
||||||
|
|
||||||
|
...(process.env.ALL_BROWSERS ? [{
|
||||||
|
name: 'firefox',
|
||||||
|
use: {...devices['Desktop Firefox']}
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
name: 'webkit',
|
||||||
|
use: {...devices['Desktop Safari']}
|
||||||
|
}] : [])
|
||||||
|
],
|
||||||
|
|
||||||
|
/* Run local dev server before starting the tests */
|
||||||
|
webServer: {
|
||||||
|
command: `yarn dev:test`,
|
||||||
|
url: `http://localhost:${E2E_PORT}/signup-form.min.js`,
|
||||||
|
reuseExistingServer: !process.env.CI,
|
||||||
|
timeout: 10000
|
||||||
|
}
|
||||||
|
});
|
49
ghost/signup-form/test/e2e/form.test.ts
Normal file
49
ghost/signup-form/test/e2e/form.test.ts
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
import {expect} from '@playwright/test';
|
||||||
|
import {initialize} from '../utils/e2e';
|
||||||
|
import {test} from '@playwright/test';
|
||||||
|
|
||||||
|
test.describe('Form', async () => {
|
||||||
|
test('Displays the title', async ({page}) => {
|
||||||
|
const frame = await initialize({page, title: 'Sign up to get the latest news and updates.'});
|
||||||
|
|
||||||
|
// Check the Frame
|
||||||
|
const h1 = frame.getByRole('heading');
|
||||||
|
expect(await h1.innerText()).toBe('Sign up to get the latest news and updates.');
|
||||||
|
});
|
||||||
|
|
||||||
|
test('Displays the description', async ({page}) => {
|
||||||
|
const frame = await initialize({page, title: 'Title', description: 'Sign up to get the latest news and updates.'});
|
||||||
|
|
||||||
|
// Check the Frame
|
||||||
|
const p = frame.getByRole('paragraph');
|
||||||
|
expect(await p.innerText()).toBe('Sign up to get the latest news and updates.');
|
||||||
|
});
|
||||||
|
|
||||||
|
test('Uses the accent color', async ({page}) => {
|
||||||
|
// Need rgb notation here, because getComputedStyle returns rgb notation
|
||||||
|
const color = 'rgb(255, 123, 0)';
|
||||||
|
const frame = await initialize({page, color});
|
||||||
|
const submitButton = frame.getByRole('button');
|
||||||
|
|
||||||
|
// Check calculated background color of the button
|
||||||
|
const backgroundColor = await submitButton.evaluate((el) => {
|
||||||
|
return window.getComputedStyle(el).backgroundColor;
|
||||||
|
});
|
||||||
|
expect(backgroundColor).toBe(color);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('Has a minimal style when title is missing', async ({page}) => {
|
||||||
|
let frame = await initialize({page});
|
||||||
|
|
||||||
|
// Check no title or description present
|
||||||
|
await expect(frame.getByRole('heading')).toHaveCount(0);
|
||||||
|
await expect(frame.getByRole('paragraph')).toHaveCount(0);
|
||||||
|
|
||||||
|
frame = await initialize({page, description: 'Ignored'});
|
||||||
|
|
||||||
|
// Check no title or description present
|
||||||
|
await expect(frame.getByRole('heading')).toHaveCount(0);
|
||||||
|
await expect(frame.getByRole('paragraph')).toHaveCount(0);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
|
@ -3,6 +3,6 @@ const assert = require('assert');
|
||||||
describe('Hello world', function () {
|
describe('Hello world', function () {
|
||||||
it('Runs a test', function () {
|
it('Runs a test', function () {
|
||||||
// TODO: Write me!
|
// TODO: Write me!
|
||||||
assert.ok(require('../index'));
|
assert.ok(require('../../index'));
|
||||||
});
|
});
|
||||||
});
|
});
|
20
ghost/signup-form/test/utils/e2e.ts
Normal file
20
ghost/signup-form/test/utils/e2e.ts
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
import {E2E_PORT} from '../../playwright.config';
|
||||||
|
|
||||||
|
export async function initialize({page, ...options}: {page: any; title?: string, description?: string, logo?: string, color?: string, site?: string, labels?: string}) {
|
||||||
|
const url = `http://localhost:${E2E_PORT}/signup-form.min.js`;
|
||||||
|
|
||||||
|
await page.goto('about:blank');
|
||||||
|
await page.setViewportSize({width: 1000, height: 1000});
|
||||||
|
|
||||||
|
await page.evaluate((data) => {
|
||||||
|
const scriptTag = document.createElement('script');
|
||||||
|
scriptTag.src = data.url;
|
||||||
|
|
||||||
|
for (const option of Object.keys(data.options)) {
|
||||||
|
scriptTag.dataset[option] = data.options[option];
|
||||||
|
}
|
||||||
|
document.body.appendChild(scriptTag);
|
||||||
|
}, {url, options});
|
||||||
|
await page.waitForSelector('iframe');
|
||||||
|
return page.frameLocator('iframe');
|
||||||
|
}
|
1
ghost/signup-form/test/utils/isTestEnv.js
Normal file
1
ghost/signup-form/test/utils/isTestEnv.js
Normal file
|
@ -0,0 +1 @@
|
||||||
|
export const isTestEnv = import.meta.env.VITE_TEST === 'true';
|
Loading…
Add table
Reference in a new issue