Skip to content

Experimental Flags

Kevin Chisholm edited this page Jul 21, 2022 · 7 revisions

Experimental Flags

When working on new features, it is common to control the availability of the feature through a flag. These features are turned off by default during the development cycle and enabled by default after there is sufficient signal that the feature is ready.

Once there is a decision to enable the flag by default in a release, we need to retire the flag.

When do we retire flags?

Flags should be retired once they have been in stable for a full release cycle (~3 months) and have not caused a significant amount of issues.

  1. Feature is developed and hidden behind a flag in beta 1 of version n.
  2. Feature flag is enabled by default in beta 1 of version n+1.
  3. Feature flag is retired in beta 1 of version n+2.

Example:

The Dart community has been working on implementing telepathic code generation to be released in Dart 6.2. Users of the Dart 6.1 beta can try this experimental feature using the telepathy=true flag. The feature seems to be stable and successful. In dart 6.2 the feature is no longer behind an experimental flag and is enabled by default. The team now cleans up the experimental flag tests and removes the flag before launching Dart 6.3.

Flag retirement work

  1. Clean up tests that use experimental flags.
  2. Ensure non-test code does not rely on experimental flags.
  3. Verify that tests in /pkg/* directory do not rely on experimental flags.
  4. Set expired: true in tools/experimental_features.yaml under the experimental flag entry.
  5. Run the update scripts.
  6. Alert the EngProd team of work completion.
  7. EngProd team increments the SDK version.
Clone this wiki locally