Skip to content

Tweaks to benchmarking #62

Tweaks to benchmarking

Tweaks to benchmarking #62

name: Test ad load time
on:
push:
branches:
- main
workflow_dispatch:
pull_request:
jobs:
benchmark:
name: Test time to load top-above-nav
timeout-minutes: 30
runs-on: ubuntu-latest
steps:
# Commercial
- name: Checkout
uses: actions/checkout@v4
- name: Set up Node
uses: ./.github/actions/setup-node-env
- name: Install Playwright Browsers
run: pnpm playwright install --with-deps chromium
- name: Build Prod (used for rewriting by playwright)
run: pnpm build:prod
env:
BUNDLE_PREFIX: ''
- name: Run Playwright
run: pnpm benchmark
- uses: actions/github-script@v7
with:
github-token: ${{secrets.GITHUB_TOKEN}}
script: |
const { readFileSync, resolve } = require('fs');
const consented = readFileSync('./benchmark-results/consented/average.txt', 'utf8');
const consentless = readFileSync('./benchmark-results/consentless/average.txt', 'utf8');
const body = `### Ad load time test results
For \`consented\`, \`top-above-nav\` took ${consented}ms to load.
For \`consentless\`, \`top-above-nav\` took ${consentless}ms to load.
Test condtions:
- 5mpbs download speed
- 1.5mpbs upload speed
- 150ms latency`;
const existingComment = await github.rest.issues.listComments({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo
});
if (existingComment.data.length > 0) {
await github.rest.issues.updateComment({
comment_id: existingComment.data[0].id,
owner: context.repo.owner,
repo: context.repo.repo,
body
});
return;
} else {
const { data } = await github.rest.issues.createComment({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
body
});
}