共有ストレージ ワークレットを使用して A/B テストを実行する。
Shared Storage API はプライバシー さまざまな用途をサポートする汎用のクロスサイト ストレージ向けのサンドボックス案 見ていきましょう。その一例が A/B Testing です。 。
ユーザーをテストグループに割り当ててから、そのグループを共有 クロスサイト環境でアクセスされるストレージ。
A/B テストを試す
共有ストレージで A/B テストをテストするには、Chrome 104.0.5086.0 以降を使用していることを確認してください。chrome://settings/adPrivacy
で、すべての広告プライバシー API を有効にします。
コマンドラインで --enable-features=PrivacySandboxAdsAPIsOverride,OverridePrivacySandboxSettingsLocalTesting,SharedStorageAPI,FencedFrames
フラグを使用して共有ストレージを有効にすることもできます。
コードサンプルでテストする
複数のサイトで A/B テストを実施することで、期待どおりの効果が得られるかどうかを確認できます。広告主またはコンテンツ制作者は、ユーザーに割り当てられているグループに基づいて、異なるコンテンツや広告を表示することを選択できます。グループの割り当ては共有ストレージに保存されますが、データの引き出しはできません。
この例では、次のようになります。
ab-testing.js
は、コントロールと 2 つのテストコンテンツをマッピングするフレームに埋め込む必要があります。このスクリプトは、テストの共有ストレージ ワークレットを呼び出します。ab-testing-worklet.js
は、ユーザーに割り当てられているグループを返して表示する共有ストレージ ワークレットです。
// Randomly assigns a user to a group 0 or 1
function getExperimentGroup() {
return Math.round(Math.random());
}
async function injectContent() {
// Register the Shared Storage worklet
await window.sharedStorage.worklet.addModule('ab-testing-worklet.js');
// Assign user to a random group (0 or 1) and store it in Shared Storage
window.sharedStorage.set('ab-testing-group', getExperimentGroup(), {
ignoreIfPresent: true,
});
// Run the URL selection operation
const fencedFrameConfig = await window.sharedStorage.selectURL(
'ab-testing',
[
{ url: `https://your-server.example/content/default-content.html` },
{ url: `https://your-server.example/content/experiment-content-a.html` }
],
{
resolveToConfig: true
}
);
// Render the chosen URL into a fenced frame
document.getElementById('content-slot').config = fencedFrameConfig;
}
injectContent();
class SelectURLOperation {
async run(urls, data) {
// Read the user's experiment group from Shared Storage
const experimentGroup = await sharedStorage.get('ab-testing-group');
// Return the corresponding URL (first or second item in the array)
return urls.indexOf(experimentGroup);
}
}
register('ab-testing', SelectURLOperation);
ユースケース
このセクションでは、Select URL API で利用可能なすべてのユースケースについて説明します。フィードバックや新しいテストケースの検出に応じて、例を追加していきます。
- 広告クリエイティブをローテーションする: クリエイティブ ID やユーザー インタラクションなどのデータを保存して、ユーザーに表示するクリエイティブをさまざまなサイト間で決定します。
- フリークエンシーで広告クリエイティブを選択する: 視聴回数データを使用して、ユーザーがさまざまなサイトで目にするクリエイティブを特定します。
- A/B テストを実施する: ユーザーをテストグループに割り当て、そのグループを共有ストレージに保存して、クロスサイトからアクセスできるようにします。
- 既知のユーザー向けにエクスペリエンスをカスタマイズする: ユーザーの登録ステータスやその他のユーザー状態に基づいて、カスタム コンテンツや行動を促すフレーズを共有します。
意見交換とフィードバックの提供
Select URL API プロポーザルは現在議論と開発中であり、変更される可能性があります。
Select URL API について、ぜひご意見をお聞かせください。
- 提案書: 詳細な提案書を確認します。
- ディスカッション: 進行中のディスカッションに参加して、質問したり、分析情報を共有したりできます。
最新情報を入手する
- メーリング リスト: メーリング リストに登録すると、Select URL API と Shared Storage API に関する最新情報やお知らせを受け取ることができます。
ご不明な点がある場合
- デベロッパー サポート: プライバシー サンドボックス デベロッパー サポート リポジトリで他のデベロッパーと交流し、質問に答えてもらうことができます。