1 | <?php |
||
17 | class Variations { |
||
18 | |||
19 | /** |
||
20 | * @var VariationInterface[] |
||
21 | */ |
||
22 | private $variations; |
||
23 | |||
24 | /** |
||
25 | * @var string |
||
26 | */ |
||
27 | private $experimentName; |
||
28 | |||
29 | /** |
||
30 | * Variations constructor. |
||
31 | * |
||
32 | * @param string $experimentName |
||
33 | * @param array|VariationInterface[] $variations |
||
34 | */ |
||
35 | 20 | public function __construct($experimentName, $variations) |
|
41 | |||
42 | /** |
||
43 | * Adds a new variation to the set of existing variations. |
||
44 | * |
||
45 | * @param array|VariationInterface $variation |
||
46 | */ |
||
47 | 19 | public function addVariation($variation) |
|
64 | |||
65 | /** |
||
66 | * Set (overwrite) all existing variations by the given variations. |
||
67 | * |
||
68 | * @param array|VariationInterface[] $variations |
||
69 | */ |
||
70 | 20 | public function setVariations($variations) |
|
80 | |||
81 | /** |
||
82 | * Get all set variations. |
||
83 | * |
||
84 | * @return VariationInterface[] |
||
85 | */ |
||
86 | 5 | public function getVariations() |
|
90 | |||
91 | 2 | protected function getNumVariations() |
|
95 | |||
96 | 2 | protected function getVariationDefaultPercentage() |
|
121 | |||
122 | /** |
||
123 | * Chooses randomly a variation from the set of existing variations. Each variation may set a percentage to |
||
124 | * allocate more or less traffic to each variation. By default all variation share the traffic equally. |
||
125 | * |
||
126 | * @return VariationInterface|null null if no variations are set |
||
127 | */ |
||
128 | 3 | public function selectRandomVariation() |
|
151 | |||
152 | /** |
||
153 | * Detects whether a variation with the given name exists in the pool of set variations. |
||
154 | * |
||
155 | * @param string $variationName |
||
156 | * @return bool |
||
157 | */ |
||
158 | 18 | public function exists($variationName) |
|
164 | |||
165 | /** |
||
166 | * Get the instance of a set variation by its variation name. If no variation matches the given name, null will be |
||
167 | * returned. |
||
168 | * |
||
169 | * @param string $variationName |
||
170 | * @return VariationInterface|null |
||
171 | */ |
||
172 | 18 | public function get($variationName) |
|
182 | |||
183 | } |