mirror of
https://github.com/PowerShell/PowerShell.git
synced 2024-11-26 19:34:22 +08:00
a42e5dbd1d
* Enable and Disable CodeQL in the right places during the official build * fix codeql condition * fix syntax error * Enable codeQL issue filing * use parameter instead of branch to force codeql * try to name the build better * Update .pipelines/PowerShell-Coordinated_Packages-Official.yml * add debugging to display name of debugging parameters * fix spacing * Update .pipelines/PowerShell-Coordinated_Packages-Official.yml
304 lines
10 KiB
YAML
304 lines
10 KiB
YAML
name: UnifiedPackageBuild-$(BUILD.SOURCEBRANCHNAME)-$(Build.BuildId)
|
|
trigger: none
|
|
|
|
parameters:
|
|
- name: InternalSDKBlobURL
|
|
displayName: URL to the blob having internal .NET SDK
|
|
type: string
|
|
default: ' '
|
|
- name: ReleaseTagVar
|
|
displayName: Release Tag
|
|
type: string
|
|
default: 'fromBranch'
|
|
- name: SKIP_SIGNING
|
|
displayName: Debugging - Skip Signing
|
|
type: string
|
|
default: 'NO'
|
|
- name: RUN_TEST_AND_RELEASE
|
|
displayName: Debugging - Run Test and Release Artifacts Stage
|
|
type: boolean
|
|
default: true
|
|
- name: RUN_WINDOWS
|
|
displayName: Debugging - Enable Windows Stage
|
|
type: boolean
|
|
default: true
|
|
- name: ENABLE_MSBUILD_BINLOGS
|
|
displayName: Debugging - Enable MSBuild Binary Logs
|
|
type: boolean
|
|
default: false
|
|
- name: FORCE_CODEQL
|
|
displayName: Debugging - Enable CodeQL and set cadence to 1 hour
|
|
type: boolean
|
|
default: false
|
|
|
|
resources:
|
|
repositories:
|
|
- repository: ComplianceRepo
|
|
type: github
|
|
endpoint: ComplianceGHRepo
|
|
name: PowerShell/compliance
|
|
ref: master
|
|
- repository: onebranchTemplates
|
|
type: git
|
|
name: OneBranch.Pipelines/GovernedTemplates
|
|
ref: refs/heads/main
|
|
|
|
variables:
|
|
- name: PS_RELEASE_BUILD
|
|
value: 1
|
|
- name: DOTNET_CLI_TELEMETRY_OPTOUT
|
|
value: 1
|
|
- name: POWERSHELL_TELEMETRY_OPTOUT
|
|
value: 1
|
|
- name: nugetMultiFeedWarnLevel
|
|
value: none
|
|
- name: NugetSecurityAnalysisWarningLevel
|
|
value: none
|
|
- name: skipNugetSecurityAnalysis
|
|
value: true
|
|
- name: branchCounterKey
|
|
value: $[format('{0:yyyyMMdd}-{1}', pipeline.startTime,variables['Build.SourceBranch'])]
|
|
- name: branchCounter
|
|
value: $[counter(variables['branchCounterKey'], 1)]
|
|
- name: BUILDSECMON_OPT_IN
|
|
value: true
|
|
- name: __DOTNET_RUNTIME_FEED
|
|
value: ${{ parameters.InternalSDKBlobURL }}
|
|
- name: LinuxContainerImage
|
|
value: onebranch.azurecr.io/linux/ubuntu-2004:latest
|
|
- name: WindowsContainerImage
|
|
value: onebranch.azurecr.io/windows/ltsc2019/vse2022:latest
|
|
- name: CDP_DEFINITION_BUILD_COUNT
|
|
value: $[counter('', 0)]
|
|
- name: ReleaseTagVar
|
|
value: ${{ parameters.ReleaseTagVar }}
|
|
- name: SKIP_SIGNING
|
|
value: ${{ parameters.SKIP_SIGNING }}
|
|
- group: mscodehub-feed-read-general
|
|
- group: mscodehub-feed-read-akv
|
|
- name: ENABLE_MSBUILD_BINLOGS
|
|
value: ${{ parameters.ENABLE_MSBUILD_BINLOGS }}
|
|
- ${{ if eq(parameters['FORCE_CODEQL'],'true') }}:
|
|
# Cadence is hours before CodeQL will allow a re-upload of the database
|
|
- name: CodeQL.Cadence
|
|
value: 1
|
|
- name: CODEQL_ENABLED
|
|
${{ if or(eq(variables['Build.SourceBranch'], 'refs/heads/master'), eq(parameters['FORCE_CODEQL'],'true')) }}:
|
|
value: true
|
|
${{ else }}:
|
|
value: false
|
|
|
|
|
|
extends:
|
|
template: v2/OneBranch.Official.CrossPlat.yml@onebranchTemplates
|
|
parameters:
|
|
customTags: 'ES365AIMigrationTooling'
|
|
featureFlags:
|
|
LinuxHostVersion:
|
|
Network: KS3
|
|
WindowsHostVersion:
|
|
Network: KS3
|
|
globalSdl:
|
|
disableLegacyManifest: true
|
|
# disabled Armorty as we dont have any ARM templates to scan. It fails on some sample ARM templates.
|
|
armory:
|
|
enabled: false
|
|
sbom:
|
|
enabled: true
|
|
codeql:
|
|
compiled:
|
|
enabled: $(CODEQL_ENABLED)
|
|
tsaEnabled: true # This enables TSA bug filing only for CodeQL 3000
|
|
credscan:
|
|
enabled: true
|
|
scanFolder: $(Build.SourcesDirectory)
|
|
suppressionsFile: $(Build.SourcesDirectory)\.config\suppress.json
|
|
cg:
|
|
enabled: true
|
|
ignoreDirectories: '.devcontainer,demos,docker,docs,src,test,tools/packaging'
|
|
asyncSdl:
|
|
enabled: true
|
|
forStages: [prep, macos, linux, windows, test_and_release_artifacts]
|
|
credscan:
|
|
enabled: true
|
|
scanFolder: $(Build.SourcesDirectory)
|
|
suppressionsFile: $(Build.SourcesDirectory)\PowerShell\.config\suppress.json
|
|
binskim:
|
|
enabled: false
|
|
# APIScan requires a non-Ready-To-Run build
|
|
apiscan:
|
|
enabled: false
|
|
tsaOptionsFile: .config\tsaoptions.json
|
|
|
|
stages:
|
|
- stage: prep
|
|
jobs:
|
|
- job: SetVars
|
|
displayName: Set Variables
|
|
pool:
|
|
type: windows
|
|
|
|
variables:
|
|
- name: ob_outputDirectory
|
|
value: '$(Build.ArtifactStagingDirectory)/ONEBRANCH_ARTIFACT/BuildJson'
|
|
- name: ob_sdl_codeSignValidation_enabled
|
|
value: false
|
|
- name: ob_sdl_codeql_compiled_enabled
|
|
value: false
|
|
- name: ob_sdl_credscan_suppressionsFile
|
|
value: $(Build.SourcesDirectory)\PowerShell\.config\suppress.json
|
|
- name: ob_sdl_tsa_configFile
|
|
value: $(Build.SourcesDirectory)\PowerShell\.config\tsaoptions.json
|
|
- name: ob_signing_setup_enabled
|
|
value: false
|
|
|
|
steps:
|
|
- checkout: self
|
|
clean: true
|
|
env:
|
|
ob_restore_phase: true # This ensures checkout is done at the beginning of the restore phase
|
|
|
|
- pwsh: |
|
|
Get-ChildItem Env: | Out-String -width 9999 -Stream | write-Verbose -Verbose
|
|
displayName: Capture environment variables
|
|
env:
|
|
ob_restore_phase: true # This ensures checkout is done at the beginning of the restore phase
|
|
|
|
- template: /.pipelines/templates/SetVersionVariables.yml@self
|
|
parameters:
|
|
ReleaseTagVar: $(ReleaseTagVar)
|
|
CreateJson: yes
|
|
UseJson: no
|
|
|
|
- stage: macos
|
|
displayName: macOS - build and sign
|
|
dependsOn: ['prep']
|
|
jobs:
|
|
- template: /.pipelines/templates/mac.yml@self
|
|
parameters:
|
|
buildArchitecture: x64
|
|
- template: /.pipelines/templates/mac.yml@self
|
|
parameters:
|
|
buildArchitecture: arm64
|
|
|
|
- stage: linux
|
|
displayName: linux - build and sign
|
|
dependsOn: ['prep']
|
|
jobs:
|
|
- template: /.pipelines/templates/linux.yml@self
|
|
parameters:
|
|
Runtime: 'linux-x64'
|
|
JobName: 'linux_x64'
|
|
|
|
- template: /.pipelines/templates/linux.yml@self
|
|
parameters:
|
|
Runtime: 'linux-x64'
|
|
JobName: 'linux_x64_minSize'
|
|
BuildConfiguration: 'minSize'
|
|
|
|
- template: /.pipelines/templates/linux.yml@self
|
|
parameters:
|
|
Runtime: 'linux-arm'
|
|
JobName: 'linux_arm'
|
|
|
|
- template: /.pipelines/templates/linux.yml@self
|
|
parameters:
|
|
Runtime: 'linux-arm64'
|
|
JobName: 'linux_arm64'
|
|
|
|
- template: /.pipelines/templates/linux.yml@self
|
|
parameters:
|
|
Runtime: 'fxdependent-linux-x64'
|
|
JobName: 'linux_fxd_x64_mariner'
|
|
|
|
- template: /.pipelines/templates/linux.yml@self
|
|
parameters:
|
|
Runtime: 'fxdependent-linux-arm64'
|
|
JobName: 'linux_fxd_arm64_mariner'
|
|
|
|
- template: /.pipelines/templates/linux.yml@self
|
|
parameters:
|
|
Runtime: 'fxdependent-noopt-linux-musl-x64'
|
|
JobName: 'linux_fxd_x64_alpine'
|
|
|
|
- template: /.pipelines/templates/linux.yml@self
|
|
parameters:
|
|
Runtime: 'fxdependent'
|
|
JobName: 'linux_fxd'
|
|
|
|
- template: /.pipelines/templates/linux.yml@self
|
|
parameters:
|
|
Runtime: 'linux-musl-x64'
|
|
JobName: 'linux_x64_alpine'
|
|
|
|
- stage: windows
|
|
displayName: windows - build and sign
|
|
dependsOn: ['prep']
|
|
condition: and(succeeded(),eq('${{ parameters.RUN_WINDOWS }}','true'))
|
|
jobs:
|
|
- template: /.pipelines/templates/windows-hosted-build.yml@self
|
|
parameters:
|
|
Architecture: x64
|
|
BuildConfiguration: release
|
|
JobName: build_windows_x64_release
|
|
- template: /.pipelines/templates/windows-hosted-build.yml@self
|
|
parameters:
|
|
Architecture: x64
|
|
BuildConfiguration: minSize
|
|
JobName: build_windows_x64_minSize_release
|
|
- template: /.pipelines/templates/windows-hosted-build.yml@self
|
|
parameters:
|
|
Architecture: x86
|
|
JobName: build_windows_x86_release
|
|
- template: /.pipelines/templates/windows-hosted-build.yml@self
|
|
parameters:
|
|
Architecture: arm64
|
|
JobName: build_windows_arm64_release
|
|
- template: /.pipelines/templates/windows-hosted-build.yml@self
|
|
parameters:
|
|
Architecture: fxdependent
|
|
JobName: build_windows_fxdependent_release
|
|
- template: /.pipelines/templates/windows-hosted-build.yml@self
|
|
parameters:
|
|
Architecture: fxdependentWinDesktop
|
|
JobName: build_windows_fxdependentWinDesktop_release
|
|
|
|
- stage: test_and_release_artifacts
|
|
displayName: Test and Release Artifacts
|
|
dependsOn: ['prep']
|
|
condition: and(succeeded(),eq('${{ parameters.RUN_TEST_AND_RELEASE }}','true'))
|
|
jobs:
|
|
- template: /.pipelines/templates/testartifacts.yml@self
|
|
|
|
- job: release_json
|
|
displayName: Create and Upload release.json
|
|
pool:
|
|
type: windows
|
|
variables:
|
|
- name: ob_outputDirectory
|
|
value: '$(Build.ArtifactStagingDirectory)/ONEBRANCH_ARTIFACT'
|
|
- name: ob_sdl_tsa_configFile
|
|
value: $(Build.SourcesDirectory)\PowerShell\.config\tsaoptions.json
|
|
- name: ob_sdl_credscan_suppressionsFile
|
|
value: $(Build.SourcesDirectory)\PowerShell\.config\suppress.json
|
|
steps:
|
|
- checkout: self
|
|
clean: true
|
|
- template: /.pipelines/templates/SetVersionVariables.yml@self
|
|
parameters:
|
|
ReleaseTagVar: $(ReleaseTagVar)
|
|
- powershell: |
|
|
$metadata = Get-Content '$(Build.SourcesDirectory)/PowerShell/tools/metadata.json' -Raw | ConvertFrom-Json
|
|
$LTS = $metadata.LTSRelease.Package
|
|
@{ ReleaseVersion = "$(Version)"; LTSRelease = $LTS } | ConvertTo-Json | Out-File "$(Build.StagingDirectory)\release.json"
|
|
Get-Content "$(Build.StagingDirectory)\release.json"
|
|
|
|
if (-not (Test-Path "$(ob_outputDirectory)\metadata")) {
|
|
New-Item -ItemType Directory -Path "$(ob_outputDirectory)\metadata"
|
|
}
|
|
|
|
Copy-Item -Path "$(Build.StagingDirectory)\release.json" -Destination "$(ob_outputDirectory)\metadata" -Force
|
|
displayName: Create and upload release.json file to build artifact
|
|
retryCountOnTaskFailure: 2
|
|
- template: /.pipelines/templates/step/finalize.yml@self
|