name: wpt env: ARCH: x86_64-linux AWS_ACCESS_KEY_ID: ${{ vars.LPD_PERF_AWS_ACCESS_KEY_ID }} AWS_SECRET_ACCESS_KEY: ${{ secrets.LPD_PERF_AWS_SECRET_ACCESS_KEY }} AWS_BUCKET: ${{ vars.LPD_PERF_AWS_BUCKET }} AWS_REGION: ${{ vars.LPD_PERF_AWS_REGION }} on: push: branches: - main paths: - "build.zig" - "src/**/*.zig" - "src/*.zig" - "tests/wpt/**" - "vendor/**" pull_request: # By default GH trigger on types opened, synchronize and reopened. # see https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#pull_request # Since we skip the job when the PR is in draft state, we want to force CI # running when the PR is marked ready_for_review w/o other change. # see https://github.com/orgs/community/discussions/25722#discussioncomment-3248917 types: [opened, synchronize, reopened, ready_for_review] paths: - ".github/**" - "build.zig" - "src/**/*.zig" - "src/*.zig" - "tests/wpt/**" - "vendor/**" # Allows you to run this workflow manually from the Actions tab workflow_dispatch: jobs: wpt: name: web platform tests # Don't run the CI with draft PR. if: github.event.pull_request.draft == false runs-on: ubuntu-latest container: image: ghcr.io/lightpanda-io/zig-browsercore:0.12.0-dev.1773-8a8fd47d2 credentials: username: ${{ github.actor }} password: ${{ secrets.GITHUB_TOKEN }} # docker blocks io_uring syscalls by default now. # see https://github.com/tigerbeetle/tigerbeetle/pull/1995 # see https://github.com/moby/moby/pull/46762 options: "--security-opt seccomp=unconfined" steps: - uses: actions/checkout@v4 with: fetch-depth: 0 token: ${{ secrets.GH_CI_PAT }} # fetch submodules recusively, to get zig-js-runtime submodules also. submodules: recursive - uses: ./.github/actions/install - run: zig build wpt -Dengine=v8 -- --safe --summary # For now WPT tests doesn't pass at all. # We accept then to continue the job on failure. # TODO remove the continue-on-error when tests will pass. continue-on-error: true - name: json output run: zig build wpt -Dengine=v8 -- --safe --json > wpt.json - name: write commit run: | echo "${{github.sha}}" > commit.txt - name: upload artifact uses: actions/upload-artifact@v4 with: name: wpt-results path: | wpt.json commit.txt retention-days: 10 perf-fmt: name: perf-fmt needs: wpt # Don't execute on PR if: github.event_name != 'pull_request' runs-on: ubuntu-latest container: image: ghcr.io/lightpanda-io/perf-fmt:latest credentials: username: ${{ github.actor }} password: ${{ secrets.GITHUB_TOKEN }} steps: - name: download artifact uses: actions/download-artifact@v4 with: name: wpt-results - name: format and send json result run: /perf-fmt wpt ${{ github.sha }} wpt.json