From 34227fadd876e9ba82a1cf359ff221b0c7bd3990 Mon Sep 17 00:00:00 2001 From: Damian Hickey <57436+damianh@users.noreply.github.com> Date: Tue, 19 Nov 2024 14:12:41 +0100 Subject: [PATCH] Seperate build job from pack job and add matrix support to run tests on windows (net481 for netstandard targeted libraries) --- .github/workflow-gen/Program.cs | 78 ++++++++++++------- .../workflows/access-token-management-ci.yml | 36 ++++++++- .../access-token-management-release.yml | 2 +- .github/workflows/identity-model-ci.yml | 37 ++++++++- .../identity-model-oidc-client-ci.yml | 37 ++++++++- .../identity-model-oidc-client-release.yml | 2 +- .github/workflows/identity-model-release.yml | 2 +- .github/workflows/ignore-this-ci.yml | 37 ++++++++- .github/workflows/ignore-this-release.yml | 2 +- ...nManagement.Tests.net8.0.v3.ncrunchproject | 8 ++ ...nManagement.Tests.net9.0.v3.ncrunchproject | 8 ++ ....OidcClient.Tests.net6.0.v3.ncrunchproject | 1 + ....OidcClient.Tests.net8.0.v3.ncrunchproject | 1 + .../PublicApiVerificationTests.cs | 6 +- ignore-this/src/IgnoreThis/IgnoreThis.csproj | 2 +- 15 files changed, 213 insertions(+), 46 deletions(-) create mode 100644 access-token-management/test/AccessTokenManagement.Tests/AccessTokenManagement.Tests.net8.0.v3.ncrunchproject create mode 100644 access-token-management/test/AccessTokenManagement.Tests/AccessTokenManagement.Tests.net9.0.v3.ncrunchproject diff --git a/.github/workflow-gen/Program.cs b/.github/workflow-gen/Program.cs index 44748172..3cd42e87 100644 --- a/.github/workflow-gen/Program.cs +++ b/.github/workflow-gen/Program.cs @@ -9,22 +9,26 @@ new("ignore-this", ["IgnoreThis"], ["IgnoreThis.Tests"], - "it"), + "it", + ["ubuntu-latest", "windows-latest"]), new("access-token-management", ["AccessTokenManagement", "AccessTokenManagement.OpenIdConnect"], ["AccessTokenManagement.Tests"], - "atm"), + "atm", + ["ubuntu-latest"]), new("identity-model", ["IdentityModel"], ["IdentityModel.Tests"], - "im"), + "im", + ["ubuntu-latest", "windows-latest"]), new("identity-model-oidc-client", ["IdentityModel.OidcClient", "IdentityModel.OidcClient.Extensions"], ["IdentityModel.OidcClient.Tests"], - "imoc") + "imoc", + ["ubuntu-latest", "windows-latest"]) ]; foreach (var component in components) @@ -54,49 +58,71 @@ void GenerateCiWorkflow(Component component) workflow.EnvDefaults(); - var job = workflow + var buildJob = workflow .Job("build") .Name("Build") - .RunsOn(GitHubHostedRunners.UbuntuLatest) - .Defaults().Run("bash", component.Name) - .Job; + .Strategy() + .Matrix(("os", component.RunsOn)) + .FailFast(false) + .Job + .RunsOn("${{ matrix.os }}") + .Defaults() + .Run("bash", component.Name) + .Job; - job.Permissions( - actions: Permission.Read, - contents: Permission.Read, - checks: Permission.Write, - packages: Permission.Write); + buildJob.Permissions(checks: Permission.Write, contents: Permission.Read); - job.TimeoutMinutes(15); + buildJob.TimeoutMinutes(15); - job.Step() + buildJob.Step() .ActionsCheckout(); - job.StepSetupDotNet(); + buildJob.StepSetupDotNet(); foreach (var testProject in component.Tests) { - job.StepTestAndReport(component.Name, testProject); + buildJob.StepTestAndReport(component.Name, testProject); } - job.StepInstallCACerts(); + var packJob = workflow.Job("pack") + .Name("Pack") + .RunsOn(GitHubHostedRunners.UbuntuLatest) + .Needs("build") + .Defaults() + .Run("bash", component.Name) + .Job; - job.StepToolRestore(); + packJob.Permissions( + actions: Permission.Read, + contents: Permission.Read, + checks: Permission.Write, + packages: Permission.Write); + + packJob.TimeoutMinutes(15); + + packJob.Step() + .ActionsCheckout(); + + packJob.StepSetupDotNet(); + + packJob.StepInstallCACerts(); + + packJob.StepToolRestore(); foreach (var project in component.Projects) { - job.StepPack(project); + packJob.StepPack(project); } - job.StepSign(); + packJob.StepSign(); - job.StepPush("MyGet", "https://www.myget.org/F/duende_identityserver/api/v2/package", "MYGET"); + packJob.StepPush("MyGet", "https://www.myget.org/F/duende_identityserver/api/v2/package", "MYGET"); - job.StepPush("GitHub", "https://nuget.pkg.github.com/DuendeSoftware/index.json", "GITHUB_TOKEN") + packJob.StepPush("GitHub", "https://nuget.pkg.github.com/DuendeSoftware/index.json", "GITHUB_TOKEN") .Env(("GITHUB_TOKEN", contexts.Secrets.GitHubToken), ("NUGET_AUTH_TOKEN", contexts.Secrets.GitHubToken)); - job.StepUploadArtifacts(component.Name); + packJob.StepUploadArtifacts(component.Name); var fileName = $"{component.Name}-ci"; WriteWorkflow(workflow, fileName); @@ -120,7 +146,7 @@ void GenerateReleaseWorkflow(Component component) .Defaults().Run("bash", component.Name).Job; tagJob.Step() - .ActionsCheckout(); + .ActionsCheckout("11bd71901bbe5b1630ceea73d27597364c9af683"); tagJob.StepSetupDotNet(); @@ -180,7 +206,7 @@ void WriteWorkflow(Workflow workflow, string fileName) Console.WriteLine($"Wrote workflow to {filePath}"); } -record Component(string Name, string[] Projects, string[] Tests, string TagPrefix); +record Component(string Name, string[] Projects, string[] Tests, string TagPrefix, string[] RunsOn); public static class StepExtensions { diff --git a/.github/workflows/access-token-management-ci.yml b/.github/workflows/access-token-management-ci.yml index e60539b0..840686a0 100644 --- a/.github/workflows/access-token-management-ci.yml +++ b/.github/workflows/access-token-management-ci.yml @@ -19,16 +19,19 @@ env: jobs: build: name: Build - runs-on: ubuntu-latest + runs-on: ${{ matrix.os }} permissions: - actions: read checks: write contents: read - packages: write defaults: run: shell: bash working-directory: access-token-management + strategy: + matrix: + os: + - ubuntu-latest + fail-fast: false timeout-minutes: 15 steps: - name: Checkout @@ -53,6 +56,33 @@ jobs: reporter: dotnet-trx fail-on-error: true fail-on-empty: true + pack: + name: Pack + needs: + - build + runs-on: ubuntu-latest + permissions: + actions: read + checks: write + contents: read + packages: write + defaults: + run: + shell: bash + working-directory: access-token-management + timeout-minutes: 15 + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Setup Dotnet + uses: actions/setup-dotnet@3e891b0cb619bf60e2c25674b222b8940e2c1c25 + with: + dotnet-version: |- + 6.0.x + 8.0.x + 9.0.x - name: Install Sectigo CodeSiging CA certificates run: |- sudo apt-get update diff --git a/.github/workflows/access-token-management-release.yml b/.github/workflows/access-token-management-release.yml index 84e74bac..a5abcfb1 100644 --- a/.github/workflows/access-token-management-release.yml +++ b/.github/workflows/access-token-management-release.yml @@ -25,7 +25,7 @@ jobs: working-directory: access-token-management steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 with: fetch-depth: 0 - name: Setup Dotnet diff --git a/.github/workflows/identity-model-ci.yml b/.github/workflows/identity-model-ci.yml index 0786abe1..ee453a96 100644 --- a/.github/workflows/identity-model-ci.yml +++ b/.github/workflows/identity-model-ci.yml @@ -19,16 +19,20 @@ env: jobs: build: name: Build - runs-on: ubuntu-latest + runs-on: ${{ matrix.os }} permissions: - actions: read checks: write contents: read - packages: write defaults: run: shell: bash working-directory: identity-model + strategy: + matrix: + os: + - ubuntu-latest + - windows-latest + fail-fast: false timeout-minutes: 15 steps: - name: Checkout @@ -53,6 +57,33 @@ jobs: reporter: dotnet-trx fail-on-error: true fail-on-empty: true + pack: + name: Pack + needs: + - build + runs-on: ubuntu-latest + permissions: + actions: read + checks: write + contents: read + packages: write + defaults: + run: + shell: bash + working-directory: identity-model + timeout-minutes: 15 + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Setup Dotnet + uses: actions/setup-dotnet@3e891b0cb619bf60e2c25674b222b8940e2c1c25 + with: + dotnet-version: |- + 6.0.x + 8.0.x + 9.0.x - name: Install Sectigo CodeSiging CA certificates run: |- sudo apt-get update diff --git a/.github/workflows/identity-model-oidc-client-ci.yml b/.github/workflows/identity-model-oidc-client-ci.yml index 90adf5b2..506f384d 100644 --- a/.github/workflows/identity-model-oidc-client-ci.yml +++ b/.github/workflows/identity-model-oidc-client-ci.yml @@ -19,16 +19,20 @@ env: jobs: build: name: Build - runs-on: ubuntu-latest + runs-on: ${{ matrix.os }} permissions: - actions: read checks: write contents: read - packages: write defaults: run: shell: bash working-directory: identity-model-oidc-client + strategy: + matrix: + os: + - ubuntu-latest + - windows-latest + fail-fast: false timeout-minutes: 15 steps: - name: Checkout @@ -53,6 +57,33 @@ jobs: reporter: dotnet-trx fail-on-error: true fail-on-empty: true + pack: + name: Pack + needs: + - build + runs-on: ubuntu-latest + permissions: + actions: read + checks: write + contents: read + packages: write + defaults: + run: + shell: bash + working-directory: identity-model-oidc-client + timeout-minutes: 15 + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Setup Dotnet + uses: actions/setup-dotnet@3e891b0cb619bf60e2c25674b222b8940e2c1c25 + with: + dotnet-version: |- + 6.0.x + 8.0.x + 9.0.x - name: Install Sectigo CodeSiging CA certificates run: |- sudo apt-get update diff --git a/.github/workflows/identity-model-oidc-client-release.yml b/.github/workflows/identity-model-oidc-client-release.yml index fa71feca..c9ea576e 100644 --- a/.github/workflows/identity-model-oidc-client-release.yml +++ b/.github/workflows/identity-model-oidc-client-release.yml @@ -25,7 +25,7 @@ jobs: working-directory: identity-model-oidc-client steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 with: fetch-depth: 0 - name: Setup Dotnet diff --git a/.github/workflows/identity-model-release.yml b/.github/workflows/identity-model-release.yml index cf91d1eb..dd9715d1 100644 --- a/.github/workflows/identity-model-release.yml +++ b/.github/workflows/identity-model-release.yml @@ -25,7 +25,7 @@ jobs: working-directory: identity-model steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 with: fetch-depth: 0 - name: Setup Dotnet diff --git a/.github/workflows/ignore-this-ci.yml b/.github/workflows/ignore-this-ci.yml index f1598fee..dad5616f 100644 --- a/.github/workflows/ignore-this-ci.yml +++ b/.github/workflows/ignore-this-ci.yml @@ -19,16 +19,20 @@ env: jobs: build: name: Build - runs-on: ubuntu-latest + runs-on: ${{ matrix.os }} permissions: - actions: read checks: write contents: read - packages: write defaults: run: shell: bash working-directory: ignore-this + strategy: + matrix: + os: + - ubuntu-latest + - windows-latest + fail-fast: false timeout-minutes: 15 steps: - name: Checkout @@ -53,6 +57,33 @@ jobs: reporter: dotnet-trx fail-on-error: true fail-on-empty: true + pack: + name: Pack + needs: + - build + runs-on: ubuntu-latest + permissions: + actions: read + checks: write + contents: read + packages: write + defaults: + run: + shell: bash + working-directory: ignore-this + timeout-minutes: 15 + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Setup Dotnet + uses: actions/setup-dotnet@3e891b0cb619bf60e2c25674b222b8940e2c1c25 + with: + dotnet-version: |- + 6.0.x + 8.0.x + 9.0.x - name: Install Sectigo CodeSiging CA certificates run: |- sudo apt-get update diff --git a/.github/workflows/ignore-this-release.yml b/.github/workflows/ignore-this-release.yml index 755e9052..78f379fe 100644 --- a/.github/workflows/ignore-this-release.yml +++ b/.github/workflows/ignore-this-release.yml @@ -25,7 +25,7 @@ jobs: working-directory: ignore-this steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 with: fetch-depth: 0 - name: Setup Dotnet diff --git a/access-token-management/test/AccessTokenManagement.Tests/AccessTokenManagement.Tests.net8.0.v3.ncrunchproject b/access-token-management/test/AccessTokenManagement.Tests/AccessTokenManagement.Tests.net8.0.v3.ncrunchproject new file mode 100644 index 00000000..46105ee2 --- /dev/null +++ b/access-token-management/test/AccessTokenManagement.Tests/AccessTokenManagement.Tests.net8.0.v3.ncrunchproject @@ -0,0 +1,8 @@ + + + + AspNetTestHostCompatibility + LostReference + + + \ No newline at end of file diff --git a/access-token-management/test/AccessTokenManagement.Tests/AccessTokenManagement.Tests.net9.0.v3.ncrunchproject b/access-token-management/test/AccessTokenManagement.Tests/AccessTokenManagement.Tests.net9.0.v3.ncrunchproject new file mode 100644 index 00000000..46105ee2 --- /dev/null +++ b/access-token-management/test/AccessTokenManagement.Tests/AccessTokenManagement.Tests.net9.0.v3.ncrunchproject @@ -0,0 +1,8 @@ + + + + AspNetTestHostCompatibility + LostReference + + + \ No newline at end of file diff --git a/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.net6.0.v3.ncrunchproject b/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.net6.0.v3.ncrunchproject index cd54b69b..5ff63f7c 100644 --- a/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.net6.0.v3.ncrunchproject +++ b/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.net6.0.v3.ncrunchproject @@ -2,6 +2,7 @@ LostReference + AspNetTestHostCompatibility \ No newline at end of file diff --git a/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.net8.0.v3.ncrunchproject b/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.net8.0.v3.ncrunchproject index cd54b69b..5ff63f7c 100644 --- a/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.net8.0.v3.ncrunchproject +++ b/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.net8.0.v3.ncrunchproject @@ -2,6 +2,7 @@ LostReference + AspNetTestHostCompatibility \ No newline at end of file diff --git a/identity-model/test/IdentityModel.Tests/Verifications/PublicApiVerificationTests.cs b/identity-model/test/IdentityModel.Tests/Verifications/PublicApiVerificationTests.cs index 2d6cc8ae..a023b63a 100644 --- a/identity-model/test/IdentityModel.Tests/Verifications/PublicApiVerificationTests.cs +++ b/identity-model/test/IdentityModel.Tests/Verifications/PublicApiVerificationTests.cs @@ -1,13 +1,13 @@ // Copyright (c) Duende Software. All rights reserved. // Licensed under the Apache License, Version 2.0. See LICENSE in the project root for license information. +#if NET8_0_OR_GREATER using PublicApiGenerator; namespace Duende.IdentityModel.Verifications; public class PublicApiVerificationTests { -#if NET8_0 [Fact] public async Task VerifyPublicApi() { @@ -19,5 +19,5 @@ public async Task VerifyPublicApi() var settings = new VerifySettings(); await Verify(publicApi, settings); } -#endif -} \ No newline at end of file +} +#endif \ No newline at end of file diff --git a/ignore-this/src/IgnoreThis/IgnoreThis.csproj b/ignore-this/src/IgnoreThis/IgnoreThis.csproj index c3769c9e..5a109d88 100644 --- a/ignore-this/src/IgnoreThis/IgnoreThis.csproj +++ b/ignore-this/src/IgnoreThis/IgnoreThis.csproj @@ -1,6 +1,6 @@ - net8.0 + netstandard2.0;net8.0 enable true Duende.IgnoreThis