From b0cf02bb45b2c1f27dd75b23030dd6c569ad29a9 Mon Sep 17 00:00:00 2001 From: James Taylor Date: Fri, 31 Jan 2020 11:24:52 +0000 Subject: [PATCH] Improve build reliability It looks like rushjs symlinking can cause issues with the CopyFiles task. Use a script instead as suggested in microsoft/azure-pipelines-tasks#9046 Signed-off-by: James Taylor --- ci/azure-pipelines.yml | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/ci/azure-pipelines.yml b/ci/azure-pipelines.yml index db21b6c6..3c1363e2 100644 --- a/ci/azure-pipelines.yml +++ b/ci/azure-pipelines.yml @@ -86,19 +86,16 @@ stages: codeCoverageTool: 'cobertura' summaryFileLocation: '**/cobertura-coverage.xml' artifactName: 'Unit Test Coverage' - # CopyFiles can follow symlinks hence be careful with node_modules - - task: CopyFiles@2 - condition: or(succeeded(), failed()) # publish either way - inputs: - contents: | - **/*.build*.log - !**/node_modules/** - targetFolder: $(Build.ArtifactStagingDirectory)/logs + - script: | + mkdir -p $(Build.ArtifactStagingDirectory)/logs + find . \( -type d -name 'node_modules' \) -prune -o -name '*.build*.log' -exec cp {} $(Build.ArtifactStagingDirectory)/logs \; + displayName: 'Copy build logs' - task: PublishBuildArtifacts@1 condition: or(succeeded(), failed()) # publish either way inputs: pathToPublish: $(Build.ArtifactStagingDirectory)/logs artifactName: 'Build logs' + displayName: 'Publish build logs' # Copy the built artifacts to the staging directory, tgz, and the docker image - script: | @@ -161,11 +158,16 @@ stages: **/*.build*.log !**/node_modules/** targetFolder: $(Build.ArtifactStagingDirectory)/testlogs + - script: | + mkdir -p $(Build.ArtifactStagingDirectory)/testlogs + find . \( -type d -name 'node_modules' \) -prune -o -name '*.build*.log' -exec cp {} $(Build.ArtifactStagingDirectory)/testlogs \; + displayName: 'Copy test logs' - task: PublishBuildArtifacts@1 condition: or(succeeded(), failed()) # publish either way inputs: pathToPublish: $(Build.ArtifactStagingDirectory)/testlogs artifactName: 'Test logs' + displayName: 'Publish test logs' - task: PublishBuildArtifacts@1 condition: or(succeeded(), failed()) # publish either way inputs: