From 75d988d683605e2b0fe09f84685b9f17e3326bf5 Mon Sep 17 00:00:00 2001 From: Ben Broderick Phillips Date: Mon, 26 Feb 2024 17:48:30 -0500 Subject: [PATCH] Add 1es changes for job/matrix generation and publish --- .../templates/jobs/generate-job-matrix.yml | 139 ++++++++++++++++++ .../templates/steps/publish-1es-artifact.yml | 34 +++++ 2 files changed, 173 insertions(+) create mode 100644 eng/common/pipelines/templates/jobs/generate-job-matrix.yml create mode 100644 eng/common/pipelines/templates/steps/publish-1es-artifact.yml diff --git a/eng/common/pipelines/templates/jobs/generate-job-matrix.yml b/eng/common/pipelines/templates/jobs/generate-job-matrix.yml new file mode 100644 index 00000000000..da70490c92c --- /dev/null +++ b/eng/common/pipelines/templates/jobs/generate-job-matrix.yml @@ -0,0 +1,139 @@ +parameters: +- name: AdditionalParameters + type: object +- name: DependsOn + type: object + default: null +- name: CloudConfig + type: object + default: {} +- name: MatrixConfigs + type: object + default: [] +- name: MatrixFilters + type: object + default: [] +- name: MatrixReplace + type: object + default: {} +- name: JobTemplatePath + type: string +# Set this to false to do a full checkout for private repositories with the azure pipelines service connection +- name: SparseCheckout + type: boolean + default: true +- name: SparseCheckoutPaths + type: object + default: [] +- name: Pool + type: string + default: azsdk-pool-mms-ubuntu-2204-general +- name: OsVmImage + type: string + default: ubuntu-22.04 +- name: Os + type: string + default: linux +# This parameter is only necessary if there are multiple invocations of this template within the SAME STAGE. +# When that occurs, provide a name other than the default value. +- name: GenerateJobName + type: string + default: 'generate_job_matrix' +- name: PreGenerationSteps + type: stepList + default: [] +# Mappings to OS name required at template compile time by 1es pipeline templates +- name: Pools + type: object + default: + - name: LinuxPool + os: linux + - name: LinuxNextPool + os: linux + - name: WindowsPool + os: windows + - name: MacPool + os: macOS + +jobs: +- job: ${{ parameters.GenerateJobName }} + variables: + - template: /eng/pipelines/templates/variables/image.yml + - name: skipComponentGovernanceDetection + value: true + - name: displayNameFilter + value: $[ coalesce(variables.jobMatrixFilter, '.*') ] + pool: + name: ${{ parameters.Pool }} + vmImage: ${{ parameters.OsVmImage }} + os: ${{ parameters.Os }} + ${{ if parameters.DependsOn }}: + dependsOn: ${{ parameters.DependsOn }} + steps: + # Skip sparse checkout for the `azure-sdk-for--pr` private mirrored repositories + # as we require the github service connection to be loaded. + - ${{ if and(parameters.SparseCheckout, not(contains(variables['Build.DefinitionName'], '-pr - '))) }}: + - template: /eng/common/pipelines/templates/steps/sparse-checkout.yml + parameters: + ${{ if ne(length(parameters.SparseCheckoutPaths), 0) }}: + Paths: ${{ parameters.SparseCheckoutPaths }} + ${{ if and(eq(length(parameters.SparseCheckoutPaths), 0), ne(parameters.AdditionalParameters.ServiceDirectory, '')) }}: + Paths: + - "sdk/${{ parameters.AdditionalParameters.ServiceDirectory }}" + + - ${{ parameters.PreGenerationSteps }} + + - ${{ each config in parameters.MatrixConfigs }}: + - ${{ each pool in parameters.Pools }}: + - ${{ if eq(config.GenerateVMJobs, 'true') }}: + - task: Powershell@2 + inputs: + pwsh: true + filePath: eng/common/scripts/job-matrix/Create-JobMatrix.ps1 + arguments: > + -ConfigPath ${{ config.Path }} + -Selection ${{ config.Selection }} + -DisplayNameFilter '$(displayNameFilter)' + -Filters '${{ join(''',''', parameters.MatrixFilters) }}', 'container=^$', 'SupportedClouds=^$|${{ parameters.CloudConfig.Cloud }}', 'Pool=.*${{ pool.name }}$' + -Replace '${{ join(''',''', parameters.MatrixReplace) }}' + -NonSparseParameters '${{ join(''',''', config.NonSparseParameters) }}' + displayName: Create ${{ pool.name }} Matrix ${{ config.Name }} + name: vm_job_matrix_${{ config.Name }}_${{ pool.name }} + + - ${{ if eq(config.GenerateContainerJobs, 'true') }}: + - task: Powershell@2 + inputs: + pwsh: true + filePath: eng/common/scripts/job-matrix/Create-JobMatrix.ps1 + arguments: > + -ConfigPath ${{ config.Path }} + -Selection ${{ config.Selection }} + -DisplayNameFilter '$(displayNameFilter)' + -Filters '${{ join(''',''', parameters.MatrixFilters) }}', 'container=^$', 'SupportedClouds=^$|${{ parameters.CloudConfig.Cloud }}', 'Pool=.*${{ pool.name }}$' + -NonSparseParameters '${{ join(''',''', config.NonSparseParameters) }}' + displayName: Create ${{ pool.name }} Container Matrix ${{ config.Name }} + name: container_job_matrix_${{ config.Name }}_${{ pool.name }} + +- ${{ each config in parameters.MatrixConfigs }}: + - ${{ each pool in parameters.Pools }}: + - ${{ if eq(config.GenerateVMJobs, 'true') }}: + - template: ${{ parameters.JobTemplatePath }} + parameters: + UsePlatformContainer: false + OSName: ${{ pool.os }} + Matrix: dependencies.${{ parameters.GenerateJobName }}.outputs['vm_job_matrix_${{ config.Name }}_${{ pool.name }}.matrix'] + DependsOn: ${{ parameters.GenerateJobName }} + CloudConfig: ${{ parameters.CloudConfig }} + ${{ each param in parameters.AdditionalParameters }}: + ${{ param.key }}: ${{ param.value }} + + - ${{ if eq(config.GenerateContainerJobs, 'true') }}: + - template: ${{ parameters.JobTemplatePath }} + parameters: + UsePlatformContainer: true + OSName: ${{ pool.os }} + Matrix: dependencies.${{ parameters.GenerateJobName }}.outputs['vm_job_matrix_${{ config.Name }}_${{ pool.name }}.matrix'] + DependsOn: ${{ parameters.GenerateJobName }} + CloudConfig: ${{ parameters.CloudConfig }} + ${{ each param in parameters.AdditionalParameters }}: + ${{ param.key }}: ${{ param.value }} diff --git a/eng/common/pipelines/templates/steps/publish-1es-artifact.yml b/eng/common/pipelines/templates/steps/publish-1es-artifact.yml new file mode 100644 index 00000000000..04b4b459e4b --- /dev/null +++ b/eng/common/pipelines/templates/steps/publish-1es-artifact.yml @@ -0,0 +1,34 @@ +# This step is used to prevent duplication of artifact publishes when there is an issue that would prevent the overall success of the job. +# Ensuring that we only publish when successful (and two a differently named artifact otherwise) will allow easy retry on a build pipeline +# without running into the "cannot override artifact" failure when we finally do get a passing run. + +# ArtifactName - The name of the artifact in the "successful" case. +# ArtifactPath - The path we will be publishing. +# CustomCondition - Used if there is additional logic necessary to prevent attempt of publish. + +parameters: + ArtifactName: '' + ArtifactPath: '' + CustomCondition: true + DisplayName: '' + +steps: + - task: 1ES.PublishPipelineArtifact@1 + condition: and(succeeded(), ${{ parameters.CustomCondition }}) + ${{ if parameters.DisplayName }}: + displayName: ${{ parameters.DisplayName }} + ${{ else }}: + displayName: 'Publish ${{ parameters.ArtifactName }} Artifacts' + inputs: + artifact: '${{ parameters.ArtifactName }}' + path: '${{ parameters.ArtifactPath }}' + + - task: 1ES.PublishPipelineArtifact@1 + condition: and(failed(), ${{ parameters.CustomCondition }}) + ${{ if parameters.DisplayName }}: + displayName: Failed - ${{ parameters.DisplayName }} + ${{ else }}: + displayName: 'Publish failed ${{ parameters.ArtifactName }} Artifacts' + inputs: + artifact: '${{ parameters.ArtifactName }}-FailedAttempt$(System.JobAttempt)' + path: '${{ parameters.ArtifactPath }}'