unleash-server
Version:
Unleash is an enterprise ready feature toggles service. It provides different strategies for handling feature toggles.
219 lines • 6.97 kB
JavaScript
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const events_1 = require("../types/events");
const slack_1 = __importDefault(require("./slack"));
const no_logger_1 = __importDefault(require("../../test/fixtures/no-logger"));
let fetchRetryCalls = [];
jest.mock('./addon', () => class Addon {
constructor(definition, { getLogger }) {
this.logger = getLogger('addon/test');
fetchRetryCalls = [];
}
async fetchRetry(url, options, retries, backoff) {
fetchRetryCalls.push({
url,
options,
retries,
backoff,
});
return Promise.resolve({ status: 200 });
}
});
test('Should call slack webhook', async () => {
const addon = new slack_1.default({
getLogger: no_logger_1.default,
unleashUrl: 'http://some-url.com',
});
const event = {
id: 1,
createdAt: new Date(),
type: events_1.FEATURE_CREATED,
createdBy: 'some@user.com',
project: 'default',
featureName: 'some-toggle',
data: {
name: 'some-toggle',
enabled: false,
type: 'release',
strategies: [{ name: 'default' }],
},
};
const parameters = {
url: 'http://hooks.slack.com',
};
await addon.handleEvent(event, parameters);
expect(fetchRetryCalls.length).toBe(1);
expect(fetchRetryCalls[0].url).toBe(parameters.url);
expect(fetchRetryCalls[0].options.body).toMatchSnapshot();
});
test('Should call slack webhook for archived toggle', async () => {
const addon = new slack_1.default({
getLogger: no_logger_1.default,
unleashUrl: 'http://some-url.com',
});
const event = {
id: 2,
createdAt: new Date(),
type: events_1.FEATURE_ARCHIVED,
featureName: 'some-toggle',
createdBy: 'some@user.com',
data: {
name: 'some-toggle',
},
};
const parameters = {
url: 'http://hooks.slack.com',
};
await addon.handleEvent(event, parameters);
expect(fetchRetryCalls.length).toBe(1);
expect(fetchRetryCalls[0].url).toBe(parameters.url);
expect(fetchRetryCalls[0].options.body).toMatchSnapshot();
});
test('Should call slack webhook for archived toggle with project info', async () => {
const addon = new slack_1.default({
getLogger: no_logger_1.default,
unleashUrl: 'http://some-url.com',
});
const event = {
id: 2,
createdAt: new Date(),
type: events_1.FEATURE_ARCHIVED,
featureName: 'some-toggle',
project: 'some-project',
createdBy: 'some@user.com',
data: {
name: 'some-toggle',
},
};
const parameters = {
url: 'http://hooks.slack.com',
};
await addon.handleEvent(event, parameters);
expect(fetchRetryCalls.length).toBe(1);
expect(fetchRetryCalls[0].url).toBe(parameters.url);
expect(fetchRetryCalls[0].options.body).toMatchSnapshot();
});
test(`Should call webhook for toggled environment`, async () => {
const addon = new slack_1.default({
getLogger: no_logger_1.default,
unleashUrl: 'http://some-url.com',
});
const event = {
id: 2,
createdAt: new Date(),
type: events_1.FEATURE_ENVIRONMENT_DISABLED,
createdBy: 'some@user.com',
environment: 'development',
project: 'default',
featureName: 'some-toggle',
data: {
name: 'some-toggle',
},
};
const parameters = {
url: 'http://hooks.slack.com',
};
await addon.handleEvent(event, parameters);
expect(fetchRetryCalls).toHaveLength(1);
expect(fetchRetryCalls[0].url).toBe(parameters.url);
expect(fetchRetryCalls[0].options.body).toMatch(/disabled/);
expect(fetchRetryCalls[0].options.body).toMatchSnapshot();
});
test('Should use default channel', async () => {
const addon = new slack_1.default({
getLogger: no_logger_1.default,
unleashUrl: 'http://some-url.com',
});
const event = {
id: 3,
createdAt: new Date(),
type: events_1.FEATURE_CREATED,
createdBy: 'some@user.com',
featureName: 'some-toggle',
data: {
name: 'some-toggle',
enabled: false,
strategies: [{ name: 'default' }],
},
};
const parameters = {
url: 'http://hooks.slack.com',
defaultChannel: 'some-channel',
};
await addon.handleEvent(event, parameters);
const req = JSON.parse(fetchRetryCalls[0].options.body);
expect(req.channel).toBe('#some-channel');
});
test('Should override default channel with data from tag', async () => {
const addon = new slack_1.default({
getLogger: no_logger_1.default,
unleashUrl: 'http://some-url.com',
});
const event = {
id: 4,
createdAt: new Date(),
type: events_1.FEATURE_CREATED,
createdBy: 'some@user.com',
featureName: 'some-toggle',
data: {
name: 'some-toggle',
enabled: false,
strategies: [{ name: 'default' }],
},
tags: [
{
type: 'slack',
value: 'another-channel',
},
],
};
const parameters = {
url: 'http://hooks.slack.com',
defaultChannel: 'some-channel',
};
await addon.handleEvent(event, parameters);
const req = JSON.parse(fetchRetryCalls[0].options.body);
expect(req.channel).toBe('#another-channel');
});
test('Should post to all channels in tags', async () => {
const addon = new slack_1.default({
getLogger: no_logger_1.default,
unleashUrl: 'http://some-url.com',
});
const event = {
id: 5,
createdAt: new Date(),
type: events_1.FEATURE_CREATED,
createdBy: 'some@user.com',
featureName: 'some-toggle',
data: {
name: 'some-toggle',
enabled: false,
strategies: [{ name: 'default' }],
},
tags: [
{
type: 'slack',
value: 'another-channel-1',
},
{
type: 'slack',
value: 'another-channel-2',
},
],
};
const parameters = {
url: 'http://hooks.slack.com',
defaultChannel: 'some-channel',
};
await addon.handleEvent(event, parameters);
const req1 = JSON.parse(fetchRetryCalls[0].options.body);
const req2 = JSON.parse(fetchRetryCalls[1].options.body);
expect(fetchRetryCalls).toHaveLength(2);
expect(req1.channel).toBe('#another-channel-1');
expect(req2.channel).toBe('#another-channel-2');
});
//# sourceMappingURL=slack.test.js.map