Skip to content

Commit

Permalink
feat: keep labels in a set and make them lowercase
Browse files Browse the repository at this point in the history
  • Loading branch information
invakid404 committed Jun 23, 2021
1 parent dead522 commit dead952
Show file tree
Hide file tree
Showing 4 changed files with 47 additions and 35 deletions.
70 changes: 40 additions & 30 deletions src/pullRequests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import {Octokit, RestEndpointMethodTypes} from '@octokit/rest'
import moment from 'moment'

import * as core from '@actions/core'
import {Unpacked} from './utils'

export interface PullRequestInfo {
number: number
Expand All @@ -12,13 +13,18 @@ export interface PullRequestInfo {
mergeCommitSha: string
author: string
repoName: string
labels: string[]
labels: Set<string>
milestone: string
body: string
assignees: string[]
requestedReviewers: string[]
}

type PullData = RestEndpointMethodTypes['pulls']['get']['response']['data']

type PullsListData =
RestEndpointMethodTypes['pulls']['list']['response']['data']

export class PullRequests {
constructor(private octokit: Octokit) {}

Expand All @@ -43,10 +49,11 @@ export class PullRequests {
mergeCommitSha: pr.data.merge_commit_sha || '',
author: pr.data.user?.login || '',
repoName: pr.data.base.repo.full_name,
labels:
labels: new Set(
pr.data.labels?.map(function (label) {
return label.name || ''
}) || [],
return label.name?.toLowerCase() || ''
}) || []
),
milestone: pr.data.milestone?.title || '',
body: pr.data.body || '',
assignees:
Expand Down Expand Up @@ -84,35 +91,10 @@ export class PullRequests {
})

for await (const response of this.octokit.paginate.iterator(options)) {
type PullsListData =
RestEndpointMethodTypes['pulls']['list']['response']['data']
const prs: PullsListData = response.data as PullsListData

for (const pr of prs.filter(p => !!p.merged_at)) {
mergedPRs.push({
number: pr.number,
title: pr.title,
htmlURL: pr.html_url,
baseBranch: pr.base.ref,
mergedAt: moment(pr.merged_at),
mergeCommitSha: pr.merge_commit_sha || '',
author: pr.user?.login || '',
repoName: pr.base.repo.full_name,
labels:
pr.labels?.map(function (label) {
return label.name || ''
}) || [],
milestone: pr.milestone?.title || '',
body: pr.body || '',
assignees:
pr.assignees?.map(function (asignee) {
return asignee?.login || ''
}) || [],
requestedReviewers:
pr.requested_reviewers?.map(function (reviewer) {
return reviewer?.login || ''
}) || []
})
mergedPRs.push(mapPullRequest(pr))
}

const firstPR = prs[0]
Expand Down Expand Up @@ -159,3 +141,31 @@ export function sortPullRequests(
}
return pullRequests
}

const mapPullRequest = (
pr: PullData | Unpacked<PullsListData>
): PullRequestInfo => ({
number: pr.number,
title: pr.title,
htmlURL: pr.html_url,
baseBranch: pr.base.ref,
mergedAt: moment(pr.merged_at),
mergeCommitSha: pr.merge_commit_sha || '',
author: pr.user?.login || '',
repoName: pr.base.repo.full_name,
labels: new Set(
pr.labels?.map(function (label) {
return label.name?.toLowerCase() || ''
}) || []
),
milestone: pr.milestone?.title || '',
body: pr.body || '',
assignees:
pr.assignees?.map(function (asignee) {
return asignee?.login || ''
}) || [],
requestedReviewers:
pr.requested_reviewers?.map(function (reviewer) {
return reviewer?.login || ''
}) || []
})
2 changes: 1 addition & 1 deletion src/releaseNotes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -176,7 +176,7 @@ export class ReleaseNotes {
mergeCommitSha: '',
author: commit.author || '',
repoName: '',
labels: [],
labels: new Set(),
milestone: '',
body: commit.message || '',
assignees: [],
Expand Down
8 changes: 4 additions & 4 deletions src/transform.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ export function buildChangelog(
label = pr.body.replace(extractor.pattern, extractor.target)
}
if (label !== '') {
pr.labels.push(label)
pr.labels.add(label.toLowerCase())
}
}
}
Expand Down Expand Up @@ -189,8 +189,8 @@ export function fillAdditionalPlaceholders(
return transformed
}

function haveCommonElements(arr1: string[], arr2: string[]): Boolean {
return arr1.some(item => arr2.includes(item))
function haveCommonElements(arr1: string[], arr2: Set<string>): Boolean {
return arr1.some(item => arr2.has(item))
}

function fillTemplate(pr: PullRequestInfo, template: string): string {
Expand All @@ -205,7 +205,7 @@ function fillTemplate(pr: PullRequestInfo, template: string): string {
transformed = transformed.replace(/\${{AUTHOR}}/g, pr.author)
transformed = transformed.replace(
/\${{LABELS}}/g,
pr.labels?.join(', ') || ''
[...pr.labels]?.join(', ') || ''
)
transformed = transformed.replace(/\${{MILESTONE}}/g, pr.milestone || '')
transformed = transformed.replace(/\${{BODY}}/g, pr.body)
Expand Down
2 changes: 2 additions & 0 deletions src/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -137,3 +137,5 @@ export function writeOutput(
}
}
}

export type Unpacked<T> = T extends (infer U)[] ? U : T

0 comments on commit dead952

Please sign in to comment.