|
1 | | -# This workflow uses actions that are not certified by GitHub. |
2 | | -# They are provided by a third-party and are governed by |
3 | | -# separate terms of service, privacy policy, and support |
4 | | -# documentation. |
| 1 | +# This workflow will build a .NET project |
| 2 | +# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-net |
5 | 3 |
|
6 | | -# This workflow will build, test, sign and package a WPF or Windows Forms desktop application |
7 | | -# built on .NET Core. |
8 | | -# To learn how to migrate your existing application to .NET Core, |
9 | | -# refer to https://docs.microsoft.com/en-us/dotnet/desktop-wpf/migration/convert-project-from-net-framework |
10 | | -# |
11 | | -# To configure this workflow: |
12 | | -# |
13 | | -# 1. Configure environment variables |
14 | | -# GitHub sets default environment variables for every workflow run. |
15 | | -# Replace the variables relative to your project in the "env" section below. |
16 | | -# |
17 | | -# 2. Signing |
18 | | -# Generate a signing certificate in the Windows Application |
19 | | -# Packaging Project or add an existing signing certificate to the project. |
20 | | -# Next, use PowerShell to encode the .pfx file using Base64 encoding |
21 | | -# by running the following Powershell script to generate the output string: |
22 | | -# |
23 | | -# $pfx_cert = Get-Content '.\SigningCertificate.pfx' -Encoding Byte |
24 | | -# [System.Convert]::ToBase64String($pfx_cert) | Out-File 'SigningCertificate_Encoded.txt' |
25 | | -# |
26 | | -# Open the output file, SigningCertificate_Encoded.txt, and copy the |
27 | | -# string inside. Then, add the string to the repo as a GitHub secret |
28 | | -# and name it "Base64_Encoded_Pfx." |
29 | | -# For more information on how to configure your signing certificate for |
30 | | -# this workflow, refer to https://github.com/microsoft/github-actions-for-desktop-apps#signing |
31 | | -# |
32 | | -# Finally, add the signing certificate password to the repo as a secret and name it "Pfx_Key". |
33 | | -# See "Build the Windows Application Packaging project" below to see how the secret is used. |
34 | | -# |
35 | | -# For more information on GitHub Actions, refer to https://github.com/features/actions |
36 | | -# For a complete CI/CD sample to get started with GitHub Action workflows for Desktop Applications, |
37 | | -# refer to https://github.com/microsoft/github-actions-for-desktop-apps |
38 | | - |
39 | | -name: .NET Core Desktop |
| 4 | +name: .NET |
40 | 5 |
|
41 | 6 | on: |
42 | 7 | push: |
43 | | - branches: [ "master" ] |
44 | | - pull_request: |
45 | | - branches: [ "master" ] |
| 8 | + branches: ["master"] |
46 | 9 |
|
47 | 10 | jobs: |
| 11 | + release: |
| 12 | + name: Create GitHub Release |
| 13 | + runs-on: ubuntu-latest |
| 14 | + outputs: |
| 15 | + tag: ${{ steps.tag.outputs.tag }} |
| 16 | + steps: |
| 17 | + - uses: actions/checkout@v4 |
| 18 | + with: |
| 19 | + fetch-depth: 0 |
| 20 | + if: github.event_name != 'push' |
| 21 | + |
| 22 | + - name: Set tag name |
| 23 | + id: tag |
| 24 | + run: | |
| 25 | + tag=v$(date +%Y%m%d.%H%M%S) |
| 26 | + echo "tag=${{ github.ref_name }}.$tag" >> $GITHUB_OUTPUT |
| 27 | + - name: Create Release |
| 28 | + env: |
| 29 | + GH_TOKEN: ${{ github.token }} |
| 30 | + GH_REPO: ${{ github.repository }} |
| 31 | + run: | |
| 32 | + tag="${{ steps.tag.outputs.tag }}" |
| 33 | + body="laolarou/ProcessorLatencyTool@${{ needs.prepare.outputs.commit }}" |
| 34 | + gh release create --draft "$tag" --title "$tag" --notes "$body" |
48 | 35 |
|
49 | 36 | build: |
50 | | - |
| 37 | + needs: [release] |
51 | 38 | strategy: |
52 | 39 | matrix: |
53 | | - configuration: [Debug, Release] |
54 | | - |
55 | | - runs-on: windows-latest # For a list of available runner types, refer to |
56 | | - # https://help.github.com/en/actions/reference/workflow-syntax-for-github-actions#jobsjob_idruns-on |
| 40 | + os: [windows-latest, macos-latest, ubuntu-latest] |
57 | 41 |
|
58 | | - env: |
59 | | - Solution_Name: your-solution-name # Replace with your solution name, i.e. MyWpfApp.sln. |
60 | | - Test_Project_Path: your-test-project-path # Replace with the path to your test project, i.e. MyWpfApp.Tests\MyWpfApp.Tests.csproj. |
61 | | - Wap_Project_Directory: your-wap-project-directory-name # Replace with the Wap project directory relative to the solution, i.e. MyWpfApp.Package. |
62 | | - Wap_Project_Path: your-wap-project-path # Replace with the path to your Wap project, i.e. MyWpf.App.Package\MyWpfApp.Package.wapproj. |
| 42 | + runs-on: ${{ matrix.os }} |
63 | 43 |
|
64 | 44 | steps: |
65 | | - - name: Checkout |
66 | | - uses: actions/checkout@v4 |
67 | | - with: |
68 | | - fetch-depth: 0 |
69 | | - |
70 | | - # Install the .NET Core workload |
71 | | - - name: Install .NET Core |
72 | | - uses: actions/setup-dotnet@v4 |
73 | | - with: |
74 | | - dotnet-version: 8.0.x |
75 | | - |
76 | | - # Add MSBuild to the PATH: https://github.com/microsoft/setup-msbuild |
77 | | - - name: Setup MSBuild.exe |
78 | | - uses: microsoft/setup-msbuild@v2 |
79 | | - |
80 | | - # Execute all unit tests in the solution |
81 | | - - name: Execute unit tests |
82 | | - run: dotnet test |
83 | | - |
84 | | - # Restore the application to populate the obj folder with RuntimeIdentifiers |
85 | | - - name: Restore the application |
86 | | - run: msbuild $env:Solution_Name /t:Restore /p:Configuration=$env:Configuration |
87 | | - env: |
88 | | - Configuration: ${{ matrix.configuration }} |
89 | | - |
90 | | - # Decode the base 64 encoded pfx and save the Signing_Certificate |
91 | | - - name: Decode the pfx |
92 | | - run: | |
93 | | - $pfx_cert_byte = [System.Convert]::FromBase64String("${{ secrets.Base64_Encoded_Pfx }}") |
94 | | - $certificatePath = Join-Path -Path $env:Wap_Project_Directory -ChildPath GitHubActionsWorkflow.pfx |
95 | | - [IO.File]::WriteAllBytes("$certificatePath", $pfx_cert_byte) |
96 | | -
|
97 | | - # Create the app package by building and packaging the Windows Application Packaging project |
98 | | - - name: Create the app package |
99 | | - run: msbuild $env:Wap_Project_Path /p:Configuration=$env:Configuration /p:UapAppxPackageBuildMode=$env:Appx_Package_Build_Mode /p:AppxBundle=$env:Appx_Bundle /p:PackageCertificateKeyFile=GitHubActionsWorkflow.pfx /p:PackageCertificatePassword=${{ secrets.Pfx_Key }} |
100 | | - env: |
101 | | - Appx_Bundle: Always |
102 | | - Appx_Bundle_Platforms: x86|x64 |
103 | | - Appx_Package_Build_Mode: StoreUpload |
104 | | - Configuration: ${{ matrix.configuration }} |
105 | | - |
106 | | - # Remove the pfx |
107 | | - - name: Remove the pfx |
108 | | - run: Remove-Item -path $env:Wap_Project_Directory\GitHubActionsWorkflow.pfx |
109 | | - |
110 | | - # Upload the MSIX package: https://github.com/marketplace/actions/upload-a-build-artifact |
111 | | - - name: Upload build artifacts |
112 | | - uses: actions/upload-artifact@v4 |
113 | | - with: |
114 | | - name: MSIX Package |
115 | | - path: ${{ env.Wap_Project_Directory }}\AppPackages |
| 45 | + - uses: actions/checkout@v4 |
| 46 | + - name: Setup .NET |
| 47 | + uses: actions/setup-dotnet@v4 |
| 48 | + with: |
| 49 | + dotnet-version: 9.0.x |
| 50 | + |
| 51 | + - name: Restore dependencies |
| 52 | + run: dotnet restore |
| 53 | + |
| 54 | + - name: Build |
| 55 | + run: dotnet publish -c Release --no-restore |
| 56 | + working-directory: ./ProcessorLatencyTool |
| 57 | + |
| 58 | + - name: Compress Build Files (Windows) |
| 59 | + if: matrix.os == 'windows-latest' |
| 60 | + run: Compress-Archive -Path publish -DestinationPath ${{ env.OS }}.zip |
| 61 | + working-directory: ./ProcessorLatencyTool/bin/Release/net9.0 |
| 62 | + env: |
| 63 | + OS: ${{ matrix.os }} |
| 64 | + |
| 65 | + - name: Compress Build Files (Unix) |
| 66 | + if: (matrix.os == 'macos-latest') || (matrix.os == 'ubuntu-latest') |
| 67 | + run: zip -9 -r ${{ env.OS }}.zip publish |
| 68 | + working-directory: ./ProcessorLatencyTool/bin/Release/net9.0 |
| 69 | + env: |
| 70 | + OS: ${{ matrix.os }} |
| 71 | + |
| 72 | + - name: Upload Built Binaries |
| 73 | + env: |
| 74 | + OS: ${{ matrix.os }} |
| 75 | + GH_TOKEN: ${{ secrets.PUBLISHTOKEN }} |
| 76 | + GH_REPO: ${{ github.repository }} |
| 77 | + run: gh release upload "${{ needs.release.outputs.tag }}" "${{ env.OS }}.zip" |
| 78 | + working-directory: ./ProcessorLatencyTool/bin/Release/net9.0 |
| 79 | + |
| 80 | + publish: |
| 81 | + name: Publish Release |
| 82 | + needs: [release, build] |
| 83 | + runs-on: ubuntu-latest |
| 84 | + steps: |
| 85 | + - name: Publish Release |
| 86 | + env: |
| 87 | + GH_TOKEN: ${{ secrets.PUBLISHTOKEN }} |
| 88 | + GH_REPO: ${{ github.repository }} |
| 89 | + run: gh release edit "${{ needs.release.outputs.tag }}" --draft=false |
| 90 | + - uses: eregon/keep-last-n-releases@v1 |
| 91 | + env: |
| 92 | + GITHUB_TOKEN: ${{ secrets.PUBLISHTOKEN }} |
| 93 | + with: |
| 94 | + n: 3 |
| 95 | + remove_tags_without_release: true |
0 commit comments