-
Notifications
You must be signed in to change notification settings - Fork 107
97 lines (81 loc) · 2.91 KB
/
db-windows.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
on:
push:
branches:
- master
- main
pull_request:
branches:
- master
- main
name: DBs (Windows)
jobs:
testthat-Windows:
runs-on: windows-latest
name: ${{ matrix.database }}
strategy:
fail-fast: false
matrix:
database:
- SQLServer
- MySQL
- PostgreSQL
- SQLite
env:
CRAN: "https://packagemanager.rstudio.com/cran/latest"
GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }}
steps:
- uses: actions/checkout@v3
- uses: r-lib/actions/setup-r@v2
- name: Install SQL Server
if: matrix.database == 'SQLServer'
uses: potatoqualitee/mssqlsuite@v1.7
with:
install: sqlengine, sqlclient
version: 2019
sa-password: Password12
show-log: true
- name: Install SQL Server Driver
if: matrix.database == 'SQLServer'
run: |
echo "ODBC_CS_SQLSERVER=Driver={ODBC Driver 17 for SQL Server};Server=localhost;Uid=sa;Pwd=Password12" >> $env:GITHUB_ENV
- name: Install MySQL
if: matrix.database == 'MySQL'
uses: ankane/setup-mysql@v1
with:
database: test
- name: Install MySQL Driver
if: matrix.database == 'MySQL'
run: |
choco install mysql.odbc
echo "ODBC_CS_MYSQL=Driver={$(Get-OdbcDriver -Platform 64-bit | Select-Object -ExpandProperty Name | Select-String -Pattern 'ANSI')};Server=127.0.0.1;Database=test;User=root;Password=" >> $env:GITHUB_ENV
- name: Install PostgreSQL
if: matrix.database == 'PostgreSQL'
uses: ankane/setup-postgres@v1
with:
database: test
- name: Install PostgreSQL Driver
if: matrix.database == 'PostgreSQL'
run: |
choco install psqlodbc
echo "ODBC_CS_POSTGRES=Driver={PostgreSQL ANSI(x64)};Server=localhost;Port=5432;BoolsAsChar=0;LFConversion=0;Database=test;UID=postgres;PWD=" >> $env:GITHUB_ENV
- name: Install SQLite
if: matrix.database == 'SQLite'
run: |
(New-Object Net.WebClient).DownloadFile('http://www.ch-werner.de/sqliteodbc/sqliteodbc_w64.exe', 'sqliteodbc_w64.exe')
./sqliteodbc_w64.exe /S
- name: Install SQLite Driver
if: matrix.database == 'SQLite'
run: |
echo "ODBC_CS_SQLITE=Driver={SQLite3 ODBC Driver};Database=${{ runner.temp }}\test;Timeout=2000" >> $env:GITHUB_ENV
- name: Install dependencies
uses: r-lib/actions/setup-r-dependencies@v2
with:
needs: check
- name: Install locally to avoid error with test_local()
run: |
install.packages(".", repos = NULL, type = "source")
shell: Rscript {0}
- name: Test
run: |
options("odbc.interruptible"=TRUE);testthat::test_local(reporter = testthat::ProgressReporter$new(max_failures = Inf, update_interval = Inf))
shell: Rscript {0}