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

Edge mode flag variable configuration

Explains the configuration settings of the cdnVariationSettings for the Optimizely Edge Agent.

👍

Beta

Optimizely Edge Agent is in beta. Apply on the Optimizely beta signup page or contact your Customer Success Manager.

The cdnVariationSettings is a powerful and essential Feature Experimentation flag variable that lets you fine-tune the behavior of Optimizely Edge Agent when operating in edge mode. This configuration object handles GET requests for granular control over content fetching, caching, and delivery on a per-variation basis.

By using the cdnVariationSettings, you can optimize your edge-based experimentation and personalization efforts, delivering the right content to the right users at the right time. This level of control is beneficial for managing complex A/B tests, where each variation may have unique requirements for content sourcing, caching, and delivery.

Key benefits of cdnVariationSettings

  • Granular control – The cdnVariationSettings lets you precisely configure content handling for each variation within an experiment. This granularity ensures that each user receives the intended experience, maintaining the integrity of the A/B test results.
  • Improved performance – By specifying caching behavior and content sources, the cdnVariationSettings can enhance the performance of edge-based experiments. Caching content at the edge reduces the need for repeated origin fetches, resulting in faster delivery and improved user experience.
  • Flexibility and scalability – The cdnVariationSettings lets you adapt your experimentation strategies without needing worker redeployment. You can do rapid iteration and optimization based on real-time insights, ensuring that experiments can scale seamlessly as traffic and complexity grow.
  • Simplified managementcdnVariationSettings streamlines managing edge-based experiments. You can control content handling, caching, and delivery directly through the configuration object, reducing the need for custom coding or complex setups.

Understand the cdnVariationSettings properties

The cdnVariationSettings is a JSON object that consists of several properties, each serving a specific purpose in controlling the behavior of Optimizely Edge Agent for GET requests.

cdnExperimentURL

The cdnExperimentURL property specifies the URL pattern that the edge worker should match against incoming GET requests to determine if they are part of a specific experiment. When a request URL matches the cdnExperimentURL, the edge worker triggers the decision-making process to determine which variation of content to deliver to the user.

Example

If an experiment is designed to test different hero banner images on a website's homepage, you could set the cdnExperimentURL to https://www.example.com/home. This subjects any GET request matching this URL to the experiment's decision-making process.

cdnResponseURL

The cdnResponseURL property specifies the URL from which the variant content should be fetched. When a request matches an experiment based on the cdnExperimentURL, the edge worker uses the cdnResponseURL to retrieve the appropriate variation content to be returned to the user.

One benefit is that the visitor from the client browser continues to see the URL for the original content they wanted to receive in the browser. However, the CDN fetches and returns the content corresponding to the defined responseURL, displaying the content to the user under the original requested URL.

This technique hides the fact that the shown content corresponds to a different URL. From the user's perspective, they view the content under the original URL they requested, while in reality, the content is served from a different URL defined by the responseURL.

This capability is useful for testing complete page redesigns or conducting experiments where entire web pages are created for A/B tests. Use the responseURL to create separate page variations and serve them to different user segments without modifying the original URL.

This approach removes the need for redirect tests to improve performance and reduce latency. Instead of redirecting the user to a different URL, the edge worker fetches the content from the defined responseURL and displays it under the original URL, providing a smooth and efficient user experience.

Example

In the hero banner experiment, the cdnResponseURL could be:

  • Variation A – https://www.example.com/home/heroExperiment_variationA.html
  • Variation B – https://www.example.com/home/heroExperiment_variationB.html.

The edge worker fetches the corresponding banner HTML file based on the assigned variation and displays it to the user under the original requested URL. The visitor continues to see the original URL in their browser, while the content served to them comes from the defined responseURL.

cacheKey

The cacheKey property determines how the response content is cached at the edge. If set to "VARIATION_KEY", the edge worker constructs a unique cache key by combining the experiment's flag key, variation key, and cdnExperimentURL. This ensures that it caches each variation's content separately for efficient retrieval on subsequent requests.

📘

should it be VARIATION_KEY or is the variation key something entered uniquely?

Example

For the hero banner experiment, setting cacheKey to "VARIATION_KEY" results in cache keys like https://www.example.com/home/heroExperiment_variationA.html and https://www.example.com/home/heroExperiment_variationB.html, ensuring that each variation's banner is cached independently.

forwardRequestToOrigin

The forwardRequestToOrigin property is a Boolean that controls whether to forward the request, along with its decision data (such as headers or cookies), to the origin server. When set to true, the edge worker acts as a smart proxy, making decisions at the edge and then passing the request and decision information to the origin for further processing.

Example

In an experiment that tests personalized product recommendations, the edge worker can make the decision based on user attributes and then forward the request to the origin, including the decided variation in the headers. The origin server then generates personalized recommendations based on the provided variation.

cacheRequestToOrigin

The cacheRequestToOrigin property is a Boolean that determines whether to cache the content fetched from the origin at the edge for future requests. When set to true, the edge worker caches the origin's response, reducing the need for repeated origin fetches for subsequent requests that qualify for the same experiment and variation.

Example

For a content-heavy experiment, such as testing different article layouts, enabling cacheRequestToOrigin ensures that the article content is cached at the edge after the first request. Subsequent users who qualify for the same variation receive the cached content, improving performance and reducing load on the origin server.

cacheTTL

The cacheTTL property specifies the Time-to-Live (TTL) value, in seconds, for the cached content. This determines how long the content remains valid in the edge cache before being considered stale and requiring a fresh fetch from the origin.

Example

For a rapidly changing experiment, such as testing different promotional offers, setting a shorter cacheTTL ensures that users receive the most up-to-date content. Conversely, for experiments with static content, you can use a longer cacheTTL to maximize caching benefits.

isControlVariation

The isControlVariation property is a Boolean that indicates whether the current variation settings represent the control group in an A/B test. This distinguishes the baseline variation from the treatment variations and accurately measures the experiment's impact.

Example

In the hero banner experiment, the variation with the existing banner design would be marked as the control variation (isControlVariation: "true"). In contrast, the new banner designs would be the treatment variations (isControlVariation: "false"). This distinction lets you properly analyze and compare the variations' performance against the control.

By configuring these properties in the cdnVariationSettings, you can precisely control how Optimizely Edge Agent handles GET requests for each variation within an experiment. This level of control lets you create highly targeted, performant, and scalable edge-based experiments that deliver personalized experiences to users while optimizing resource utilization and minimizing operational complexity.