Skip to content
This repository has been archived by the owner on Jul 3, 2024. It is now read-only.
name: API permissions check
on:
push:
branches:
- main
workflow_dispatch:
jobs:
test:
name: Check API permissions with Dev Proxy
timeout-minutes: 60
runs-on: ubuntu-latest
env:
LOG_FILE: devproxy.log
DEVPROXY_VERSION: v0.19.0
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
cache: "npm"
- name: Install dependencies
run: npm ci
- name: Create env.js file in src folder
run: echo "const appId = '${{ vars.APPID }}';" > src/env.js
- name: Show env.js file
run: cat src/env.js
- name: Create dotenv file
run: |
echo "TEST_USERNAME=${{ vars.TEST_USERNAME }}" > .env
echo "TEST_PASSWORD=${{ secrets.TEST_PASSWORD }}" >> .env
#################################
# Cache + install of Playwright #
#################################
- name: Store Playwright's Version
run: |
PLAYWRIGHT_VERSION=$(npm ls @playwright/test | grep @playwright | sed 's/.*@//')
echo "Playwright's Version: $PLAYWRIGHT_VERSION"
echo "PLAYWRIGHT_VERSION=$PLAYWRIGHT_VERSION" >> $GITHUB_ENV
- name: Cache Playwright Browsers for Playwright's Version
id: cache-playwright
uses: actions/cache@v4
with:
path: ~/.cache/ms-playwright
key: playwright-ubuntu-${{ env.PLAYWRIGHT_VERSION }}
- name: Install Playwright Browsers
if: steps.cache-playwright.outputs.cache-hit != 'true'
run: npx playwright install --with-deps
################################
# Cache + install of Dev Proxy #
################################
- name: Cache Dev Proxy
id: cache-devproxy
uses: actions/cache@v4
with:
path: ./devproxy
key: devproxy-${{ env.DEVPROXY_VERSION }}
- name: Install Dev Proxy
if: steps.cache-devproxy.outputs.cache-hit != 'true'
run: bash -c "$(curl -sL https://aka.ms/devproxy/setup.sh)" -- ${{ env.DEVPROXY_VERSION }}
- name: Check Dev Proxy version
run: ./devproxy/devproxy --version
- name: Run Dev Proxy
run: /bin/bash run.sh
- name: Upload Dev Proxy logs
uses: actions/upload-artifact@v4
with:
name: ${{ env.LOG_FILE }}
path: ${{ env.LOG_FILE }}
# only when using a reporting plugin with the Markdown reporter
- name: Upload Dev Proxy reports
uses: actions/upload-artifact@v4
with:
name: Reports
path: ./*Reporter*
# only when using a reporting plugin with the Markdown reporter
- name: Write summary
run: |
cat MinimalPermissionsGuidancePlugin_MarkdownReporter.md >> $GITHUB_STEP_SUMMARY