From 3552ab535d70111ce3357efdc7cb0f85e358b639 Mon Sep 17 00:00:00 2001 From: Viktor Hofer Date: Thu, 12 Dec 2024 12:00:48 +0100 Subject: [PATCH 1/2] Use Build.ArtifactStagingDirectory now that we run with native containers in AzDO Before when we running with a custom docker invocation we couldn't write to files outside of the mount. Now that we use the native AzDO container integration that shouldn't be an issue anymore. --- eng/pipelines/templates/jobs/vmr-build.yml | 7 ++++--- src/SourceBuild/content/Directory.Build.props | 1 - 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/eng/pipelines/templates/jobs/vmr-build.yml b/eng/pipelines/templates/jobs/vmr-build.yml index 5f0e9376a14d..f2eff52d6297 100644 --- a/eng/pipelines/templates/jobs/vmr-build.yml +++ b/eng/pipelines/templates/jobs/vmr-build.yml @@ -177,10 +177,8 @@ jobs: - name: sourcesPath value: $(vmrPath) - # Must be a path under $(sourcesPath). Inside the docker container, we mount $(sourcesPath) to /vmr - # and can't write outside of that folder. - name: artifactsStagingDir - value: $(sourcesPath)/artifacts/staging + value: $(Build.ArtifactStagingDirectory)/artifacts templateContext: outputParentDirectory: $(Build.ArtifactStagingDirectory) @@ -421,6 +419,7 @@ jobs: fi extraBuildProperties="$extraBuildProperties /p:VerticalName=$(Agent.JobName)" + extraBuildProperties="$extraBuildProperties /p:ArtifactsStagingDir=$(artifactsStagingDir)" buildArgs="$(additionalBuildArgs) $customBuildArgs $extraBuildProperties" @@ -455,6 +454,7 @@ jobs: customPreBuildArgs='' customBuildArgs='' extraBuildProperties='' + customBuildArgs="--ci --prepareMachine -c ${{ parameters.configuration }}" if [[ '${{ parameters.runOnline }}' == 'False' ]]; then customPreBuildArgs="$customPreBuildArgs sudo" @@ -484,6 +484,7 @@ jobs: fi extraBuildProperties="$extraBuildProperties /p:VerticalName=$(Agent.JobName)" + extraBuildProperties="$extraBuildProperties /p:ArtifactsStagingDir=$(artifactsStagingDir)" if [[ -n "${{ parameters.extraProperties }}" ]]; then extraBuildProperties="$extraBuildProperties ${{ parameters.extraProperties }}" diff --git a/src/SourceBuild/content/Directory.Build.props b/src/SourceBuild/content/Directory.Build.props index 563f6f1e8bf5..e8b6663ffcd4 100644 --- a/src/SourceBuild/content/Directory.Build.props +++ b/src/SourceBuild/content/Directory.Build.props @@ -202,7 +202,6 @@ $(ArtifactsAssetManifestsDir)$([MSBuild]::ValueOrDefault('$(VerticalName)', 'VerticalManifest')).xml - $(ArtifactsDir)staging From fc6ff1057939c8a53a7db9c7f15bbb7765fa450c Mon Sep 17 00:00:00 2001 From: Viktor Hofer Date: Thu, 12 Dec 2024 14:08:42 +0100 Subject: [PATCH 2/2] Add ArtifactsStagingDir parameter to build command --- eng/pipelines/templates/jobs/vmr-build.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/eng/pipelines/templates/jobs/vmr-build.yml b/eng/pipelines/templates/jobs/vmr-build.yml index f2eff52d6297..8aaed9b0ba55 100644 --- a/eng/pipelines/templates/jobs/vmr-build.yml +++ b/eng/pipelines/templates/jobs/vmr-build.yml @@ -301,13 +301,13 @@ jobs: if /I '${{ parameters.useDevVersions }}'=='True' set extraBuildArguments=%extraBuildArguments% -dev set extraBuildProperties= if not [${{ parameters.buildPass }}]==[] set extraBuildProperties=%extraBuildProperties% /p:DotNetBuildPass=${{ parameters.buildPass }} - call build.cmd -ci -cleanWhileBuilding -prepareMachine %extraBuildArguments% -c ${{ parameters.configuration }} /p:TargetOS=${{ parameters.targetOS }} /p:TargetArchitecture=${{ parameters.targetArchitecture }} /p:VerticalName=$(Agent.JobName) %extraBuildProperties% ${{ parameters.extraProperties }} + call build.cmd -ci -cleanWhileBuilding -prepareMachine %extraBuildArguments% -c ${{ parameters.configuration }} /p:TargetOS=${{ parameters.targetOS }} /p:TargetArchitecture=${{ parameters.targetArchitecture }} /p:VerticalName=$(Agent.JobName) /p:ArtifactsStagingDir=$(artifactsStagingDir) %extraBuildProperties% ${{ parameters.extraProperties }} displayName: Build workingDirectory: ${{ variables.sourcesPath }} - ${{ if eq(parameters.runTests, 'True') }}: - script: | - call build.cmd -ci -prepareMachine -test -excludeCIBinarylog /bl:artifacts/log/Release/Test.binlog -c ${{ parameters.configuration }} /p:TargetOS=${{ parameters.targetOS }} /p:TargetArchitecture=${{ parameters.targetArchitecture }} /p:VerticalName=$(Agent.JobName) ${{ parameters.extraProperties }} + call build.cmd -ci -prepareMachine -test -excludeCIBinarylog /bl:artifacts/log/Release/Test.binlog -c ${{ parameters.configuration }} /p:TargetOS=${{ parameters.targetOS }} /p:TargetArchitecture=${{ parameters.targetArchitecture }} /p:VerticalName=$(Agent.JobName) /p:ArtifactsStagingDir=$(artifactsStagingDir) ${{ parameters.extraProperties }} displayName: Run Tests workingDirectory: ${{ variables.sourcesPath }} timeoutInMinutes: ${{ variables.runTestsTimeout }}