Skip to content

Proposal: Experimental features interface / API #7026

Open
@loujaybee

Description

@loujaybee

This issue is a proposal to implement for a product-wide approach for experimental features in Gitpod.

Context / Motivations

We have the concept of "VS Code Insiders", an experimental pre-release designed for power-users to be able to test out features in VS Code before they're rolled out to the full user base (see below) [1].

But the IDE interface is now starting to get cluttered, and the distinction between pre-release versions isn't very clear (it already was not entirely clear what the insider's version is).

We are now considering applying the same approach (insiders/early access IDE's) for EAP [1] versions of JetBrains IDE's, where we have a pre-release version and a stable.

Additionally, we've had challenges in the past of users not knowing when a feature is a beta / pre-release vs a stable one (e.g. #8783). This causes potential to upset or confusion for users and causes additional support burden due to increased GitHub tickets, questions from users, etc. The docs labels help somewhat, but do not guarantee that a user understands fully the implications of an experimental feature:

image

We have beta labels in-app, but again, do not ensure that a user is entirely aware of implications of an experimental feature:
image

The same challenge applies also for experimental commands within gp cli

Solution

  • A clear description of the experimental feature (to the user) e.g. what the feature does, what are the impacts
  • A way to toggle on/off the feature

From a technical design perspective, the solution needs to be able to be easily plugged into other aspects of the application, so a logical API and/or interface is essential. The solution should also play nicely with any existing feature flag behaviours, and potentially could be used for A/B testing in the future. We'd also need to consider how this might look when integrated with other API's such as gp CLI.

Related: #6826 (comment)
Related internal Slack discussion.

CC: @jakobhero

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions