From eee6b9848ee0eb80709611d3b21b23966d932730 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 | 114 ++++++++++++------
.../workflows/access-token-management-ci.yml | 57 +++++++--
.../access-token-management-release.yml | 2 +-
.github/workflows/identity-model-ci.yml | 70 +++++++++--
.../identity-model-oidc-client-ci.yml | 57 +++++++--
.../identity-model-oidc-client-release.yml | 2 +-
.github/workflows/identity-model-release.yml | 2 +-
.github/workflows/ignore-this-ci.yml | 70 +++++++++--
.github/workflows/ignore-this-release.yml | 2 +-
...nManagement.Tests.net8.0.v3.ncrunchproject | 8 ++
...nManagement.Tests.net9.0.v3.ncrunchproject | 8 ++
...IdentityModel.OidcClient.Extensions.csproj | 2 +-
.../IdentityModel.OidcClient.csproj | 2 +-
.../IdentityModel.OidcClient.Tests.csproj | 2 +-
....OidcClient.Tests.net6.0.v3.ncrunchproject | 1 +
....OidcClient.Tests.net8.0.v3.ncrunchproject | 1 +
.../PublicApiVerificationTests.cs | 6 +-
ignore-this/src/IgnoreThis/IgnoreThis.csproj | 2 +-
.../IgnoreThis.Tests/IgnoreThis.Tests.csproj | 5 +-
src.props | 3 +-
20 files changed, 336 insertions(+), 80 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..73d4099c 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"])
];
foreach (var component in components)
@@ -54,49 +58,76 @@ 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, "net8.0");
+ buildJob.StepTestAndReport(component.Name, testProject, "net9.0");
+ if (component.RunsOn.Contains("windows-latest"))
+ {
+ buildJob.StepTestAndReport(component.Name, testProject, "net481");
+ }
}
- job.StepInstallCACerts();
+ var packJob = workflow.Job("pack")
+ .Name("Pack")
+ .RunsOn(GitHubHostedRunners.UbuntuLatest)
+ .Needs("build")
+ .Defaults()
+ .Run("bash", component.Name)
+ .Job;
+
+ packJob.Permissions(
+ actions: Permission.Read,
+ contents: Permission.Read,
+ checks: Permission.Write,
+ packages: Permission.Write);
+
+ packJob.TimeoutMinutes(15);
- job.StepToolRestore();
+ 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 +151,7 @@ void GenerateReleaseWorkflow(Component component)
.Defaults().Run("bash", component.Name).Job;
tagJob.Step()
- .ActionsCheckout();
+ .ActionsCheckout("11bd71901bbe5b1630ceea73d27597364c9af683");
tagJob.StepSetupDotNet();
@@ -180,7 +211,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
{
@@ -197,27 +228,40 @@ public static void StepSetupDotNet(this Job job)
public static Step IfRefMain(this Step step)
=> step.If("github.ref == 'refs/heads/main'");
- public static void StepTestAndReport(this Job job, string componentName, string testProject)
+ public static Step IfWindows(this Step step)
+ => step.If("matrix.os == 'windows-latest'");
+
+ public static void StepTestAndReport(this Job job, string componentName, string testProject, string framework)
{
var path = $"test/{testProject}";
- var logFileName = "Tests.trx";
- var flags = $"--logger \"console;verbosity=normal\" " +
+ var logFileName = $"tests-{framework}.trx";
+ var flags = $"--configuration Release " +
+ $"--framework {framework} " +
+ $"--logger \"console;verbosity=normal\" " +
$"--logger \"trx;LogFileName={logFileName}\" " +
$"--collect:\"XPlat Code Coverage\"";
- job.Step()
- .Name($"Test - {testProject}")
- .Run($"dotnet test -c Release {path} {flags}");
+ var isWindows = framework == "net481";
- job.Step()
- .Name($"Test report - {testProject}")
+ var testStep = job.Step()
+ .Name($"Test - {testProject}-{framework}")
+ .Run($"dotnet test {path} {flags}");
+
+ var testReportStep = job.Step()
+ .Name($"Test report {testProject}-{framework}")
.Uses("dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5") // v1.9.1
.If("success() || failure()")
.With(
- ("name", $"Test Report - {testProject}"),
+ ("name", $"Test Report {testProject}-{framework}"),
("path", $"{componentName}/{path}/TestResults/{logFileName}"),
("reporter", "dotnet-trx"),
("fail-on-error", "true"),
("fail-on-empty", "true"));
+
+ if (isWindows)
+ {
+ testStep.IfWindows();
+ testReportStep.IfWindows();
+ }
}
// These intermediate certificates are required for signing and are not installed on the GitHub runners by default.
diff --git a/.github/workflows/access-token-management-ci.yml b/.github/workflows/access-token-management-ci.yml
index e60539b0..66fae85a 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
@@ -42,17 +45,55 @@ jobs:
6.0.x
8.0.x
9.0.x
- - name: Test - AccessTokenManagement.Tests
- run: dotnet test -c Release test/AccessTokenManagement.Tests --logger "console;verbosity=normal" --logger "trx;LogFileName=Tests.trx" --collect:"XPlat Code Coverage"
- - name: Test report - AccessTokenManagement.Tests
+ - name: Test - AccessTokenManagement.Tests-net8.0
+ run: dotnet test test/AccessTokenManagement.Tests --configuration Release --framework net8.0 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net8.0.trx" --collect:"XPlat Code Coverage"
+ - name: Test report AccessTokenManagement.Tests-net8.0
+ if: success() || failure()
+ uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
+ with:
+ name: Test Report AccessTokenManagement.Tests-net8.0
+ path: access-token-management/test/AccessTokenManagement.Tests/TestResults/tests-net8.0.trx
+ reporter: dotnet-trx
+ fail-on-error: true
+ fail-on-empty: true
+ - name: Test - AccessTokenManagement.Tests-net9.0
+ run: dotnet test test/AccessTokenManagement.Tests --configuration Release --framework net9.0 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net9.0.trx" --collect:"XPlat Code Coverage"
+ - name: Test report AccessTokenManagement.Tests-net9.0
if: success() || failure()
uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
with:
- name: Test Report - AccessTokenManagement.Tests
- path: access-token-management/test/AccessTokenManagement.Tests/TestResults/Tests.trx
+ name: Test Report AccessTokenManagement.Tests-net9.0
+ path: access-token-management/test/AccessTokenManagement.Tests/TestResults/tests-net9.0.trx
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..6ac2d357 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
@@ -42,17 +46,67 @@ jobs:
6.0.x
8.0.x
9.0.x
- - name: Test - IdentityModel.Tests
- run: dotnet test -c Release test/IdentityModel.Tests --logger "console;verbosity=normal" --logger "trx;LogFileName=Tests.trx" --collect:"XPlat Code Coverage"
- - name: Test report - IdentityModel.Tests
+ - name: Test - IdentityModel.Tests-net8.0
+ run: dotnet test test/IdentityModel.Tests --configuration Release --framework net8.0 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net8.0.trx" --collect:"XPlat Code Coverage"
+ - name: Test report IdentityModel.Tests-net8.0
+ if: success() || failure()
+ uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
+ with:
+ name: Test Report IdentityModel.Tests-net8.0
+ path: identity-model/test/IdentityModel.Tests/TestResults/tests-net8.0.trx
+ reporter: dotnet-trx
+ fail-on-error: true
+ fail-on-empty: true
+ - name: Test - IdentityModel.Tests-net9.0
+ run: dotnet test test/IdentityModel.Tests --configuration Release --framework net9.0 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net9.0.trx" --collect:"XPlat Code Coverage"
+ - name: Test report IdentityModel.Tests-net9.0
if: success() || failure()
uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
with:
- name: Test Report - IdentityModel.Tests
- path: identity-model/test/IdentityModel.Tests/TestResults/Tests.trx
+ name: Test Report IdentityModel.Tests-net9.0
+ path: identity-model/test/IdentityModel.Tests/TestResults/tests-net9.0.trx
reporter: dotnet-trx
fail-on-error: true
fail-on-empty: true
+ - name: Test - IdentityModel.Tests-net481
+ if: matrix.os == 'windows-latest'
+ run: dotnet test test/IdentityModel.Tests --configuration Release --framework net481 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net481.trx" --collect:"XPlat Code Coverage"
+ - name: Test report IdentityModel.Tests-net481
+ if: matrix.os == 'windows-latest'
+ uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
+ with:
+ name: Test Report IdentityModel.Tests-net481
+ path: identity-model/test/IdentityModel.Tests/TestResults/tests-net481.trx
+ 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..b1920d6c 100644
--- a/.github/workflows/identity-model-oidc-client-ci.yml
+++ b/.github/workflows/identity-model-oidc-client-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: identity-model-oidc-client
+ strategy:
+ matrix:
+ os:
+ - ubuntu-latest
+ fail-fast: false
timeout-minutes: 15
steps:
- name: Checkout
@@ -42,17 +45,55 @@ jobs:
6.0.x
8.0.x
9.0.x
- - name: Test - IdentityModel.OidcClient.Tests
- run: dotnet test -c Release test/IdentityModel.OidcClient.Tests --logger "console;verbosity=normal" --logger "trx;LogFileName=Tests.trx" --collect:"XPlat Code Coverage"
- - name: Test report - IdentityModel.OidcClient.Tests
+ - name: Test - IdentityModel.OidcClient.Tests-net8.0
+ run: dotnet test test/IdentityModel.OidcClient.Tests --configuration Release --framework net8.0 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net8.0.trx" --collect:"XPlat Code Coverage"
+ - name: Test report IdentityModel.OidcClient.Tests-net8.0
+ if: success() || failure()
+ uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
+ with:
+ name: Test Report IdentityModel.OidcClient.Tests-net8.0
+ path: identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/TestResults/tests-net8.0.trx
+ reporter: dotnet-trx
+ fail-on-error: true
+ fail-on-empty: true
+ - name: Test - IdentityModel.OidcClient.Tests-net9.0
+ run: dotnet test test/IdentityModel.OidcClient.Tests --configuration Release --framework net9.0 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net9.0.trx" --collect:"XPlat Code Coverage"
+ - name: Test report IdentityModel.OidcClient.Tests-net9.0
if: success() || failure()
uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
with:
- name: Test Report - IdentityModel.OidcClient.Tests
- path: identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/TestResults/Tests.trx
+ name: Test Report IdentityModel.OidcClient.Tests-net9.0
+ path: identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/TestResults/tests-net9.0.trx
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..2a443224 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
@@ -42,17 +46,67 @@ jobs:
6.0.x
8.0.x
9.0.x
- - name: Test - IgnoreThis.Tests
- run: dotnet test -c Release test/IgnoreThis.Tests --logger "console;verbosity=normal" --logger "trx;LogFileName=Tests.trx" --collect:"XPlat Code Coverage"
- - name: Test report - IgnoreThis.Tests
+ - name: Test - IgnoreThis.Tests-net8.0
+ run: dotnet test test/IgnoreThis.Tests --configuration Release --framework net8.0 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net8.0.trx" --collect:"XPlat Code Coverage"
+ - name: Test report IgnoreThis.Tests-net8.0
+ if: success() || failure()
+ uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
+ with:
+ name: Test Report IgnoreThis.Tests-net8.0
+ path: ignore-this/test/IgnoreThis.Tests/TestResults/tests-net8.0.trx
+ reporter: dotnet-trx
+ fail-on-error: true
+ fail-on-empty: true
+ - name: Test - IgnoreThis.Tests-net9.0
+ run: dotnet test test/IgnoreThis.Tests --configuration Release --framework net9.0 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net9.0.trx" --collect:"XPlat Code Coverage"
+ - name: Test report IgnoreThis.Tests-net9.0
if: success() || failure()
uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
with:
- name: Test Report - IgnoreThis.Tests
- path: ignore-this/test/IgnoreThis.Tests/TestResults/Tests.trx
+ name: Test Report IgnoreThis.Tests-net9.0
+ path: ignore-this/test/IgnoreThis.Tests/TestResults/tests-net9.0.trx
reporter: dotnet-trx
fail-on-error: true
fail-on-empty: true
+ - name: Test - IgnoreThis.Tests-net481
+ if: matrix.os == 'windows-latest'
+ run: dotnet test test/IgnoreThis.Tests --configuration Release --framework net481 --logger "console;verbosity=normal" --logger "trx;LogFileName=tests-net481.trx" --collect:"XPlat Code Coverage"
+ - name: Test report IgnoreThis.Tests-net481
+ if: matrix.os == 'windows-latest'
+ uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5
+ with:
+ name: Test Report IgnoreThis.Tests-net481
+ path: ignore-this/test/IgnoreThis.Tests/TestResults/tests-net481.trx
+ 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/src/IdentityModel.OidcClient.Extensions/IdentityModel.OidcClient.Extensions.csproj b/identity-model-oidc-client/src/IdentityModel.OidcClient.Extensions/IdentityModel.OidcClient.Extensions.csproj
index 77abc243..d998da0c 100644
--- a/identity-model-oidc-client/src/IdentityModel.OidcClient.Extensions/IdentityModel.OidcClient.Extensions.csproj
+++ b/identity-model-oidc-client/src/IdentityModel.OidcClient.Extensions/IdentityModel.OidcClient.Extensions.csproj
@@ -1,6 +1,6 @@
- netstandard2.0;net6.0;net8.0
+ netstandard2.0;net8.0
Duende.IdentityModel.OidcClient
Duende.IdentityModel.OidcClient.Extensions
Duende.IdentityModel.OidcClient.Extensions
diff --git a/identity-model-oidc-client/src/IdentityModel.OidcClient/IdentityModel.OidcClient.csproj b/identity-model-oidc-client/src/IdentityModel.OidcClient/IdentityModel.OidcClient.csproj
index 829d6469..6c465d13 100644
--- a/identity-model-oidc-client/src/IdentityModel.OidcClient/IdentityModel.OidcClient.csproj
+++ b/identity-model-oidc-client/src/IdentityModel.OidcClient/IdentityModel.OidcClient.csproj
@@ -1,6 +1,6 @@
- netstandard2.0;net6.0;net8.0
+ netstandard2.0;net8.0
Duende.IdentityModel.OidcClient
Duende.IdentityModel.OidcClient
Duende.IdentityModel.OidcClient
diff --git a/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.csproj b/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.csproj
index 6f498d1b..44476346 100644
--- a/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.csproj
+++ b/identity-model-oidc-client/test/IdentityModel.OidcClient.Tests/IdentityModel.OidcClient.Tests.csproj
@@ -1,6 +1,6 @@
- net6.0;net8.0
+ net8.0;net9.0
Duende.IdentityModel.OidcClient
../../../key.snk
true
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..0e7c05b9 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;net9.0
enable
true
Duende.IgnoreThis
diff --git a/ignore-this/test/IgnoreThis.Tests/IgnoreThis.Tests.csproj b/ignore-this/test/IgnoreThis.Tests/IgnoreThis.Tests.csproj
index 2d2ae076..36823e58 100644
--- a/ignore-this/test/IgnoreThis.Tests/IgnoreThis.Tests.csproj
+++ b/ignore-this/test/IgnoreThis.Tests/IgnoreThis.Tests.csproj
@@ -1,8 +1,11 @@
- net8.0
+ net8.0;net9.0
Duende.IgnoreThis
+
+ net481;$(TargetFrameworks)
+
diff --git a/src.props b/src.props
index 676c4b97..d8753f7e 100644
--- a/src.props
+++ b/src.props
@@ -33,7 +33,8 @@
../../../key.snk
true
-
+
+ true
true