Skip to content

Enabling legacy-peer-deps=true on infra to get around CI build issues #2196

Enabling legacy-peer-deps=true on infra to get around CI build issues

Enabling legacy-peer-deps=true on infra to get around CI build issues #2196

Workflow file for this run

name: Unit Tests
on: [push]
jobs:
test-server:
name: Test GraphQL API Server
runs-on: ubuntu-latest
services:
postgres:
image: underbluewaters/seasketch_db_base:0.0.1
ports:
- "5432:5432"
env:
POSTGRES_PASSWORD: password
redis:
image: "redis:alpine"
ports:
- "6379:6379"
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v3
with:
node-version: "18.6"
cache: "npm"
# - name: Setup tmate session
# uses: mxschmitt/action-tmate@v3
- name: Install dependencies
run: |
npx [email protected] bootstrap --ci
- name: Init docker db
working-directory: ./packages/api
env:
TEST_DB: postgres://postgres:password@localhost:5432/
run: |
node tests/init_dockerdb.js
- name: Run Tests
working-directory: ./packages/api
run: |
npx jest --ci --reporters=default --reporters=jest-junit
env:
TEST_DB: postgres://postgres:password@localhost:5432/
SES_EMAIL_SOURCE: [email protected]
- uses: IgnusG/[email protected]
if: always()
with:
access-token: ${{ secrets.GITHUB_TOKEN }}
working-directory: ./packages/api
check-name: API Test Output
run-name: Test GraphQL API Server
database-drift:
name: Check for schema and generated code drift
runs-on: ubuntu-latest
services:
postgres:
image: underbluewaters/seasketch_db_base:0.0.1
ports:
- "54321:5432"
env:
POSTGRES_PASSWORD: password
redis:
image: "redis:alpine"
ports:
- "6379:6379"
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v3
with:
node-version: "18.6"
cache: "npm"
- name: Install dependencies
run: |
npx [email protected] bootstrap --ci
- name: Initialize database
working-directory: ./packages/api
env:
TEST_DB: postgres://postgres:password@localhost:54321/
DATABASE_URL: postgres://postgres:password@localhost:54321/seasketch
ADMIN_DATABASE_URL: postgres://postgres:password@localhost:54321/seasketch
AUTH0_CLIENT_ID: ${{ secrets.AUTH0_CLIENT_ID }}
AUTH0_CLIENT_SECRET: ${{ secrets.AUTH0_CLIENT_SECRET }}
AUTH0_DOMAIN: ${{ secrets.AUTH0_DOMAIN }}
GM_DBURL: postgres://postgres:password@localhost:54321/seasketch_shadow
MAPBOX_ACCESS_TOKEN: ${{ secrets.MAPBOX_ACCESS_TOKEN }}
run: |
node tests/init_dockerdb.js
IN_TESTS=1 npm run db:migrate -- --shadow
node dist/src/createCleanGraphqlSchema.js
- name: Check for graphql schema drift
working-directory: ./packages/api
run: |
ls -lh generated-schema*
npm run db:drift
- name: Check for drift in hooks
working-directory: ./packages/client
run: |
npx graphql-codegen --config codegen.yml
git diff --exit-code ./src/generated/graphql.ts
test-client:
name: Test React Client
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v3
with:
node-version: "18.6"
cache: "npm"
- name: Install dependencies
run: |
npx [email protected] bootstrap --ci
- name: Test client
working-directory: ./packages/client
env:
SKIP_PREFLIGHT_CHECK: true
REACT_APP_GRAPHQL_ENDPOINT: http://localhost:3857/graphql
run: |
npm run test -- --ci --testResultsProcessor="jest-junit" --watchAll=false
- uses: IgnusG/[email protected]
if: always()
with:
access-token: ${{ secrets.GITHUB_TOKEN }}
working-directory: ./packages/client
check-name: React Client Test Output
run-name: Test React Client
build-client:
name: Build React Client
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v3
with:
node-version: "18.6"
cache: "npm"
- id: short_sha
run: |
echo `git rev-parse HEAD`
echo "::set-output name=sha::`git rev-parse --short HEAD`"
- name: Install dependencies
run: |
npx [email protected] bootstrap --ci
- name: Build client
working-directory: ./packages/client
env:
SKIP_PREFLIGHT_CHECK: true
REACT_APP_AUTH0_CLIENT_ID: ${{ secrets.REACT_APP_AUTH0_CLIENT_ID }}
REACT_APP_AUTH0_DOMAIN: ${{ secrets.REACT_APP_AUTH0_DOMAIN }}
REACT_APP_AUTH0_SCOPE: ${{ secrets.REACT_APP_AUTH0_SCOPE }}
REACT_APP_AUTH0_AUDIENCE: ${{ secrets.REACT_APP_AUTH0_AUDIENCE }}
REACT_APP_MAPBOX_ACCESS_TOKEN: abc123
REACT_APP_GRAPHQL_ENDPOINT: https://example.com/graphql
REACT_APP_BUILD: ${{ steps.short_sha.outputs.sha }}
run: |
NODE_OPTIONS=--openssl-legacy-provider CI=false npm run build
# integration-tests:
# name: Cypress Integration Tests
# runs-on: ubuntu-latest
# timeout-minutes: 60
# # container: cypress/browsers:node16.5.0-chrome94-ff93
# services:
# postgres:
# image: underbluewaters/seasketch_db_base
# ports:
# - "5432:5432"
# env:
# POSTGRES_PASSWORD: password
# redis:
# image: "redis:alpine"
# ports:
# - "6379:6379"
# steps:
# - uses: actions/checkout@v4
# - uses: actions/setup-node@v2
# with:
# node-version: "18.6"
# - id: short_sha
# run: |
# echo `git rev-parse HEAD`
# echo "::set-output name=sha::`git rev-parse --short HEAD`"
# - name: Cache node modules
# uses: actions/cache@v2
# env:
# cache-name: cache-integration-node-modules
# with:
# # npm cache files are stored in `~/.npm` on Linux/macOS
# path: |
# node_modules
# */*/node_modules
# ~/.npm
# ~/.cache/Cypress
# key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
# restore-keys: |
# ${{ runner.os }}-build-${{ env.cache-name }}-
# ${{ runner.os }}-build-
# ${{ runner.os }}-
# - name: Install
# run: |
# npm install
# npm install -g lerna
# npm install serve -g
# lerna bootstrap
# - name: Init docker db
# working-directory: ./packages/api
# env:
# TEST_DB: postgres://postgres:password@localhost:5432/
# DATABASE_URL: postgres://postgres:password@localhost:5432/seasketch
# run: |
# node tests/init_dockerdb.js
# npm run db:migrate
# - name: Start API Server
# working-directory: ./packages/api
# env:
# DATABASE_URL: postgres://graphile:password@localhost:5432/seasketch
# ADMIN_DATABASE_URL: postgres://postgres:password@localhost:5432/seasketch
# AUTH0_CLIENT_ID: ${{ secrets.AUTH0_CLIENT_ID }}
# AUTH0_CLIENT_SECRET: ${{ secrets.AUTH0_CLIENT_SECRET }}
# AUTH0_DOMAIN: ${{ secrets.AUTH0_DOMAIN }}
# JWKS_URI: ${{ secrets.JWKS_URI }}
# JWT_AUD: ${{ secrets.JWT_AUD }}
# JWT_ISS: ${{ secrets.JWT_ISS }}
# PUBLIC_S3_BUCKET: ${{ secrets.PUBLIC_S3_BUCKET }}
# PUBLIC_UPLOADS_DOMAIN: ${{ secrets.PUBLIC_UPLOADS_DOMAIN }}
# S3_REGION: ${{ secrets.S3_REGION }}
# SES_EMAIL_SOURCE: ${{ secrets.SES_EMAIL_SOURCE }}
# UNSPLASH_KEY: ${{ secrets.UNSPLASH_KEY }}
# NODE_ENV: staging
# GRAPHILE_WORKER_CONCURRENCY: 5
# AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
# AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
# IS_CYPRESS_TEST_ENV: "true"
# run: |
# npm run build
# npm start &
# - name: Start client
# working-directory: ./packages/client
# run: |
# NODE_OPTIONS=--openssl-legacy-provider CI=false npm run build
# serve -s build &
# env:
# SKIP_PREFLIGHT_CHECK: true
# REACT_APP_AUTH0_CLIENT_ID: ${{ secrets.REACT_APP_AUTH0_CLIENT_ID }}
# REACT_APP_AUTH0_DOMAIN: ${{ secrets.REACT_APP_AUTH0_DOMAIN }}
# REACT_APP_AUTH0_SCOPE: ${{ secrets.REACT_APP_AUTH0_SCOPE }}
# REACT_APP_AUTH0_AUDIENCE: ${{ secrets.REACT_APP_AUTH0_AUDIENCE }}
# REACT_APP_MAPBOX_ACCESS_TOKEN: ${{ secrets.REACT_APP_MAPBOX_ACCESS_TOKEN }}
# REACT_APP_GRAPHQL_ENDPOINT: http://localhost:3857/graphql
# CYPRESS_BASE_URL: http://localhost:3000
# REACT_APP_BUILD: e2e-tests-${{ steps.short_sha.outputs.sha }}
# - name: Cypress run
# uses: cypress-io/github-action@v2
# with:
# record: true
# browser: chrome
# wait-on: "http://localhost:3000"
# install-command: "true"
# working-directory: ./packages/client
# wait-on-timeout: 240
# config: baseUrl=http://localhost:3000
# env:
# CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORDING_KEY }}
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# CYPRESS_AUTH0_CLIENT_SECRET: ${{ secrets.CYPRESS_AUTH0_CLIENT_SECRET }}
# REACT_APP_AUTH0_CLIENT_ID: ${{ secrets.REACT_APP_AUTH0_CLIENT_ID }}
# REACT_APP_AUTH0_DOMAIN: ${{ secrets.REACT_APP_AUTH0_DOMAIN }}
# REACT_APP_AUTH0_SCOPE: ${{ secrets.REACT_APP_AUTH0_SCOPE }}
# REACT_APP_AUTH0_AUDIENCE: ${{ secrets.REACT_APP_AUTH0_AUDIENCE }}
# REACT_APP_GRAPHQL_ENDPOINT: http://localhost:3857/graphql
# CYPRESS_TEST_DB: postgres://postgres:password@localhost:5432/seasketch
# AUTH0_MANAGEMENT_API_CLIENT_ID: ${{ secrets.AUTH0_MANAGEMENT_API_CLIENT_ID }}
# AUTH0_MANAGEMENT_API_CLIENT_SECRET: ${{ secrets.AUTH0_MANAGEMENT_API_CLIENT_SECRET }}
# percy-visual-tests:
# name: Percy Visual Testing
# runs-on: ubuntu-latest
# timeout-minutes: 60
# # container: cypress/browsers:node16.5.0-chrome94-ff93
# services:
# postgres:
# image: underbluewaters/seasketch_db_base
# ports:
# - "5432:5432"
# env:
# POSTGRES_PASSWORD: password
# redis:
# image: "redis:alpine"
# ports:
# - "6379:6379"
# steps:
# - uses: actions/checkout@v4
# - uses: actions/setup-node@v2
# with:
# node-version: "18.6"
# - id: short_sha
# run: |
# echo `git rev-parse HEAD`
# echo "::set-output name=sha::`git rev-parse --short HEAD`"
# - name: Cache node modules
# uses: actions/cache@v2
# env:
# cache-name: cache-integration-node-modules
# with:
# # npm cache files are stored in `~/.npm` on Linux/macOS
# path: |
# node_modules
# */*/node_modules
# ~/.npm
# ~/.cache/Cypress
# key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
# restore-keys: |
# ${{ runner.os }}-build-${{ env.cache-name }}-
# ${{ runner.os }}-build-
# ${{ runner.os }}-
# - name: Install
# run: |
# npm install
# npm install -g lerna
# npm install serve -g
# lerna bootstrap
# - name: Init docker db
# working-directory: ./packages/api
# env:
# TEST_DB: postgres://postgres:password@localhost:5432/
# DATABASE_URL: postgres://postgres:password@localhost:5432/seasketch
# run: |
# node tests/init_dockerdb.js
# npm run db:migrate
# - name: Start API Server
# working-directory: ./packages/api
# env:
# DATABASE_URL: postgres://graphile:password@localhost:5432/seasketch
# ADMIN_DATABASE_URL: postgres://postgres:password@localhost:5432/seasketch
# AUTH0_CLIENT_ID: ${{ secrets.AUTH0_CLIENT_ID }}
# AUTH0_CLIENT_SECRET: ${{ secrets.AUTH0_CLIENT_SECRET }}
# AUTH0_DOMAIN: ${{ secrets.AUTH0_DOMAIN }}
# HOST: ${{ secrets.HOST }}
# JWKS_URI: ${{ secrets.JWKS_URI }}
# JWT_AUD: ${{ secrets.JWT_AUD }}
# JWT_ISS: ${{ secrets.JWT_ISS }}
# PUBLIC_S3_BUCKET: ${{ secrets.PUBLIC_S3_BUCKET }}
# PUBLIC_UPLOADS_DOMAIN: ${{ secrets.PUBLIC_UPLOADS_DOMAIN }}
# S3_REGION: ${{ secrets.S3_REGION }}
# SES_EMAIL_SOURCE: ${{ secrets.SES_EMAIL_SOURCE }}
# UNSPLASH_KEY: ${{ secrets.UNSPLASH_KEY }}
# NODE_ENV: staging
# GRAPHILE_WORKER_CONCURRENCY: 5
# AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
# AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
# IS_CYPRESS_TEST_ENV: "true"
# run: |
# npm run build
# npm start &
# - name: Start client
# working-directory: ./packages/client
# run: |
# NODE_OPTIONS=--openssl-legacy-provider CI=false npm run build
# serve -s build &
# env:
# SKIP_PREFLIGHT_CHECK: true
# REACT_APP_AUTH0_CLIENT_ID: ${{ secrets.REACT_APP_AUTH0_CLIENT_ID }}
# REACT_APP_AUTH0_DOMAIN: ${{ secrets.REACT_APP_AUTH0_DOMAIN }}
# REACT_APP_AUTH0_SCOPE: ${{ secrets.REACT_APP_AUTH0_SCOPE }}
# REACT_APP_AUTH0_AUDIENCE: ${{ secrets.REACT_APP_AUTH0_AUDIENCE }}
# REACT_APP_MAPBOX_ACCESS_TOKEN: ${{ secrets.REACT_APP_MAPBOX_ACCESS_TOKEN }}
# REACT_APP_GRAPHQL_ENDPOINT: http://localhost:3857/graphql
# CYPRESS_BASE_URL: http://localhost:3000
# REACT_APP_BUILD: e2e-tests-${{ steps.short_sha.outputs.sha }}
# - name: Percy/Cypress Run
# working-directory: ./packages/client
# run: npx @percy/cli exec -- cypress run --record false
# env:
# CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORDING_KEY }}
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# CYPRESS_AUTH0_CLIENT_SECRET: ${{ secrets.CYPRESS_AUTH0_CLIENT_SECRET }}
# REACT_APP_AUTH0_CLIENT_ID: ${{ secrets.REACT_APP_AUTH0_CLIENT_ID }}
# REACT_APP_AUTH0_DOMAIN: ${{ secrets.REACT_APP_AUTH0_DOMAIN }}
# REACT_APP_AUTH0_SCOPE: ${{ secrets.REACT_APP_AUTH0_SCOPE }}
# REACT_APP_AUTH0_AUDIENCE: ${{ secrets.REACT_APP_AUTH0_AUDIENCE }}
# REACT_APP_GRAPHQL_ENDPOINT: http://localhost:3857/graphql
# CYPRESS_TEST_DB: postgres://postgres:password@localhost:5432/seasketch
# PERCY_TOKEN: ${{ secrets.PERCY_TOKEN }}
# ACTIONS_ALLOW_UNSECURE_COMMANDS: true
# AUTH0_MANAGEMENT_API_CLIENT_ID: ${{ secrets.AUTH0_MANAGEMENT_API_CLIENT_ID }}
# AUTH0_MANAGEMENT_API_CLIENT_SECRET: ${{ secrets.AUTH0_MANAGEMENT_API_CLIENT_SECRET }}