This topic gives a brief code example of how to use the Optimizely Ruby SDK to evaluate feature flags, activate A/B tests, or feature tests.
Once you have installed the Ruby SDK, import the Optimizely library into your code, get your Optimizely project's datafile, and instantiate a client. Then, you can use the client to evaluate feature flags, activate an A/B test, or feature test.
This example demonstrates the basic usage of each of these concepts. This example shows how to:
Evaluate a feature with the key
price_filterand check a configuration variable on it called
min_price. The SDK evaluates your feature test and rollouts to determine whether the feature is enabled for a particular user, and which minimum price they should see if so.
Run an A/B test called
app_redesign. This experiment has two variations,
treatment. It uses the
activatemethod to assign the user to a variation, returning its key. As a side effect, the activate function also sends an impression event to Optimizely to record that the current user has been exposed to the experiment.
Use event tracking to track an event called
purchased. This conversion event measures the impact of an experiment. Using the track method, the purchase is automatically attributed back to the running A/B and feature tests we've activated, and the SDK sends a network request to Optimizely via the customizable event dispatcher so we can count it on your results page.
require "optimizely" # Initialize an Optimizely client optimizely_client = Optimizely::Project.new(datafile) # Evaluate a feature flag and a variable enabled = optimizely_client.is_feature_enabled('price_filter', user_id) min_price = optimizely_client.get_feature_variable_integer('price_filter', 'min_price', user_id) # Activate an A/B test variation = optimizely_client.activate('app_redesign', user_id) if variation == 'control' # Execute code for variation "control" elsif variation == 'treatment' # Execute code for variation "treatment" else # Execute code for users who don't qualify for the experiment end # Track an event optimizely_client.track('purchased', user_id)
Updated about 1 year ago