Polianin Nikita
f17ee43805
Some checks failed
Test with Different Databases / test (sqlite) (pull_request) Failing after 4m6s
Test with Different Databases / test (postgresql) (pull_request) Failing after 4m8s
Test with Different Databases / test (mysql) (pull_request) Failing after 4m8s
.NET Test Pipeline / build-and-test (pull_request) Successful in 4m41s
67 lines
2.4 KiB
YAML
67 lines
2.4 KiB
YAML
name: Test with Different Databases
|
|
|
|
on:
|
|
pull_request:
|
|
push:
|
|
branches:
|
|
[master, 'release/*']
|
|
|
|
jobs:
|
|
test:
|
|
strategy:
|
|
matrix:
|
|
db-provider: [sqlite, mysql, postgresql]
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: Set up .NET Core
|
|
uses: actions/setup-dotnet@v4
|
|
with:
|
|
dotnet-version: 8.0.x
|
|
|
|
- name: Restore dependencies
|
|
run: dotnet restore
|
|
|
|
- name: Build the solution
|
|
run: dotnet build --configuration Release
|
|
|
|
- name: Install jq
|
|
run: sudo apt-get install -y jq
|
|
|
|
- name: Modify configuration for SQLite
|
|
if: matrix.db-provider == 'sqlite'
|
|
run: |
|
|
jq '.DbSettings.TypeDatabase = 1 | .DbSettings.ConnectionStringSql = "Data Source=test.db3"' Settings.json > temp.json && mv temp.json Settings.json
|
|
|
|
- name: Modify configuration for MySQL
|
|
if: matrix.db-provider == 'mysql'
|
|
run: |
|
|
jq '.DbSettings.TypeDatabase = 0 | .DbSettings.ConnectionStringSql = "Server=127.0.0.1;Port=5555;Database=testdb;Uid=root;Pwd=root;"' Settings.json > temp.json && mv temp.json Settings.json
|
|
|
|
- name: Install MySQL
|
|
if: matrix.db-provider == 'mysql'
|
|
run: |
|
|
sudo apt-get update
|
|
sudo apt-get install -y mysql-server
|
|
sudo service mysql start
|
|
sudo mysql -e "CREATE DATABASE testdb; CREATE USER 'root'@'localhost' IDENTIFIED BY 'root'; GRANT ALL PRIVILEGES ON testdb.* TO 'root'@'localhost'; FLUSH PRIVILEGES;"
|
|
|
|
- name: Modify configuration for PostgreSQL
|
|
if: matrix.db-provider == 'postgresql'
|
|
run: |
|
|
jq '.DbSettings.TypeDatabase = 2 | .DbSettings.ConnectionStringSql = "Host=127.0.0.1;Port=6666;Database=testdb;Username=postgres;Password=postgres"' Settings.json > temp.json && mv temp.json Settings.json
|
|
|
|
- name: Install PostgreSQL
|
|
if: matrix.db-provider == 'postgresql'
|
|
run: |
|
|
sudo apt-get update
|
|
sudo apt-get install -y postgresql postgresql-contrib
|
|
sudo service postgresql start
|
|
sudo -u postgres psql -c "CREATE DATABASE testdb;"
|
|
sudo -u postgres psql -c "CREATE USER postgres WITH PASSWORD 'postgres';"
|
|
sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE testdb TO postgres;"
|
|
|
|
- name: Run tests
|
|
run: dotnet test --configuration Release --no-build --no-restore --verbosity normal |