🚥 Flag Evaluation
Overview
In a feature flag system, flag evaluation is the process of determining the current state (which variant to use) of a feature flag for a given evaluation context.
This process happens at runtime, allowing you to dynamically control the behavior of your application without redeploying code.
What Happens During Evaluation?
The evaluation process typically involves these steps:
- Retrieving the Flag Configuration: The system fetches the configuration for the specific flag being evaluated. This configuration includes information such as the flag's default value, targeting rules, and any other relevant settings.
- Contextual Input: The evaluation receives context about the current request or user. This context can include information like:
- A targeting key
- Device type
- Location
- Custom attributes
- Rule Evaluation: The system evaluates the targeting rules defined for the flag against the provided context. These rules determine which users or requests should see the feature enabled (or a specific variant). Common targeting strategies include:
- Percentage rollout: Enable the feature for a percentage of users (e.g., 50%).
- User targeting: Enable the feature for specific users.
- Attribute-based targeting: Enable the feature based on user attributes (e.g., users with a "premium" subscription).
- Returning the Flag Value: Based on the rule evaluation, the system returns the appropriate value for the flag (e.g.,
true
,false
, or a variant value like"variantA"
).
Supported type of flags
GO Feature Flag supports a variety of flag types, including:
- Boolean
- String
- Integer
- Double
- Object
For each flag type, the SDKs are providing specific APIs to be able to retrieve your flag in the right type inside your code.
Example
Let's say you have a feature flag called new_checkout_flow
with the following configuration:
new_checkout_flow:
variations:
enabled: true
disabled: false
targeting:
- query: user_segment eq "early_adopters"
variation: enabled
defaultRule:
percentage:
enabled: 20
disabled: 80
If a user belongs to the early_adopters
segment, the flag evaluation will return true
.
If a user does not belong to that segment, there's a 20% chance the flag will return true
due to the percentage rollout rule. Otherwise, the flag will return the false
.
Basic evaluation with GO Feature Flag
After setting up your flag configuration, you can evaluate the flag in your application code. For this example (in JS), we'll use the OpenFeature SDKs, with a GO Feature Flag provider:
const evaluationContext = {
targetingKey: "<my-key>",
"user_segment": "early_adopters",
};
const defaultValue = false;
// get a boolean value
const boolValue = await client.getBooleanValue(
'new_checkout_flow',
defaultValue,
evaluationContext);
As you can see, the evaluation context API takes 3 parameters (this is true in most languages):
- The name of the flag to evaluate.
- A default value to return if the flag is not found or the evaluation fails. The evaluation API will always return a value, even if there is an error.
- An evaluation context giving information about the current user or request (more information about evaluation context).
You can also see that we explicitely asking for a boolean value because new_checkout_flow
is a boolean flag.
Benefits of Dynamic Evaluation
Dynamic flag evaluation provides several advantages:
- Instant control: Change the state of features without deploying new code.
- A/B testing: Run experiments and gather data on different feature variations.
- Gradual rollouts: Release features to a small group of users before wider deployment.
- Kill switches: Quickly disable problematic features in production.