Signalerjs
Signalerjs
is an AB testing library. It provides a JavaScript interface to sample users into test groups and specify different logic depending on the test group in which a user has been placed. We will refer to each test as a "feature" and the different test groups per "feature" as "feature flags" (hence the name "Signaler").
Installation
npm install --save signalerjs
Requirements
Note that if you plan to use Signalerjs
in browsers that do not have Promise
support, you will need to polyfill it yourself with something like es6-promise
.
Setup
import Signaler from 'signalerjs';
var Signaler = require('signalerjs');
var Signaler = window.signalerjs;
Configuration
Signalerjs
can get feature flag information from a server endpoint or from a JavaScript object on initialization.
With Server
Signalerjs
can work in conjunction with a server endpoint that provides JSON data about the features. In this case, the endpoint url needs to be specified in the constructor. Server endpoint requirements.
var serverEndpoint = '/features';
var signal = new Signaler(serverEndpoint);
Without Server
Signalerjs
can also work entirely on the client-side without the need for a server. In this case the features with their possible flags are specified as an object in the constructor. See feature definition docs;
var features = {
featureOne: {
expires: 30,
flags: ['test', 'control', 'other'],
},
featureTwo: {
expires: '15 Jan 2016 20:28:44 GMT',
flags: ['test', 'control']
},
featureThree:
expires: 30,
flags: {
flagValue: 0.3,
control: 0.7
}
}
};
var signal = new Signaler(features);
Other Config
See configuration docs for more details and customizing cookie option settings.
General API
See full API docs.
signal.featureFlags().then(function(flags) {
});
signal.featureFlag('flagOne').then(function(flag) {
});
Example AB Test Usage
signal.featureFlag('flagOne').then(function(flag) {
if (flag === 'test') {
else if (flag === 'control') {
} else {
}
});