From cf944a37c095b299b194211629d6e367e0403dcf Mon Sep 17 00:00:00 2001 From: Wes Haggard Date: Wed, 4 Dec 2024 11:36:28 -0800 Subject: [PATCH 1/2] Use new generation tool that supports service connections --- .../templates/jobs/prepare-pipelines.yml | 25 +++++++++++++++++++ .../steps/install-pipeline-generation.yml | 2 +- 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/eng/common/pipelines/templates/jobs/prepare-pipelines.yml b/eng/common/pipelines/templates/jobs/prepare-pipelines.yml index d432c215f3d..0f1d5ffd804 100644 --- a/eng/common/pipelines/templates/jobs/prepare-pipelines.yml +++ b/eng/common/pipelines/templates/jobs/prepare-pipelines.yml @@ -22,8 +22,11 @@ jobs: Prefix: 'na' DevOpsPath: 'na' InternalVariableGroups: '' + InternalServiceConnections: '' + GeneratePublicCIPipeline: '' GenerateUnifiedWeekly: '' TestVariableGroups: '' + TestServiceConnections: '' # Standard set of variable groups for the Azure SDK repositories AzureSDK_Maven_Release_Pipeline_Secrets: 1 @@ -70,6 +73,12 @@ jobs: exit 1 } + $generatePublicCIPipeline = 'true' + $generateUnifiedWeekly = 'false' + + $testServiceConnections = '"Azure" "azure-sdk-tests" "azure-sdk-tests-china" "azure-sdk-tests-preview" "azure-sdk-tests-public" "azure-sdk-tests-usgov" "Azure SDK Test Resources - LiveTestSecrets"' + $internalServiceConnections = '"Azure" "Azure SDK Artifacts" "Azure SDK Engineering System" "opensource-api-connection" "AzureSDKEngKeyVault Secrets"' + # Map the language prefix to the appropriate variable groups switch ($prefix) { @@ -81,16 +90,19 @@ jobs: $internalVariableGroups = '$(AzureSDK_Maven_Release_Pipeline_Secrets) $(Release_Secrets_for_GitHub) $(APIReview_AutoCreate_Configurations)' } "js" { + $generatePublicCIPipeline = 'false' $internalVariableGroups = '$(NPM_Registry_Authentication) $(Release_Secrets_for_GitHub) $(APIReview_AutoCreate_Configurations)' $testVariableGroups = '$(Secrets_for_Resource_Provisioner)' } "python" { + $generatePublicCIPipeline = 'false' $internalVariableGroups = '$(Release_Secrets_for_GitHub) $(APIReview_AutoCreate_Configurations)' $testVariableGroups = '$(Secrets_for_Resource_Provisioner)' } "net" { $internalVariableGroups = '$(AzureSDK_Nuget_Release_Pipeline_Secrets) $(Release_Secrets_for_GitHub) $(APIReview_AutoCreate_Configurations)' $testVariableGroups = '$(Secrets_for_Resource_Provisioner)' + $internalServiceConnections += ' "Azure SDK Symbols Publishing" Nuget.org' } "cpp" { $internalVariableGroups = '$(Release_Secrets_for_GitHub) $(APIReview_AutoCreate_Configurations) $(Secrets_for_Resource_Provisioner)' @@ -110,9 +122,16 @@ jobs: Write-Host "InternalVariableGroups = $internalVariableGroups" Write-Host "TestVariableGroups = $testVariableGroups" + Write-Host "TestServiceConnections = $testServiceConnections" + Write-Host "InternalServiceConnections = $internalServiceConnections" + Write-Host "GeneratePublicCIPipeline = $generatePublicCIPipeline" Write-Host "GenerateUnifiedWeekly = $generateUnifiedWeekly" + Write-Host "##vso[task.setvariable variable=InternalVariableGroups]$internalVariableGroups" Write-Host "##vso[task.setvariable variable=TestVariableGroups]$testVariableGroups" + Write-Host "##vso[task.setvariable variable=TestServiceConnections]$testServiceConnections" + Write-Host "##vso[task.setvariable variable=InternalServiceConnections]$internalServviceConnections" + Write-host "##vso[task.setvariable variable=GeneratePublicCIPipeline]$generatePublicCIPipeline" Write-Host "##vso[task.setvariable variable=GenerateUnifiedWeekly]$generateUnifiedWeekly" displayName: Setup pipeline generation variables @@ -135,7 +154,9 @@ jobs: --branch refs/heads/$(DefaultBranch) --set-managed-variables --debug + --serviceconnections "Azure" displayName: 'Generate ci pipelines for: ${{ parameters.Repository }}' + condition: and(succeeded(), eq(variables['GeneratePublicCIPipeline'],'true')) continueOnError: true - task: AzureCLI@2 inputs: @@ -157,6 +178,7 @@ jobs: --set-managed-variables --debug --variablegroups $(InternalVariableGroups) $(TestVariableGroups) + --serviceconnections $(InternalServiceConnections) $(TestServiceConnections) displayName: 'Generate release pipelines for: ${{ parameters.Repository }}' continueOnError: true - task: AzureCLI@2 @@ -179,6 +201,7 @@ jobs: --set-managed-variables --debug --variablegroups $(TestVariableGroups) + --serviceconnections $(TestServiceConnections) displayName: 'Generate test pipelines for: ${{ parameters.Repository }}' condition: and(succeeded(), ne(variables['TestVariableGroups'],'')) continueOnError: true @@ -202,6 +225,7 @@ jobs: --set-managed-variables --debug --variablegroups $(TestVariableGroups) + --serviceconnections $(TestServiceConnections) displayName: 'Generate weekly test pipelines (multi-cloud) for: ${{ parameters.Repository }}' condition: and(succeeded(), ne(variables['TestVariableGroups'],'')) continueOnError: true @@ -225,6 +249,7 @@ jobs: --set-managed-variables --debug --variablegroups $(InternalVariableGroups) $(TestVariableGroups) + --serviceconnections $(InternalServiceConnections) $(TestServiceConnections) displayName: 'Generate weekly unified test pipelines (multi-cloud) for: ${{ parameters.Repository }}' condition: and(succeeded(), ne(variables['GenerateUnifiedWeekly'],'')) continueOnError: true diff --git a/eng/common/pipelines/templates/steps/install-pipeline-generation.yml b/eng/common/pipelines/templates/steps/install-pipeline-generation.yml index 9d857571c5d..e16671294fd 100644 --- a/eng/common/pipelines/templates/steps/install-pipeline-generation.yml +++ b/eng/common/pipelines/templates/steps/install-pipeline-generation.yml @@ -9,7 +9,7 @@ steps: - script: > dotnet tool install Azure.Sdk.Tools.PipelineGenerator - --version 1.1.0-dev.20240604.1 + --version 1.1.0-dev.20241204.1 --add-source https://pkgs.dev.azure.com/azure-sdk/public/_packaging/azure-sdk-for-net/nuget/v3/index.json --tool-path ${{parameters.ToolPath}} workingDirectory: $(Pipeline.Workspace)/pipeline-generator From a32ca92bc917f5492059d539d99e01909ec954a8 Mon Sep 17 00:00:00 2001 From: Wes Haggard Date: Thu, 5 Dec 2024 10:04:49 -0800 Subject: [PATCH 2/2] Fix condition for generating weekly test pipelines --- eng/common/pipelines/templates/jobs/prepare-pipelines.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eng/common/pipelines/templates/jobs/prepare-pipelines.yml b/eng/common/pipelines/templates/jobs/prepare-pipelines.yml index 0f1d5ffd804..2192c1ebfbf 100644 --- a/eng/common/pipelines/templates/jobs/prepare-pipelines.yml +++ b/eng/common/pipelines/templates/jobs/prepare-pipelines.yml @@ -251,5 +251,5 @@ jobs: --variablegroups $(InternalVariableGroups) $(TestVariableGroups) --serviceconnections $(InternalServiceConnections) $(TestServiceConnections) displayName: 'Generate weekly unified test pipelines (multi-cloud) for: ${{ parameters.Repository }}' - condition: and(succeeded(), ne(variables['GenerateUnifiedWeekly'],'')) + condition: and(succeeded(), eq(variables['GenerateUnifiedWeekly'],'true')) continueOnError: true