Skip to content

Merge pull request #108 from Freeesia/feature/fix_misc #253

Merge pull request #108 from Freeesia/feature/fix_misc

Merge pull request #108 from Freeesia/feature/fix_misc #253

Workflow file for this run

# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.
# This workflow will build, test, sign and package a WPF or Windows Forms desktop application
# built on .NET Core.
# To learn how to migrate your existing application to .NET Core,
# refer to https://docs.microsoft.com/en-us/dotnet/desktop-wpf/migration/convert-project-from-net-framework
#
# To configure this workflow:
#
# 1. Configure environment variables
# GitHub sets default environment variables for every workflow run.
# Replace the variables relative to your project in the "env" section below.
#
# 2. Signing
# Generate a signing certificate in the Windows Application
# Packaging Project or add an existing signing certificate to the project.
# Next, use PowerShell to encode the .pfx file using Base64 encoding
# by running the following Powershell script to generate the output string:
#
# $pfx_cert = Get-Content '.\SigningCertificate.pfx' -Encoding Byte
# [System.Convert]::ToBase64String($pfx_cert) | Out-File 'SigningCertificate_Encoded.txt'
#
# Open the output file, SigningCertificate_Encoded.txt, and copy the
# string inside. Then, add the string to the repo as a GitHub secret
# and name it "Base64_Encoded_Pfx."
# For more information on how to configure your signing certificate for
# this workflow, refer to https://github.com/microsoft/github-actions-for-desktop-apps#signing
#
# Finally, add the signing certificate password to the repo as a secret and name it "Pfx_Key".
# See "Build the Windows Application Packaging project" below to see how the secret is used.
#
# For more information on GitHub Actions, refer to https://github.com/features/actions
# For a complete CI/CD sample to get started with GitHub Action workflows for Desktop Applications,
# refer to https://github.com/microsoft/github-actions-for-desktop-apps
name: .NET Desktop
on:
push:
branches: [master]
tags: ["*.*.*"]
pull_request:
branches: [master]
jobs:
build:
strategy:
matrix:
self: [true, false]
# For a list of available runner types, refer to
# https://help.github.com/en/actions/reference/workflow-syntax-for-github-actions#jobsjob_idruns-on
runs-on: windows-latest
outputs:
version: ${{ steps.gitversion.outputs.assemblySemFileVer }}
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
submodules: recursive
- uses: actions/cache@v4
with:
path: ~/.nuget/packages
key: ${{ runner.os }}-nuget-${{ hashFiles('**/*.csproj') }} #hash of project files
restore-keys: |
${{ runner.os }}-nuget-
- uses: actions/setup-dotnet@v4
with:
dotnet-version: 8.0.x
- uses: gittools/actions/gitversion/[email protected]
with:
versionSpec: "5.x"
- id: gitversion
uses: gittools/actions/gitversion/[email protected]
- run: |
dotnet publish VdLabel -c Release -o publish --sc ${{ matrix.self }} `
-p:Version=${{ steps.gitversion.outputs.fullSemVer }} `
-p:AssemblyVersion=${{ steps.gitversion.outputs.assemblySemVer }} `
-p:FileVersion=${{ steps.gitversion.outputs.assemblySemFileVer }} `
-p:InformationalVersion=${{ steps.gitversion.outputs.informationalVersion }}
- uses: actions/upload-artifact@v4
with:
name: VdLabel${{ matrix.self && '-full' || '' }}-${{ steps.gitversion.outputs.fullSemVer }}
path: publish\
license:
if: ${{ startsWith(github.ref, 'refs/tags/') }}
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/cache@v4
with:
path: licenses
key: ${{ runner.os }}-licenses-${{ hashFiles('**/*.csproj') }} #hash of project files
restore-keys: |
${{ runner.os }}-licenses-
- run: |
dotnet tool restore
dotnet project-licenses -t -u -m -e \
--packages-filter /Analyzers$/ \
--include-project-file \
--manual-package-information manual-package-information.json \
-i VdLabel \
-f licenses
- uses: actions/upload-artifact@v4
with:
name: licenses
path: licenses/
installer:
if: ${{ startsWith(github.ref, 'refs/tags/') }}
needs:
- build
- license
runs-on: windows-latest
steps:
- uses: actions/checkout@v4
- uses: actions/cache@v4
with:
path: ~/.nuget/packages
key: ${{ runner.os }}-nuget-${{ hashFiles('**/*.csproj') }} #hash of project files
restore-keys: |
${{ runner.os }}-nuget-
- uses: actions/setup-dotnet@v4
with:
dotnet-version: 8.0.x
- uses: actions/download-artifact@v4
with:
path: artifacts
pattern: VdLabel-full-*
merge-multiple: true
- uses: actions/download-artifact@v4
with:
path: artifacts/licenses
name: licenses
- run: |
dotnet tool restore
dotnet wix extension -g add WixToolset.Util.wixext WixToolset.UI.wixext
dotnet run -c Release
working-directory: VdLabel.Wix
- uses: actions/upload-artifact@v4
with:
name: VdLabel-${{ needs.build.outputs.version }}.msi
path: publish\
release:
if: ${{ success() && startsWith(github.ref, 'refs/tags/') }}
needs:
- installer
- build
- license
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- uses: actions/download-artifact@v4
- run: |
for dir in VdLabel-*/; do
base=$(basename "$dir")
if ! find "$dir" -maxdepth 1 -type f -name "*.msi" | read; then
# .msiファイルが存在しない場合、既存の処理を実行
mkdir -p "${dir}licenses/"
cp -r licenses/* "${dir}licenses/"
(cd "$dir" && zip -r "../${base}.zip" .)
fi
# .msiファイルが存在する場合は何もしない
done
- uses: softprops/action-gh-release@v2
with:
generate_release_notes: true
draft: true
prerelease: false
files: |
VdLabel-*.zip
VdLabel-*.msi/VdLabel-*.msi