Disclaimer: This website requires Please enable JavaScript in your browser settings for the best experience.

The availability of features may depend on your plan type. Contact your Customer Success Manager if you have any questions.

🚨 Calling all developers! We invite you to provide your input on Feature Experimentation by completing this brief survey.

Dev guideRecipesAPI Reference
Dev guideAPI ReferenceUser GuideLegal TermsGitHubDev CommunityOptimizely AcademySubmit a ticketLog In
Dev guide

OptimizelyDecision for the Python SDK

Describes the OptimizelyDecision object for the Python SDK, which is returned from the decide methods in Optimizely Feature Experimentation.

Version

SDK v3.7 and higher

Object model

The following shows the object model for the OptimizelyDecision object.

class OptimizelyDecision(object):
    def __init__(self, variation_key=None, enabled=None,
                 variables=None, rule_key=None, flag_key=None, user_context=None, reasons=None):
        self.variation_key = variation_key
        self.enabled = enabled or False
        self.variables = variables or {}
        self.rule_key = rule_key
        self.flag_key = flag_key
        self.user_context = user_context
        self.reasons = reasons or []

    def as_json(self):
        return {
            'variation_key': self.variation_key,
            'enabled': self.enabled,
            'variables': self.variables,
            'rule_key': self.rule_key,
            'flag_key': self.flag_key,
            'user_context': self.user_context.as_json(),
            'reasons': self.reasons
        }

The following table describes the fields of the OptimizelyDecision object:

FieldTypeDescription
enabledBooleanWhether the flag is enabled or not. Optimizely Feature Experimentation never returns null for this field; it returns false when it fails to make a decision due to an error.
variablesmapKey-value pairs of all the flag variables. When there are no variables defined for the flag or SDK cannot get variables, this field returns an empty map. When SDK fails to get variables for a decision, the Reasons field includes the error messages regardless of the Include Reason option.
variation_keyString (nullable)When SDK fails to make a decision, this field returns null and the Reasons field includes the log messages if the Include Reasons option is set.
In legacy projects, there is an edge case: 1. no messages in the Reasons field and 2. null value in the Variation Key field means that a variation cannot be found (for example, because the flag is part of a rollout).
rule_keyString (nullable)The key of the flag rule that the user bucketed into for this decision.
When a valid rule key is not available, returns a copy of the experiment key.
Returns null if neither a valid rule key nor experiment key is found.
flag_keyStringThe key of the flag for which the decision was made.
user_contextOptimizelyUserContextThe user associated with the call to the Decide method.
reasonsArrayAn array of relevant error and log messages, in chronological order. Optimizely returns messages in this field:
- when errors are detected while making decisions.
- when reasons for decisions are enabled in the decide options
- an empty array when there are no messages.

See the following section for more information.

Reasons

The returned decision object includes error and log messages in the Reasons field.

Error reasons

For the sake of consistency with other decision results, Optimizely Feature Experimentation returns a decision with null fields instead of throwing errors or exceptions.

Critical errors are always included in the reasons field of the returned decision object regardless of the include reasons option you set on the Decide method.

ErrorPossible reasons
null variation_key- Optimizely Feature Experimentation SDK not configured properly yet
- User context is not valid
- No flag was found for key
empty variables- Invalid variables for OptimizelyJSON
- Variable value for key is invalid or wrong type

Log reasons

Optimizely Feature Experimentation collects log messages in the reasons field of the returned OptimizelyDecision object in the order in which they are logged.

The following types of log messages are only included in the reasons field if you set the include reasons option on the Decide method:

  • Log messages related to bucketing users based on audiences or attributes.
  • Log messages related to bucketing users based on traffic percentages.

Examples

For an example of a returned decision object, see Decide methods.