From 877f51696ee8752c68e8a2b6f1c4b3551c7d9e2a Mon Sep 17 00:00:00 2001 From: Jake Date: Mon, 11 Nov 2024 16:18:11 +0000 Subject: [PATCH] Setup test for new prebid analytics endpoint (#1654) Co-authored-by: Emma Imber <108270776+emma-imber@users.noreply.github.com> --- .changeset/rare-pants-jump.md | 5 ++++ package.json | 2 +- pnpm-lock.yaml | 8 +++--- src/experiments/ab-tests.ts | 2 ++ .../tests/new-header-bidding-endpoint.ts | 28 +++++++++++++++++++ src/lib/header-bidding/prebid/prebid.ts | 9 ++++++ 6 files changed, 49 insertions(+), 5 deletions(-) create mode 100644 .changeset/rare-pants-jump.md create mode 100644 src/experiments/tests/new-header-bidding-endpoint.ts diff --git a/.changeset/rare-pants-jump.md b/.changeset/rare-pants-jump.md new file mode 100644 index 000000000..9123e3ebd --- /dev/null +++ b/.changeset/rare-pants-jump.md @@ -0,0 +1,5 @@ +--- +'@guardian/commercial': minor +--- + +Setup test for new prebid analytics endpoint diff --git a/package.json b/package.json index ad236c027..b84dc2347 100644 --- a/package.json +++ b/package.json @@ -103,7 +103,7 @@ }, "dependencies": { "@changesets/cli": "^2.26.2", - "@guardian/prebid.js": "8.52.0-7", + "@guardian/prebid.js": "8.52.0-8", "@octokit/core": "^6.1.2", "fastdom": "^1.0.11", "lodash-es": "^4.17.21", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index a33b0ddea..584a9868b 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -9,8 +9,8 @@ dependencies: specifier: ^2.26.2 version: 2.27.7 '@guardian/prebid.js': - specifier: 8.52.0-7 - version: 8.52.0-7(babel-core@7.0.0-bridge.0)(tslib@2.7.0)(typescript@5.5.3) + specifier: 8.52.0-8 + version: 8.52.0-8(babel-core@7.0.0-bridge.0)(tslib@2.7.0)(typescript@5.5.3) '@octokit/core': specifier: ^6.1.2 version: 6.1.2 @@ -1995,8 +1995,8 @@ packages: typescript: 5.5.3 dev: true - /@guardian/prebid.js@8.52.0-7(babel-core@7.0.0-bridge.0)(tslib@2.7.0)(typescript@5.5.3): - resolution: {integrity: sha512-RWg8vyyfZccrqRXu5w+nnghsskYCHkLWQqXdFh1iSadYRU+exuNcynxStKdzUZdPNnh8aUyEuMIoaZXHmEZEYg==} + /@guardian/prebid.js@8.52.0-8(babel-core@7.0.0-bridge.0)(tslib@2.7.0)(typescript@5.5.3): + resolution: {integrity: sha512-JQ9unudgn5DAwLoqEiBdjuEaEFOhR9JZhjHD46pm4306C1XfYF0ts3YWIT9poq6vN1tbMQJw0NQeyXcL5QGIcA==} engines: {node: '>=12.0.0'} dependencies: '@babel/core': 7.25.2 diff --git a/src/experiments/ab-tests.ts b/src/experiments/ab-tests.ts index 6ea72ede6..f6b637ccc 100644 --- a/src/experiments/ab-tests.ts +++ b/src/experiments/ab-tests.ts @@ -1,5 +1,6 @@ import type { ABTest } from '@guardian/ab-core'; import { mpuWhenNoEpic } from './tests/mpu-when-no-epic'; +import { newHeaderBiddingEndpoint } from './tests/new-header-bidding-endpoint'; import { optOutFrequencyCap } from './tests/opt-out-frequency-cap'; /** @@ -11,4 +12,5 @@ export const concurrentTests: ABTest[] = [ // one test per line mpuWhenNoEpic, optOutFrequencyCap, + newHeaderBiddingEndpoint, ]; diff --git a/src/experiments/tests/new-header-bidding-endpoint.ts b/src/experiments/tests/new-header-bidding-endpoint.ts new file mode 100644 index 000000000..fdeee324c --- /dev/null +++ b/src/experiments/tests/new-header-bidding-endpoint.ts @@ -0,0 +1,28 @@ +import type { ABTest } from '@guardian/ab-core'; + +export const newHeaderBiddingEndpoint: ABTest = { + id: 'newHeaderBiddingEndpoint', + author: '@commercial-dev', + start: '2024-11-11', + expiry: '2024-11-30', + audience: 0 / 100, + audienceOffset: 0 / 100, + audienceCriteria: '', + successMeasure: '', + description: 'Test new header bidding (prebid) analytics endpoint.', + variants: [ + { + id: 'control', + test: (): void => { + /* no-op */ + }, + }, + { + id: 'variant', + test: (): void => { + /* no-op */ + }, + }, + ], + canRun: () => true, +}; diff --git a/src/lib/header-bidding/prebid/prebid.ts b/src/lib/header-bidding/prebid/prebid.ts index 8742ce3ec..a83875a26 100644 --- a/src/lib/header-bidding/prebid/prebid.ts +++ b/src/lib/header-bidding/prebid/prebid.ts @@ -8,6 +8,8 @@ import { PREBID_TIMEOUT } from '../../../core/constants/prebid-timeout'; import { EventTimer } from '../../../core/event-timer'; import type { PageTargeting } from '../../../core/targeting/build-page-targeting'; import type { Advert } from '../../../define/Advert'; +import { isUserInVariant } from '../../../experiments/ab'; +import { newHeaderBiddingEndpoint } from '../../../experiments/tests/new-header-bidding-endpoint'; import { getPageTargeting } from '../../build-page-targeting'; import { getAdvertById } from '../../dfp/get-advert-by-id'; import { isUserLoggedInOktaRefactor } from '../../identity/api'; @@ -124,6 +126,8 @@ type EnableAnalyticsConfig = { options: { ajaxUrl: string; pv: string; + enableV2Endpoint: boolean; + ajaxUrlV2: string; }; }; @@ -423,6 +427,11 @@ const initialise = ( options: { ajaxUrl: window.guardian.config.page.ajaxUrl ?? '', pv: window.guardian.ophan.pageViewId, + enableV2Endpoint: isUserInVariant( + newHeaderBiddingEndpoint, + 'variant', + ), + ajaxUrlV2: `//performance-events.code.dev-guardianapis.com/header-bidding`, }, }, ]);