MireaBackend/.gitea/workflows/database_test.yaml
Polianin Nikita c9c6a99fe9
Some checks failed
Test with Different Databases / test (postgresql) (pull_request) Failing after 1s
Test with Different Databases / test (sqlite) (pull_request) Failing after 1s
Test with Different Databases / test (mysql) (pull_request) Failing after 2s
.NET Test Pipeline / build-and-test (pull_request) Failing after 4m48s
test: trying to set up tests to test application in different databases
2024-05-30 21:45:45 +03:00

77 lines
2.3 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
services:
mysql:
image: mysql:latest
env:
MYSQL_ROOT_PASSWORD: root
MYSQL_DATABASE: testdb
options: >-
--health-cmd "mysqladmin ping --silent"
--health-interval 10s
--health-timeout 5s
--health-retries 5
ports:
- 3306:3306
postgres:
image: postgres:latest
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
POSTGRES_DB: testdb
options: >-
--health-cmd "pg_isready -U postgres"
--health-interval 10s
--health-timeout 5s
--health-retries 5
ports:
- 5432:5432
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=3306;Database=testdb;Uid=root;Pwd=root;"' Settings.json > temp.json && mv temp.json Settings.json
- name: Modify configuration for PostgreSQL
if: matrix.db-provider == 'postgresql'
run: |
jq '.DbSettings.TypeDatabase = 2 | .DbSettings.ConnectionStringSql = "Host=127.0.0.1;Port=5432;Database=testdb;Username=postgres;Password=postgres"' Settings.json > temp.json && mv temp.json Settings.json
- name: Run tests
run: dotnet test --configuration Release --no-build --no-restore --verbosity normal