-
-
Notifications
You must be signed in to change notification settings - Fork 9
107 lines (95 loc) · 3.66 KB
/
benchmark.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
name: benchmark
on:
push:
branches: [main]
pull_request:
branches: [main]
workflow_dispatch:
permissions:
# deployments permission to deploy GitHub pages website
deployments: write
# contents permission to update benchmark contents in gh-pages branch
contents: write
env:
VALGRIND_VERSION: '1:3.18.1-1ubuntu2'
jobs:
benchmark:
runs-on: ubuntu-latest
timeout-minutes: 30
steps:
- uses: actions/checkout@v3
- uses: pnpm/action-setup@v2
- uses: actions/setup-node@v3
with:
# Fix the version to stabilize results.
node-version: 20.9.0
cache: 'pnpm'
- run: pnpm install
- name: pnpm run build
run: pnpm run build
# ref: https://stackoverflow.com/a/59277514
- name: Cache valgrind
uses: actions/cache@v3
id: cache-valgrind
with:
path: '~/valgrind'
key: ${{ runner.os }}-${{ env.VALGRIND_VERSION}}
- name: Install valgrind
env:
CACHE_HIT: ${{steps.cache-valgrind.outputs.cache-hit}}
run: |
if [[ "$CACHE_HIT" == 'true' ]]; then
sudo cp --verbose --force --recursive ~/valgrind/* /
else
sudo apt-get install --yes valgrind="$VALGRIND_VERSION"
mkdir -p ~/valgrind
sudo dpkg -L valgrind | while IFS= read -r f; do if test -f $f; then echo $f; fi; done | xargs cp --parents --target-directory ~/valgrind/
fi
- name: Setup cachegrind-benchmarking
run: node benchmark/setup-cachegrind-benchmarking.js
- name: Run cachegrind-benchmarking
run: |
# NOTE: Some options are passed to the node command to get consistent results.
# ref: https://pythonspeed.com/articles/consistent-benchmarking-in-ci/#consistent-benchmarking-is-hard-and-its-even-harder-in-the-cloud
# ref: https://github.com/v8/v8/blob/d55d51a2427b5c60b94cf5a9f2bbfbacdfe19b8c/src/flags/flag-definitions.h#L2349-L2372
RESULT=$( \
python3 \
third-party/cachegrind-benchmarking/cachegrind.py \
node \
--random-gc-interval=0 \
--no-randomize-all-allocations \
--hash-seed=0 \
--random-seed=0 \
--fuzzer-random-seed=0 \
--no-turbo-stress-instruction-scheduling \
--no-stress-compaction-random \
--predictable \
--predictable-gc-schedule \
benchmark/run-cachegrind-benchmarking.js \
)
echo \
\{ \
\"name\": \"cachegrind-benchmarking\", \
\"unit\": \"instructions\", \
\"value\": $RESULT \
\} \
>> benchmark/result.jsonl
- name: Convert jsonl to json
run: jq -s '.' benchmark/result.jsonl > benchmark/result.json
- name: Upload benchmark
uses: benchmark-action/github-action-benchmark@v1
with:
tool: customSmallerIsBetter
output-file-path: benchmark/result.json
github-token: ${{ secrets.GITHUB_TOKEN }}
auto-push: ${{ github.ref == 'refs/heads/main' }}
comment-on-alert: true
fail-on-alert: true
# Alerts when a 115% performance degradation occurs.
#
# There is 3.6% noise (maximum score is 3.68% greater than minimum score) for 30 runs.
# This noise is a little loud but negligible in most situations.
# ref: https://github.com/mizdra/eslint-interactive/commit/b751cfdef788ac6eb6b39d2d015494123cae51c1#comments
alert-threshold: '115%'
# for test
# comment-always: true