-
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
138 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,138 @@ | ||
name: K6 Loki qxip/qryn (HEAVY) | ||
on: | ||
workflow_dispatch: | ||
inputs: | ||
qryn_tag: | ||
description: 'Build/Tag for qryn (latest)' | ||
required: false | ||
clickhouse_tag: | ||
description: 'BuildTag for ClickHouse (latest)' | ||
required: false | ||
clickhouse_image: | ||
description: 'Image for CowsDB (ghcr.io/cowsdb/cowsdb)' | ||
required: false | ||
|
||
jobs: | ||
build: | ||
name: Run k6 on qryn:latest | ||
runs-on: ubuntu-latest | ||
continue-on-error: true | ||
env: | ||
CLICKHOUSE_VERSION: "${{ github.event.inputs.clickhouse_image || 'ghcr.io/cowsdb/cowsdb' }}:${{ github.event.inputs.clickhouse_tag || 'latest' }}" | ||
QRYN_VERSION: "ghcr.io/metrico/qryn:${{ github.event.inputs.qryn_tag || 'latest' }}" | ||
services: | ||
clickhouse: | ||
image: "${{ github.event.inputs.clickhouse_image || 'ghcr.io/cowsdb/cowsdb' }}:${{ github.event.inputs.clickhouse_tag || 'latest' }}" | ||
ports: | ||
- 8123:8123 | ||
env: | ||
PORT: 8123 | ||
qryn: | ||
image: "ghcr.io/metrico/qryn:${{ github.event.inputs.qryn_tag || 'latest' }}" | ||
ports: | ||
- 3100:3100 | ||
env: | ||
CLICKHOUSE_SERVER: clickhouse | ||
CLICKHOUSE_AUTH: "qryn:qryn" | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
with: | ||
repository: metrico/qryn-bench | ||
path: . | ||
- uses: actions/setup-go@v4 | ||
with: | ||
go-version: '1.20' | ||
- name: Download k6 for Prometheus | ||
run: | | ||
wget https://github.com/metrico/qryn-bench/releases/download/latest/k6 | ||
chmod +x k6 | ||
- name: Download k6 for Prometheus | ||
run: | | ||
wget https://github.com/metrico/qryn-bench/releases/download/latest/k6-tracing -O k6-tracing | ||
chmod +x k6-tracing | ||
- name: Collect Workflow Telemetry | ||
uses: runforesight/workflow-telemetry-action@v1.8.7 | ||
|
||
- name: Wait for Loki API | ||
uses: mydea/action-wait-for-api@v1 | ||
with: | ||
url: "http://localhost:3100/loki/api/v1/label" | ||
expected-response-field: "status" | ||
expected-response-field-value: "success" | ||
timeout: 30 | ||
- name: Run k6 loki test | ||
run: ./k6 run --out csv=results.csv loki/qryn-loki-loadtest.js | ||
env: | ||
K6_VUS: 1 | ||
K6_ITERACTIONS: 500 | ||
- run: mv summary.txt loki_summary.txt | ||
if: always() | ||
- name: Wait for Prom API | ||
uses: mydea/action-wait-for-api@v1 | ||
with: | ||
url: "http://localhost:3100/api/v1/query" | ||
expected-response-field: "status" | ||
expected-response-field-value: "success" | ||
timeout: 30 | ||
- name: Run k6 prometheus test | ||
run: ./k6 run --out csv=results.csv prometheus/qryn-loadtest.js | ||
env: | ||
K6_WRITE_HOSTNAME: "localhost:3100" | ||
K6_READ_HOSTNAME: "localhost:3100" | ||
K6_WRITE_REQUEST_RATE: 10 | ||
K6_WRITE_SERIES_PER_REQUEST: 15 | ||
K6_READ_REQUEST_RATE: 5 | ||
K6_DURATION_MIN: 5 | ||
K6_SCRAPE_INTERVAL_SECONDS: 15 | ||
RAMP_UP_MIN: 1 | ||
- run: mv summary.txt prom_summary.txt | ||
if: always() | ||
- name: Wait for Tempo API | ||
uses: mydea/action-wait-for-api@v1 | ||
with: | ||
url: "http://localhost:3100/api/search/tags" | ||
- name: Run k6 tempo test | ||
run: ./k6-tracing run --out csv=results.csv tempo/qryn-tempo-template.js | ||
env: | ||
K6_TEMPO_ENDPOINT: "http://localhost:3100" | ||
K6_VUS: 1 | ||
K6_DURATION_MINUTES: 5 | ||
K6_ITERATIONS: 200 | ||
- run: mv summary.txt tempo_summary.txt | ||
if: always() | ||
- name: Strip Text report | ||
if: always() | ||
run: | | ||
sed -i 's/[^[:print:]]/*/' *_summary.txt | ||
sed -i 's/[\d128-\d255]//g' *_summary.txt | ||
- uses: actions/upload-artifact@v3 | ||
if: always() | ||
with: | ||
name: results | ||
path: | | ||
loki_summary.txt | ||
prom_summary.txt | ||
tempo_summary.txt | ||
- name: Summary Report | ||
if: always() | ||
run: | | ||
echo "### qryn image" >> $GITHUB_STEP_SUMMARY | ||
echo "qxip/qryn:${{ github.event.inputs.qryn_tag || 'latest' }}" >> $GITHUB_STEP_SUMMARY | ||
echo "" >> $GITHUB_STEP_SUMMARY | ||
echo "### cowsdb image" >> $GITHUB_STEP_SUMMARY | ||
echo "${{ github.event.inputs.clickhouse_image || 'ghcr.io/cowsdb/cowsdb' }}:${{ github.event.inputs.clickhouse_tag || 'latest' }}" >> $GITHUB_STEP_SUMMARY | ||
echo "" >> $GITHUB_STEP_SUMMARY | ||
echo "### Loki Test" >> $GITHUB_STEP_SUMMARY | ||
cat loki_summary.txt >> $GITHUB_STEP_SUMMARY | ||
echo "" >> $GITHUB_STEP_SUMMARY | ||
echo "### Prometheus Test" >> $GITHUB_STEP_SUMMARY | ||
cat prom_summary.txt >> $GITHUB_STEP_SUMMARY | ||
echo "" >> $GITHUB_STEP_SUMMARY | ||
echo "### Tempo Test" >> $GITHUB_STEP_SUMMARY | ||
cat tempo_summary.txt >> $GITHUB_STEP_SUMMARY | ||
- name: Pull Docker logs | ||
run: | | ||
docker logs "${{ job.services.clickhouse.id }}" | ||
docker logs "${{ job.services.qryn.id }}" |