forked from getsentry/sentry
61 lines (53 loc) · 1.9 KB
/
snuba-integration-test.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
name: snuba integration
on:
push:
branches:
- master
- releases/**
pull_request:
jobs:
test:
name: snuba test
runs-on: ubuntu-20.04
timeout-minutes: 30
strategy:
matrix:
instance: [0, 1]
env:
USE_SNUBA: 1
MIGRATIONS_TEST_MIGRATE: 1
USE_REDIS_INDEXER: 1
steps:
- uses: actions/checkout@v2
with:
# Avoid codecov error message related to SHA resolution:
# https://github.com/codecov/codecov-bash/blob/7100762afbc822b91806a6574658129fe0d23a7d/codecov#L891
fetch-depth: '2'
# If we make these jobs "required" to merge on GH, then on every PR, GitHub automatically
# creates a status check in the "pending" state. This means that the workflow needs to run
# for every PR in order to update the status checks.
#
# In order to optimize CI usage, we want the tests to only run when python files change,
# since frontend changes should have no effect on these test suites. We cannot use GH workflow
# path filters because entire workflow would be skipped vs skipping individual jobs which
# would still allow this status check to pass.
- name: Check for python file changes
uses: getsentry/paths-filter@v2
id: changes
with:
token: ${{ github.token }}
filters: .github/file-filters.yml
- name: Setup sentry env
uses: ./.github/actions/setup-sentry
if: steps.changes.outputs.backend == 'true'
id: setup
with:
pip-cache-version: ${{ secrets.PIP_CACHE_VERSION }}
snuba: true
kafka: true
- name: Run snuba test (${{ steps.setup.outputs.matrix-instance-number }} of ${{ strategy.job-total }})
if: steps.changes.outputs.backend == 'true'
run: |
make test-snuba
- name: Handle artifacts
uses: ./.github/actions/artifacts