memgraph/.github/workflows/daily_benchmark.yaml

107 lines
4.2 KiB
YAML
Raw Normal View History

2021-06-08 14:44:12 +08:00
name: Daily Benchmark
on:
workflow_dispatch:
schedule:
2023-02-01 06:20:49 +08:00
- cron: "0 22 * * *"
2021-06-08 14:44:12 +08:00
jobs:
release_benchmarks:
name: "Release benchmarks"
runs-on: [self-hosted, Linux, X64, Diff, Gen7]
env:
THREADS: 24
MEMGRAPH_ENTERPRISE_LICENSE: ${{ secrets.MEMGRAPH_ENTERPRISE_LICENSE }}
MEMGRAPH_ORGANIZATION_NAME: ${{ secrets.MEMGRAPH_ORGANIZATION_NAME }}
2021-06-08 14:44:12 +08:00
steps:
- name: Set up repository
2022-11-09 17:48:34 +08:00
uses: actions/checkout@v3
2021-06-08 14:44:12 +08:00
with:
# Number of commits to fetch. `0` indicates all history for all
# branches and tags. (default: 1)
fetch-depth: 0
- name: Build release binaries
run: |
# Activate toolchain.
2022-01-18 19:51:27 +08:00
source /opt/toolchain-v4/activate
2021-06-08 14:44:12 +08:00
# Initialize dependencies.
./init
# Build only memgraph release binaries.
cd build
cmake -DCMAKE_BUILD_TYPE=release ..
make -j$THREADS
- name: Run macro benchmarks
run: |
cd tests/macro_benchmark
./harness QuerySuite MemgraphRunner \
--groups aggregation 1000_create unwind_create dense_expand match \
--no-strict
2021-10-27 15:05:46 +08:00
- name: Get branch name (merge)
if: github.event_name != 'pull_request'
shell: bash
run: echo "BRANCH_NAME=$(echo ${GITHUB_REF#refs/heads/} | tr / -)" >> $GITHUB_ENV
- name: Get branch name (pull request)
if: github.event_name == 'pull_request'
shell: bash
run: echo "BRANCH_NAME=$(echo ${GITHUB_HEAD_REF} | tr / -)" >> $GITHUB_ENV
2021-06-08 14:44:12 +08:00
- name: Upload macro benchmark results
run: |
cd tools/bench-graph-client
virtualenv -p python3 ve3
source ve3/bin/activate
pip install -r requirements.txt
./main.py --benchmark-name "macro_benchmark" \
2023-10-28 18:52:14 +08:00
--benchmark-results "../../tests/macro_benchmark/.harness_summary" \
2021-06-08 14:44:12 +08:00
--github-run-id "${{ github.run_id }}" \
2021-10-27 15:05:46 +08:00
--github-run-number "${{ github.run_number }}" \
--head-branch-name "${{ env.BRANCH_NAME }}"
2021-06-08 14:44:12 +08:00
- name: Run mgbench
run: |
cd tests/mgbench
./benchmark.py vendor-native --num-workers-for-benchmark 12 --export-results benchmark_pokec.json pokec/medium/*/*
./benchmark.py vendor-native --num-workers-for-benchmark 1 --export-results benchmark_supernode.json supernode
2021-06-08 14:44:12 +08:00
./benchmark.py vendor-native --num-workers-for-benchmark 1 --export-results benchmark_high_write_set_property.json high_write_set_property
./benchmark.py vendor-native --num-workers-for-benchmark 12 --export-results cartesian.json cartesian
2021-06-08 14:44:12 +08:00
- name: Upload mgbench results
run: |
cd tools/bench-graph-client
virtualenv -p python3 ve3
source ve3/bin/activate
pip install -r requirements.txt
./main.py --benchmark-name "mgbench" \
2023-10-28 18:52:14 +08:00
--benchmark-results "../../tests/mgbench/benchmark_pokec.json" \
--github-run-id "${{ github.run_id }}" \
--github-run-number "${{ github.run_number }}" \
--head-branch-name "${{ env.BRANCH_NAME }}"
./main.py --benchmark-name "supernode" \
2023-10-28 18:52:14 +08:00
--benchmark-results "../../tests/mgbench/benchmark_supernode.json" \
2021-06-08 14:44:12 +08:00
--github-run-id "${{ github.run_id }}" \
2021-10-27 15:05:46 +08:00
--github-run-number "${{ github.run_number }}" \
--head-branch-name "${{ env.BRANCH_NAME }}"
./main.py --benchmark-name "high_write_set_property" \
2023-10-28 18:52:14 +08:00
--benchmark-results "../../tests/mgbench/benchmark_high_write_set_property.json" \
--github-run-id "${{ github.run_id }}" \
--github-run-number "${{ github.run_number }}" \
--head-branch-name "${{ env.BRANCH_NAME }}"
./main.py --benchmark-name "cartesian" \
2023-10-28 18:52:14 +08:00
--benchmark-results "../../tests/mgbench/cartesian.json" \
--github-run-id "${{ github.run_id }}" \
--github-run-number "${{ github.run_number }}" \
--head-branch-name "${{ env.BRANCH_NAME }}"