1 | ;
|
2 | var __assign = (this && this.__assign) || function () {
|
3 | __assign = Object.assign || function(t) {
|
4 | for (var s, i = 1, n = arguments.length; i < n; i++) {
|
5 | s = arguments[i];
|
6 | for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
7 | t[p] = s[p];
|
8 | }
|
9 | return t;
|
10 | };
|
11 | return __assign.apply(this, arguments);
|
12 | };
|
13 | var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
14 | var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
15 | if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
16 | else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
17 | return c > 3 && r && Object.defineProperty(target, key, r), r;
|
18 | };
|
19 | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
20 | return new (P || (P = Promise))(function (resolve, reject) {
|
21 | function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
22 | function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
23 | function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
24 | step((generator = generator.apply(thisArg, _arguments || [])).next());
|
25 | });
|
26 | };
|
27 | var __generator = (this && this.__generator) || function (thisArg, body) {
|
28 | var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
29 | return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
30 | function verb(n) { return function (v) { return step([n, v]); }; }
|
31 | function step(op) {
|
32 | if (f) throw new TypeError("Generator is already executing.");
|
33 | while (_) try {
|
34 | if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
35 | if (y = 0, t) op = [op[0] & 2, t.value];
|
36 | switch (op[0]) {
|
37 | case 0: case 1: t = op; break;
|
38 | case 4: _.label++; return { value: op[1], done: false };
|
39 | case 5: _.label++; y = op[1]; op = [0]; continue;
|
40 | case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
41 | default:
|
42 | if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
43 | if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
44 | if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
45 | if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
46 | if (t[2]) _.ops.pop();
|
47 | _.trys.pop(); continue;
|
48 | }
|
49 | op = body.call(thisArg, _);
|
50 | } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
51 | if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
52 | }
|
53 | };
|
54 | var __read = (this && this.__read) || function (o, n) {
|
55 | var m = typeof Symbol === "function" && o[Symbol.iterator];
|
56 | if (!m) return o;
|
57 | var i = m.call(o), r, ar = [], e;
|
58 | try {
|
59 | while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
60 | }
|
61 | catch (error) { e = { error: error }; }
|
62 | finally {
|
63 | try {
|
64 | if (r && !r.done && (m = i["return"])) m.call(i);
|
65 | }
|
66 | finally { if (e) throw e.error; }
|
67 | }
|
68 | return ar;
|
69 | };
|
70 | var __spread = (this && this.__spread) || function () {
|
71 | for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));
|
72 | return ar;
|
73 | };
|
74 | var __importStar = (this && this.__importStar) || function (mod) {
|
75 | if (mod && mod.__esModule) return mod;
|
76 | var result = {};
|
77 | if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
78 | result["default"] = mod;
|
79 | return result;
|
80 | };
|
81 | var __importDefault = (this && this.__importDefault) || function (mod) {
|
82 | return (mod && mod.__esModule) ? mod : { "default": mod };
|
83 | };
|
84 | Object.defineProperty(exports, "__esModule", { value: true });
|
85 | var _a;
|
86 | var fs = __importStar(require("fs"));
|
87 | var semver_1 = require("semver");
|
88 | var util_1 = require("util");
|
89 | var typescript_memoize_1 = require("typescript-memoize");
|
90 | var changelog_1 = __importDefault(require("./changelog"));
|
91 | var log_parse_1 = __importDefault(require("./log-parse"));
|
92 | var semver_2 = __importStar(require("./semver"));
|
93 | var exec_promise_1 = __importDefault(require("./utils/exec-promise"));
|
94 | var logger_1 = require("./utils/logger");
|
95 | var make_hooks_1 = require("./utils/make-hooks");
|
96 | var slack_1 = __importDefault(require("./utils/slack"));
|
97 | exports.defaultLabels = [
|
98 | semver_2.default.major,
|
99 | semver_2.default.minor,
|
100 | semver_2.default.patch,
|
101 | 'skip-release',
|
102 | 'release',
|
103 | 'prerelease'
|
104 | ];
|
105 | exports.isVersionLabel = function (label) {
|
106 | return exports.defaultLabels.includes(label);
|
107 | };
|
108 | exports.defaultLabelDefinition = (_a = {},
|
109 | _a[semver_2.default.major] = {
|
110 | name: 'major',
|
111 | title: '💥 Breaking Change',
|
112 | description: 'Increment the major version when merged'
|
113 | },
|
114 | _a[semver_2.default.minor] = {
|
115 | name: 'minor',
|
116 | title: '🚀 Enhancement',
|
117 | description: 'Increment the minor version when merged'
|
118 | },
|
119 | _a[semver_2.default.patch] = {
|
120 | name: 'patch',
|
121 | title: '🐛 Bug Fix',
|
122 | description: 'Increment the patch version when merged'
|
123 | },
|
124 | _a['skip-release'] = {
|
125 | name: 'skip-release',
|
126 | description: 'Preserve the current version when merged'
|
127 | },
|
128 | _a.release = {
|
129 | name: 'release',
|
130 | description: 'Create a release when this pr is merged'
|
131 | },
|
132 | _a.prerelease = {
|
133 | name: 'prerelease',
|
134 | title: '🚧 Prerelease',
|
135 | description: 'Create a pre-release version when merged'
|
136 | },
|
137 | _a.internal = {
|
138 | name: 'internal',
|
139 | title: '🏠 Internal',
|
140 | description: 'Changes only affect the internal API'
|
141 | },
|
142 | _a.documentation = {
|
143 | name: 'documentation',
|
144 | title: '📝 Documentation',
|
145 | description: 'Changes only affect the documentation'
|
146 | },
|
147 | _a);
|
148 | exports.getVersionMap = function (labels) {
|
149 | if (labels === void 0) { labels = exports.defaultLabelDefinition; }
|
150 | return Object.entries(labels).reduce(function (semVer, _a) {
|
151 | var _b = __read(_a, 2), label = _b[0], labelDef = _b[1];
|
152 | if (exports.isVersionLabel(label)) {
|
153 | semVer.set(label, labelDef.name);
|
154 | }
|
155 | return semVer;
|
156 | // tslint:disable-next-line align
|
157 | }, new Map());
|
158 | };
|
159 | var readFile = util_1.promisify(fs.readFile);
|
160 | var writeFile = util_1.promisify(fs.writeFile);
|
161 | /**
|
162 | * A class for interacting with the git remote
|
163 | */
|
164 | var Release = /** @class */ (function () {
|
165 | function Release(git, options, logger) {
|
166 | if (options === void 0) { options = {
|
167 | skipReleaseLabels: [],
|
168 | labels: exports.defaultLabelDefinition
|
169 | }; }
|
170 | if (logger === void 0) { logger = logger_1.dummyLog(); }
|
171 | this.options = options;
|
172 | this.logger = logger;
|
173 | this.hooks = make_hooks_1.makeReleaseHooks();
|
174 | this.versionLabels = exports.getVersionMap(options.labels);
|
175 | this.git = git;
|
176 | }
|
177 | /**
|
178 | * Generate a changelog from a range of commits.
|
179 | *
|
180 | * @param from sha or tag to start changelog from
|
181 | * @param to sha or tag to end changelog at (defaults to HEAD)
|
182 | */
|
183 | Release.prototype.generateReleaseNotes = function (from, to) {
|
184 | if (to === void 0) { to = 'HEAD'; }
|
185 | return __awaiter(this, void 0, void 0, function () {
|
186 | var commits, project, changelog;
|
187 | return __generator(this, function (_a) {
|
188 | switch (_a.label) {
|
189 | case 0: return [4 /*yield*/, this.getCommitsInRelease(from, to)];
|
190 | case 1:
|
191 | commits = _a.sent();
|
192 | return [4 /*yield*/, this.git.getProject()];
|
193 | case 2:
|
194 | project = _a.sent();
|
195 | changelog = new changelog_1.default(this.logger, {
|
196 | owner: this.git.options.owner,
|
197 | repo: this.git.options.repo,
|
198 | baseUrl: project.html_url,
|
199 | jira: this.options.jira,
|
200 | labels: this.options.labels
|
201 | });
|
202 | this.hooks.onCreateChangelog.call(changelog);
|
203 | changelog.loadDefaultHooks();
|
204 | return [2 /*return*/, changelog.generateReleaseNotes(commits)];
|
205 | }
|
206 | });
|
207 | });
|
208 | };
|
209 | Release.prototype.getCommitsInRelease = function (from, to) {
|
210 | if (to === void 0) { to = 'HEAD'; }
|
211 | return __awaiter(this, void 0, void 0, function () {
|
212 | var allCommits, allPrCommits, allPrCommitHashes;
|
213 | var _this = this;
|
214 | return __generator(this, function (_a) {
|
215 | switch (_a.label) {
|
216 | case 0: return [4 /*yield*/, this.getCommits(from, to)];
|
217 | case 1:
|
218 | allCommits = _a.sent();
|
219 | return [4 /*yield*/, Promise.all(allCommits
|
220 | .filter(function (commit) { return commit.pullRequest; })
|
221 | .map(function (commit) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
|
222 | return [2 /*return*/, this.git.getCommitsForPR(Number(commit.pullRequest.number))];
|
223 | }); }); }))];
|
224 | case 2:
|
225 | allPrCommits = _a.sent();
|
226 | allPrCommitHashes = allPrCommits
|
227 | .filter(Boolean)
|
228 | .reduce(function (all, pr) { return __spread(all, pr.map(function (subCommit) { return subCommit.sha; })); }, []);
|
229 | return [2 /*return*/, allCommits
|
230 | .filter(function (commit) {
|
231 | return !allPrCommitHashes.includes(commit.hash) &&
|
232 | !commit.subject.includes('[skip ci]');
|
233 | })
|
234 | .map(function (commit) {
|
235 | if (commit.pullRequest) {
|
236 | return commit;
|
237 | }
|
238 | commit.labels = __spread(['pushToMaster'], commit.labels);
|
239 | return commit;
|
240 | })];
|
241 | }
|
242 | });
|
243 | });
|
244 | };
|
245 | /**
|
246 | * Prepend a set of release notes to the changelog.md
|
247 | *
|
248 | * @param releaseNotes Release notes to prepend to the changelog
|
249 | * @param lastRelease Last release version of the code. Could be the first commit SHA
|
250 | * @param currentVersion Current version of the code
|
251 | * @param message Message to commit the changelog with
|
252 | */
|
253 | Release.prototype.addToChangelog = function (releaseNotes, lastRelease, currentVersion, message) {
|
254 | if (message === void 0) { message = 'Update CHANGELOG.md [skip ci]'; }
|
255 | return __awaiter(this, void 0, void 0, function () {
|
256 | var version, bump, date, prefixed, newChangelog, oldChangelog;
|
257 | return __generator(this, function (_a) {
|
258 | switch (_a.label) {
|
259 | case 0:
|
260 | this.logger.verbose.info('Adding new changes to changelog.');
|
261 | if (!lastRelease.match(/\d+\.\d+\.\d+/)) return [3 /*break*/, 2];
|
262 | return [4 /*yield*/, this.calcNextVersion(lastRelease)];
|
263 | case 1:
|
264 | version = _a.sent();
|
265 | return [3 /*break*/, 4];
|
266 | case 2: return [4 /*yield*/, this.getSemverBump(lastRelease)];
|
267 | case 3:
|
268 | bump = _a.sent();
|
269 | version = semver_1.inc(currentVersion, bump);
|
270 | _a.label = 4;
|
271 | case 4:
|
272 | this.logger.verbose.info('Calculated next version to be:', version);
|
273 | date = new Date().toDateString();
|
274 | prefixed = this.options.noVersionPrefix || (version && version.startsWith('v'))
|
275 | ? version
|
276 | : "v" + version;
|
277 | newChangelog = "# " + prefixed + " (" + date + ")\n\n" + releaseNotes;
|
278 | if (!fs.existsSync('CHANGELOG.md')) return [3 /*break*/, 6];
|
279 | this.logger.verbose.info('Old changelog exists, prepending changes.');
|
280 | return [4 /*yield*/, readFile('CHANGELOG.md', 'utf8')];
|
281 | case 5:
|
282 | oldChangelog = _a.sent();
|
283 | newChangelog = newChangelog + "\n\n---\n\n" + oldChangelog;
|
284 | _a.label = 6;
|
285 | case 6: return [4 /*yield*/, writeFile('CHANGELOG.md', newChangelog)];
|
286 | case 7:
|
287 | _a.sent();
|
288 | this.logger.verbose.info('Wrote new changelog to filesystem.');
|
289 | return [4 /*yield*/, exec_promise_1.default('git', ['add', 'CHANGELOG.md'])];
|
290 | case 8:
|
291 | _a.sent();
|
292 | return [4 /*yield*/, exec_promise_1.default('git', ['commit', '-m', "\"" + message + "\"", '--no-verify'])];
|
293 | case 9:
|
294 | _a.sent();
|
295 | this.logger.verbose.info('Commited new changelog.');
|
296 | return [2 /*return*/];
|
297 | }
|
298 | });
|
299 | });
|
300 | };
|
301 | /**
|
302 | * Get a range of commits. The commits will have PR numbers and labels attached
|
303 | *
|
304 | * @param from Tag or SHA to start at
|
305 | * @param to Tage or SHA to end at (defaults to HEAD)
|
306 | */
|
307 | Release.prototype.getCommits = function (from, to) {
|
308 | if (to === void 0) { to = 'HEAD'; }
|
309 | return __awaiter(this, void 0, void 0, function () {
|
310 | var gitlog, logParse, commits;
|
311 | var _this = this;
|
312 | return __generator(this, function (_a) {
|
313 | switch (_a.label) {
|
314 | case 0:
|
315 | this.logger.verbose.info("Getting commits from " + from + " to " + to);
|
316 | return [4 /*yield*/, this.git.getGitLog(from, to)];
|
317 | case 1:
|
318 | gitlog = _a.sent();
|
319 | this.logger.veryVerbose.info('Got gitlog:\n', gitlog);
|
320 | return [4 /*yield*/, this.createLogParse()];
|
321 | case 2:
|
322 | logParse = _a.sent();
|
323 | return [4 /*yield*/, logParse.normalizeCommits(gitlog)];
|
324 | case 3:
|
325 | commits = _a.sent();
|
326 | this.logger.veryVerbose.info('Added labels to commits:\n', commits);
|
327 | return [4 /*yield*/, Promise.all(commits.map(function (commit) { return __awaiter(_this, void 0, void 0, function () {
|
328 | var resolvedAuthors, prCommits, author;
|
329 | var _this = this;
|
330 | return __generator(this, function (_a) {
|
331 | switch (_a.label) {
|
332 | case 0:
|
333 | resolvedAuthors = [];
|
334 | if (!commit.pullRequest) return [3 /*break*/, 3];
|
335 | return [4 /*yield*/, this.git.getCommitsForPR(Number(commit.pullRequest.number))];
|
336 | case 1:
|
337 | prCommits = _a.sent();
|
338 | if (!prCommits) {
|
339 | return [2 /*return*/];
|
340 | }
|
341 | return [4 /*yield*/, Promise.all(prCommits.map(function (prCommit) { return __awaiter(_this, void 0, void 0, function () {
|
342 | return __generator(this, function (_a) {
|
343 | if (prCommit && prCommit.author) {
|
344 | return [2 /*return*/, this.git.getUserByUsername(prCommit.author.login)];
|
345 | }
|
346 | return [2 /*return*/];
|
347 | });
|
348 | }); }))];
|
349 | case 2:
|
350 | resolvedAuthors = _a.sent();
|
351 | return [3 /*break*/, 5];
|
352 | case 3:
|
353 | if (!commit.authorEmail) return [3 /*break*/, 5];
|
354 | return [4 /*yield*/, this.git.getUserByEmail(commit.authorEmail)];
|
355 | case 4:
|
356 | author = _a.sent();
|
357 | resolvedAuthors.push(author);
|
358 | _a.label = 5;
|
359 | case 5:
|
360 | commit.authors = resolvedAuthors.map(function (author) { return (__assign({}, author, { username: author ? author.login : undefined })); });
|
361 | commit.authors.map(function (author) {
|
362 | _this.logger.veryVerbose.info("Found author: " + author.username);
|
363 | });
|
364 | return [2 /*return*/];
|
365 | }
|
366 | });
|
367 | }); }))];
|
368 | case 4:
|
369 | _a.sent();
|
370 | return [2 /*return*/, commits];
|
371 | }
|
372 | });
|
373 | });
|
374 | };
|
375 | Release.prototype.addLabelsToProject = function (labels, options) {
|
376 | if (options === void 0) { options = {}; }
|
377 | return __awaiter(this, void 0, void 0, function () {
|
378 | var oldLabels, labelsToCreate, repoMetadata, justLabelNames, state, state;
|
379 | var _this = this;
|
380 | return __generator(this, function (_a) {
|
381 | switch (_a.label) {
|
382 | case 0: return [4 /*yield*/, this.git.getProjectLabels()];
|
383 | case 1:
|
384 | oldLabels = _a.sent();
|
385 | labelsToCreate = Object.entries(labels).filter(function (_a) {
|
386 | var _b = __read(_a, 2), versionLabel = _b[0], labelDef = _b[1];
|
387 | if (!labelDef) {
|
388 | return;
|
389 | }
|
390 | if (oldLabels && oldLabels.includes(labelDef.name)) {
|
391 | return;
|
392 | }
|
393 | if (versionLabel === 'release' &&
|
394 | !_this.options.onlyPublishWithReleaseLabel) {
|
395 | return;
|
396 | }
|
397 | if (versionLabel === 'skip-release' &&
|
398 | _this.options.onlyPublishWithReleaseLabel) {
|
399 | return;
|
400 | }
|
401 | return true;
|
402 | });
|
403 | if (!!options.dryRun) return [3 /*break*/, 3];
|
404 | return [4 /*yield*/, Promise.all(labelsToCreate.map(function (_a) {
|
405 | var _b = __read(_a, 2), versionLabel = _b[0], labelDef = _b[1];
|
406 | return __awaiter(_this, void 0, void 0, function () {
|
407 | return __generator(this, function (_c) {
|
408 | switch (_c.label) {
|
409 | case 0:
|
410 | if (!labelDef) {
|
411 | return [2 /*return*/];
|
412 | }
|
413 | return [4 /*yield*/, this.git.createLabel(versionLabel, labelDef)];
|
414 | case 1:
|
415 | _c.sent();
|
416 | return [2 /*return*/];
|
417 | }
|
418 | });
|
419 | });
|
420 | }))];
|
421 | case 2:
|
422 | _a.sent();
|
423 | _a.label = 3;
|
424 | case 3: return [4 /*yield*/, this.git.getProject()];
|
425 | case 4:
|
426 | repoMetadata = _a.sent();
|
427 | justLabelNames = labelsToCreate.map(function (_a) {
|
428 | var _b = __read(_a, 1), name = _b[0];
|
429 | return name;
|
430 | });
|
431 | if (justLabelNames.length > 0) {
|
432 | state = options.dryRun ? 'Would have created' : 'Created';
|
433 | this.logger.log.log(state + " labels: " + justLabelNames.join(', '));
|
434 | }
|
435 | else {
|
436 | state = options.dryRun ? 'would have been' : 'were';
|
437 | this.logger.log.log("No labels " + state + " created, they must have already been present on your project.");
|
438 | }
|
439 | if (!options.dryRun) {
|
440 | this.logger.log.log("\nYou can see these, and more at " + repoMetadata.html_url + "/labels");
|
441 | }
|
442 | return [2 /*return*/];
|
443 | }
|
444 | });
|
445 | });
|
446 | };
|
447 | /**
|
448 | * Calculate the SEMVER bump over a range of commits using the PR labels
|
449 | *
|
450 | * @param from Tag or SHA to start at
|
451 | * @param to Tage or SHA to end at (defaults to HEAD)
|
452 | */
|
453 | Release.prototype.getSemverBump = function (from, to) {
|
454 | if (to === void 0) { to = 'HEAD'; }
|
455 | return __awaiter(this, void 0, void 0, function () {
|
456 | var commits, labels, _a, onlyPublishWithReleaseLabel, skipReleaseLabels, options, result;
|
457 | return __generator(this, function (_b) {
|
458 | switch (_b.label) {
|
459 | case 0: return [4 /*yield*/, this.getCommits(from, to)];
|
460 | case 1:
|
461 | commits = _b.sent();
|
462 | labels = commits.map(function (commit) { return commit.labels; });
|
463 | _a = this.options, onlyPublishWithReleaseLabel = _a.onlyPublishWithReleaseLabel, skipReleaseLabels = _a.skipReleaseLabels;
|
464 | options = { onlyPublishWithReleaseLabel: onlyPublishWithReleaseLabel, skipReleaseLabels: skipReleaseLabels };
|
465 | this.logger.verbose.info('Calculating SEMVER bump using:\n', {
|
466 | labels: labels,
|
467 | versionLabels: this.versionLabels,
|
468 | options: options
|
469 | });
|
470 | result = semver_2.calculateSemVerBump(labels, this.versionLabels, options);
|
471 | this.logger.verbose.success('Calculated SEMVER bump:', result);
|
472 | return [2 /*return*/, result];
|
473 | }
|
474 | });
|
475 | });
|
476 | };
|
477 | /**
|
478 | * Post the release notes to slack.
|
479 | *
|
480 | * @param releaseNotes Release notes to post to slack
|
481 | * @param tag Version to include in the title of the slack message
|
482 | */
|
483 | Release.prototype.postToSlack = function (releaseNotes, tag) {
|
484 | return __awaiter(this, void 0, void 0, function () {
|
485 | var project;
|
486 | return __generator(this, function (_a) {
|
487 | switch (_a.label) {
|
488 | case 0:
|
489 | if (!this.options.slack) {
|
490 | throw new Error('Slack url must be set to post a message to slack.');
|
491 | }
|
492 | return [4 /*yield*/, this.git.getProject()];
|
493 | case 1:
|
494 | project = _a.sent();
|
495 | this.logger.verbose.info('Posting release notes to slack.');
|
496 | return [4 /*yield*/, slack_1.default(releaseNotes, {
|
497 | tag: tag,
|
498 | owner: this.git.options.owner,
|
499 | repo: this.git.options.repo,
|
500 | baseUrl: project.html_url,
|
501 | slackUrl: this.options.slack
|
502 | })];
|
503 | case 2:
|
504 | _a.sent();
|
505 | this.logger.verbose.info('Posted release notes to slack.');
|
506 | return [2 /*return*/];
|
507 | }
|
508 | });
|
509 | });
|
510 | };
|
511 | Release.prototype.calcNextVersion = function (lastTag) {
|
512 | return __awaiter(this, void 0, void 0, function () {
|
513 | var bump;
|
514 | return __generator(this, function (_a) {
|
515 | switch (_a.label) {
|
516 | case 0: return [4 /*yield*/, this.getSemverBump(lastTag)];
|
517 | case 1:
|
518 | bump = _a.sent();
|
519 | return [2 /*return*/, semver_1.inc(lastTag, bump)];
|
520 | }
|
521 | });
|
522 | });
|
523 | };
|
524 | Release.prototype.createLogParse = function () {
|
525 | return __awaiter(this, void 0, void 0, function () {
|
526 | var logParse;
|
527 | var _this = this;
|
528 | return __generator(this, function (_a) {
|
529 | logParse = new log_parse_1.default();
|
530 | logParse.hooks.parseCommit.tapPromise('Labels', function (commit) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
|
531 | return [2 /*return*/, this.addLabelsToCommit(commit)];
|
532 | }); }); });
|
533 | logParse.hooks.parseCommit.tapPromise('PR Commits', function (commit) { return __awaiter(_this, void 0, void 0, function () {
|
534 | var prsSinceLastRelease;
|
535 | return __generator(this, function (_a) {
|
536 | switch (_a.label) {
|
537 | case 0: return [4 /*yield*/, this.getPRsSinceLastRelease()];
|
538 | case 1:
|
539 | prsSinceLastRelease = _a.sent();
|
540 | return [2 /*return*/, this.getPRForRebasedCommits(commit, prsSinceLastRelease)];
|
541 | }
|
542 | });
|
543 | }); });
|
544 | this.hooks.onCreateLogParse.call(logParse);
|
545 | return [2 /*return*/, logParse];
|
546 | });
|
547 | });
|
548 | };
|
549 | Release.prototype.getPRsSinceLastRelease = function () {
|
550 | return __awaiter(this, void 0, void 0, function () {
|
551 | var lastRelease, error_1, firstCommit, _a, prsSinceLastRelease, data;
|
552 | var _this = this;
|
553 | return __generator(this, function (_b) {
|
554 | switch (_b.label) {
|
555 | case 0:
|
556 | _b.trys.push([0, 2, , 5]);
|
557 | return [4 /*yield*/, this.git.getLatestReleaseInfo()];
|
558 | case 1:
|
559 | lastRelease = _b.sent();
|
560 | return [3 /*break*/, 5];
|
561 | case 2:
|
562 | error_1 = _b.sent();
|
563 | return [4 /*yield*/, this.git.getFirstCommit()];
|
564 | case 3:
|
565 | firstCommit = _b.sent();
|
566 | _a = {};
|
567 | return [4 /*yield*/, this.git.getCommitDate(firstCommit)];
|
568 | case 4:
|
569 | lastRelease = (_a.published_at = _b.sent(),
|
570 | _a);
|
571 | return [3 /*break*/, 5];
|
572 | case 5:
|
573 | if (!lastRelease) {
|
574 | return [2 /*return*/, []];
|
575 | }
|
576 | return [4 /*yield*/, this.git.searchRepo({
|
577 | q: "is:pr is:merged merged:>=" + lastRelease.published_at
|
578 | })];
|
579 | case 6:
|
580 | prsSinceLastRelease = _b.sent();
|
581 | if (!prsSinceLastRelease || !prsSinceLastRelease.items) {
|
582 | return [2 /*return*/, []];
|
583 | }
|
584 | return [4 /*yield*/, Promise.all(prsSinceLastRelease.items.map(function (pr) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
|
585 | return [2 /*return*/, this.git.getPullRequest(Number(pr.number))];
|
586 | }); }); }))];
|
587 | case 7:
|
588 | data = _b.sent();
|
589 | return [2 /*return*/, data.map(function (item) { return item.data; })];
|
590 | }
|
591 | });
|
592 | });
|
593 | };
|
594 | /**
|
595 | * Add the PR labels to the commit
|
596 | *
|
597 | * @param commits Commits to modify
|
598 | */
|
599 | Release.prototype.addLabelsToCommit = function (commit) {
|
600 | return __awaiter(this, void 0, void 0, function () {
|
601 | var labels;
|
602 | return __generator(this, function (_a) {
|
603 | switch (_a.label) {
|
604 | case 0:
|
605 | if (!commit.labels) {
|
606 | commit.labels = [];
|
607 | }
|
608 | if (!commit.pullRequest) return [3 /*break*/, 2];
|
609 | return [4 /*yield*/, this.git.getLabels(commit.pullRequest.number)];
|
610 | case 1:
|
611 | labels = (_a.sent()) || [];
|
612 | commit.labels = __spread(labels, commit.labels);
|
613 | _a.label = 2;
|
614 | case 2: return [2 /*return*/, commit];
|
615 | }
|
616 | });
|
617 | });
|
618 | };
|
619 | /**
|
620 | * Commits from rebased PRs do not have messages that tie them to a PR
|
621 | * Instead we have to find all PRs since the last release and try to match
|
622 | * their merge commit SHAs.
|
623 | *
|
624 | * @param commits Commits to modify
|
625 | */
|
626 | Release.prototype.getPRForRebasedCommits = function (commit, pullRequests) {
|
627 | var matchPr = pullRequests.find(function (pr) { return pr.merge_commit_sha === commit.hash; });
|
628 | if (!commit.pullRequest && matchPr) {
|
629 | var labels = matchPr.labels.map(function (label) { return label.name; }) || [];
|
630 | commit.labels = __spread(labels, commit.labels);
|
631 | commit.pullRequest = {
|
632 | number: matchPr.number
|
633 | };
|
634 | }
|
635 | return commit;
|
636 | };
|
637 | __decorate([
|
638 | typescript_memoize_1.Memoize()
|
639 | ], Release.prototype, "createLogParse", null);
|
640 | __decorate([
|
641 | typescript_memoize_1.Memoize()
|
642 | ], Release.prototype, "getPRsSinceLastRelease", null);
|
643 | return Release;
|
644 | }());
|
645 | exports.default = Release;
|
646 | //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsZWFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9yZWxlYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSxxQ0FBeUI7QUFDekIsaUNBQTBDO0FBQzFDLDZCQUFpQztBQUdqQyx5REFBNkM7QUFDN0MsMERBQW9DO0FBR3BDLDBEQUF3RDtBQUN4RCxpREFBdUQ7QUFDdkQsc0VBQStDO0FBQy9DLHlDQUFtRDtBQUNuRCxpREFBc0Q7QUFDdEQsd0RBQXdDO0FBVTNCLFFBQUEsYUFBYSxHQUFtQjtJQUMzQyxnQkFBTSxDQUFDLEtBQUs7SUFDWixnQkFBTSxDQUFDLEtBQUs7SUFDWixnQkFBTSxDQUFDLEtBQUs7SUFDWixjQUFjO0lBQ2QsU0FBUztJQUNULFlBQVk7Q0FDYixDQUFDO0FBRVcsUUFBQSxjQUFjLEdBQUcsVUFBQyxLQUFhO0lBQzFDLE9BQUEscUJBQWEsQ0FBQyxRQUFRLENBQUMsS0FBcUIsQ0FBQztBQUE3QyxDQUE2QyxDQUFDO0FBNEJuQyxRQUFBLHNCQUFzQjtJQUNqQyxHQUFDLGdCQUFNLENBQUMsS0FBSyxJQUFHO1FBQ2QsSUFBSSxFQUFFLE9BQU87UUFDYixLQUFLLEVBQUUscUJBQXFCO1FBQzVCLFdBQVcsRUFBRSx5Q0FBeUM7S0FDdkQ7SUFDRCxHQUFDLGdCQUFNLENBQUMsS0FBSyxJQUFHO1FBQ2QsSUFBSSxFQUFFLE9BQU87UUFDYixLQUFLLEVBQUUsaUJBQWlCO1FBQ3hCLFdBQVcsRUFBRSx5Q0FBeUM7S0FDdkQ7SUFDRCxHQUFDLGdCQUFNLENBQUMsS0FBSyxJQUFHO1FBQ2QsSUFBSSxFQUFFLE9BQU87UUFDYixLQUFLLEVBQUUsYUFBYTtRQUNwQixXQUFXLEVBQUUseUNBQXlDO0tBQ3ZEO0lBQ0Qsa0JBQWMsR0FBRTtRQUNkLElBQUksRUFB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 |
\ | No newline at end of file |