2021-10-07 10:22:20 +02:00
|
|
|
import {
|
|
|
|
FEATURE_ARCHIVED,
|
|
|
|
FEATURE_CREATED,
|
|
|
|
FEATURE_ENVIRONMENT_DISABLED,
|
2021-11-12 13:15:51 +01:00
|
|
|
IEvent,
|
2021-10-07 10:22:20 +02:00
|
|
|
} from '../types/events';
|
2021-08-12 15:04:37 +02:00
|
|
|
import { Logger } from '../logger';
|
|
|
|
|
|
|
|
import DatadogAddon from './datadog';
|
|
|
|
|
|
|
|
import noLogger from '../../test/fixtures/no-logger';
|
|
|
|
|
|
|
|
let fetchRetryCalls: any[] = [];
|
2021-05-03 22:08:14 +02:00
|
|
|
|
2021-05-28 11:10:24 +02:00
|
|
|
jest.mock(
|
|
|
|
'./addon',
|
|
|
|
() =>
|
|
|
|
class Addon {
|
2021-08-12 15:04:37 +02:00
|
|
|
logger: Logger;
|
|
|
|
|
2021-05-28 11:10:24 +02:00
|
|
|
constructor(definition, { getLogger }) {
|
|
|
|
this.logger = getLogger('addon/test');
|
2021-08-12 15:04:37 +02:00
|
|
|
fetchRetryCalls = [];
|
2021-05-28 11:10:24 +02:00
|
|
|
}
|
2021-05-03 22:08:14 +02:00
|
|
|
|
2021-05-28 11:10:24 +02:00
|
|
|
async fetchRetry(url, options, retries, backoff) {
|
2021-08-12 15:04:37 +02:00
|
|
|
fetchRetryCalls.push({
|
|
|
|
url,
|
|
|
|
options,
|
|
|
|
retries,
|
|
|
|
backoff,
|
|
|
|
});
|
2021-05-28 11:10:24 +02:00
|
|
|
return Promise.resolve({ status: 200 });
|
|
|
|
}
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
test('Should call datadog webhook', async () => {
|
2021-05-03 22:08:14 +02:00
|
|
|
const addon = new DatadogAddon({
|
|
|
|
getLogger: noLogger,
|
|
|
|
unleashUrl: 'http://some-url.com',
|
2023-09-19 13:08:10 +02:00
|
|
|
flagResolver: {
|
|
|
|
getAll: jest.fn().mockReturnValue([]),
|
|
|
|
getVariant: jest.fn(),
|
|
|
|
isEnabled: jest.fn().mockReturnValue(false),
|
|
|
|
},
|
2021-05-03 22:08:14 +02:00
|
|
|
});
|
2021-08-12 15:04:37 +02:00
|
|
|
const event: IEvent = {
|
|
|
|
id: 1,
|
|
|
|
createdAt: new Date(),
|
2021-05-03 22:08:14 +02:00
|
|
|
type: FEATURE_CREATED,
|
|
|
|
createdBy: 'some@user.com',
|
2021-11-12 13:15:51 +01:00
|
|
|
featureName: 'some-toggle',
|
2021-05-03 22:08:14 +02:00
|
|
|
data: {
|
|
|
|
name: 'some-toggle',
|
|
|
|
enabled: false,
|
|
|
|
strategies: [{ name: 'default' }],
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const parameters = {
|
|
|
|
url: 'http://api.datadoghq.com/api/v1/events',
|
2023-07-05 09:42:17 +02:00
|
|
|
apiKey: 'fakeKey',
|
2021-05-03 22:08:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
await addon.handleEvent(event, parameters);
|
2021-08-12 15:04:37 +02:00
|
|
|
expect(fetchRetryCalls.length).toBe(1);
|
|
|
|
expect(fetchRetryCalls[0].url).toBe(parameters.url);
|
|
|
|
expect(fetchRetryCalls[0].options.body).toMatchSnapshot();
|
2021-05-03 22:08:14 +02:00
|
|
|
});
|
|
|
|
|
2021-10-07 10:22:20 +02:00
|
|
|
test('Should call datadog webhook for archived toggle', async () => {
|
2021-05-03 22:08:14 +02:00
|
|
|
const addon = new DatadogAddon({
|
|
|
|
getLogger: noLogger,
|
|
|
|
unleashUrl: 'http://some-url.com',
|
2023-09-19 13:08:10 +02:00
|
|
|
flagResolver: {
|
|
|
|
getAll: jest.fn().mockReturnValue([]),
|
|
|
|
getVariant: jest.fn(),
|
|
|
|
isEnabled: jest.fn().mockReturnValue(false),
|
|
|
|
},
|
2021-05-03 22:08:14 +02:00
|
|
|
});
|
2021-08-12 15:04:37 +02:00
|
|
|
const event: IEvent = {
|
|
|
|
id: 2,
|
|
|
|
createdAt: new Date(),
|
2021-05-03 22:08:14 +02:00
|
|
|
type: FEATURE_ARCHIVED,
|
|
|
|
createdBy: 'some@user.com',
|
2021-11-12 13:15:51 +01:00
|
|
|
featureName: 'some-toggle',
|
2021-05-03 22:08:14 +02:00
|
|
|
data: {
|
|
|
|
name: 'some-toggle',
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const parameters = {
|
|
|
|
url: 'http://api.datadoghq.com/api/v1/events',
|
2023-07-05 09:42:17 +02:00
|
|
|
apiKey: 'fakeKey',
|
2021-05-03 22:08:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
await addon.handleEvent(event, parameters);
|
2021-08-12 15:04:37 +02:00
|
|
|
expect(fetchRetryCalls.length).toBe(1);
|
2022-10-05 11:30:51 +02:00
|
|
|
expect(fetchRetryCalls[0].url).toBe(parameters.url);
|
|
|
|
expect(fetchRetryCalls[0].options.body).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Should call datadog webhook for archived toggle with project info', async () => {
|
|
|
|
const addon = new DatadogAddon({
|
|
|
|
getLogger: noLogger,
|
|
|
|
unleashUrl: 'http://some-url.com',
|
2023-09-19 13:08:10 +02:00
|
|
|
flagResolver: {
|
|
|
|
getAll: jest.fn().mockReturnValue([]),
|
|
|
|
getVariant: jest.fn(),
|
|
|
|
isEnabled: jest.fn().mockReturnValue(false),
|
|
|
|
},
|
2022-10-05 11:30:51 +02:00
|
|
|
});
|
|
|
|
const event: IEvent = {
|
|
|
|
id: 2,
|
|
|
|
createdAt: new Date(),
|
|
|
|
type: FEATURE_ARCHIVED,
|
|
|
|
createdBy: 'some@user.com',
|
|
|
|
featureName: 'some-toggle',
|
|
|
|
project: 'some-project',
|
|
|
|
data: {
|
|
|
|
name: 'some-toggle',
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const parameters = {
|
|
|
|
url: 'http://api.datadoghq.com/api/v1/events',
|
2023-07-05 09:42:17 +02:00
|
|
|
apiKey: 'fakeKey',
|
2022-10-05 11:30:51 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
await addon.handleEvent(event, parameters);
|
|
|
|
expect(fetchRetryCalls.length).toBe(1);
|
2021-08-12 15:04:37 +02:00
|
|
|
expect(fetchRetryCalls[0].url).toBe(parameters.url);
|
|
|
|
expect(fetchRetryCalls[0].options.body).toMatchSnapshot();
|
2021-05-03 22:08:14 +02:00
|
|
|
});
|
2021-10-07 10:22:20 +02:00
|
|
|
|
2023-09-29 14:18:21 +02:00
|
|
|
test('Should call datadog webhook for toggled environment', async () => {
|
2021-10-07 10:22:20 +02:00
|
|
|
const addon = new DatadogAddon({
|
|
|
|
getLogger: noLogger,
|
|
|
|
unleashUrl: 'http://some-url.com',
|
2023-09-19 13:08:10 +02:00
|
|
|
flagResolver: {
|
|
|
|
getAll: jest.fn().mockReturnValue([]),
|
|
|
|
getVariant: jest.fn(),
|
|
|
|
isEnabled: jest.fn().mockReturnValue(false),
|
|
|
|
},
|
2021-10-07 10:22:20 +02:00
|
|
|
});
|
|
|
|
const event: IEvent = {
|
|
|
|
id: 2,
|
|
|
|
createdAt: new Date(),
|
|
|
|
type: FEATURE_ENVIRONMENT_DISABLED,
|
|
|
|
createdBy: 'some@user.com',
|
|
|
|
environment: 'development',
|
|
|
|
project: 'default',
|
2021-11-12 13:15:51 +01:00
|
|
|
featureName: 'some-toggle',
|
2021-10-07 10:22:20 +02:00
|
|
|
data: {
|
|
|
|
name: 'some-toggle',
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const parameters = {
|
|
|
|
url: 'http://hooks.slack.com',
|
2023-07-05 09:42:17 +02:00
|
|
|
apiKey: 'fakeKey',
|
2021-10-07 10:22:20 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
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();
|
|
|
|
});
|
2023-07-05 09:42:17 +02:00
|
|
|
|
2023-09-29 14:18:21 +02:00
|
|
|
test('Should include customHeaders in headers when calling service', async () => {
|
2023-07-05 09:42:17 +02:00
|
|
|
const addon = new DatadogAddon({
|
|
|
|
getLogger: noLogger,
|
|
|
|
unleashUrl: 'http://some-url.com',
|
2023-09-19 13:08:10 +02:00
|
|
|
flagResolver: {
|
|
|
|
getAll: jest.fn().mockReturnValue([]),
|
|
|
|
getVariant: jest.fn(),
|
|
|
|
isEnabled: jest.fn().mockReturnValue(false),
|
|
|
|
},
|
2023-07-05 09:42:17 +02:00
|
|
|
});
|
|
|
|
const event: IEvent = {
|
|
|
|
id: 2,
|
|
|
|
createdAt: new Date(),
|
|
|
|
type: 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',
|
|
|
|
apiKey: 'fakeKey',
|
|
|
|
customHeaders: `{ "MY_CUSTOM_HEADER": "MY_CUSTOM_VALUE" }`,
|
|
|
|
};
|
|
|
|
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();
|
|
|
|
expect(fetchRetryCalls[0].options.headers).toMatchSnapshot();
|
|
|
|
});
|
2023-07-10 15:38:53 +02:00
|
|
|
|
2023-09-29 14:18:21 +02:00
|
|
|
test('Should not include source_type_name when included in the config', async () => {
|
2023-07-10 15:38:53 +02:00
|
|
|
const addon = new DatadogAddon({
|
|
|
|
getLogger: noLogger,
|
|
|
|
unleashUrl: 'http://some-url.com',
|
2023-09-19 13:08:10 +02:00
|
|
|
flagResolver: {
|
|
|
|
getAll: jest.fn().mockReturnValue([]),
|
|
|
|
getVariant: jest.fn(),
|
|
|
|
isEnabled: jest.fn().mockReturnValue(false),
|
|
|
|
},
|
2023-07-10 15:38:53 +02:00
|
|
|
});
|
|
|
|
const event: IEvent = {
|
|
|
|
id: 2,
|
|
|
|
createdAt: new Date(),
|
|
|
|
type: 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',
|
|
|
|
apiKey: 'fakeKey',
|
|
|
|
sourceTypeName: 'my-custom-source-type',
|
|
|
|
};
|
|
|
|
|
|
|
|
await addon.handleEvent(event, parameters);
|
|
|
|
expect(fetchRetryCalls).toHaveLength(1);
|
|
|
|
expect(fetchRetryCalls[0].url).toBe(parameters.url);
|
|
|
|
expect(fetchRetryCalls[0].options.body).toMatch(
|
|
|
|
/"source_type_name":"my-custom-source-type"/,
|
|
|
|
);
|
|
|
|
expect(fetchRetryCalls[0].options.body).toMatchSnapshot();
|
|
|
|
expect(fetchRetryCalls[0].options.headers).toMatchSnapshot();
|
|
|
|
});
|
2023-09-19 13:08:10 +02:00
|
|
|
|
|
|
|
test('Should call datadog webhook with JSON when template set', async () => {
|
|
|
|
const addon = new DatadogAddon({
|
|
|
|
getLogger: noLogger,
|
|
|
|
unleashUrl: 'http://some-url.com',
|
|
|
|
flagResolver: {
|
|
|
|
getAll: jest.fn().mockReturnValue([]),
|
|
|
|
getVariant: jest.fn(),
|
|
|
|
isEnabled: jest.fn().mockReturnValue(true),
|
|
|
|
},
|
|
|
|
});
|
|
|
|
const event: IEvent = {
|
|
|
|
id: 1,
|
|
|
|
createdAt: new Date(),
|
|
|
|
type: FEATURE_CREATED,
|
|
|
|
createdBy: 'some@user.com',
|
|
|
|
featureName: 'some-toggle',
|
|
|
|
data: {
|
|
|
|
name: 'some-toggle',
|
|
|
|
enabled: false,
|
|
|
|
strategies: [{ name: 'default' }],
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const parameters = {
|
|
|
|
url: 'http://api.datadoghq.com/api/v1/events',
|
|
|
|
apiKey: 'fakeKey',
|
|
|
|
bodyTemplate:
|
|
|
|
'{\n "event": "{{event.type}}",\n "createdBy": "{{event.createdBy}}"\n}',
|
|
|
|
};
|
|
|
|
|
|
|
|
await addon.handleEvent(event, parameters);
|
|
|
|
expect(fetchRetryCalls.length).toBe(1);
|
|
|
|
expect(fetchRetryCalls[0].url).toBe(parameters.url);
|
|
|
|
expect(fetchRetryCalls[0].options.body).toMatchSnapshot();
|
|
|
|
});
|