mirror of
https://github.com/status-im/status-github-bot.git
synced 2025-01-28 05:54:59 +00:00
Use cleared nomenclature for GH responses
This commit is contained in:
parent
97e358e1f5
commit
e8dbc4070e
@ -43,8 +43,8 @@ async function getReviewApprovalState (github, robot, repo, pullRequest) {
|
|||||||
const reviewsWithChangesRequested = finalReviews.filter(reviewState => reviewState === 'CHANGES_REQUESTED')
|
const reviewsWithChangesRequested = finalReviews.filter(reviewState => reviewState === 'CHANGES_REQUESTED')
|
||||||
if (reviewsWithChangesRequested.length === 0) {
|
if (reviewsWithChangesRequested.length === 0) {
|
||||||
// Get detailed pull request
|
// Get detailed pull request
|
||||||
const fullPullRequest = await github.pullRequests.get({owner: repo.owner.login, repo: repo.name, number: pullRequest.number})
|
const fullPullRequestPayload = await github.pullRequests.get({owner: repo.owner.login, repo: repo.name, number: pullRequest.number})
|
||||||
pullRequest = fullPullRequest.data
|
pullRequest = fullPullRequestPayload.data
|
||||||
if (pullRequest.mergeable !== null && pullRequest.mergeable !== undefined && !pullRequest.mergeable) {
|
if (pullRequest.mergeable !== null && pullRequest.mergeable !== undefined && !pullRequest.mergeable) {
|
||||||
if (process.env.DRY_RUN || process.env.DRY_RUN_PR_TO_TEST) {
|
if (process.env.DRY_RUN || process.env.DRY_RUN_PR_TO_TEST) {
|
||||||
robot.log.debug(`pullRequest.mergeable is ${pullRequest.mergeable}, considering as failed`)
|
robot.log.debug(`pullRequest.mergeable is ${pullRequest.mergeable}, considering as failed`)
|
||||||
@ -91,18 +91,18 @@ async function getPullRequestReviewStates (github, repo, pullRequest) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function getProjectFromName (github, ownerName, repoName, projectBoardName) {
|
async function getProjectFromName (github, ownerName, repoName, projectBoardName) {
|
||||||
const ghprojects = await github.projects.getRepoProjects({
|
const ghprojectsPayload = await github.projects.getRepoProjects({
|
||||||
owner: ownerName,
|
owner: ownerName,
|
||||||
repo: repoName,
|
repo: repoName,
|
||||||
state: 'open'
|
state: 'open'
|
||||||
})
|
})
|
||||||
|
|
||||||
return ghprojects.data.find(p => p.name === projectBoardName)
|
return ghprojectsPayload.data.find(p => p.name === projectBoardName)
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getProjectCardForPullRequest (github, columnId, pullRequestUrl) {
|
async function getProjectCardForPullRequest (github, columnId, pullRequestUrl) {
|
||||||
const ghcards = await github.projects.getProjectCards({column_id: columnId})
|
const ghcardsPayload = await github.projects.getProjectCards({column_id: columnId})
|
||||||
const ghcard = ghcards.data.find(c => c.content_url === pullRequestUrl)
|
const ghcard = ghcardsPayload.data.find(c => c.content_url === pullRequestUrl)
|
||||||
|
|
||||||
return ghcard
|
return ghcard
|
||||||
}
|
}
|
||||||
@ -146,8 +146,8 @@ async function checkOpenPullRequests (robot, context) {
|
|||||||
// Fetch column IDs
|
// Fetch column IDs
|
||||||
let ghcolumns
|
let ghcolumns
|
||||||
try {
|
try {
|
||||||
ghcolumns = await github.projects.getProjectColumns({ project_id: project.id })
|
const ghcolumnsPayload = await github.projects.getProjectColumns({ project_id: project.id })
|
||||||
ghcolumns = ghcolumns.data
|
ghcolumns = ghcolumnsPayload.data
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
robot.log.error(`Couldn't fetch the github columns for project: ${err}`, ownerName, repoName, project.id)
|
robot.log.error(`Couldn't fetch the github columns for project: ${err}`, ownerName, repoName, project.id)
|
||||||
return
|
return
|
||||||
@ -226,12 +226,12 @@ async function assignPullRequestToCorrectColumn (github, robot, repo, pullReques
|
|||||||
robot.log.debug(`assignPullRequestToTest - Handling Pull Request #${prNumber} on repo ${ownerName}/${repoName}. PR should be in ${dstColumn.name} column`)
|
robot.log.debug(`assignPullRequestToTest - Handling Pull Request #${prNumber} on repo ${ownerName}/${repoName}. PR should be in ${dstColumn.name} column`)
|
||||||
|
|
||||||
// Look for PR card in source column(s)
|
// Look for PR card in source column(s)
|
||||||
let ghcard = null
|
let existingGHCard = null
|
||||||
let srcColumn = null
|
let srcColumn = null
|
||||||
for (const c of srcColumns) {
|
for (const c of srcColumns) {
|
||||||
try {
|
try {
|
||||||
ghcard = await getProjectCardForPullRequest(github, c.id, pullRequest.issue_url)
|
existingGHCard = await getProjectCardForPullRequest(github, c.id, pullRequest.issue_url)
|
||||||
if (ghcard) {
|
if (existingGHCard) {
|
||||||
srcColumn = c
|
srcColumn = c
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
@ -241,19 +241,19 @@ async function assignPullRequestToCorrectColumn (github, robot, repo, pullReques
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ghcard) {
|
if (existingGHCard) {
|
||||||
// Move PR card to the destination column
|
// Move PR card to the destination column
|
||||||
try {
|
try {
|
||||||
robot.log.trace(`Found card in source column ${srcColumn.name}`, ghcard.id, srcColumn.id)
|
robot.log.trace(`Found card in source column ${srcColumn.name}`, existingGHCard.id, srcColumn.id)
|
||||||
|
|
||||||
if (process.env.DRY_RUN || process.env.DRY_RUN_PR_TO_TEST) {
|
if (process.env.DRY_RUN || process.env.DRY_RUN_PR_TO_TEST) {
|
||||||
robot.log.info(`Would have moved card ${ghcard.id} to ${dstColumn.name} for PR #${prNumber}`)
|
robot.log.info(`Would have moved card ${existingGHCard.id} to ${dstColumn.name} for PR #${prNumber}`)
|
||||||
} else {
|
} else {
|
||||||
// Found in the source column, let's move it to the destination column
|
// Found in the source column, let's move it to the destination column
|
||||||
await github.projects.moveProjectCard({id: ghcard.id, position: 'bottom', column_id: dstColumn.id})
|
await github.projects.moveProjectCard({id: existingGHCard.id, position: 'bottom', column_id: dstColumn.id})
|
||||||
}
|
}
|
||||||
|
|
||||||
robot.log.info(`Moved card ${ghcard.id} to ${dstColumn.name} for PR #${prNumber}`)
|
robot.log.info(`Moved card ${existingGHCard.id} to ${dstColumn.name} for PR #${prNumber}`)
|
||||||
|
|
||||||
slackHelper.sendMessage(robot, slackClient, room, `Assigned PR to ${dstColumn.name} column\n${pullRequest.html_url}`)
|
slackHelper.sendMessage(robot, slackClient, room, `Assigned PR to ${dstColumn.name} column\n${pullRequest.html_url}`)
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
@ -266,9 +266,9 @@ async function assignPullRequestToCorrectColumn (github, robot, repo, pullReques
|
|||||||
|
|
||||||
// Look for PR card in destination column
|
// Look for PR card in destination column
|
||||||
try {
|
try {
|
||||||
ghcard = await getProjectCardForPullRequest(github, dstColumn.id, pullRequest.issue_url)
|
const existingGHCard = await getProjectCardForPullRequest(github, dstColumn.id, pullRequest.issue_url)
|
||||||
if (ghcard) {
|
if (existingGHCard) {
|
||||||
robot.log.trace(`Found card in target column, ignoring`, ghcard.id, dstColumn.id)
|
robot.log.trace(`Found card in target column, ignoring`, existingGHCard.id, dstColumn.id)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
@ -280,14 +280,13 @@ async function assignPullRequestToCorrectColumn (github, robot, repo, pullReques
|
|||||||
robot.log.info(`Would have created card in ${dstColumn.name} column for PR #${prNumber}`)
|
robot.log.info(`Would have created card in ${dstColumn.name} column for PR #${prNumber}`)
|
||||||
} else {
|
} else {
|
||||||
// It wasn't in either the source nor the destination columns, let's create a new card for it in the destination column
|
// It wasn't in either the source nor the destination columns, let's create a new card for it in the destination column
|
||||||
ghcard = await github.projects.createProjectCard({
|
const ghcardPayload = await github.projects.createProjectCard({
|
||||||
column_id: dstColumn.id,
|
column_id: dstColumn.id,
|
||||||
content_type: 'PullRequest',
|
content_type: 'PullRequest',
|
||||||
content_id: pullRequest.id
|
content_id: pullRequest.id
|
||||||
})
|
})
|
||||||
ghcard = ghcard.data
|
|
||||||
|
|
||||||
robot.log.info(`Created card ${ghcard.id} in ${dstColumn.name} for PR #${prNumber}`)
|
robot.log.info(`Created card ${ghcardPayload.data.id} in ${dstColumn.name} for PR #${prNumber}`)
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
// We normally arrive here because there is already a card for the PR in another column
|
// We normally arrive here because there is already a card for the PR in another column
|
||||||
|
@ -55,14 +55,14 @@ async function assignPullRequestToReview (context, robot) {
|
|||||||
const projectBoardName = projectBoardConfig.name
|
const projectBoardName = projectBoardConfig.name
|
||||||
const reviewColumnName = projectBoardConfig['review-column-name']
|
const reviewColumnName = projectBoardConfig['review-column-name']
|
||||||
try {
|
try {
|
||||||
const ghprojects = await github.projects.getRepoProjects({
|
const ghprojectsPayload = await github.projects.getRepoProjects({
|
||||||
owner: ownerName,
|
owner: ownerName,
|
||||||
repo: repoName,
|
repo: repoName,
|
||||||
state: 'open'
|
state: 'open'
|
||||||
})
|
})
|
||||||
|
|
||||||
// Find 'Pipeline for QA' project
|
// Find 'Pipeline for QA' project
|
||||||
const project = ghprojects.data.find(p => p.name === projectBoardName)
|
const project = ghprojectsPayload.data.find(p => p.name === projectBoardName)
|
||||||
if (!project) {
|
if (!project) {
|
||||||
robot.log.error(`Couldn't find project ${projectBoardName} in repo ${ownerName}/${repoName}`)
|
robot.log.error(`Couldn't find project ${projectBoardName} in repo ${ownerName}/${repoName}`)
|
||||||
return
|
return
|
||||||
@ -72,9 +72,9 @@ async function assignPullRequestToReview (context, robot) {
|
|||||||
|
|
||||||
// Fetch REVIEW column ID
|
// Fetch REVIEW column ID
|
||||||
try {
|
try {
|
||||||
const ghcolumns = await github.projects.getProjectColumns({ project_id: project.id })
|
const ghcolumnsPayload = await github.projects.getProjectColumns({ project_id: project.id })
|
||||||
|
|
||||||
column = ghcolumns.data.find(c => c.name === reviewColumnName)
|
column = ghcolumnsPayload.data.find(c => c.name === reviewColumnName)
|
||||||
if (!column) {
|
if (!column) {
|
||||||
robot.log.error(`Couldn't find ${reviewColumnName} column in project ${project.name}`)
|
robot.log.error(`Couldn't find ${reviewColumnName} column in project ${project.name}`)
|
||||||
return
|
return
|
||||||
@ -95,13 +95,13 @@ async function assignPullRequestToReview (context, robot) {
|
|||||||
if (process.env.DRY_RUN) {
|
if (process.env.DRY_RUN) {
|
||||||
robot.log.debug('Would have created card', column.id, payload.pull_request.id)
|
robot.log.debug('Would have created card', column.id, payload.pull_request.id)
|
||||||
} else {
|
} else {
|
||||||
const ghcard = await github.projects.createProjectCard({
|
const ghcardPayload = await github.projects.createProjectCard({
|
||||||
column_id: column.id,
|
column_id: column.id,
|
||||||
content_type: 'PullRequest',
|
content_type: 'PullRequest',
|
||||||
content_id: payload.pull_request.id
|
content_id: payload.pull_request.id
|
||||||
})
|
})
|
||||||
|
|
||||||
robot.log.debug(`Created card: ${ghcard.data.url}`, ghcard.data.id)
|
robot.log.debug(`Created card: ${ghcardPayload.data.url}`, ghcardPayload.data.id)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Send message to Slack
|
// Send message to Slack
|
||||||
|
@ -72,13 +72,13 @@ async function assignIssueToBountyAwaitingForApproval (context, robot, assign) {
|
|||||||
try {
|
try {
|
||||||
const orgName = ownerName
|
const orgName = ownerName
|
||||||
|
|
||||||
const ghprojects = await github.projects.getOrgProjects({
|
const ghprojectsPayload = await github.projects.getOrgProjects({
|
||||||
org: orgName,
|
org: orgName,
|
||||||
state: 'open'
|
state: 'open'
|
||||||
})
|
})
|
||||||
|
|
||||||
// Find 'Status SOB Swarm' project
|
// Find 'Status SOB Swarm' project
|
||||||
const project = ghprojects.data.find(p => p.name === projectBoardName)
|
const project = ghprojectsPayload.data.find(p => p.name === projectBoardName)
|
||||||
if (!project) {
|
if (!project) {
|
||||||
robot.log.error(`Couldn't find project ${projectBoardName} in ${orgName} org`)
|
robot.log.error(`Couldn't find project ${projectBoardName} in ${orgName} org`)
|
||||||
return
|
return
|
||||||
@ -88,9 +88,9 @@ async function assignIssueToBountyAwaitingForApproval (context, robot, assign) {
|
|||||||
|
|
||||||
// Fetch bounty-awaiting-approval column ID
|
// Fetch bounty-awaiting-approval column ID
|
||||||
try {
|
try {
|
||||||
const ghcolumns = await github.projects.getProjectColumns({ project_id: project.id })
|
const ghcolumnsPayload = await github.projects.getProjectColumns({ project_id: project.id })
|
||||||
|
|
||||||
column = ghcolumns.data.find(c => c.name === approvalColumnName)
|
column = ghcolumnsPayload.data.find(c => c.name === approvalColumnName)
|
||||||
if (!column) {
|
if (!column) {
|
||||||
robot.log.error(`Couldn't find ${approvalColumnName} column in project ${project.name}`)
|
robot.log.error(`Couldn't find ${approvalColumnName} column in project ${project.name}`)
|
||||||
return
|
return
|
||||||
@ -106,7 +106,7 @@ async function assignIssueToBountyAwaitingForApproval (context, robot, assign) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
let ghcard = null
|
let ghcardPayload = null
|
||||||
if (process.env.DRY_RUN) {
|
if (process.env.DRY_RUN) {
|
||||||
if (assign) {
|
if (assign) {
|
||||||
robot.log.info(`Would have created card for issue`, column.id, payload.issue.id)
|
robot.log.info(`Would have created card for issue`, column.id, payload.issue.id)
|
||||||
@ -117,12 +117,12 @@ async function assignIssueToBountyAwaitingForApproval (context, robot, assign) {
|
|||||||
if (assign) {
|
if (assign) {
|
||||||
try {
|
try {
|
||||||
// Create project card for the issue in the bounty-awaiting-approval column
|
// Create project card for the issue in the bounty-awaiting-approval column
|
||||||
ghcard = await github.projects.createProjectCard({
|
ghcardPayload = await github.projects.createProjectCard({
|
||||||
column_id: column.id,
|
column_id: column.id,
|
||||||
content_type: 'Issue',
|
content_type: 'Issue',
|
||||||
content_id: payload.issue.id
|
content_id: payload.issue.id
|
||||||
})
|
})
|
||||||
ghcard = ghcard.data
|
const ghcard = ghcardPayload.data
|
||||||
|
|
||||||
robot.log(`Created card: ${ghcard.url}`, ghcard.id)
|
robot.log(`Created card: ${ghcard.url}`, ghcard.id)
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
@ -130,7 +130,7 @@ async function assignIssueToBountyAwaitingForApproval (context, robot, assign) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
try {
|
try {
|
||||||
ghcard = await getProjectCardForIssue(github, column.id, payload.issue.url)
|
const ghcard = await getProjectCardForIssue(github, column.id, payload.issue.url)
|
||||||
if (ghcard) {
|
if (ghcard) {
|
||||||
await github.projects.deleteProjectCard({id: ghcard.id})
|
await github.projects.deleteProjectCard({id: ghcard.id})
|
||||||
robot.log(`Deleted card: ${ghcard.url}`, ghcard.id)
|
robot.log(`Deleted card: ${ghcard.url}`, ghcard.id)
|
||||||
@ -153,8 +153,8 @@ async function assignIssueToBountyAwaitingForApproval (context, robot, assign) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function getProjectCardForIssue (github, columnId, issueUrl) {
|
async function getProjectCardForIssue (github, columnId, issueUrl) {
|
||||||
const ghcards = await github.projects.getProjectCards({column_id: columnId})
|
const ghcardsPayload = await github.projects.getProjectCards({column_id: columnId})
|
||||||
const ghcard = ghcards.data.find(c => c.content_url === issueUrl)
|
const ghcard = ghcardsPayload.data.find(c => c.content_url === issueUrl)
|
||||||
|
|
||||||
return ghcard
|
return ghcard
|
||||||
}
|
}
|
||||||
|
@ -49,14 +49,14 @@ async function greetNewContributor (context, robot) {
|
|||||||
robot.log(`greetNewContributor - Handling Pull Request #${prNumber} on repo ${ownerName}/${repoName}`)
|
robot.log(`greetNewContributor - Handling Pull Request #${prNumber} on repo ${ownerName}/${repoName}`)
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const ghissues = await github.issues.getForRepo({
|
const ghissuesPayload = await github.issues.getForRepo({
|
||||||
owner: ownerName,
|
owner: ownerName,
|
||||||
repo: repoName,
|
repo: repoName,
|
||||||
state: 'all',
|
state: 'all',
|
||||||
creator: payload.pull_request.user.login
|
creator: payload.pull_request.user.login
|
||||||
})
|
})
|
||||||
|
|
||||||
const userPullRequests = ghissues.data.filter(issue => issue.pull_request)
|
const userPullRequests = ghissuesPayload.data.filter(issue => issue.pull_request)
|
||||||
if (userPullRequests.length === 1) {
|
if (userPullRequests.length === 1) {
|
||||||
try {
|
try {
|
||||||
const welcomeMessage = welcomeBotConfig.message
|
const welcomeMessage = welcomeBotConfig.message
|
||||||
|
Loading…
x
Reference in New Issue
Block a user