From 8e94604846537f11322433f7a0f1bcc8f0ca254f Mon Sep 17 00:00:00 2001 From: Konrad Jamrozik Date: Thu, 9 Feb 2023 17:14:32 -0800 Subject: [PATCH] Install `.NET 7.0.x` from `global.json` and `.NET 6.0.0` runtime. Remove `DotNetCoreVersion` param. (#5395) --- .../stages/archetype-sdk-tool-dotnet.yml | 11 +---- .../templates/steps/install-dotnet.yml | 40 +++++++++---------- 2 files changed, 19 insertions(+), 32 deletions(-) diff --git a/eng/pipelines/templates/stages/archetype-sdk-tool-dotnet.yml b/eng/pipelines/templates/stages/archetype-sdk-tool-dotnet.yml index 2b0ec52dc91..d73a3edc4a9 100644 --- a/eng/pipelines/templates/stages/archetype-sdk-tool-dotnet.yml +++ b/eng/pipelines/templates/stages/archetype-sdk-tool-dotnet.yml @@ -15,9 +15,6 @@ parameters: - name: TestDirectory type: string default: '' - - name: DotNetCoreVersion - type: string - default: '' - name: NoWarn type: boolean default: false @@ -65,8 +62,6 @@ stages: steps: - template: /eng/pipelines/templates/steps/install-dotnet.yml - parameters: - DotNetCoreVersion: ${{ parameters.DotNetCoreVersion }} - script: 'dotnet pack /p:ArtifactsPackagesDir=$(packagesToPublishDir) $(Warn) -c Release' displayName: 'Build and Package' @@ -115,8 +110,6 @@ stages: steps: - template: /eng/pipelines/templates/steps/install-dotnet.yml - parameters: - DotNetCoreVersion: ${{ parameters.DotNetCoreVersion }} - template: /eng/pipelines/templates/steps/produce-net-standalone-packs.yml parameters: @@ -144,8 +137,6 @@ stages: steps: - template: /eng/pipelines/templates/steps/install-dotnet.yml - parameters: - DotNetCoreVersion: ${{ parameters.DotNetCoreVersion }} - script: 'dotnet test /p:ArtifactsPackagesDir=$(Build.ArtifactStagingDirectory) $(Warn) --logger trx' displayName: 'Test' @@ -161,7 +152,7 @@ stages: condition: succeededOrFailed() inputs: testResultsFiles: '**/*.trx' - testRunTitle: $(System.JobDisplayName) ${{ parameters.DotNetCoreVersion }} + testRunTitle: $(System.JobDisplayName) testResultsFormat: 'VSTest' mergeTestResults: true diff --git a/eng/pipelines/templates/steps/install-dotnet.yml b/eng/pipelines/templates/steps/install-dotnet.yml index 8c9af6a3c8e..c2d0a9774e0 100644 --- a/eng/pipelines/templates/steps/install-dotnet.yml +++ b/eng/pipelines/templates/steps/install-dotnet.yml @@ -1,29 +1,25 @@ -parameters: - # Use this parameter if you want to override the .NET SDK set by global.json - - name: DotNetCoreVersion - type: string - default: '' - steps: - # We set DOTNET_ROLL_FORWARD so that .NET assemblies targeting older versions of .NET can run on newer ones. - # See also: - # https://learn.microsoft.com/en-us/dotnet/core/tools/dotnet#options-for-running-an-application - # https://learn.microsoft.com/en-us/dotnet/core/runtime-discovery/troubleshoot-app-launch?pivots=os-windows#required-framework-not-found - # https://aka.ms/dotnet/app-launch-failed - # https://learn.microsoft.com/en-us/azure/devops/pipelines/scripts/logging-commands?view=azure-devops&tabs=powershell - # https://learn.microsoft.com/en-us/azure/devops/pipelines/process/set-variables-scripts?view=azure-devops&tabs=powershell - - pwsh: | - echo "##vso[task.setvariable variable=DOTNET_ROLL_FORWARD;]Major" - displayName: "Set DOTNET_ROLL_FORWARD to Major" - # https://learn.microsoft.com/azure/devops/pipelines/tasks/reference/use-dotnet-v2?view=azure-pipelines + + # We aim to keep .NET SDK coming from global.json to bethe newest, to enable us to use the latest & greatest, + # and allow us to gradually migrate our .NET sources to such version. + # About global.json: https://learn.microsoft.com/en-us/dotnet/core/tools/global-json + - task: UseDotNet@2 # About UseDotNet@2 task: https://learn.microsoft.com/azure/devops/pipelines/tasks/reference/use-dotnet-v2?view=azure-pipelines + displayName: "Use .NET SDK from global.json" + retryCountOnTaskFailure: 3 + inputs: + useGlobalJson: true + + # We install .NET 6.0.x runtime in addition to .NET coming from global.json because most of our tools target 6.0.x. + # Once we migrate all tools to a newer .NET version, we should update this to install that version instead. - task: UseDotNet@2 - displayName: "Use .NET SDK ${{ coalesce( parameters.DotNetCoreVersion, 'from global.json') }}" + displayName: "Use .NET runtime 6.0.x" retryCountOnTaskFailure: 3 inputs: - ${{ if eq( parameters.DotNetCoreVersion, '') }}: - useGlobalJson: true - ${{ else }}: - version: ${{ parameters.DotNetCoreVersion }} + packageType: runtime + version: 6.0.x + # performMultiLevelLookup comes into play when given .NET executable target runtime is different + # than the installed .NET SDK. Without this, such runtime would not be found. + performMultiLevelLookup: true # Future work: add NuGet packages caching. See: # https://github.com/Azure/azure-sdk-tools/issues/5086 \ No newline at end of file