mirror of
https://github.com/go-task/task.git
synced 2025-01-10 04:18:53 +02:00
132 lines
5.5 KiB
Plaintext
132 lines
5.5 KiB
Plaintext
---
|
|
slug: /experiments/
|
|
sidebar_position: 6
|
|
---
|
|
|
|
# Experiments
|
|
|
|
:::caution
|
|
|
|
All experimental features are subject to breaking changes and/or removal _at any
|
|
time_. We strongly recommend that you do not use these features in a production
|
|
environment. They are intended for testing and feedback only.
|
|
|
|
:::
|
|
|
|
In order to allow Task to evolve quickly, we sometimes roll out breaking changes
|
|
to minor versions behind experimental flags. This allows us to gather feedback
|
|
on breaking changes before committing to a major release. This process can also
|
|
be used to gather feedback on important non-breaking features before their
|
|
design is completed. This document describes the
|
|
[experiment workflow](#workflow) and how you can get involved.
|
|
|
|
You can view the full list of active experiments in the sidebar submenu to the
|
|
left of the page and click on each one to find out more about it.
|
|
|
|
## Enabling Experiments
|
|
|
|
Task uses environment variables to detect whether or not an experiment is
|
|
enabled. All of the experiment variables will begin with the same `TASK_X_`
|
|
prefix followed by the name of the experiment. You can find the exact name for
|
|
each experiment on their respective pages in the sidebar. If the variable is set
|
|
`=1` then it will be enabled. Some experiments may have multiple proposals, in
|
|
which case, you will need to set the variable equal to the number of the
|
|
proposal that you want to enable (`=2`, `=3` etc).
|
|
|
|
There are three main ways to set the environment variables for an experiment.
|
|
Which method you use depends on how you intend to use the experiment:
|
|
|
|
1. Prefixing your task commands with the relevant environment variable(s). For
|
|
example, `TASK_X_{FEATURE}=1 task {my-task}`. This is intended for one-off
|
|
invocations of Task to test out experimental features.
|
|
1. Adding the relevant environment variable(s) in your "dotfiles" (e.g.
|
|
`.bashrc`, `.zshrc` etc.). This will permanently enable experimental features
|
|
for your personal environment.
|
|
|
|
```shell title="~/.bashrc"
|
|
export TASK_X_FEATURE=1
|
|
```
|
|
|
|
1. Creating a `.env` file in the same directory as your root Taskfile that
|
|
contains the relevant environment variable(s). This allows you to enable an
|
|
experimental feature at a project level. If you commit the `.env` file to
|
|
source control then other users of your project will also have these
|
|
experiments enabled.
|
|
|
|
```shell title=".env"
|
|
TASK_X_FEATURE=1
|
|
```
|
|
|
|
## Workflow
|
|
|
|
Experiments are a way for us to test out new features in Task before committing
|
|
to them in a major release. Because this concept is built around the idea of
|
|
feedback from our community, we have built a workflow for the process of
|
|
introducing these changes. This ensures that experiments are given the attention
|
|
and time that they need and that we are getting the best possible results out of
|
|
them.
|
|
|
|
The sections below describe the various stages that an experiment must go
|
|
through from its proposal all the way to being released in a major version of
|
|
Task.
|
|
|
|
### 1. Proposal
|
|
|
|
All experimental features start with a proposal in the form of a GitHub issue.
|
|
If the maintainers decide that an issue has enough support and is a breaking
|
|
change or is complex/controversial enough to require user feedback, then the
|
|
issue will be marked with the `experiment: proposal` label. At this point, the
|
|
issue becomes a proposal and a period of consultation begins. During this
|
|
period, we request that users provide feedback on the proposal and how it might
|
|
effect their use of Task. It is up to the discretion of the maintainers to
|
|
decide how long this period lasts.
|
|
|
|
### 2. Draft
|
|
|
|
Once a proposal's consultation ends, a contributor may pick up the work and
|
|
begin the initial implementation. Once a PR is opened, the maintainers will
|
|
ensure that it meets the requirements for an experimental feature (i.e. flags
|
|
are in the right format etc) and merge the feature. Once this code is released,
|
|
the status will be updated via the `experiment: draft` label. This indicates
|
|
that an implementation is now available for use in a release and the experiment
|
|
is open for feedback.
|
|
|
|
:::note
|
|
|
|
During the draft period, major changes to the implementation may be made based
|
|
on the feedback received from users. There are _no stability guarantees_ and
|
|
experimental features may be abandoned _at any time_.
|
|
|
|
:::
|
|
|
|
### 3. Candidate
|
|
|
|
Once an acceptable level of consensus has been reached by the community and
|
|
feedback/changes are less frequent/significant, the status may be updated via
|
|
the `experiment: candidate` label. This indicates that a proposal is _likely_ to
|
|
accepted and will enter a period for final comments and minor changes.
|
|
|
|
### 4. Stable
|
|
|
|
Once a suitable amount of time has passed with no changes or feedback, an
|
|
experiment will be given the `experiment: stable` label. At this point, the
|
|
functionality will be treated like any other feature in Task and any changes
|
|
_must_ be backward compatible. This allows users to migrate to the new
|
|
functionality without having to worry about anything breaking in future
|
|
releases. This provides the best experience for users migrating to a new major
|
|
version.
|
|
|
|
### 5. Released
|
|
|
|
When making a new major release of Task, all experiments marked as
|
|
`experiment: stable` will move to `experiment: released` and their behaviors
|
|
will become the new default in Task. Experiments in an earlier stage (i.e. not
|
|
stable) cannot be released and so will continue to be experiments in the new
|
|
version.
|
|
|
|
### Abandoned / Superseded
|
|
|
|
If an experiment is unsuccessful at any point then it will be given the
|
|
`experiment: abandoned` or `experiment: superseded` labels depending on which is
|
|
more suitable. These experiments will be removed from Task.
|