V3: Migrate to Vite #187
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
name: Local integration tests - Extended Version | |
on: | |
pull_request: | |
branches: [main] | |
jobs: | |
extended-integration-test: | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [macos-12, macos-13, windows-2022] | |
# See supported Node.js release schedule at https://nodejs.org/en/about/releases/ | |
node-version: [18, 20] | |
timeout-minutes: 11 | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js ${{ matrix.node-version }} | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ matrix.node-version }} | |
- name: Install packages | |
run: yarn install | |
- name: Allow running mkcert on Mac | |
run: sudo security authorizationdb write com.apple.trust-settings.admin allow | |
if: runner.os == 'MacOS' | |
- name: Install mkcert | |
run: brew install mkcert | |
if: runner.os == 'MacOS' | |
- name: Run mkcert setup [mkcert -install] | |
run: mkcert -install | |
if: runner.os == 'MacOS' | |
- name: Install https cert [yarn setup:https] | |
run: yarn setup:https | |
if: runner.os == 'MacOS' | |
- run: | | |
mkdir certs | |
.\scripts\generate-cert.ps1 | |
shell: pwsh | |
if: runner.os == 'Windows' | |
- name: Add .clasprc.json to home folder | |
run: echo "$DOT_CLASPRC" > $HOME/.clasprc.json | |
shell: bash | |
env: | |
DOT_CLASPRC: ${{ secrets.DOT_CLASPRC }} | |
- name: Add .clasp.json to project directory | |
run: echo "$DOT_CLASP" > .clasp.json | |
shell: bash | |
env: | |
DOT_CLASP: ${{ secrets.DOT_CLASP }} | |
- name: Add environment variables to .env file | |
run: | | |
echo "EMAIL=$TEST_ACCOUNT_EMAIL" > .env | |
echo "TEST_RECOVERY_EMAIL=$TEST_RECOVERY_EMAIL" >> .env | |
echo "PASSWORD=$TEST_ACCOUNT_PASSWORD" >> .env | |
echo "SHEET_URL=$TEST_SPREADSHEET_URL" >> .env | |
echo "S3_BUCKET_NAME=$S3_BUCKET_NAME" >> .env | |
echo "AWS_SECRET_ACCESS_KEY=$AWS_SECRET_ACCESS_KEY" >> .env | |
echo "AWS_ACCESS_KEY_ID=$AWS_ACCESS_KEY_ID" >> .env | |
shell: bash | |
env: | |
TEST_ACCOUNT_EMAIL: ${{ secrets.TEST_ACCOUNT_EMAIL }} | |
TEST_RECOVERY_EMAIL: ${{ secrets.TEST_RECOVERY_EMAIL }} | |
TEST_ACCOUNT_PASSWORD: ${{ secrets.TEST_ACCOUNT_PASSWORD }} | |
TEST_SPREADSHEET_URL: ${{ secrets.TEST_SPREADSHEET_URL }} | |
S3_BUCKET_NAME: ${{ secrets.S3_BUCKET_NAME }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
- name: Build and deploy dev setup [yarn deploy:dev] | |
run: yarn deploy:dev | |
env: | |
NODE_OPTIONS: '--max_old_space_size=4096' | |
- name: Run integration tests | |
# use ci-reporter to publish failing diff images to s3 bucket | |
# run: yarn test:integration:extended:ci-reporter | |
run: yarn test:integration:extended | |
shell: bash |