Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@guardian/ab-rendering

Package Overview
Dependencies
Maintainers
34
Versions
4
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@guardian/ab-rendering

Client-side ab testing framework (broken out from Frontend)

  • 0.2.0
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
Maintainers
34
Weekly downloads
 
Created
Source

ab-rendering

Client-side ab testing framework (broken out from Frontend)

API

Initialise AB Tests

import { AB } from '@guardian/ab-rendering';

// See config object values below
const coreConfig = {};
const ophanConfig = {};

const abTests = new AB(config);

// Provides access to:
// test being a single AB tests
// [tests] being an array of ab tests
abTests.runnableTest(test);
abTests.firstRunnableTest([tests]);
abTests.isUserInVariant(test, variantId);

// [tests] being an array of *runnable* ab tests
abTest.registerCompleteEvents([tests]);
abTest.registerImpressionEvents([tests]);
abTest.trackABTests([tests]);
coreConfig
ConfigTypeExampleNote
mvtMaxValuenumber10000MVT % is calculated from 0 to mvtMaxValue
mvtCookieIdnumbergetCookie('mvtCookie')The user's MVT ID to calculate what tests and variants they fall into
pageIsSensitivebooleanguardian.config.page.isSensitiveSensitive pages must have explicit settings in AB tests
abTestSwitchesRecord<string, boolean>{'TestOne': true}An object containing all of the boolean values of abTestSwitches, in Frontend from page.config.switches.abTests
forcedTestVariantOptional: { testId: ABTest['id']; variant: Variant }In Frontend this might be set by the URL override, but otherwise can be used to force a user into a test and variant at init time
forcedTestExceptionOptional: ABTest['id']Can be used to force a user out of a test (in Frontend, again with url override)
arrayOfTestObjectsABTest[]Pass all tests definitions into the config
ServerSideTetsServerSideTestsServerSideTets are accessed via window config in Frontend
errorReporterErrorReporterFuncPass an error reporter, probably Sentry
ophanRecordOphanRecordFunctionProbably Ophan's 'record' function

TODO

  • Generate flow types from Typescript definition https://github.com/joarwilk/flowgen
  • Move time-utils to a packaged lib folder

FAQs

Package last updated on 15 Jun 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc