dressca-backend CI #317
Workflow file for this run
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
--- | |
# cSpell:ignore lcov msbuild NOLOGO OPTOUT | |
name: dressca-backend CI | |
on: | |
pull_request: | |
branches: [ main ] | |
paths: | |
- 'samples/Dressca/dressca-backend/**' | |
- '.github/workflows/samples-dressca-backend.ci.yml' | |
workflow_dispatch: | |
env: | |
WORKING_DIRECTORY: samples/Dressca/dressca-backend | |
PATH_CACHE: /tmp/docker-img | |
defaults: | |
run: | |
working-directory: samples/Dressca/dressca-backend | |
jobs: | |
build: | |
name: バックエンドアプリケーションのビルド | |
runs-on: ubuntu-latest | |
env: | |
DOTNET_NOLOGO: true | |
DOTNET_CLI_TELEMETRY_OPTOUT: true | |
BUILD_CONFIGURATION: Debug | |
BUILD_SUMMARY_FILE: BuildSummary.md | |
permissions: | |
checks: write | |
contents: read | |
pull-requests: write | |
steps: | |
- name: ブランチのチェックアウト | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- name: .NET SDK のセットアップ | |
uses: actions/[email protected] | |
with: | |
dotnet-version: 6.0.x | |
include-prerelease: false | |
- name: NuGet パッケージの復元 | |
run: dotnet restore | |
- id: application-build | |
name: アプリケーションのビルド | |
run: dotnet build --no-restore --configuration ${{ env.BUILD_CONFIGURATION }} --verbosity minimal > build-result.txt | |
- name: ビルド結果の表示 | |
shell: bash | |
if: ${{ success() || (failure() && steps.application-build.conclusion == 'failure') }} | |
run: | | |
echo '# Build Result :gear:' >> $GITHUB_STEP_SUMMARY | |
cat build-result.txt | sed -n -e 's/^/> /p' >> $GITHUB_STEP_SUMMARY | |
- name: キャッシュIDの作成 | |
id: imagetag | |
run: | | |
VARIANT=$(TZ=UTC-9 date '+%Y%m') | |
NAME_IMAGE=SQLServerDockerImage | |
# キャッシュする tar アーカイブ名とパスの設定 | |
NAME_TAR="${NAME_IMAGE}.${VARIANT}.tar" | |
PATH_TAR=${{ env.PATH_CACHE }}"/${NAME_TAR}" | |
# 変数を他の run でも使えるように output | |
echo "NAME_TAR=${NAME_TAR}" >> "$GITHUB_OUTPUT" | |
echo "PATH_TAR=${PATH_TAR}" >> "$GITHUB_OUTPUT" | |
- name: キャッシュ有効化 | |
id: cache | |
uses: actions/cache@v3 | |
with: | |
path: ${{ env.PATH_CACHE }} | |
key: ${{ steps.imagetag.outputs.NAME_TAR }} | |
#- name: キャッシュがある場合にロード | |
# if: steps.cache.outputs.cache-hit == 'true' | |
# run: docker load --input ${{ steps.imagetag.outputs.PATH_TAR }} | |
- name: キャッシュがない場合にイメージをプルして保存 | |
if: steps.cache.outputs.cache-hit != 'true' | |
run: | | |
mkdir -p ${{ env.PATH_CACHE }} | |
sudo docker pull mcr.microsoft.com/mssql/server:2022-latest | |
sudo docker run -e "ACCEPT_EULA=Y" \ | |
-e "MSSQL_SA_PASSWORD=P@ssw0rd" \ | |
-p 1433:1433 --name sql1 \ | |
--hostname sql1 \ | |
-d \ | |
mcr.microsoft.com/mssql/server:2022-latest | |
sudo docker exec sql1 /opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P "P@ssw0rd" -Q "CREATE DATABASE Dressca_Eshop;" | |
sudo docker save mcr.microsoft.com/mssql/server:2022-latest -o ${{ steps.imagetag.outputs.PATH_TAR }} | |
- name: 結合テスト用にSQL Serverをセットアップ | |
run: | | |
sudo docker load --input ${{ steps.imagetag.outputs.PATH_TAR }} | |
sudo docker run mcr.microsoft.com/mssql/server:2022-latest -e "ACCEPT_EULA=Y" \ | |
-e "MSSQL_SA_PASSWORD=P@ssw0rd" \ | |
-p 1433:1433 --name sql1 \ | |
--hostname sql1 \ | |
-d \ | |
mcr.microsoft.com/mssql/server:2022-latest | |
- id: run-tests | |
name: テストの実行 | |
continue-on-error: true | |
run: dotnet test --settings:./tests/Dressca.IntegrationTest/citest.runsettings --no-build --logger trx --verbosity normal --configuration ${{ env.BUILD_CONFIGURATION }} --collect "XPlat Code Coverage" | |
- id: create-test-result-report | |
name: テスト結果ページの作成 | |
uses: dorny/test-reporter@v1 | |
if: ${{ success() || (failure() && steps.run-tests.conclusion == 'failure') }} | |
with: | |
name: 'Test results' | |
path: '**/TestResults/*.trx' | |
path-replace-backslashes: 'true' | |
reporter: 'dotnet-trx' | |
only-summary: 'false' | |
list-suites: 'all' | |
list-tests: 'all' | |
max-annotations: '10' | |
fail-on-error: 'true' | |
- name: テスト結果のサマリー表示 | |
shell: bash | |
if: ${{ success() || (failure() && steps.run-tests.conclusion == 'failure') }} | |
run: | | |
echo '## Test Result :memo:' >> ${{ env.BUILD_SUMMARY_FILE }} | |
echo 'Test was a **${{ steps.create-test-result-report.outputs.conclusion }}**.' >> ${{ env.BUILD_SUMMARY_FILE }} | |
echo 'Completed in ${{ steps.create-test-result-report.outputs.time }}ms with **${{ steps.create-test-result-report.outputs.passed }}** passed, **${{ steps.create-test-result-report.outputs.failed }}** failed and ${{ steps.create-test-result-report.outputs.skipped }} skipped.' >> ${{ env.BUILD_SUMMARY_FILE }} | |
cat ${{ env.BUILD_SUMMARY_FILE }} >> $GITHUB_STEP_SUMMARY | |
- id: create-coverage-report | |
name: コードカバレッジレポートの解析と作成 | |
uses: danielpalme/ReportGenerator-GitHub-Action@5 | |
if: ${{ success() || (failure() && steps.run-tests.conclusion == 'failure') }} | |
with: | |
reports: '**/TestResults/*/coverage.cobertura.xml' | |
targetdir: '${{ env.WORKING_DIRECTORY }}/CoverageReport' | |
reporttypes: 'MarkdownSummaryGithub' | |
- name: コードカバレッジの結果表示 | |
shell: bash | |
if: ${{ success() || (failure() && steps.run-tests.conclusion == 'failure') }} | |
run: | | |
sed -i s/'# Summary'/'## Coverage :triangular_ruler:'/g CoverageReport/SummaryGithub.md | |
sed -i -e '/^## Coverage$/d' CoverageReport/SummaryGithub.md | |
cat CoverageReport/SummaryGithub.md >> $GITHUB_STEP_SUMMARY | |
cat CoverageReport/SummaryGithub.md >> ${{ env.BUILD_SUMMARY_FILE }} | |
- name: ビルドサマリーをPull-requestに表示 | |
uses: marocchino/sticky-pull-request-comment@v2 | |
if: ${{ github.event_name == 'pull_request' && (success() || (failure() && steps.run-tests.conclusion == 'failure')) }} | |
with: | |
recreate: true | |
path: '${{ env.WORKING_DIRECTORY }}/${{ env.BUILD_SUMMARY_FILE }}' |