A Python SDK for Molasses. It allows you to evaluate user's status for a feature. It also helps simplify logging events for A/B testing.
Molasses uses server sent events to get instant updates with an option for polling to check if you have updated features. Once initialized, it takes microseconds to evaluate if a user is active.
pip install molassesStart by initializing the client with an APIKey. This begins the
polling for any feature updates. The updates happen every 15 seconds.
from molasses import MolassesClient
client = MolassesClient("test_key")If you decide not to track analytics events (experiment started,
experiment success) you can turn them off by setting the send_events
field to False
client = MolassesClient("test_key", send_events=False)You can call is_active with the key name and optionally a user’s
information. The id field is used to determine whether a user is
part of a percentage of users. If you have other constraints based on
user params you can pass those in the params field.
client.is_active("FOO_TEST", {
"id":"foo",
"params":{
"isBetaUser":"false",
"isScaredUser":"false"
}
})You can check if a feature is active for a user who is anonymous by just
calling is_active with the key. You won’t be able to do percentage
roll outs or track that user’s behavior.
client.is_active("TEST_FEATURE_FOR_USER")To track an analytics events called the track method.
client.track("Button Clicked",{
"id":"foo",
"params":{
"isBetaUser":"false",
"isScaredUser":"false"
}
},
{
"version": "v2.3.0"
})To track whether an experiment was successful you can call
experiment_started. experiment_started takes the feature’s name, any
additional parameters for the event and the user.
client.experiment_started("GOOGLE_SSO",{
"id":"foo",
"params":{
"isBetaUser":"false",
"isScaredUser":"false"
}
},
{
"version": "v2.3.0"
})To track whether an experiment was successful you can call
experiment_success. experiment_success takes the feature’s name, any
additional parameters for the event and the user.
client.experiment_success("GOOGLE_SSO",{
"id":"foo",
"params":{
"isBetaUser":"false",
"isScaredUser":"false"
}
},
{
"version": "v2.3.0"
})from molasses import MolassesClient
client = MolassesClient("test_key")
if client.is_active('NEW_CHECKOUT'):
print "we are a go"
else:
print "we are a no go"This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.