Skip to content

Latest commit

 

History

History
31 lines (25 loc) · 2.93 KB

ChangeWaves.md

File metadata and controls

31 lines (25 loc) · 2.93 KB

What are Change Waves?

A Change Wave is a set of risky features developed under the same opt-out flag. The purpose of this is to warn developers of "risky" changes that will become standard functionality down the line. If there's something we think is worth the risk, we found that Change Waves were a good middle ground between making necessary changes and warning customers of what will soon be permanent.

Why Opt-Out vs. Opt-In?

Opt-out is a better approach for us because we'd likely get limited feedback when a feature impacts customer builds. When a feature does impact a customer negatively, it's a quick switch to disable and allows time to adapt. The key aspect to Change Waves is that it smooths the transition for customers adapting to risky changes that the MSBuild team feels strongly enough to take.

How do they work?

The opt-out comes in the form of setting the environment variable MSBuildDisableFeaturesFromVersion to the Change Wave (or version) that contains the feature you want disabled. This version happens to be the version of MSBuild that the features were developed for. See the mapping of change waves to features below.

MSBuildDisableFeaturesFromVersion Values & Outcomes

MSBuildDisableFeaturesFromVersion Value Result Receive Warning?
Unset All Change Waves will be enabled, meaning all features behind each Change Wave will be enabled. No
Any valid & current Change Wave (Ex: 16.8) All features behind Change Wave 16.8 and higher will be disabled. No
Invalid Value (Ex: 16.9 when valid waves are 16.8 and 16.10) Default to the closest valid value (ascending). Ex: Setting 16.9 will default you to 16.10. No
Out of Rotation (Ex: 17.1 when the highest wave is 17.0) Clamp to the closest valid value. Ex: 17.1 clamps to 17.0, and 16.5 clamps to 16.8 Yes
Invalid Format (Ex: 16x8, 17_0, garbage) All Change Waves will be enabled, meaning all features behind each Change Wave will be enabled. Yes

Change Waves & Associated Features

Current Rotation of Change Waves

16.8

16.10

17.0

Change Waves No Longer In Rotation