Google Optimize (GO) is a free tool provided by Google as part of Google Analytics.
It allows you to set up A/B, multivariate or redirect tests to determine whether changes made to your web pages/apps are moving you towards your pre-determined goals or away from them.
This 'how to' assumes you already know the basics of A/B or multivariate testing along with the required terminology, but if not, you can read our introduction here: https://github.com/iteles/learn-ab-and-multivariate-testing.
If you found this page, you probably already agree that A/B testing is something you want to try. The 'Why?' we're answering here is 'Why use Google Optimize?':
- It's free which makes it a good starting point for the bootstrapped startup or the individual looking to get some testing practice
- It's reliable provided you know how to use it and analyse the results correctly
- Setup is relatively easy and quick for full page 'redirect' tests, as well as for more specific, smaller A/B tests
Our your problem areas, set your goals, formulated your hypothesis and designed your variations. If you need some help with this, we've written a Getting Started with A/B testing step-by-step for you.
Google Optimize allows you to run three different types of tests:
- Redirect tests allow you to test full pages against each other. This
means that if you want to test a change in button text, you'll need to produce a
duplicate of the whole page you're testing and change the text on just that
button. Redirect tests really come into their own when used to test large site
redesigns. One pitfall of redirects is that you'll have a different ending to
your URL for each page you test
(e.g.
www.example.com
for one variation andwww.example.com/welcome
for another) - A/B tests give you more specific control over the elements and text that you want to test, perfect for tests like the button example above. Optimize comes with a really handy Chrome extension that allows you to make changes to the HTML/CSS/text of any test page and then create tests based on those changes.
- Multivariate: WiP
[Work in Progress]
To do an experiment you will need the Chrome browser, and a live website, which you have control over the code of.
The first thing to do to set up Google Optimize is going to be to add these code snippets right at the top of the head
of the page you want to test. Don't worry, we'll fill the codes in later.
<!-- this code snippet will stop your original version flashing up before your variant -->
<style>.async-hide { opacity: 0 !important} </style>
<script>(function(a,s,y,n,c,h,i,d,e){s.className+=' '+y;h.start=1*new Date;
h.end=i=function(){s.className=s.className.replace(RegExp(' ?'+y),'')};
(a[n]=a[n]||[]).hide=h;setTimeout(function(){i();h.end=null},c);h.timeout=c;
})(window,document.documentElement,'async-hide','dataLayer',4000,
{'GTM-PFH9FWG':true});</script>
<!-- end snippet -->
<!-- Google Analytics -->
<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');
ga('create', '<FILL THIS IN LATER>', 'auto');
ga('require', '<FILL THIS IN LATER>');
ga('send', 'pageview');
</script>
<!-- End Google Analytics -->
You're going to need to create an account on Google Optimize and Google Analytics On the Optimize dashboard click on "Create Experiment"
Add the name of the experiment and the url of the page you wish to do the experiment on
Now you're going to need to create a property on Google Analytics, google has a really good guide for this so I'll leave it to them to show you how! : https://support.google.com/analytics/answer/1042508?hl=en
Put the tracking id from your property in the google analytics snippet in your code, right here:
ga('create', '<FILL THIS IN LATER>', 'auto');
Select the property you just made in the Optimize dashboard
You'll be prompted with "get optimize snippet", this is the code we have pasted at the top of our html already. Still click through as it will give you a code you need.
Take the code given to you (starting with "GTM") and pop it into your snippet, here:
ga('require', '<FILL THIS IN LATER>');
Click on your experiment to open it up In the bottom left link your property
Add in an objective (we'll be going for session duration)
Add a hypothesis of what you expect, this is an experiment afterall! Click on "New Variant"
Give your variant a relevant and memorable name!
Then click on "0 changes" to edit your variant.
At this point you should be prompted to install the Chrome Optimize plugin, just click through and install it.
The editor has a really nice interface. you can click on an element, then click
"Edit Element" to change the HTML, so you can add some classes. This works
super well with tachyons! you can
also add extra CSS classes by clicking <>
.
You can make a small change, or even add loads more HTML into the body if you want a big change
Click save and then click done when you've made your changes You can always add more variants or edit the ones that are there before you start the experiment, but once it's started you can't update anything, you're locked in to your choices, and you can't pause the experiment, only stop it and start a whole new one, so make sure you're happy with your variants!
If you've done this all correctly then you'll have an option to start your experiment. If you're all ready, go ahead and click start!
Your experiment is started!
now, open your site in your browser, and open an incognito window with the same site, and hopefully you'll have both variants! It's a 50/50 chance so if you don't get the variant in either window just close the incognito window and open it again, and go back to your site. You have to close and open the incognito window, not just refresh so that Chrome acknowledges them as 2 separate sessions. Optimize is smart and wont send the same session to two different versions of the same page, that's confusing.
As you can see below, we have the same url, with 2 different versions!
Start a new experiment, this time selecting "Multivariate" rather than A/B test.
Click on your new experiment to enter the dashboard.
Add and objective and hypothesis, just as you would for the A/B test Now you're going to be adding your variants, this is where things are different!
Each section is one set of variables, so the variants within each section will never be combined with eachother, but they will be combined with all of the variants of all of the other sections.
Editing a variant is exactly the same as it is for an A/B test.
We're going to add 2 extra options for the colour of the button and 2 extra options for the call to action, which totals 3 for each including the original controls, and Optimize tells us how many total options we have, in this case, 9.
If you want to see what the different combinations look like you can click on the Combinations tab. You can click on the image of a screen with a phone, and it will give you the option to preview the combination, if you click "Web Preview" you will have your page loaded with that combination on it.
This preview will stay active on your page until deactivated, so anyone visitng will see this variant. To deactivate it, click the (now blue) screen icon again and select "Turn Off Preview".
It can be worth checking all of them just to make sure they are as you expect them to be, as you won't be able to change them once the experiment has started.
Once you've set all of this up, you can start your experiment!
It would take a while and be annoying to have load up every variant by opening and closing incognito windows, but as long as you get one variant other than your original in a different session then you know that your experiment is working 👍.
You should continually assess your priorities. These are suggested steps but not hard and fast rules for every situation.
- Plan what your next experiment will be if your challenger fails or if it 'wins'
(compared to the control)
- Start by aiming to improve on your winner rather than moving immediately onto a completely different experiment
- Remember: Just because a specific design 'won' in an experiment doesn't make it untouchable - don't be afraid of making it the control in further experiments with new ideas
- Try to have someone responsible for shipping the changes - if you just 'provide recommendations for change' based on your experiment results, they may just get lost
- If you prefer to learn from videos then here is a really good video tutorial on setting up an A/B test with Google Optimize: https://www.youtube.com/watch?v=vDDMMbhvSVU
Tips to improve your testing:
- http://marketingland.com/12-tips-to-take-your-ab-multivariate-testing-to-the-next-level-50249
- also for interpreting your results section: http://www.optimizeandprophesize.com/jonathan_mendezs_blog/2008/05/multivariate-te.html
- and https://econsultancy.com/blog/6740-what-your-mother-never-taught-you-about-multivariate-testing/
For more information on the differences between, and different use cases of A/B and Multivariate testing then we recommend having a look at our learn-ab-and-multivariate-testing
repo.