chore(pkg/replication): add replication lag metric #4364
Workflow file for this run
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
name: immudb Stress | |
on: | |
pull_request: | |
branches: | |
- '**' | |
schedule: | |
- cron: '0 0 * * *' | |
jobs: | |
stress-build: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Setup runner for Go | |
uses: actions/setup-go@v5 | |
with: | |
go-version: "1.18" | |
- uses: actions/checkout@v4 | |
- name: Build stress tool | |
run: | | |
go build embedded/tools/stress_tool/stress_tool.go | |
- name: "| Entries: 1M | Workers: 20 | Batch: 1k | Batches: 50 |" | |
id: e_1m_w_20_b_1k_bs_50 | |
run: | | |
rm -rf data | |
SECONDS=0 | |
./stress_tool -mode auto -committers 20 -kvCount 1000 -txCount 50 -txRead -synced | |
echo "duration_1=$SECONDS" >> $GITHUB_ENV | |
- name: "| Entries: 1M | Workers: 50 | Batch: 1k | Batches: 20 |" | |
id: e_1m_w_50_b_1k_bs_20 | |
run: | | |
rm -rf data | |
SECONDS=0 | |
./stress_tool -mode auto -committers 50 -kvCount 1000 -txCount 20 -txRead -synced | |
echo "duration_2=$SECONDS" >> $GITHUB_ENV | |
- name: "| Entries: 1M | Workers: 100 | Batch: 1k | Batches: 10 |" | |
id: e_1m_w_100_b_1k_bs_10 | |
run: | | |
rm -rf data | |
SECONDS=0 | |
./stress_tool -mode auto -committers 100 -kvCount 1000 -txCount 10 -txRead -synced | |
echo "duration_3=$SECONDS" >> $GITHUB_ENV | |
- name: Create the Mattermost message | |
if: github.event.schedule == '0 0 * * *' | |
run: > | |
echo "{\"text\":\"### Stress tests results for scheduled daily run on ${{ github.ref_name }} branch\n | |
| Step | Result | Duration |\n | |
| ---- | ------ | -------- |\n | |
| Entries: 1M - Workers: 20 - Batch: 1k - Batches: 50 | ${{ steps.e_1m_w_20_b_1k_bs_50.outcome }} | ${{ env.duration_1 }}s |\n | |
| Entries: 1M - Workers: 50 - Batch: 1k - Batches: 20 | ${{ steps.e_1m_w_50_b_1k_bs_20.outcome }} | ${{ env.duration_2 }}s |\n | |
| Entries: 1M - Workers: 100 - Batch: 1k - Batches: 10 | ${{ steps.e_1m_w_100_b_1k_bs_10.outcome }} | ${{ env.duration_3 }}s |\n | |
**Check details [here](${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }})** | |
\"}" > mattermost.json && echo MM_PAYLOAD=$(cat mattermost.json) >> $GITHUB_ENV | |
- name: Notify on immudb channel on Mattermost | |
if: github.event.schedule == '0 0 * * *' | |
uses: mattermost/action-mattermost-notify@master | |
with: | |
MATTERMOST_WEBHOOK_URL: ${{ secrets.MATTERMOST_WEBHOOK_URL }} | |
MATTERMOST_CHANNEL: 'immudb-tests' | |
PAYLOAD: ${{ env.MM_PAYLOAD }} |