forked from Expensify/App
-
Notifications
You must be signed in to change notification settings - Fork 0
/
deployBlocker.test.js
159 lines (149 loc) · 7.07 KB
/
deployBlocker.test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
const path = require('path');
const kieMockGithub = require('@kie/mock-github');
const utils = require('./utils/utils');
const assertions = require('./assertions/deployBlockerAssertions');
const mocks = require('./mocks/deployBlockerMocks');
const eAct = require('./utils/ExtendedAct');
jest.setTimeout(90 * 1000);
let mockGithub;
const FILES_TO_COPY_INTO_TEST_REPO = [
...utils.deepCopy(utils.FILES_TO_COPY_INTO_TEST_REPO),
{
src: path.resolve(__dirname, '..', '.github', 'workflows', 'deployBlocker.yml'),
dest: '.github/workflows/deployBlocker.yml',
},
];
describe('test workflow deployBlocker', () => {
const githubToken = 'dummy_github_token';
const actor = 'Dummy Author';
const secrets = {
OS_BOTIFY_TOKEN: 'dummy_osbotify_token',
SLACK_WEBHOOK: 'dummy_slack_webhook',
};
beforeAll(async () => {
// in case of the tests being interrupted without cleanup the mock repo directory may be left behind
// which breaks the next test run, this removes any possible leftovers
utils.removeMockRepoDir();
});
beforeEach(async () => {
// create a local repository and copy required files
mockGithub = new kieMockGithub.MockGithub({
repo: {
testDeployBlockerWorkflowRepo: {
files: FILES_TO_COPY_INTO_TEST_REPO,
// if any branches besides main are need add: pushedBranches: ['staging', 'production'],
},
},
});
await mockGithub.setup();
});
afterEach(async () => {
await mockGithub.teardown();
});
describe('issue labeled', () => {
const event = 'issues';
const eventOptions = {
action: 'labeled',
label: {
name: 'DeployBlockerCash',
},
issue: {
title: 'Labeled issue title',
number: '1234',
html_url: 'http://issue.html.url',
},
};
describe('label is DeployBlockerCash', () => {
const testEventOptions = utils.deepCopy(eventOptions);
testEventOptions.label = {name: 'DeployBlockerCash'};
it('runs the workflow and announces success on Slack', async () => {
const repoPath = mockGithub.repo.getPath('testDeployBlockerWorkflowRepo') || '';
const workflowPath = path.join(repoPath, '.github', 'workflows', 'deployBlocker.yml');
let act = new eAct.ExtendedAct(repoPath, workflowPath);
act = utils.setUpActParams(act, event, testEventOptions, secrets, githubToken, {}, {});
const testMockSteps = {
deployBlocker: mocks.DEPLOYBLOCKER__DEPLOYBLOCKER__STEP_MOCKS,
};
const testMockJobs = {
updateChecklist: {
steps: mocks.DEPLOYBLOCKER__UPDATECHECKLIST__STEP_MOCKS,
runsOn: 'ubuntu-latest',
},
};
const result = await act.runEvent(event, {
workflowFile: path.join(repoPath, '.github', 'workflows', 'deployBlocker.yml'),
mockSteps: testMockSteps,
actor,
logFile: utils.getLogFilePath('deployBlocker', expect.getState().currentTestName),
mockJobs: testMockJobs,
});
assertions.assertUpdateChecklistJobExecuted(result);
assertions.assertDeployBlockerJobExecuted(result);
});
describe('one step fails', () => {
it('announces failure on Slack', async () => {
const repoPath = mockGithub.repo.getPath('testDeployBlockerWorkflowRepo') || '';
const workflowPath = path.join(repoPath, '.github', 'workflows', 'deployBlocker.yml');
let act = new eAct.ExtendedAct(repoPath, workflowPath);
act = utils.setUpActParams(act, event, testEventOptions, secrets, githubToken, {}, {});
const testMockSteps = {
deployBlocker: utils.deepCopy(mocks.DEPLOYBLOCKER__DEPLOYBLOCKER__STEP_MOCKS),
};
testMockSteps.deployBlocker[1] = utils.createMockStep(
'Give the issue/PR the Hourly, Engineering labels',
'Give the issue/PR the Hourly, Engineering labels',
'DEPLOYBLOCKER',
[],
['GITHUB_TOKEN'],
null,
null,
false,
);
const testMockJobs = {
updateChecklist: {
steps: mocks.DEPLOYBLOCKER__UPDATECHECKLIST__STEP_MOCKS,
runsOn: 'ubuntu-latest',
},
};
const result = await act.runEvent(event, {
workflowFile: path.join(repoPath, '.github', 'workflows', 'deployBlocker.yml'),
mockSteps: testMockSteps,
actor,
logFile: utils.getLogFilePath('deployBlocker', expect.getState().currentTestName),
mockJobs: testMockJobs,
});
assertions.assertUpdateChecklistJobExecuted(result);
assertions.assertDeployBlockerJobExecuted(result, true, false, 1);
});
});
});
describe('label is different', () => {
const testEventOptions = utils.deepCopy(eventOptions);
testEventOptions.label = {name: 'Different Label'};
it('does not run workflow', async () => {
const repoPath = mockGithub.repo.getPath('testDeployBlockerWorkflowRepo') || '';
const workflowPath = path.join(repoPath, '.github', 'workflows', 'deployBlocker.yml');
let act = new eAct.ExtendedAct(repoPath, workflowPath);
act = utils.setUpActParams(act, event, testEventOptions, secrets, githubToken, {}, {});
const testMockSteps = {
deployBlocker: mocks.DEPLOYBLOCKER__DEPLOYBLOCKER__STEP_MOCKS,
};
const testMockJobs = {
updateChecklist: {
steps: mocks.DEPLOYBLOCKER__UPDATECHECKLIST__STEP_MOCKS,
runsOn: 'ubuntu-latest',
},
};
const result = await act.runEvent(event, {
workflowFile: path.join(repoPath, '.github', 'workflows', 'deployBlocker.yml'),
mockSteps: testMockSteps,
actor,
logFile: utils.getLogFilePath('deployBlocker', expect.getState().currentTestName),
mockJobs: testMockJobs,
});
assertions.assertUpdateChecklistJobExecuted(result, false);
assertions.assertDeployBlockerJobExecuted(result, false);
});
});
});
});