- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.2k
Run test template tests with Arcade #51020
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
|  | @@ -102,6 +102,7 @@ extends: | |
| oneESCompat: | ||
| templateFolderName: templates-official | ||
| publishTaskPrefix: 1ES. | ||
| populateInternalRuntimeVariables: true | ||
| runtimeSourceProperties: /p:DotNetRuntimeSourceFeed=https://ci.dot.net/internal /p:DotNetRuntimeSourceFeedKey=$(dotnetbuilds-internal-container-read-token-base64) | ||
| locBranch: release/10.0.1xx | ||
| # WORKAROUND: BinSkim requires the folder exist prior to scanning. | ||
|  | @@ -141,6 +142,14 @@ extends: | |
| _SignType: real | ||
| dependsOn: Official_windows_x64 | ||
| downloadManifestMsiPackages: true | ||
| ### TestTemplatesCG ### | ||
| # Note: This job is only used to allow the test templates to be built locally on the agent as opposed to Helix. | ||
| # The tests acquire the templates' PackageReferences from NuGet, which allows them to be scanned by CG (component governance). | ||
| # CG is only ran internally, so this job makes sense to only run alongside of the official jobs. | ||
| - categoryName: TestTemplatesCG | ||
| testProjects: $(Build.SourcesDirectory)/test/dotnet-new.IntegrationTests/dotnet-new.IntegrationTests.csproj | ||
| testRunnerAdditionalArguments: -class Microsoft.DotNet.Cli.New.IntegrationTests.DotnetNewTestTemplatesTests | ||
| publishXunitResults: true | ||
|  | ||
| ############### LINUX ############### | ||
| - template: /eng/pipelines/templates/jobs/sdk-job-matrix.yml@self | ||
|  | @@ -153,6 +162,7 @@ extends: | |
| oneESCompat: | ||
| templateFolderName: templates-official | ||
| publishTaskPrefix: 1ES. | ||
| populateInternalRuntimeVariables: true | ||
| runtimeSourceProperties: /p:DotNetRuntimeSourceFeed=https://ci.dot.net/internal /p:DotNetRuntimeSourceFeedKey=$(dotnetbuilds-internal-container-read-token-base64) | ||
| ${{ if and(eq(parameters.runTestBuild, false), ne(variables['Build.Reason'], 'PullRequest')) }}: | ||
| timeoutInMinutes: 90 | ||
|  | @@ -235,6 +245,7 @@ extends: | |
| oneESCompat: | ||
| templateFolderName: templates-official | ||
| publishTaskPrefix: 1ES. | ||
| populateInternalRuntimeVariables: true | ||
| runtimeSourceProperties: /p:DotNetRuntimeSourceFeed=https://ci.dot.net/internal /p:DotNetRuntimeSourceFeedKey=$(dotnetbuilds-internal-container-read-token-base64) | ||
| ${{ if and(eq(parameters.runTestBuild, false), ne(variables['Build.Reason'], 'PullRequest')) }}: | ||
| timeoutInMinutes: 90 | ||
|  | @@ -260,6 +271,8 @@ extends: | |
| vmImage: macOS-latest | ||
| os: macOS | ||
| helixTargetQueue: osx.13.arm64 | ||
| populateInternalRuntimeVariables: true | ||
| runtimeSourceProperties: /p:DotNetRuntimeSourceFeed=https://ci.dot.net/internal /p:DotNetRuntimeSourceFeedKey=$(dotnetbuilds-internal-container-read-token-base64) | ||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm fairly certain this is necessary but was missing. This job is only ran when the checkbox for enableArm64Job is used in a manual run. So, probably no one noticed. | ||
| macOSJobParameterSets: | ||
| - categoryName: TestBuild | ||
| targetArchitecture: arm64 | ||
|  | @@ -270,7 +283,9 @@ extends: | |
| - template: /eng/dotnet-format/dotnet-format-integration.yml@self | ||
| parameters: | ||
| oneESCompat: | ||
| templateFolderName: templates-official | ||
| publishTaskPrefix: 1ES. | ||
| populateInternalRuntimeVariables: true | ||
| runtimeSourceProperties: /p:DotNetRuntimeSourceFeed=https://ci.dot.net/internal /p:DotNetRuntimeSourceFeedKey=$(dotnetbuilds-internal-container-read-token-base64) | ||
|  | ||
| ############### PUBLISH STAGE ############### | ||
|  | ||
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
|  | @@ -12,7 +12,9 @@ parameters: | |
| testProjects: $(Build.SourcesDirectory)/test/UnitTests.proj | ||
| publishRetryConfig: false | ||
| publishXunitResults: false | ||
| testRunnerAdditionalArguments: '' | ||
| enableSbom: true | ||
| populateInternalRuntimeVariables: false | ||
| timeoutInMinutes: 150 | ||
| ### ENV VARS ### | ||
| testFullMSBuild: false | ||
|  | @@ -71,11 +73,11 @@ jobs: | |
| targetPath: $(Build.SourcesDirectory)/eng/BuildConfiguration | ||
| artifactName: BuildConfiguration | ||
|  | ||
| # Populate internal runtime variables. | ||
| - template: /eng/common/templates/steps/enable-internal-sources.yml | ||
| parameters: | ||
| legacyCredential: $(dn-bot-dnceng-artifact-feeds-rw) | ||
| - template: /eng/common/templates/steps/enable-internal-runtimes.yml | ||
| - ${{ if eq(parameters.populateInternalRuntimeVariables, true) }}: | ||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This also didn't need to run on every build. It only applies to internal builds. So, added the parameter to control that. | ||
| - template: /eng/common/${{ parameters.oneESCompat.templateFolderName }}/steps/enable-internal-sources.yml | ||
| parameters: | ||
| legacyCredential: $(dn-bot-dnceng-artifact-feeds-rw) | ||
| - template: /eng/common/${{ parameters.oneESCompat.templateFolderName }}/steps/enable-internal-runtimes.yml | ||
|  | ||
| - ${{ if eq(parameters.downloadManifestMsiPackages, true) }}: | ||
| - task: DownloadBuildArtifacts@1 | ||
|  | @@ -84,7 +86,7 @@ jobs: | |
| downloadPath: $(Build.SourcesDirectory)/artifacts/downloaded-manifest-msi-packages | ||
| itemPattern: '**/*Manifest-*.Msi.*.nupkg' | ||
| checkDownloadedFiles: true | ||
| displayName: Download Manifest msi packages | ||
| displayName: 🟣 Download Manifest MSI Packages | ||
|  | ||
| ############### BUILDING ############### | ||
| - ${{ if eq(parameters.pool.os, 'windows') }}: | ||
|  | @@ -131,30 +133,20 @@ jobs: | |
| OPENSSL_ENABLE_SHA1_SIGNATURES: 1 | ||
|  | ||
| ############### TESTING ############### | ||
| - ${{ if eq(parameters.pool.os, 'windows') }}: | ||
| - ${{ if eq(parameters.targetArchitecture, 'x64') }}: | ||
| - powershell: eng/common/build.ps1 | ||
| -restore -test -ci -prepareMachine -nativeToolsOnMachine | ||
| -configuration $(buildConfiguration) | ||
| /p:Projects="$(Build.SourcesDirectory)/test/dotnet-new.IntegrationTests/dotnet-new.IntegrationTests.csproj" | ||
| /p:TestRunnerAdditionalArguments="-class Microsoft.DotNet.Cli.New.IntegrationTests.DotnetNewTestTemplatesTests" | ||
| ${{ parameters.runtimeSourceProperties }} | ||
| /bl:$(Build.SourcesDirectory)/artifacts/log/$(buildConfiguration)/TestTemplateTests.binlog | ||
| displayName: 🟣 Run Test Templates Tests | ||
| condition: succeeded() | ||
|  | ||
| - ${{ if eq(parameters.runTests, true) }}: | ||
| - ${{ if eq(parameters.runAoTTests, true) }}: | ||
| # For the reason this is here, see: https://github.com/dotnet/sdk/issues/22655 | ||
| - script: $(Build.SourcesDirectory)/artifacts/bin/redist/$(buildConfiguration)/dotnet/dotnet workload install wasm-tools --skip-manifest-update | ||
| workingDirectory: $(Build.SourcesDirectory)/artifacts/bin | ||
| displayName: 🟣 Install wasm-tools Workload | ||
|  | ||
| # For the /p:Projects syntax for PowerShell, see: https://github.com/dotnet/msbuild/issues/471#issuecomment-1146466335 | ||
| - ${{ if eq(parameters.pool.os, 'windows') }}: | ||
| - powershell: eng/common/build.ps1 | ||
| -restore -test -ci -prepareMachine -nativeToolsOnMachine | ||
| -configuration $(buildConfiguration) | ||
| /p:Projects=\`"${{ replace(parameters.testProjects, ';', '`;') }}\`" | ||
| /p:TestRunnerAdditionalArguments="${{ parameters.testRunnerAdditionalArguments }}" | ||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Needed to add a way to pass this value. Since the arguments do not include  | ||
| /p:TargetArchitecture=${{ parameters.targetArchitecture }} | ||
| ${{ parameters.runtimeSourceProperties }} | ||
| /p:CustomHelixTargetQueue=${{ parameters.helixTargetQueue }} | ||
|  | @@ -167,6 +159,7 @@ jobs: | |
| HelixAccessToken: $(HelixApiAccessToken) | ||
| RunAoTTests: ${{ parameters.runAoTTests }} | ||
| TestFullMSBuild: ${{ parameters.testFullMSBuild }} | ||
|  | ||
| - ${{ else }}: | ||
| # For the /p:Projects syntax for Bash, see: https://github.com/dotnet/msbuild/issues/471#issuecomment-1690189034 | ||
| # The /p:CustomHelixTargetQueue syntax is: <queue-name>@<container-url> | ||
|  | @@ -175,6 +168,7 @@ jobs: | |
| -restore -test -ci -prepareMachine | ||
| -configuration $(buildConfiguration) | ||
| '/p:Projects="${{ parameters.testProjects }}"' | ||
| /p:TestRunnerAdditionalArguments="${{ parameters.testRunnerAdditionalArguments }}" | ||
| /p:TargetArchitecture=${{ parameters.targetArchitecture }} | ||
| /p:TargetRid=${{ parameters.runtimeIdentifier }} | ||
| ${{ parameters.osProperties }} | ||
|  | ||
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
|  | @@ -31,7 +31,6 @@ parameters: | |
| container: azureLinux30Amd64 | ||
| helixTargetContainer: $(helixTargetContainerPrefix)ubuntu-24.04-helix-amd64 | ||
| osProperties: /p:OSName=linux /p:BuildSdkDeb=true | ||
| runTests: true | ||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This was not necessary as runTests defaults to true. | ||
| # Helix is hanging on this job using the container. See: https://github.com/dotnet/dnceng/issues/6000 | ||
| disableJob: true | ||
| - categoryName: TemplateEngine | ||
|  | ||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is the primary change. Let me know if this doesn't make sense. @Youssef1313
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It makes sense.