Make SdkResolver-provided environment variables take precedence over ambient environment#12655
Conversation
|
Hello @@copilot, I noticed that you’re changing an .swr file or any file under src/Package/MSBuild.VSSetup.. Please make sure to validate this change by an experimental VS insertion. This is accomplished by pushing to an exp/* branch, which requires write permissions to this repo. |
|
The package vuln thing that's plaguing other builds is hitting this one too, so it's hard to tell if this change actually passes tests. |
c24c943 to
5b852f6
Compare
There was a problem hiding this comment.
Pull Request Overview
This PR fixes the precedence order for SDK resolver environment variables, making them override ambient environment variables from the host process as originally intended, rather than being overridden by them.
Key Changes:
- Modified
ProjectInstance.csandProject.csto allow SDK-resolved environment variables to override ambient environment variables - Fixed a serialization bug in
SdkResult.cswhere_environmentVariablesToAddwasn't being translated for out-of-proc scenarios - Added logging when SDK variables override ambient ones through a new resource string
SdkEnvironmentVariableOverridingAmbient
Reviewed Changes
Copilot reviewed 18 out of 18 changed files in this pull request and generated 2 comments.
Show a summary per file
| File | Description |
|---|---|
| ProjectInstance.cs | Removed check preventing SDK env vars from overriding ambient vars; added logic to remove conflicting ambient vars and log overrides |
| Project.cs | Removed check preventing SDK env vars from overriding ambient vars; SDK values now always override ambient values |
| SdkResult.cs | Fixed serialization bug by adding translation for _environmentVariablesToAdd; updated Equals and GetHashCode to include the field |
| Strings.resx | Added new log message resource string for SDK variable overrides |
| Strings.*.xlf | Added translations (marked as "new") for the new log message across all localization files |
| SdkResultEvaluation_Tests.cs | Added two tests verifying SDK env vars override ambient vars and first SDK wins when multiple SDKs set the same variable |
|
@copilot retarget this PR to |
I've improved the implementation (commit 79626cc) to align with
Regarding retargeting to
Warning Firewall rules blocked me from connecting to one or more addresses (expand for details)I tried to connect to the following addresses, but was blocked by firewall rules:
If you need me to access, download, or install something from one of these locations, you can either:
|
79626cc to
e1a79ed
Compare
Co-authored-by: baronfel <573979+baronfel@users.noreply.github.com>
Co-authored-by: baronfel <573979+baronfel@users.noreply.github.com>
Updated [Microsoft.Build](https://github.com/dotnet/msbuild) from 18.6.3 to 18.7.1. <details> <summary>Release notes</summary> _Sourced from [Microsoft.Build's releases](https://github.com/dotnet/msbuild/releases)._ ## 18.7.1 ## What's Changed * Fix TraceEngine file contention deadlock in multithreaded mode by @JanProvaznik in dotnet/msbuild#13446 * Remove duplicate test cases in MultithreadableTaskAnalyzer by @Youssef1313 in dotnet/msbuild#13483 * Ensure ThreadSafeTaskAnalyzer.Tests is considered as a unit test project by @Youssef1313 in dotnet/msbuild#13481 * Fix MSBuildTask0002 analyzer warnings in already-migrated tasks by @JanProvaznik in dotnet/msbuild#13466 * Fix race conditions in task host path resolution by @AR-May in dotnet/msbuild#13485 * Migrate ToolTask and Al task to TaskEnvironment API by @OvesN in dotnet/msbuild#13423 * Bump main to 18.7, add vs18.6 to merge flow by @MichalPavlik in dotnet/msbuild#13472 * Avoid allocations in GetHashCode implementations by @DustinCampbell in dotnet/msbuild#13475 * Add PATs rotation to agentic workflow(s) by @JanKrivanek in dotnet/msbuild#13496 * Fix ASP.NET WebSite projects to copy netstandard.dll facade when required by @JanProvaznik in dotnet/msbuild#13058 * Migrate AspNetCompiler to TaskEnvironment API by @OvesN in dotnet/msbuild#13424 * Add review workflow by @JanKrivanek in dotnet/msbuild#13503 * Strengthen reviewer skill: add step-back analysis dimensions by @JanProvaznik in dotnet/msbuild#13504 * Add 'Request Speedometer Perf Run' to VS experimental insertion build policies by @Copilot in dotnet/msbuild#13505 * Remove duplicate @ prefix from issueAuthor in GitOps by @akoeplinger in dotnet/msbuild#13492 * Improve review aw by @JanKrivanek in dotnet/msbuild#13510 * Migrates unit tests to use RoslynCodeTaskFactory to enable running tests under .NET Core by @jankratochvilcz in dotnet/msbuild#13500 * Fix cross-AppDomain TaskItem modifier cache regression by @DustinCampbell in dotnet/msbuild#13493 * Discourage review agent from approving PRs by @JanKrivanek in dotnet/msbuild#13512 * Stop trying to deploy ValueTuple by @rainersigwald in dotnet/msbuild#13507 * Ad-hoc re-sign bootstrap dotnet on macOS to prevent SIGKILL by @jankratochvilcz in dotnet/msbuild#13513 * RoslynCodeTaskFactory: Log MSB3753 when task class does not implement ITask by @jankratochvilcz in dotnet/msbuild#13517 * Update gh-aw (upon mcp policy changes) by @JanKrivanek in dotnet/msbuild#13526 * Eliminate XmlChildNodes allocations in GetXmlNodeInnerContents by @nareshjo in dotnet/msbuild#13509 * Fix telemetry allocation regression: per-engine collector ownership by @JanProvaznik in dotnet/msbuild#13516 * Migrate to xunit.v3 by @Youssef1313 in dotnet/msbuild#13482 * Fix stray brace in HandleBuildCancel trace string causing MSB1025 by @Copilot in dotnet/msbuild#13535 * Bumping to 10.0.4 runtime packages by @MichalPavlik in dotnet/msbuild#13533 * Remove early return in GetCanonicalForm, always call System.IO.Path by @OvesN in dotnet/msbuild#13532 * Do not overwrite GetCopyToOutputDirectoryItemsDependsOn, just add new… by @snechaev in dotnet/msbuild#13474 * Migrate GetReferenceAssemblyPaths task to TaskEnvironment API by @OvesN in dotnet/msbuild#13495 * Stabilize ToolTaskThatTimeoutAndRetry test by @rainersigwald in dotnet/msbuild#13489 * [automated] Merge branch 'vs18.6' => 'main' by @github-actions[bot] in dotnet/msbuild#13506 * Add extra test assertions around tests by @Youssef1313 in dotnet/msbuild#13536 * Add static eval for repo skills/agents via skill-validator by @JanKrivanek in dotnet/msbuild#13537 * Migrate SGen task to Task environment API by @OvesN in dotnet/msbuild#13457 * Fix TerminalLogger assert failure for metaproj files and cached project eval ID by @OvesN in dotnet/msbuild#13480 * Filter out approving review from pr-reviewer agent by @JanKrivanek in dotnet/msbuild#13553 * Use a unique task name per invocation to tabilize RoslynCodeTaskFactory_ReuseCompilation test by @huulinhnguyen-dev in dotnet/msbuild#13551 * Brief doc on feedback/logging/data systems by @rainersigwald in dotnet/msbuild#13554 * Localized file check-in by OneLocBuild Task: Build definition ID 9434: Build ID 13881982 by @dotnet-bot in dotnet/msbuild#13437 * Stage 3: Forward BuildProjectFile* callbacks from OOP TaskHost to worker node by @JanProvaznik in dotnet/msbuild#13350 * Enable TaskHost Callbacks by default by @JanProvaznik in dotnet/msbuild#13579 * Remove unactionable info from reviewer agent by @JanKrivanek in dotnet/msbuild#13578 * Enlighten RequiresFramework35SP1Assembly task for multithreaded mode by @jankratochvilcz in dotnet/msbuild#13575 * Make SdkResolver-provided environment variables take precedence over ambient environment by @Copilot in dotnet/msbuild#12655 * Add dotnet/skills marketplace and enable plugins by @Evangelink in dotnet/msbuild#13582 * The skills/agents check filters-in only touched files by @JanKrivanek in dotnet/msbuild#13586 * Fix skill-validation workflow failing when agents directory is deleted by @JeremyKuhne in dotnet/msbuild#13592 ... (truncated) Commits viewable in [compare view](dotnet/msbuild@v18.6.3...v18.7.1). </details> Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Context
The SdkResolver system allows SDK resolvers to provide environment variables to the MSBuild engine when an SDK is resolved. These variables were previously overridden by ambient environment variables from the host process, preventing the resolver from being the source of truth. This PR fixes that precedence order.
Changes Made
ProjectInstance.cs —
AddSdkResolvedEnvironmentVariable:_environmentVariablePropertiesbefore setting the new valueLogIfValueDiffersprivate helper (matchingmain's pattern) that logs the old and new values only when they differErrorUtilities.VerifyThrowArgumentLength(name)andErrorUtilities.VerifyThrowArgumentNull(value)Project.cs —
AddSdkResolvedEnvironmentVariable:SetPropertyto override ambient valuesErrorUtilities.VerifyThrowArgumentLength(name)andErrorUtilities.VerifyThrowArgumentNull(value)SdkResult.cs:
_environmentVariablesToAddwas not included inTranslate, breaking out-of-proc scenariosEqualsandGetHashCodeto include_environmentVariablesToAddStrings.resx and XLF files:
SdkEnvironmentVariableAlreadySetandSdkEnvironmentVariableAlreadySetBySdkto 3-arg format ({0}= name,{1}= new value,{2}= existing value)SdkEnvironmentVariableOverridingAmbientwith 3-arg format for diagnostics when an SDK overrides an ambient valueSdkEnvironmentVariableSetstringTesting
Two new tests were added in
SdkResultEvaluation_Tests.cs:SdkResolverEnvironmentVariablesOverrideAmbientEnvironmentVariables— verifies that an SDK-resolved env var takes precedence over an ambient env var with the same nameFirstSdkEnvironmentVariableWinsOverSubsequentSdks— verifies that among multiple SDKs, the first one to set a given variable winsAll 14
SdkResultEvaluationtests pass.Notes
New precedence order (highest to lowest):
Null
nameorvalueparameters toAddSdkResolvedEnvironmentVariableare rejected early with appropriate exceptions, matching the validation pattern used elsewhere in MSBuild property-setting code.Original prompt
Fixes #12654
✨ Let Copilot coding agent set things up for you — coding agent works faster and does higher quality work when set up for your repo.