Events
Events and impressions play a crucial role in feature flag systems like FlagSync, serving as the foundation for tracking user interactions, gathering data, and measuring the impact of features and Experiments.
By capturing relevant events, such as feature usage, user actions, and conversions, FlagSync enables teams to gain insights into feature performance and experiment outcomes.
Events
Events are manually sent to FlagSync when the track
function is called from the SDK. They are critical for tracking how feature rollouts affect user behavior. And apart from providing real-time insights, events can be linked to metrics and experiments.
Impressions
Flag impressions are automatically sent to FlagSync when the flag
function is called from the SDK; this function returns the applicable flag variant for the user context. Impressions are often used in conjunction with metrics to calculate the success criteria of experiments.
track
track
When you call the track
function to submit events, you can optionally provide key-value properties or a numeric eventValue
.
We'll discuss the differences below, and when you might choose one over the other.
Example (Page Load Time)
Say you're releasing a new feature and want to ensure page load times have not degraded. Or, you're testing some optimizations and want to validate that they've had a positive effect.
We'll use the eventValue
for this type of event.
First, you'll start by submitting an Event.
Later on, you may create a Metric called "Average Page Load Time" from the
page_load_time
event to harvest the values.Finally, you may link this metric with a feature flag in an Experiment to prove your hypothesis.
Learn about Metrics to see how they work alongside events.
Example (Purchase Events)
Say you're releasing a feature that you believe will increase the purchase amounts of your customers. Or, you're testing different discount amounts that you believe will increase the overall number of purchases.
You'll most likely want to track purchase events within your application along with the item purchased.
We'll use properties
for this type of event.
Later on, you may create a Metric called "Average Purchase Price per User" to harvest the
price
of items submitted with thepurchase_event
.Or, you may create a Metric called "Count of Discounts" to track the
discount
value.Finally, you may link these metrics with a feature flag in an Experiment to prove your hypothesis.
Learn about Metrics to see how they work alongside events.
flag
flag
A flag impression is automatically registered whenever the flag
function is called from the SDK. This function returns the applicable flag variant value for the requesting user context.
Say you have a flag, register-button-copy
, that serves the following variants:
Register
Join Now
Sign Up
When the flag value is retrieved with the flag
function, an impression is registered. This notifies FlagSync that User ABC was served Register, Join Now, or Sign Up.
Last updated