-
Notifications
You must be signed in to change notification settings - Fork 20
113 lines (113 loc) · 3.19 KB
/
slo.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
108
109
110
111
112
113
#name: SLO tests
#
#on:
# push:
# branches: [ master ]
# pull_request:
# branches: [ master ]
# workflow_dispatch:
# inputs:
# github_pull_request_number:
# required: true
# description: ''
# slo_workload_duration_seconds:
# default: '600'
# required: false
# description: ''
# slo_workload_read_max_rps:
# default: '1000'
# required: false
# description: ''
# slo_workload_write_max_rps:
# default: '100'
# required: false
# description: ''
#
#env:
# CARGO_TERM_COLOR: always
# CARGO_REGISTRIES_CRATES_IO_PROTOCOL: sparse
# RUST_VERSION_OLD: "1.68.0"
# RUST_VERSION_NEW: "1.81.0"
#
#jobs:
# ydb-slo-action-init:
# if: (!contains(github.event.pull_request.labels.*.name, 'no slo'))
#
# name: Run YDB SLO Tests
# runs-on: ubuntu-latest
#
# strategy:
# fail-fast: false
# matrix:
# example:
# - native
# rust_version:
# - "RUST_VERSION_OLD"
# - "RUST_VERSION_NEW"
#
# concurrency:
# group: slo-${{ github.ref }}-${{ matrix.example }}
# cancel-in-progress: true
#
# steps:
# - name: Checkout
# uses: actions/checkout@v4
# with:
# submodules: true
#
# - name: Install rust
# uses: dtolnay/rust-toolchain@v1
# with:
# toolchain: ${{ env[matrix.rust_version] }}
# components: clippy
#
# - name: Rust version
# id: rust_version_step
# run: |
# rustc --version
# cargo --version
# echo "CARGO_INCREMENTAL=$CARGO_INCREMENTAL"
# echo "::set-output name=version::$(rustc --version | cut -d ' ' -f 2)"
#
# - name: Rust cache
# uses: Swatinem/rust-cache@v2
#
# - name: Inititialize YDB SLO
# uses: ydb-platform/ydb-slo-action/init@main
# with:
# github_pull_request_number: ${{ github.event.inputs.github_pull_request_number }}
# github_token: ${{ secrets.GITHUB_TOKEN }}
# workload_name: ${{ matrix.example }}
# ydb_database_node_count: 5
#
# - name: Prepare SLO Database
# run: |
# cargo run --example ${{ matrix.example }} grpc://localhost:2136 /local tableName create
#
# - name: Run SLO Tests
# env:
# REF: '${{ github.head_ref || github.ref }}'
# run: |
# cargo run --example ${{ matrix.example }} grpc://localhost:2136 /local tableName run \
# -time ${{ inputs.slo_workload_duration_seconds || 600}} \
# -read-rps ${{ inputs.slo_workload_read_max_rps || 1000}} \
# -write-rps ${{ inputs.slo_workload_write_max_rps || 100}} \
# -read-timeout 1000 \
# -write-timeout 1000 || true
#
# - if: always()
# name: Cleanup SLO Database
# run: |
# cargo run --example ${{ matrix.example }} grpc://localhost:2136 /local tableName cleanup
#
# - if: always()
# name: Store ydb chaos testing logs
# run: |
# docker logs ydb-chaos > chaos-ydb.log
#
# - if: always()
# uses: actions/upload-artifact@v4
# with:
# name: ${{ matrix.workload }}-chaos-ydb.log
# path: ./chaos-ydb.log
# retention-days: 1