Skip to content

Ecosystem Image Fix #253

Ecosystem Image Fix

Ecosystem Image Fix #253

Workflow file for this run

# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json
name: CI Checks
on:
pull_request:
jobs:
lint:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Use Node.js
uses: actions/setup-node@v4
with:
node-version: 20
cache: 'npm'
- name: Install Dependencies
# If this fails, run 'npm run fix-package-lock' and commit the result
run: npm ci
- name: Lint
run: npm run lint
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Use Node.js
uses: actions/setup-node@v4
with:
node-version: 20
cache: 'npm'
- name: Install Dependencies
# If this fails, run 'npm run fix-package-lock' and commit the result
run: npm ci
- name: Build
env:
BASE_PATH: ''
run: |
npm run build
touch build/.nojekyll
- name: Upload artifact
uses: actions/upload-pages-artifact@v3
with:
path: ./build
unit:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Use Node.js
uses: actions/setup-node@v4
with:
node-version: 20
cache: 'npm'
- name: Install Dependencies
# If this fails, run 'npm run fix-package-lock' and commit the result
run: npm ci
- name: Unit Tests
run: npm run test:unit
e2e:
runs-on: ubuntu-latest
container:
image: mcr.microsoft.com/playwright:v1.36.2-jammy
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Use Node.js
uses: actions/setup-node@v4
with:
node-version: 20
cache: 'npm'
- name: Install Dependencies
# If this fails, run 'npm run fix-package-lock' and commit the result
run: npm ci
- name: Install Playwright Browsers
run: npx playwright install chromium # does not need "--with-deps" because we are using the official image
- name: E2E Tests
run: npm run test:integration
# Preview PRs when actions/deploy-pages preview option is in public
# https://github.com/actions/deploy-pages/issues/180
# deploy-preview:
# # Skip unless it is an open PR
# if: github.event_name == 'pull_request' && github.event.action != 'closed'
# environment:
# name: github-pages
# url: ${{ steps.deployment.outputs.page_url }}
# # Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
# permissions:
# contents: read
# pages: write
# id-token: write
# runs-on: ubuntu-latest
# needs: build
# steps:
# - name: Deploy to GitHub Pages
# id: deployment
# uses: actions/deploy-pages@v4
# with:
# preview: 'true'