-
Notifications
You must be signed in to change notification settings - Fork 6
136 lines (116 loc) · 4.14 KB
/
ci.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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
name: "CI: Build and Test"
on:
pull_request:
branches: [main]
paths:
- "**.cs"
- "**.csproj"
- "**.props"
- "**.targets"
- "**.sln"
- "**.ps1"
- "**.config"
- "**.yml"
- "**.json"
jobs:
build_and_test:
name: Build and Test
runs-on: ubuntu-latest
defaults:
run:
shell: pwsh
env:
ASPNETCORE_ENVIRONMENT: CI
NODE_VERSION: ""
DATABASE_BACKUP_FILENAME: ""
DOTNET_CLI_TELEMETRY_OPTOUT: 1
DOTNET_SKIP_FIRST_TIME_EXPERIENCE: 1
DOTNET_NOLOGO: 1
PROJECT_NAME: Kentico.Community.Portal.Web
ASPNETCORE_URLS: https://localhost:45039
steps:
- uses: actions/checkout@v4
- name: "Get node.js version from package.json"
run: |
$nodeVersion = (Get-Content -Raw -Path ./src/${{ env.PROJECT_NAME }}/package.json | ConvertFrom-Json).engines.node
"NODE_VERSION=$nodeVersion" >> $env:GITHUB_ENV
- name: "Install Node.js from package.json version"
uses: actions/setup-node@v4
with:
node-version: "${{ env.NODE_VERSION }}"
- name: Setup .NET
uses: actions/setup-dotnet@v4
with:
global-json-file: global.json
- name: Install dependencies
run: dotnet restore --locked-mode
- name: Build Solution
run: |
dotnet build `
-c Release `
--no-restore
- name: Get Database Backup Name
run: |
$latestBackup = Get-Content -Path "./database/backups.txt" -TotalCount 1
"DATABASE_BACKUP_FILENAME=$latestBackup" >> $env:GITHUB_ENV
- name: Extract Database Backup
run: |
Expand-Archive `
-Path "./database/${{ env.DATABASE_BACKUP_FILENAME }}.zip" `
-DestinationPath "./database"
- name: Install a SQL Server suite of tools (SQLEngine, SQLPackage)
uses: potatoqualitee/mssqlsuite@9a0136e208df60b8ecb62909f076bc34854fa55a # set as a commit hash for security - v1.7
with:
install: sqlpackage, sqlengine
sa-password: Pass@12345
version: 2022
- name: Restore Database .bak
run: |
docker exec sql mkdir /var/opt/mssql/backup
docker cp "./database/${{ env.DATABASE_BACKUP_FILENAME }}" sql:/var/opt/mssql/backup
sqlcmd `
-S localhost `
-d master `
-U "sa" `
-P "Pass@12345" `
-Q "RESTORE DATABASE [Kentico.Community] FROM DISK='/var/opt/mssql/backup/${{ env.DATABASE_BACKUP_FILENAME }}' WITH MOVE 'Kentico.Community' TO '/var/opt/mssql/data/Kentico.Community.mdf', MOVE 'Kentico.Community_log' TO '/var/opt/mssql/data/Kentico.Community_log.ldf'"
if: endsWith(env.DATABASE_BACKUP_FILENAME, '.bak')
- name: Restore Database .bacpac
run: |
sqlpackage `
/a:Import `
/tsn:localhost `
/tdn:Kentico.Community `
/tu:sa `
/tp:Pass@12345 `
/sf:"./database/${{ env.DATABASE_BACKUP_FILENAME }}" `
/tec:False
if: endsWith(env.DATABASE_BACKUP_FILENAME, '.bacpac')
- name: Restore CI Repository
run: |
./scripts/Restore-CI.ps1 -WorkspaceFolder $PWD
- name: Publish Application
run: |
dotnet publish `
./src/${{ env.PROJECT_NAME }} `
-c Release `
-o ./publish `
--no-build `
--no-restore
- name: Install Playwright Dependencies
run: |
./test/Kentico.Community.Portal.Web.E2E.Tests/bin/Release/net8.0/playwright.ps1 install
- name: Run Application and Test Solution
run: |
cd ./publish
Start-Job -ScriptBlock { dotnet ./${{ env.PROJECT_NAME }}.dll } -Name ${{ env.PROJECT_NAME }}
Receive-Job -Name ${{ env.PROJECT_NAME }}
cd ../
dotnet test `
-c Release `
--no-build `
--no-restore `
-s ./test/e2e.runsettings
Receive-Job -Name ${{ env.PROJECT_NAME }}
Stop-Job -Name ${{ env.PROJECT_NAME }}
Remove-Job -Name ${{ env.PROJECT_NAME }}