Fix PR error duplications.

Also, extract pr-reviewer-suggestions.js
1.0.19.xpi
This commit is contained in:
Sage Vaillancourt 2024-12-19 14:45:58 -05:00
parent 945d819f0e
commit fc18f4e929
5 changed files with 78 additions and 80 deletions

View File

@ -1,7 +1,7 @@
{
"name": "Sage's BitBucket Addon",
"description": "Ensure searches don't include forks (and other enhancements)",
"version": "1.0.18",
"version": "1.0.19",
"manifest_version": 2,
"browser_specific_settings": {
"gecko": {
@ -30,6 +30,7 @@
"backtick-comments.js",
"csharp-quotes.js",
"file-scroll.js",
"pr-reviewer-suggestions.js",
"repo-search-sorter.js",
"show-errored-prs.js",
"var-highlighter.js"

View File

@ -0,0 +1,69 @@
if (location.toString().includes('/pull-requests?create')) {
const names = [
"Tam Nguyen",
"David Daniel",
"Nikalas Culvey",
"Michael Mezzina",
"Sage Vaillancourt",
"John Cyr",
"Adam Weizman",
"Caleb Soper",
"Rockey Liles",
"Fernando Batista"
]
const urlPrefix = 'https://git.add123.com/rest/api/latest'
fetch(`${urlPrefix}/projects/ADD/repos?limit=999`)
.then(resp => resp.json())
.then(async ({values: allRepos}) => {
const prListUrls = allRepos.map(repo => `${urlPrefix}/projects/ADD/repos/${repo.slug}/pull-requests`)
const allPullRequests = (await Promise.all(
prListUrls.map(async prListUrl => await fetch(prListUrl).then(resp => resp.json())))
).flatMap(({values}) => values)
const reviewerCounts = Object.fromEntries(names.map(name => [name, 0]))
allPullRequests.forEach(({reviewers}) => {
reviewers?.map(r => r.user.displayName)
.filter(displayName => !["Chris Gamache", "Tom Keels"].includes(displayName))
.forEach(displayName => {
reviewerCounts[displayName] ??= 0
reviewerCounts[displayName] += 1
})
})
const sortedCounts = Object.entries(reviewerCounts)
.map(([name, count]) => ({ name, count }))
.toSorted((a, b) => a.count - b.count)
const tryDisplay = () => setTimeout(() => {
if (document.getElementById('reviewer-counts')) {
return
}
const formBodyMain = document.querySelector('.create-pull-request-form .form-body .form-body-main')
if (formBodyMain) {
const countsParent = formBodyMain.lastChild.cloneNode(true)
const reviewerCountsNode = document.createElement('ol')
reviewerCountsNode.id = 'reviewer-counts'
reviewerCountsNode.style.columns = '3'
reviewerCountsNode.style.listStyle = 'none'
reviewerCountsNode.style.paddingLeft = '2px'
reviewerCountsNode.style.marginTop = 'auto'
// reviewerCountsNode.style.lineHeight = '95%'
reviewerCountsNode.style.fontSize = '0.9em'
sortedCounts.slice(0, 6).forEach(({ name, count }) => {
const listItem = document.createElement('li')
listItem.innerText = `${count} PR${count !== 1 ? 's' : 's'} ${name}`
reviewerCountsNode.appendChild(listItem)
})
const label = countsParent.querySelector('.form-label')
label.innerText = 'Now reviewing'
const message = countsParent.querySelector('.form-field-content')
message.replaceChildren(reviewerCountsNode)
formBodyMain.appendChild(countsParent)
} else {
tryDisplay()
}
}, 300)
tryDisplay()
})
}

View File

@ -33,77 +33,4 @@ const sortSearchResult = () => {
}
}
/////////////////////////////
// PR Reviewer Suggestions //
/////////////////////////////
if (location.toString().includes('/pull-requests?create')) {
const names = [
"Tam Nguyen",
"David Daniel",
"Nikalas Culvey",
"Michael Mezzina",
"Sage Vaillancourt",
"John Cyr",
"Adam Weizman",
"Caleb Soper",
"Rockey Liles",
"Fernando Batista"
]
const urlPrefix = 'https://git.add123.com/rest/api/latest'
fetch(`${urlPrefix}/projects/ADD/repos?limit=999`)
.then(resp => resp.json())
.then(async ({values: allRepos}) => {
const prListUrls = allRepos.map(repo => `${urlPrefix}/projects/ADD/repos/${repo.slug}/pull-requests`)
const allPullRequests = (await Promise.all(
prListUrls.map(async prListUrl => await fetch(prListUrl).then(resp => resp.json())))
).flatMap(({values}) => values)
const reviewerCounts = Object.fromEntries(names.map(name => [name, 0]))
allPullRequests.forEach(({reviewers}) => {
reviewers?.map(r => r.user.displayName)
.filter(displayName => !["Chris Gamache", "Tom Keels"].includes(displayName))
.forEach(displayName => {
reviewerCounts[displayName] ??= 0
reviewerCounts[displayName] += 1
})
})
const sortedCounts = Object.entries(reviewerCounts)
.map(([name, count]) => ({ name, count }))
.toSorted((a, b) => a.count - b.count)
const tryDisplay = () => setTimeout(() => {
if (document.getElementById('reviewer-counts')) {
return
}
const formBodyMain = document.querySelector('.create-pull-request-form .form-body .form-body-main')
if (formBodyMain) {
const countsParent = formBodyMain.lastChild.cloneNode(true)
const reviewerCountsNode = document.createElement('ol')
reviewerCountsNode.id = 'reviewer-counts'
reviewerCountsNode.style.columns = '3'
reviewerCountsNode.style.listStyle = 'none'
reviewerCountsNode.style.paddingLeft = '2px'
reviewerCountsNode.style.marginTop = 'auto'
// reviewerCountsNode.style.lineHeight = '95%'
reviewerCountsNode.style.fontSize = '0.9em'
sortedCounts.slice(0, 6).forEach(({ name, count }) => {
const listItem = document.createElement('li')
listItem.innerText = `${count} PR${count !== 1 ? 's' : 's'} ${name}`
reviewerCountsNode.appendChild(listItem)
})
const label = countsParent.querySelector('.form-label')
label.innerText = 'Now reviewing'
const message = countsParent.querySelector('.form-field-content')
message.replaceChildren(reviewerCountsNode)
formBodyMain.appendChild(countsParent)
} else {
tryDisplay()
}
}, 300)
tryDisplay()
})
}
addFix(sortSearchResult)

Binary file not shown.

View File

@ -3,7 +3,6 @@ const bbUrlPrefix = 'https://git.add123.com/rest/api/latest'
const pullRequestHasErrored = async pr => {
const latestCommitId = pr?.fromRef?.latestCommit
if (!latestCommitId) {
console.log('no latestCommitId on pr', pr)
return false
}
const buildStats = await fetch(`https://git.add123.com/rest/build-status/latest/commits/stats/${latestCommitId}`).then(resp => resp.json())
@ -20,7 +19,7 @@ const getAllRepos = async () => {
return allRepos
}
const withErroredPrs = async action => {
const getErroredPrs = async () => {
const allPullRequests = (await getAllRepos()
.then(async allRepos => {
const prListUrls = allRepos.map(repo => `${bbUrlPrefix}/projects/ADD/repos/${repo.slug}/pull-requests`)
@ -31,7 +30,7 @@ const withErroredPrs = async action => {
const erroredPullRequests = []
for (const pullRequest of allPullRequests) {
if (await pullRequestHasErrored(pullRequest)) {
action(pullRequest)
erroredPullRequests.push(pullRequest)
}
}
return erroredPullRequests
@ -55,6 +54,7 @@ const showErroredPrs = async () => {
let errorList = document.getElementById('bb-addon-pr-error-list')
if (!errorParent) {
errorParent = mainPanel.getElementsByClassName('dashboard-pull-request-table')[0].cloneNode()
errorParent.id = 'bb-addon-pr-error-table'
const header = document.createElement('h3')
header.innerText = 'Pull requests with errors'
@ -68,9 +68,10 @@ const showErroredPrs = async () => {
mainPanel.insertBefore(errorParent, getElementAfterErrorList(mainPanel))
}
Array.from(errorList.children).slice(1).forEach(child => errorList.removeChild(child))
await withErroredPrs(pr => {
const erroredPrs = await getErroredPrs()
Array.from(errorList.children).forEach(child => errorList.removeChild(child))
erroredPrs.forEach(pr => {
const element = document.createElement('li')
const link = document.createElement('a')
link.href = pr.links.self[0].href
@ -83,5 +84,5 @@ const showErroredPrs = async () => {
if (location.toString().includes('/dashboard')) {
addFix(() => showErroredPrs().catch(console.error))
setInterval(() => showErroredPrs().catch(console.error), 1000 * 60 * 5)
setInterval(() => showErroredPrs().catch(console.error), 1000 * 60 * 2)
}