Налаштування A/B-тестування
Google Optimize був закритий у 2023 році. Актуальні інструменти — Statsig, Growthbook, Optimizely, VWO або власна реалізація через Edge Functions.
Вибір інструменту
| Інструмент | Тип | Найкраще для |
|---|---|---|
| Growthbook | Open source / SaaS | Технічні команди, self-hosted |
| Statsig | SaaS | Швидкий старт, інтеграція з аналітикою |
| Optimizely | Enterprise SaaS | Великі компанії, складні експерименти |
| VWO | SaaS | Маркетингові команди без розробників |
| Vercel Edge Experiments | PaaS | Next.js на Vercel |
| Власна реалізація | - | Повний контроль, мінімальні витрати |
Реалізація через Vercel Edge Middleware
// middleware.ts
import { NextResponse } from 'next/server';
import type { NextRequest } from 'next/server';
const EXPERIMENT_COOKIE = 'exp_checkout_v2';
const VARIANTS = ['control', 'variant-a', 'variant-b'];
function assignVariant(): string {
const rand = Math.random();
if (rand < 0.34) return 'control';
if (rand < 0.67) return 'variant-a';
return 'variant-b';
}
export function middleware(request: NextRequest) {
const response = NextResponse.next();
// Виключити: боти, вже призначені користувачі
const existing = request.cookies.get(EXPERIMENT_COOKIE)?.value;
if (existing && VARIANTS.includes(existing)) {
return response;
}
const variant = assignVariant();
response.cookies.set(EXPERIMENT_COOKIE, variant, {
maxAge: 60 * 60 * 24 * 30, // 30 днів
httpOnly: true,
sameSite: 'lax',
});
// Передати варіант у заголовку для Server Components
response.headers.set('x-ab-checkout', variant);
return response;
}
export const config = {
matcher: ['/checkout/:path*'],
};
// app/checkout/page.tsx
import { cookies, headers } from 'next/headers';
export default function CheckoutPage() {
const variant = headers().get('x-ab-checkout') ??
cookies().get('exp_checkout_v2')?.value ??
'control';
return (
<>
{variant === 'control' && <CheckoutV1 />}
{variant === 'variant-a' && <CheckoutV2OneStep />}
{variant === 'variant-b' && <CheckoutV2TwoStep />}
<ABTracker experiment="checkout_v2" variant={variant} />
</>
);
}
Відстеження результатів
// components/ABTracker.tsx (Client Component)
'use client';
import { useEffect } from 'react';
export function ABTracker({ experiment, variant }: {
experiment: string;
variant: string;
}) {
useEffect(() => {
// GA4
gtag('event', 'experiment_impression', {
experiment_id: experiment,
variant_id: variant,
});
// PostHog
posthog.capture('$experiment_started', {
'$experiment_id': experiment,
'$variant_key': variant,
});
}, [experiment, variant]);
return null;
}
// Відстеження конверсії — під час покупки
function trackConversion(variant: string) {
gtag('event', 'purchase', {
experiment_id: 'checkout_v2',
variant_id: variant,
value: orderTotal,
});
}
Statsig: швидка інтеграція
// Statsig SDK
import Statsig from 'statsig-node';
await Statsig.initialize(process.env.STATSIG_SERVER_KEY!);
// У API маршруті / Server Action
const experiment = Statsig.getExperiment(
{ userID: userId, email: userEmail },
'checkout_redesign'
);
const checkoutLayout = experiment.get('layout', 'single-page');
const ctaColor = experiment.get('cta_color', 'blue');
// Клієнтська сторона (React SDK)
import { useExperiment } from 'statsig-react';
function PricingCTA() {
const { config } = useExperiment('pricing_cta');
const buttonText = config.get('button_text', 'Get Started');
const buttonVariant = config.get('button_variant', 'primary');
return (
<Button
variant={buttonVariant}
onClick={() => {
statsig.logEvent('cta_clicked', buttonText);
}}
>
{buttonText}
</Button>
);
}
Статистична значущість
Перед запуском тесту — розрахувати необхідний розмір вибірки:
# Python: розрахунок розміру вибірки
from statsmodels.stats.power import zt_ind_solve_power
# CVR = 3%, очікуваний ефект = +15% (до 3.45%)
baseline_rate = 0.03
expected_effect = 0.15 # відносне поліпшення
lift = baseline_rate * expected_effect # 0.0045 абсолютно
n = zt_ind_solve_power(
effect_size=lift / (baseline_rate * (1 - baseline_rate)) ** 0.5,
alpha=0.05, # 95% впевненість
power=0.8, # 80% статистичної потужності
)
print(f"Sample size per variant: {int(n)}") # ~12,000
Правило: не зупиняйте тест перед досягненням запланованого розміру вибірки, навіть якщо результати виглядають добре.
Аналіз результатів у GA4
GA4 → Explore → Free Form
Dimension: Experiment Variant (custom event parameter)
Metric: Conversions, Revenue
Segment за варіантом → порівняння конверсій
Налаштування A/B-тестування з відстеженням у GA4/PostHog — 2–4 робочих дні залежно від технічного стеку.







