generated from Kentico/repo-template
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
update scripts, setting auto hotfix from pipeline
- Loading branch information
1 parent
0de403f
commit da3c634
Showing
11 changed files
with
558 additions
and
307 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,161 +1,190 @@ | ||
name: "CI: Build and Test" | ||
|
||
on: | ||
push: | ||
branches: [main, feat/automatic_E2E_testing] | ||
# paths: | ||
# - "**.cs" | ||
# - "**.tsx" | ||
# - "**.js" | ||
# - "**.csproj" | ||
# - "**.props" | ||
# - "**.targets" | ||
# - "**.sln" | ||
# - "**/Client/**/*.json" | ||
pull_request: | ||
branches: [main] | ||
paths: | ||
- "**.cs" | ||
- "**.cshtml" | ||
- "**.tsx" | ||
- "**.js" | ||
- "**.json" | ||
- "**.csproj" | ||
- "**.props" | ||
- "**.targets" | ||
- "**.sln" | ||
|
||
jobs: | ||
build_and_test: | ||
name: Build and Test | ||
runs-on: ubuntu-latest | ||
defaults: | ||
run: | ||
shell: pwsh | ||
|
||
env: | ||
ASPNETCORE_ENVIRONMENT: CI | ||
DATABASE_BACKUP_FILENAME: "" | ||
DOTNET_CLI_TELEMETRY_OPTOUT: 1 | ||
DOTNET_SKIP_FIRST_TIME_EXPERIENCE: 1 | ||
DOTNET_NOLOGO: 1 | ||
PROJECT_NAME: DancingGoat | ||
ASPNETCORE_URLS: https://localhost:14070 | ||
STATUS_CHECK_URL: https://localhost:14070/status | ||
DATABASE_USER: "sa" | ||
DATABASE_PASSWORD: "Pass@12345" | ||
DATABASE_NAME: "XByK_DancingGoat_Zapier" | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- 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 ` | ||
--configuration 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: ${{ env.DATABASE_PASSWORD }} | ||
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 ${{ env.DATABASE_USER }} ` | ||
-P ${{ env.DATABASE_PASSWORD }} ` | ||
-Q "RESTORE DATABASE [XByK_DancingGoat_Zapier] FROM DISK='/var/opt/mssql/backup/${{ env.DATABASE_BACKUP_FILENAME }}' WITH MOVE 'XByK_DancingGoat_Zapier' TO '/var/opt/mssql/data/XByK_DancingGoat_Zapier.mdf', MOVE 'XByK_DancingGoat_Zapier_log' TO '/var/opt/mssql/data/XByK_DancingGoat_Zapier_log.ldf'" | ||
- name: Restore CI Repository | ||
working-directory: "./scripts" | ||
run: | | ||
./Restore-CI.ps1 | ||
- name: Publish Application | ||
run: | | ||
dotnet publish ` | ||
./examples/${{ env.PROJECT_NAME }} ` | ||
-c Release ` | ||
-o ./publish ` | ||
--no-build ` | ||
--no-restore | ||
#- name: Install Playwright Dependencies | ||
# TODO: to je blbost | ||
#run: | | ||
# ./test/Kentico.Community.Portal.Web.E2E.Tests/bin/Release/net8.0/playwright.ps1 install | ||
|
||
- name: Install Azurite | ||
id: azuright | ||
uses: potatoqualitee/azuright@e56d2754eb15218d507961493bc83ca037216887 # set as a commit hash for security - v1.1 | ||
|
||
|
||
- name: Test Solution | ||
run: | | ||
dotnet test ` | ||
--configuration Release ` | ||
--no-build ` | ||
--no-restore | ||
- name: Run Application and E2E Tests | ||
run: | | ||
# Run the ASP.NET Core app as a background job | ||
cd ./publish | ||
Start-Job -ScriptBlock { dotnet ./${{ env.PROJECT_NAME }}.dll } -Name ${{ env.PROJECT_NAME }} | ||
Receive-Job -Name ${{ env.PROJECT_NAME }} | ||
cd ../ | ||
# The ASP.NET Core app can take a few seconds to start, so we delay running tests | ||
# until it is ready, and fail if we go over a maximum wait time | ||
$limit = 10 | ||
$attempts = 0 | ||
$success = $false | ||
while ($attempts -lt $limit -and -not $success) { | ||
Start-Sleep -Seconds 1 | ||
try { | ||
$response = Invoke-WebRequest -Uri ${{ env.STATUS_CHECK_URL }} -Method Get -SkipCertificateCheck | ||
if ($response.StatusCode -eq 200) { | ||
Write-Output "Application is ready." | ||
$success = $true | ||
} | ||
} | ||
catch { | ||
Write-Output "Attempt $attempts - Application not ready yet." | ||
} | ||
$attempts++ | ||
} | ||
if (-not $success) { | ||
Write-Output "Application did not respond in time." | ||
exit 1 | ||
} | ||
# TODO: Run the E2E tests | ||
# Stop the background ASP.NET Core application | ||
Receive-Job -Name ${{ env.PROJECT_NAME }} | ||
Stop-Job -Name ${{ env.PROJECT_NAME }} | ||
Remove-Job -Name ${{ env.PROJECT_NAME }} | ||
name: "CI: Build and Test" | ||
|
||
on: | ||
push: | ||
branches: [main, feat/automatic_E2E_testing] | ||
# paths: | ||
# - "**.cs" | ||
# - "**.tsx" | ||
# - "**.js" | ||
# - "**.csproj" | ||
# - "**.props" | ||
# - "**.targets" | ||
# - "**.sln" | ||
# - "**/Client/**/*.json" | ||
pull_request: | ||
branches: [main] | ||
paths: | ||
- "**.cs" | ||
- "**.cshtml" | ||
- "**.tsx" | ||
- "**.js" | ||
- "**.json" | ||
- "**.csproj" | ||
- "**.props" | ||
- "**.targets" | ||
- "**.sln" | ||
|
||
jobs: | ||
build_and_test: | ||
name: Test E2E | ||
runs-on: ubuntu-latest | ||
defaults: | ||
run: | ||
shell: pwsh | ||
|
||
env: | ||
ASPNETCORE_ENVIRONMENT: CI | ||
DATABASE_BACKUP_FILENAME: "" | ||
DOTNET_CLI_TELEMETRY_OPTOUT: 1 | ||
DOTNET_SKIP_FIRST_TIME_EXPERIENCE: 1 | ||
DOTNET_NOLOGO: 1 | ||
PROJECT_NAME: DancingGoat | ||
STATUS_CHECK_URL: https://localhost:14070/status | ||
DATABASE_USER: "sa" | ||
DATABASE_PASSWORD: "Pass@12345" | ||
DATABASE_NAME: "XByK_DancingGoat_Zapier" | ||
XPERIENCE_BY_KENTICO_LICENSE: ${{ secrets.XPERIENCE_BY_KENTICO_LICENSE }} | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Setup .NET | ||
uses: actions/setup-dotnet@v4 | ||
with: | ||
global-json-file: global.json | ||
|
||
- name: Setup Node | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version: lts/* | ||
|
||
# - name: Install NPM | ||
# run: | | ||
# cd test/Playwright | ||
# npm ci | ||
# npx playwright install --with-deps | ||
# cd ../.. | ||
|
||
- 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: ${{ env.DATABASE_PASSWORD }} | ||
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 ${{ env.DATABASE_USER }} ` | ||
-P ${{ env.DATABASE_PASSWORD }} ` | ||
-Q "RESTORE DATABASE [XByK_DancingGoat_Zapier] FROM DISK='/var/opt/mssql/backup/${{ env.DATABASE_BACKUP_FILENAME }}' WITH MOVE 'XByK_DancingGoat_Zapier' TO '/var/opt/mssql/data/XByK_DancingGoat_Zapier.mdf', MOVE 'XByK_DancingGoat_Zapier_log' TO '/var/opt/mssql/data/XByK_DancingGoat_Zapier_log.ldf'" | ||
# - name: Imports license key to DB | ||
# run: | | ||
# sqlcmd ` | ||
# -S localhost ` | ||
# -d ${{ env.DATABASE_NAME }} ` | ||
# -U ${{ env.DATABASE_USER }} ` | ||
# -P ${{ env.DATABASE_PASSWORD }} ` | ||
# -Q "UPDATE CMS_SettingsKey SET KeyValue='${{ env.XPERIENCE_BY_KENTICO_LICENSE }}' WHERE KeyName='CMSLicenseKey'" | ||
|
||
- name: Reset DB consistency for last applied hotfix | ||
run: | | ||
dotnet build ` | ||
--configuration Release | ||
cd scripts | ||
./Reset-DatabaseConsistency.ps1 | ||
cd .. | ||
- name: Build Solution for last hotfix | ||
run: | | ||
dotnet build ` | ||
--configuration Release ` | ||
-p:XbyKVersion=* | ||
cd scripts | ||
./Reset-DatabaseConsistency.ps1 -ExcludeCIRestore | ||
cd .. | ||
- name: Publish Application | ||
run: | | ||
dotnet publish ` | ||
./examples/${{ env.PROJECT_NAME }} ` | ||
-c Release ` | ||
-o ./publish ` | ||
--no-build ` | ||
--no-restore | ||
- name: Install Azurite | ||
id: azuright | ||
uses: potatoqualitee/azuright@e56d2754eb15218d507961493bc83ca037216887 # set as a commit hash for security - v1.1 | ||
|
||
|
||
- name: Test Solution | ||
run: | | ||
dotnet test ` | ||
--configuration Release ` | ||
--no-build ` | ||
--no-restore | ||
- name: Run Application and E2E Tests | ||
run: | | ||
# Run the ASP.NET Core app as a background job | ||
cd ./publish | ||
Start-Job -ScriptBlock { dotnet ./${{ env.PROJECT_NAME }}.dll } -Name ${{ env.PROJECT_NAME }} | ||
Receive-Job -Name ${{ env.PROJECT_NAME }} | ||
cd ../ | ||
# The ASP.NET Core app can take a few seconds to start, so we delay running tests | ||
# until it is ready, and fail if we go over a maximum wait time | ||
$limit = 10 | ||
$attempts = 0 | ||
$success = $false | ||
while ($attempts -lt $limit -and -not $success) { | ||
Start-Sleep -Seconds 1 | ||
try { | ||
$response = Invoke-WebRequest -Uri ${{ env.STATUS_CHECK_URL }} -Method Get -SkipCertificateCheck | ||
if ($response.StatusCode -eq 200) { | ||
Write-Output "Application is ready." | ||
$success = $true | ||
} | ||
} | ||
catch { | ||
Write-Output "Attempt $attempts - Application not ready yet." | ||
} | ||
$attempts++ | ||
} | ||
if (-not $success) { | ||
Write-Output "Application did not respond in time." | ||
exit 1 | ||
} | ||
# TODO: Run the E2E tests | ||
# cd test/Playwright | ||
# npx playwright test | ||
# cd ../.. | ||
|
||
# Stop the background ASP.NET Core application | ||
Receive-Job -Name ${{ env.PROJECT_NAME }} | ||
Stop-Job -Name ${{ env.PROJECT_NAME }} | ||
Remove-Job -Name ${{ env.PROJECT_NAME }} | ||
|
||
# - uses: actions/upload-artifact@v4 | ||
# with: | ||
# name: playwright-report | ||
# path: ./test/Playwright/playwright-report/ | ||
# retention-days: 30 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,22 +1,25 @@ | ||
<Project> | ||
<PropertyGroup> | ||
<ManagePackageVersionsCentrally>true</ManagePackageVersionsCentrally> | ||
<CentralPackageVersionOverrideEnabled>false</CentralPackageVersionOverrideEnabled> | ||
<RestorePackagesWithLockFile>true</RestorePackagesWithLockFile> | ||
<DisableImplicitNuGetFallbackFolder>true</DisableImplicitNuGetFallbackFolder> | ||
</PropertyGroup> | ||
<ItemGroup> | ||
<PackageVersion Include="Kentico.Xperience.Admin" Version="29.3.0" /> | ||
<PackageVersion Include="Kentico.Xperience.WebApp" Version="29.3.0" /> | ||
<PackageVersion Include="kentico.xperience.azurestorage" Version="29.3.0" /> | ||
<PackageVersion Include="kentico.xperience.imageprocessing" Version="29.3.0" /> | ||
<PackageVersion Include="Microsoft.SourceLink.GitHub" Version="8.0.0" /> | ||
<PackageVersion Include="SonarAnalyzer.CSharp" Version="9.6.0.74858" /> | ||
<PackageVersion Include="Microsoft.NET.Test.Sdk" Version="17.8.0" /> | ||
<PackageVersion Include="NUnit" Version="4.0.1" /> | ||
<PackageVersion Include="NUnit3TestAdapter" Version="4.5.0" /> | ||
<PackageVersion Include="NUnit.Analyzers" Version="3.10.0" /> | ||
<PackageVersion Include="coverlet.collector" Version="6.0.0" /> | ||
<PackageVersion Include="AspNetCore.Authentication.ApiKey" Version="8.0.0" /> | ||
</ItemGroup> | ||
<Project> | ||
<PropertyGroup> | ||
<ManagePackageVersionsCentrally>true</ManagePackageVersionsCentrally> | ||
<CentralPackageVersionOverrideEnabled>true</CentralPackageVersionOverrideEnabled> | ||
<RestorePackagesWithLockFile>true</RestorePackagesWithLockFile> | ||
<DisableImplicitNuGetFallbackFolder>true</DisableImplicitNuGetFallbackFolder> | ||
<CentralPackageFloatingVersionsEnabled>true</CentralPackageFloatingVersionsEnabled> | ||
<LastAppliedHotfix>29.3.0</LastAppliedHotfix> | ||
<XbyKVersion Condition="'$(XbyKVersion)' == ''">$(LastAppliedHotfix)</XbyKVersion> | ||
</PropertyGroup> | ||
<ItemGroup> | ||
<PackageVersion Include="Kentico.Xperience.Admin" Version="$(LastAppliedHotfix)" /> | ||
<PackageVersion Include="Kentico.Xperience.WebApp" Version="$(LastAppliedHotfix)" /> | ||
<PackageVersion Include="kentico.xperience.azurestorage" Version="$(LastAppliedHotfix)" /> | ||
<PackageVersion Include="kentico.xperience.imageprocessing" Version="$(LastAppliedHotfix)" /> | ||
<PackageVersion Include="Microsoft.SourceLink.GitHub" Version="8.0.0" /> | ||
<PackageVersion Include="SonarAnalyzer.CSharp" Version="9.6.0.74858" /> | ||
<PackageVersion Include="Microsoft.NET.Test.Sdk" Version="17.8.0" /> | ||
<PackageVersion Include="NUnit" Version="4.0.1" /> | ||
<PackageVersion Include="NUnit3TestAdapter" Version="4.5.0" /> | ||
<PackageVersion Include="NUnit.Analyzers" Version="3.10.0" /> | ||
<PackageVersion Include="coverlet.collector" Version="6.0.0" /> | ||
<PackageVersion Include="AspNetCore.Authentication.ApiKey" Version="8.0.0" /> | ||
</ItemGroup> | ||
</Project> |
Oops, something went wrong.