composer require thoughtco/statamic-ab-tester
There are two types of experiments you can run:
An Entry experiment lets you select an entry and display its content on the page. This can be selected from any collection and will be available as an entry
variable inside the ab
tag.
A Manual experiment lets you determine what you want to do inside the experiment, e.g. show a different nav UI, show a different button style. You can use the autogenerated variant:id
or use variant:label
to determine what to show to the user.
This package provides tags that you can use in your Statamic templates:
This tag sets an A/B test for the given handle. It will randomly choose a experiment variant, record a hit and provide the experiment and handle to the content of the tag.
If you want your variant to persist over the session lifetime, set session="true"
{{ ab experiment="experiment_handle" session="true" }}
{{ experiment }} {{ variant }}
{{ /ab }}
This tag marks an A/B test as successful.
{{ ab:success experiment="experiment_handle" variant="variant_handle" }}
or if you've used session="true" on the ab tag:
{{ ab:success experiment="experiment_handle" from_session="true" }}
This tag marks an A/B test as a failure.
{{ ab:failure experiment="experiment_handle" variant="variant_handle" }}
or if you've used session="true" on the ab tag:
{{ ab:failure experiment="experiment_handle" from_session="true" }}
This package provides a facade for interacting with experiments:
\Thoughtco\StatamicABTester\Experiment
$experiment = \Thoughtco\StatamicABTester\Experiment::find('experiment_handle');
\Thoughtco\StatamicABTester\Experiment::all();
\Thoughtco\StatamicABTester\Experiment::query()->where('handle', 'test')->get();
Once you have an experiment you can record hits, successes, failures and get results.
Mark an experiment as being viewed:
$experiment->recordHit($variantHandle);
Mark an experiment as being successful:
$experiment->recordSuccess($variantHandle);
Mark an experiment as being a failure:
$experiment->recordFailure($variantHandle);
Get the results of an experiment:
$experiment->results();