forked from bluesky/tiled
-
Notifications
You must be signed in to change notification settings - Fork 0
148 lines (122 loc) · 3.98 KB
/
ci.yml
File metadata and controls
148 lines (122 loc) · 3.98 KB
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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
name: CI
on:
pull_request:
push:
branches:
- main
schedule:
- cron: '00 4 * * *' # daily at 4AM
env:
TEST_TAG: bluesky/tiled:test
jobs:
pre-commit:
name: Static Code Checks
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: pre-commit/action@v3.0.0
linux_checks:
name: Test on Linux
runs-on: ubuntu-latest
strategy:
matrix:
python-version:
- "3.9"
- "3.10"
- "3.11"
- "3.12"
- "3.13"
fail-fast: false
steps:
- uses: actions/checkout@v3
- name: Install uv and set the python version
uses: astral-sh/setup-uv@v6
with:
python-version: ${{ matrix.python-version }}
- name: Install tiled
run: uv sync --all-extras
- name: Start LDAP service in container.
shell: bash -l {0}
run: source continuous_integration/scripts/start_LDAP.sh
- name: Download SQLite example data.
shell: bash -l {0}
run: source continuous_integration/scripts/download_sqlite_data.sh
- name: Start PostgreSQL service in container.
shell: bash -l {0}
run: source continuous_integration/scripts/start_postgres.sh
- name: Ensure example data is migrated to current catalog database schema.
# The example data is expected to be kept up to date to the latest Tiled
# release, but this CI run may include some unreleased schema changes,
# so we run a migration here.
shell: bash -l {0}
run: |
set -vxeuo pipefail
uv run tiled catalog upgrade-database sqlite:///tiled_test_db_sqlite.db
uv run tiled catalog upgrade-database postgresql://postgres:secret@localhost:5432/tiled-example-data
- name: Test with pytest
shell: bash -l {0}
run: |
set -vxeuo pipefail
uv run coverage run -m pytest -v
uv run coverage report -m
uv run coverage xml -o cov.xml
env:
# Provide test suite with a PostgreSQL database to use.
TILED_TEST_POSTGRESQL_URI: postgresql://postgres:secret@localhost:5432
# Opt in to LDAPAuthenticator tests.
TILED_TEST_LDAP: 1
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v4
with:
name: ${{ inputs.python-version }}/${{ inputs.runs-on }}
files: cov.xml
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
windows_checks:
name: Test on Windows
runs-on: windows-latest
strategy:
matrix:
python-version: ["3.12"]
fail-fast: false
steps:
- uses: actions/checkout@v3
- name: Install uv and set the python version
uses: astral-sh/setup-uv@v6
with:
python-version: ${{ matrix.python-version }}
- name: Install tiled
run: uv sync --all-extras
env:
TILED_BUILD_SKIP_UI: 1
- name: Test with pytest
run: uv run pytest -v
container_canary:
name: Build and validate container
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Install Container Canary
run: |
curl -L https://github.com/NVIDIA/container-canary/releases/download/v0.2.1/canary_linux_amd64 > /usr/local/bin/canary
chmod +x /usr/local/bin/canary
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3
- name: Build Docker image on multiple arch
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6
with:
context: .
file: Containerfile
platforms: linux/amd64,linux/arm64
- name: Tag and load Docker image on single arch for testing (will use cache)
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6
with:
context: .
file: Containerfile
load: true
push: false
tags: ${{ env.TEST_TAG }}
- name: Validate container
run: |
canary validate --file canary-validator.yml ${{ env.TEST_TAG }}