Merge pull request #719 from peter-evans/add-to-lists

fix: add to labels and assignees instead of resetting
This commit is contained in:
Peter Evans 2021-02-08 10:19:41 +09:00 committed by GitHub
commit 34371f09e5
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 7965 additions and 23 deletions

14
dist/index.js vendored
View file

@ -975,22 +975,20 @@ class GitHubHelper {
const headBranch = `${headOwner}:${inputs.branch}`; const headBranch = `${headOwner}:${inputs.branch}`;
// Create or update the pull request // Create or update the pull request
const pull = yield this.createOrUpdate(inputs, baseRepository, headBranch); const pull = yield this.createOrUpdate(inputs, baseRepository, headBranch);
// Set milestone, labels and assignees // Apply milestone
const updateIssueParams = {};
if (inputs.milestone) { if (inputs.milestone) {
updateIssueParams['milestone'] = inputs.milestone;
core.info(`Applying milestone '${inputs.milestone}'`); core.info(`Applying milestone '${inputs.milestone}'`);
yield this.octokit.issues.update(Object.assign(Object.assign({}, this.parseRepository(baseRepository)), { issue_number: pull.number, milestone: inputs.milestone }));
} }
// Apply labels
if (inputs.labels.length > 0) { if (inputs.labels.length > 0) {
updateIssueParams['labels'] = inputs.labels;
core.info(`Applying labels '${inputs.labels}'`); core.info(`Applying labels '${inputs.labels}'`);
yield this.octokit.issues.addLabels(Object.assign(Object.assign({}, this.parseRepository(baseRepository)), { issue_number: pull.number, labels: inputs.labels }));
} }
// Apply assignees
if (inputs.assignees.length > 0) { if (inputs.assignees.length > 0) {
updateIssueParams['assignees'] = inputs.assignees;
core.info(`Applying assignees '${inputs.assignees}'`); core.info(`Applying assignees '${inputs.assignees}'`);
} yield this.octokit.issues.addAssignees(Object.assign(Object.assign({}, this.parseRepository(baseRepository)), { issue_number: pull.number, labels: inputs.assignees }));
if (Object.keys(updateIssueParams).length > 0) {
yield this.octokit.issues.update(Object.assign(Object.assign(Object.assign({}, this.parseRepository(baseRepository)), { issue_number: pull.number }), updateIssueParams));
} }
// Request reviewers and team reviewers // Request reviewers and team reviewers
const requestReviewersParams = {}; const requestReviewersParams = {};

7940
package-lock.json generated

File diff suppressed because it is too large Load diff

View file

@ -117,25 +117,31 @@ export class GitHubHelper {
// Create or update the pull request // Create or update the pull request
const pull = await this.createOrUpdate(inputs, baseRepository, headBranch) const pull = await this.createOrUpdate(inputs, baseRepository, headBranch)
// Set milestone, labels and assignees // Apply milestone
const updateIssueParams = {}
if (inputs.milestone) { if (inputs.milestone) {
updateIssueParams['milestone'] = inputs.milestone
core.info(`Applying milestone '${inputs.milestone}'`) core.info(`Applying milestone '${inputs.milestone}'`)
}
if (inputs.labels.length > 0) {
updateIssueParams['labels'] = inputs.labels
core.info(`Applying labels '${inputs.labels}'`)
}
if (inputs.assignees.length > 0) {
updateIssueParams['assignees'] = inputs.assignees
core.info(`Applying assignees '${inputs.assignees}'`)
}
if (Object.keys(updateIssueParams).length > 0) {
await this.octokit.issues.update({ await this.octokit.issues.update({
...this.parseRepository(baseRepository), ...this.parseRepository(baseRepository),
issue_number: pull.number, issue_number: pull.number,
...updateIssueParams milestone: inputs.milestone
})
}
// Apply labels
if (inputs.labels.length > 0) {
core.info(`Applying labels '${inputs.labels}'`)
await this.octokit.issues.addLabels({
...this.parseRepository(baseRepository),
issue_number: pull.number,
labels: inputs.labels
})
}
// Apply assignees
if (inputs.assignees.length > 0) {
core.info(`Applying assignees '${inputs.assignees}'`)
await this.octokit.issues.addAssignees({
...this.parseRepository(baseRepository),
issue_number: pull.number,
labels: inputs.assignees
}) })
} }