Skip to content

Commit

Permalink
ci: move PTE e2e tests out in own workflow (#5080)
Browse files Browse the repository at this point in the history
* ci: move PTE e2e tests into own worker and folder

* ci: remove shard sequencer, it was GitHub cache :tableflip:
  • Loading branch information
skogsmaskin authored Oct 27, 2023
1 parent fd7db60 commit afa3f71
Show file tree
Hide file tree
Showing 27 changed files with 83 additions and 46 deletions.
63 changes: 63 additions & 0 deletions .github/workflows/e2e-pte.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
name: End-to-End PTE collaboration tests
on:
# Build on pushes branches that have a PR (including drafts)
pull_request:
# Build on commits pushed to branches without a PR if it's in the allowlist
push:
branches: [next]
jobs:
playwright-test:
timeout-minutes: 30
runs-on: ubuntu-latest
env:
TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
TURBO_TEAM: ${{ vars.TURBO_TEAM }}
strategy:
fail-fast: false
matrix:
project: [chromium]
# Add more shards here if needed
shardIndex: [1, 2]
shardTotal: [2]
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 18

- name: Cache node modules
id: cache-node-modules
uses: actions/cache@v3
env:
cache-name: cache-node-modules
with:
path: '**/node_modules'
key: ${{ runner.os }}-modules-${{ env.cache-name }}-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-modules-${{ env.cache-name }}-
${{ runner.os }}-modules-
${{ runner.os }}-
- name: Install project dependencies
if: steps.cache-node-modules.outputs.cache-hit != 'true'
run: yarn install --frozen-lockfile

- name: Store Playwright's Version
run: |
PLAYWRIGHT_VERSION=$(npx playwright --version | sed 's/Version //')
echo "Playwright's Version: $PLAYWRIGHT_VERSION"
echo "PLAYWRIGHT_VERSION=$PLAYWRIGHT_VERSION" >> $GITHUB_ENV
- name: Cache Playwright Browsers for Playwright's Version
id: cache-playwright-browsers
uses: actions/cache@v3
with:
path: ~/.cache/ms-playwright
key: playwright-browsers-${{ env.PLAYWRIGHT_VERSION }}

- name: Install Playwright Browsers
if: steps.cache-playwright-browsers.outputs.cache-hit != 'true'
run: npx playwright install --with-deps

- name: Run end-to-end tests
run: cd packages/@sanity/portable-text-editor && yarn test:e2e --silent --shard=${{ matrix.shardIndex}}/${{ matrix.shardTotal }}
38 changes: 0 additions & 38 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -63,27 +63,6 @@ jobs:
${{ runner.os }}-build-
${{ runner.os }}-
- name: Install project dependencies
if: steps.cache-node-modules.outputs.cache-hit != 'true'
run: yarn install --frozen-lockfile

- name: Store Playwright's Version
run: |
PLAYWRIGHT_VERSION=$(npx playwright --version | sed 's/Version //')
echo "Playwright's Version: $PLAYWRIGHT_VERSION"
echo "PLAYWRIGHT_VERSION=$PLAYWRIGHT_VERSION" >> $GITHUB_ENV
- name: Cache Playwright Browsers for Playwright's Version
id: cache-playwright-browsers
uses: actions/cache@v3
with:
path: ~/.cache/ms-playwright
key: playwright-browsers-${{ env.PLAYWRIGHT_VERSION }}

- name: Install Playwright Browsers
if: steps.cache-playwright-browsers.outputs.cache-hit != 'true'
run: npx playwright install --with-deps

- name: Build CLI
run: yarn build:cli # Needed for CLI tests

Expand Down Expand Up @@ -140,23 +119,6 @@ jobs:
if: steps.cache-node-modules.outputs.cache-hit != 'true'
run: yarn install --frozen-lockfile

- name: Store Playwright's Version
run: |
PLAYWRIGHT_VERSION=$(npx playwright --version | sed 's/Version //')
echo "Playwright's Version: $PLAYWRIGHT_VERSION"
echo "PLAYWRIGHT_VERSION=$PLAYWRIGHT_VERSION" >> $GITHUB_ENV
- name: Cache Playwright Browsers for Playwright's Version
id: cache-playwright-browsers
uses: actions/cache@v3
with:
path: ~/.cache/ms-playwright
key: playwright-browsers-${{ env.PLAYWRIGHT_VERSION }}

- name: Install Playwright Browsers
if: steps.cache-playwright-browsers.outputs.cache-hit != 'true'
run: npx playwright install --with-deps

- name: Test
id: test
run: |
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/** @jest-environment ./test/setup/collaborative.jest.env.ts */
/** @jest-environment ./setup/collaborative.jest.env.ts */
import os from 'os'
import '../setup/globals.jest'
import {noop} from 'lodash'
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/** @jest-environment ./test/setup/collaborative.jest.env.ts */
/** @jest-environment ./setup/collaborative.jest.env.ts */

import '../setup/globals.jest'

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/** @jest-environment ./test/setup/collaborative.jest.env.ts */
/** @jest-environment ./setup/collaborative.jest.env.ts */
import {toPlainText} from '@portabletext/toolkit'
import '../setup/globals.jest'
import type {PortableTextBlock} from '@sanity/types'
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/** @jest-environment ./test/setup/collaborative.jest.env.ts */
/** @jest-environment ./setup/collaborative.jest.env.ts */

import '../setup/globals.jest'
import type {PortableTextBlock} from '@sanity/types'
Expand Down
13 changes: 13 additions & 0 deletions packages/@sanity/portable-text-editor/e2e-tests/e2e.config.cjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
'use strict'

const {createJestConfig} = require('../../../../test/config.cjs')

// eslint-disable-next-line no-console
console.info('Running collaborate editing tests for the Portable Text Editor')

module.exports = createJestConfig({
displayName: require('../package.json').name,
globalSetup: './setup/globalSetup.ts',
globalTeardown: './setup/globalTeardown.ts',
setupFilesAfterEnv: ['./setup/afterEnv.ts'],
})
4 changes: 1 addition & 3 deletions packages/@sanity/portable-text-editor/jest.config.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,5 @@ const {createJestConfig} = require('../../../test/config.cjs')

module.exports = createJestConfig({
displayName: require('./package.json').name,
globalSetup: '<rootDir>/test/setup/globalSetup.ts',
globalTeardown: '<rootDir>/test/setup/globalTeardown.ts',
setupFilesAfterEnv: ['<rootDir>/test/setup/afterEnv.ts'],
modulePathIgnorePatterns: ['<rootDir>/e2e-tests'],
})
1 change: 1 addition & 0 deletions packages/@sanity/portable-text-editor/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@
"prettier": "prettier --write './**/*.{ts,tsx,js,css,html}'",
"dev": "cd ./test/ && ts-node serve",
"test": "jest",
"test:e2e": "cd e2e-tests && jest --config=e2e.config.cjs",
"test:watch": "jest --watch",
"watch": "pkg-utils watch --tsconfig tsconfig.lib.json"
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ const debugVerbose = debug.enabled && false

// The editor will commit changes in a throttled fashion in order
// not to overload the network and degrade performance while typing.
const FLUSH_PATCHES_THROTTLED_MS = process.env.NODE_ENV === 'test' ? 100 : 1000
const FLUSH_PATCHES_THROTTLED_MS = process.env.NODE_ENV === 'test' ? 500 : 1000

/**
* @internal
Expand Down

2 comments on commit afa3f71

@vercel
Copy link

@vercel vercel bot commented on afa3f71 Oct 27, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Successfully deployed to the following URLs:

performance-studio – ./

performance-studio.sanity.build
performance-studio-git-next.sanity.build

@vercel
Copy link

@vercel vercel bot commented on afa3f71 Oct 27, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Successfully deployed to the following URLs:

test-studio – ./

test-studio.sanity.build
test-studio-git-next.sanity.build

Please sign in to comment.