-
Notifications
You must be signed in to change notification settings - Fork 111
Expand file tree
/
Copy pathintegration-tests-sqlserver.yml
More file actions
99 lines (95 loc) · 2.93 KB
/
Copy pathintegration-tests-sqlserver.yml
File metadata and controls
99 lines (95 loc) · 2.93 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
---
name: Integration tests on SQL Server
on: # yamllint disable-line rule:truthy
workflow_dispatch:
push:
branches:
- master
- v*
paths:
- 'dbt/**'
- 'tests/functional/**'
- 'devops/**'
- 'docker-compose.yml'
- '**/*.lock'
- '.locks/**'
- 'pyproject.toml'
- 'pytest.ini'
- '.github/workflows/integration-tests-sqlserver.yml'
pull_request:
branches:
- master
- v*
paths:
- 'dbt/**'
- 'tests/functional/**'
- 'devops/**'
- 'docker-compose.yml'
- '**/*.lock'
- '.locks/**'
- 'pyproject.toml'
- 'pytest.ini'
- '.github/workflows/integration-tests-sqlserver.yml'
schedule:
- cron: '0 22 * * 0'
jobs:
integration-tests-sql-server:
name: Regular ${{ matrix.backend }}
if: github.actor != 'dependabot[bot]'
strategy:
matrix:
python_version: ["3.10", "3.11", "3.12", "3.13"]
msodbc_version: ["17", "18"]
sqlserver_version: ["2017", "2019", "2022"]
collation: ["SQL_Latin1_General_CP1_CS_AS", "SQL_Latin1_General_CP1_CI_AS"]
backend:
- pyodbc
- mssql-python
exclude:
- backend: pyodbc
python_version: "3.12"
- backend: pyodbc
python_version: "3.13"
- backend: mssql-python
python_version: "3.10"
- backend: mssql-python
python_version: "3.11"
include:
- backend: pyodbc
install_extra: pyodbc
use_mssql_python: "False"
- backend: mssql-python
install_extra: mssql
use_mssql_python: "True"
runs-on: ubuntu-latest
container:
image: ghcr.io/${{ github.repository }}:CI-${{ matrix.python_version }}-msodbc${{ matrix.msodbc_version }}
credentials:
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
services:
sqlserver:
image: ghcr.io/${{ github.repository }}:server-${{ matrix.sqlserver_version }}
env:
ACCEPT_EULA: 'Y'
SA_PASSWORD: 5atyaNadella
DBT_TEST_USER_1: DBT_TEST_USER_1
DBT_TEST_USER_2: DBT_TEST_USER_2
DBT_TEST_USER_3: DBT_TEST_USER_3
COLLATION: ${{ matrix.collation }}
steps:
- uses: actions/checkout@v6
- name: Install uv
run: pip install uv
- name: Install dependencies
env:
INSTALL_EXTRA: ${{ matrix.install_extra }}
run: uv pip install --system -e ".[$INSTALL_EXTRA]" --group dev
- name: Run functional tests
run: pytest -ra -v tests/functional --profile "ci_sql_server"
env:
DBT_TEST_USER_1: DBT_TEST_USER_1
DBT_TEST_USER_2: DBT_TEST_USER_2
DBT_TEST_USER_3: DBT_TEST_USER_3
SQLSERVER_TEST_DRIVER: "ODBC Driver ${{ matrix.msodbc_version }} for SQL Server"
SQLSERVER_TEST_USE_MSSQL_PYTHON: ${{ matrix.use_mssql_python }}