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