-
Notifications
You must be signed in to change notification settings - Fork 16
73 lines (64 loc) · 3.45 KB
/
dotnet.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
name: .NET
on: [push, pull_request, workflow_dispatch]
jobs:
db:
strategy:
fail-fast: false
matrix:
include:
- db: SqlServer2008
connectionstring: "Server=localhost;initial catalog=envers;User Id=sa;Password=P@ssw0rd"
dialect: "NHibernate.Dialect.MsSql2008Dialect"
driverclass: "NHibernate.Driver.SqlClientDriver"
- db: PostgreSQL
connectionstring: "Host=localhost;Username=envers;Password=envers;Database=envers;Enlist=true;"
dialect: "NHibernate.Dialect.PostgreSQL83Dialect"
driverclass: "NHibernate.Driver.NpgsqlDriver"
- db: Firebird
connectionstring: "DataSource=localhost;Database=envers;User=SYSDBA;Password=envers;charset=utf8;"
dialect: "NHibernate.Dialect.FirebirdDialect"
driverclass: "NHibernate.Driver.FirebirdClientDriver"
- db: MySQL
connectionstring: "Server=localhost;Uid=root;Password=envers;Database=envers;SslMode=none;"
dialect: "NHibernate.Dialect.MySQL8InnoDBDialect"
driverclass: "NHibernate.Driver.MySqlConnector.MySqlConnectorDriver, NHibernate.Driver.MySqlConnector"
- db: Oracle
connectionstring: "User ID=envers;Password=envers;Metadata Pooling=false;Self Tuning=false;Data Source=(DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = XEPDB1)))"
dialect: "NHibernate.Dialect.Oracle10gDialect"
driverclass: "NHibernate.Driver.OracleManagedDataClientDriver"
runs-on: ubuntu-latest
env:
connection.connection_string: ${{matrix.connectionstring}}
dialect: ${{matrix.dialect}}
connection.driver_class: ${{matrix.driverclass}}
LANG: en-US.UTF-8
name: ${{matrix.db}}
steps:
- name: Set up SqlServer
if: matrix.db == 'SqlServer2008'
run: |
docker run -e "ACCEPT_EULA=Y" -e "SA_PASSWORD=P@ssw0rd" -e "MSSQL_PID=Express" -p 1433:1433 -d mcr.microsoft.com/mssql/server:2019-latest;
- name: Set up MySQL
if: matrix.db == 'MySQL'
run: |
sudo service mysql stop
docker run --name mysql --tmpfs /var/lib/mysql:rw,noexec,nosuid,size=256m -e MYSQL_ROOT_PASSWORD=envers -e MYSQL_USER=envers -e MYSQL_PASSWORD=envers -e MYSQL_DATABASE=envers -p 3306:3306 --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3 -d mysql:8.0 mysqld --lower_case_table_names=1 --skip-ssl --default_authentication_plugin=mysql_native_password
- name: Set up Oracle
if: matrix.db == 'Oracle'
run: |
docker run -d -p 1521:1521 -e APP_USER=envers -e APP_USER_PASSWORD=envers -e ORACLE_PASSWORD=envers gvenzl/oracle-xe:18-slim
- name: Set up PostgreSQL
if: matrix.db == 'PostgreSQL'
run: |
docker run -d -e POSTGRES_USER=envers -e POSTGRES_PASSWORD=envers -e POSTGRES_DB=envers -p 5432:5432 postgres:13
- name: Set up Firebird
if: matrix.db == 'Firebird'
run: |
docker run --name firebird -e EnableWireCrypt=true -e FIREBIRD_USER=envers -e FIREBIRD_PASSWORD=envers -e ISC_PASSWORD=envers -e FIREBIRD_DATABASE=envers -p 3050:3050 -d jacobalberty/firebird:v3.0
- uses: actions/checkout@v2
- name: Setup .NET
uses: actions/setup-dotnet@v1
with:
dotnet-version: 6.0.x
- name: Compile and run tests
run: dotnet test Src\\Envers.sln -c Release -f net6.0