|
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. |
5 | | - |
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 | 1 | name: .NET Core Desktop |
40 | 2 |
|
41 | 3 | on: |
|
45 | 7 | branches: [ "main" ] |
46 | 8 |
|
47 | 9 | jobs: |
48 | | - |
49 | 10 | build: |
50 | | - |
51 | 11 | strategy: |
52 | 12 | matrix: |
53 | 13 | configuration: [Debug, Release] |
54 | 14 |
|
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 |
| 15 | + runs-on: windows-latest |
57 | 16 |
|
58 | 17 | env: |
59 | | - Solution_Name: RAYTRACER_UNILIGHT # 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. |
| 18 | + Solution_Name: RAYTRACER_UNILIGHT.sln |
| 19 | + Project_Name: RAYTRACER_UNILIGHT.csproj |
63 | 20 |
|
64 | 21 | 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 |
| 22 | + - name: Checkout |
| 23 | + uses: actions/checkout@v4 |
| 24 | + with: |
| 25 | + fetch-depth: 0 |
| 26 | + |
| 27 | + # Install the .NET SDK |
| 28 | + - name: Setup .NET |
| 29 | + uses: actions/setup-dotnet@v4 |
| 30 | + with: |
| 31 | + dotnet-version: 8.0.x |
| 32 | + |
| 33 | + # Add MSBuild to PATH |
| 34 | + - name: Setup MSBuild.exe |
| 35 | + uses: microsoft/setup-msbuild@v2 |
| 36 | + |
| 37 | + # Restore NuGet packages |
| 38 | + - name: Restore |
| 39 | + run: msbuild $env:Solution_Name /t:Restore /p:Configuration=${{ matrix.configuration }} |
| 40 | + |
| 41 | + # Build the project |
| 42 | + - name: Build |
| 43 | + run: msbuild $env:Solution_Name /p:Configuration=${{ matrix.configuration }} |
| 44 | + |
| 45 | + # Run tests (if you add a test project later) |
| 46 | + - name: Run tests |
| 47 | + run: dotnet test $env:Solution_Name --configuration ${{ matrix.configuration }} |
| 48 | + continue-on-error: true |
| 49 | + |
| 50 | + # Publish the project (generates an exe in artifact folder) |
| 51 | + - name: Publish |
| 52 | + run: dotnet publish $env:Project_Name -c ${{ matrix.configuration }} -o publish |
| 53 | + |
| 54 | + # Upload build output as artifact |
| 55 | + - name: Upload build artifacts |
| 56 | + uses: actions/upload-artifact@v4 |
| 57 | + with: |
| 58 | + name: RAYTRACER_UNILIGHT_${{ matrix.configuration }} |
| 59 | + path: publish/** |
0 commit comments