2018-01-22 13:48:57 +00:00
// Description:
// Script that listens to new GitHub pull requests
2018-01-28 08:24:30 +00:00
// and assigns them to the REVIEW column on the 'Pipeline for QA' project
2018-01-22 13:48:57 +00:00
//
// Dependencies:
// github: "^13.1.0"
2018-01-23 18:38:25 +00:00
// probot-config: "^0.1.0"
2018-01-22 13:48:57 +00:00
// probot-slack-status: "^0.2.2"
//
// Author:
// PombeirP
2018-01-23 14:27:25 +00:00
const defaultConfig = require ( '../lib/config' )
2018-02-08 12:09:59 +00:00
const getConfig = require ( 'probot-config' )
2018-01-23 14:27:25 +00:00
const Slack = require ( 'probot-slack-status' )
2018-02-13 14:51:00 +00:00
const slackHelper = require ( '../lib/slack' )
2018-01-22 13:48:57 +00:00
2018-02-13 14:51:00 +00:00
const botName = 'assign-new-pr-to-review'
2018-01-23 14:27:25 +00:00
let slackClient = null
2018-01-22 13:48:57 +00:00
2018-01-28 08:24:30 +00:00
module . exports = ( robot ) => {
2018-01-22 13:48:57 +00:00
// robot.on('slack.connected', ({ slack }) => {
Slack ( robot , ( slack ) => {
2018-02-13 14:51:00 +00:00
robot . log . trace ( ` ${ botName } - Connected, assigned slackClient ` )
2018-01-23 14:27:25 +00:00
slackClient = slack
} )
2018-01-28 08:24:30 +00:00
2018-01-22 13:48:57 +00:00
robot . on ( 'pull_request.opened' , async context => {
// Make sure we don't listen to our own messages
2018-01-23 14:27:25 +00:00
if ( context . isBot ) { return }
2018-01-28 08:24:30 +00:00
2018-01-22 13:48:57 +00:00
// A new PR was opened
2018-01-23 14:27:25 +00:00
await assignPullRequestToReview ( context , robot )
} )
}
2018-01-22 13:48:57 +00:00
2018-01-28 08:24:30 +00:00
async function assignPullRequestToReview ( context , robot ) {
2018-02-07 16:04:59 +00:00
const { github , payload } = context
2018-02-08 12:09:59 +00:00
const config = await getConfig ( context , 'github-bot.yml' , defaultConfig ( robot , '.github/github-bot.yml' ) )
2018-01-23 14:27:25 +00:00
const ownerName = payload . repository . owner . login
const repoName = payload . repository . name
const prNumber = payload . pull _request . number
2018-01-28 08:24:30 +00:00
2018-02-08 12:09:59 +00:00
const projectBoardConfig = config ? config [ 'project-board' ] : null
2018-01-28 08:24:30 +00:00
if ( ! projectBoardConfig ) {
return
2018-01-23 14:30:24 +00:00
}
2018-01-28 08:24:30 +00:00
2018-02-13 14:51:00 +00:00
robot . log ( ` ${ botName } - Handling Pull Request # ${ prNumber } on repo ${ ownerName } / ${ repoName } ` )
2018-01-28 08:24:30 +00:00
2018-01-22 13:48:57 +00:00
// Fetch repo projects
// TODO: The repo project and project column info should be cached
// in order to improve performance and reduce roundtrips
2018-01-28 08:24:30 +00:00
let column = null
const projectBoardName = projectBoardConfig . name
const reviewColumnName = projectBoardConfig [ 'review-column-name' ]
2018-01-22 13:48:57 +00:00
try {
2018-02-05 16:12:16 +00:00
const ghprojectsPayload = await github . projects . getRepoProjects ( {
2018-01-22 13:48:57 +00:00
owner : ownerName ,
repo : repoName ,
2018-01-28 08:24:30 +00:00
state : 'open'
2018-01-23 14:27:25 +00:00
} )
2018-01-28 08:24:30 +00:00
// Find 'Pipeline for QA' project
2018-02-05 16:12:16 +00:00
const project = ghprojectsPayload . data . find ( p => p . name === projectBoardName )
2018-01-22 13:48:57 +00:00
if ( ! project ) {
2018-02-13 14:51:00 +00:00
robot . log . error ( ` ${ botName } - Couldn't find project ${ projectBoardName } in repo ${ ownerName } / ${ repoName } ` )
2018-01-23 14:27:25 +00:00
return
2018-01-22 13:48:57 +00:00
}
2018-01-28 08:24:30 +00:00
2018-02-13 14:51:00 +00:00
robot . log . debug ( ` ${ botName } - Fetched ${ project . name } project ( ${ project . id } ) ` )
2018-01-28 08:24:30 +00:00
2018-01-22 13:48:57 +00:00
// Fetch REVIEW column ID
try {
2018-02-05 16:12:16 +00:00
const ghcolumnsPayload = await github . projects . getProjectColumns ( { project _id : project . id } )
2018-01-28 08:24:30 +00:00
2018-02-05 16:12:16 +00:00
column = ghcolumnsPayload . data . find ( c => c . name === reviewColumnName )
2018-01-22 13:48:57 +00:00
if ( ! column ) {
2018-02-13 14:51:00 +00:00
robot . log . error ( ` ${ botName } - Couldn't find ${ reviewColumnName } column in project ${ project . name } ` )
2018-01-23 14:27:25 +00:00
return
2018-01-22 13:48:57 +00:00
}
2018-01-28 08:24:30 +00:00
2018-02-13 14:51:00 +00:00
robot . log . debug ( ` ${ botName } - Fetched ${ column . name } column ( ${ column . id } ) ` )
2018-01-22 13:48:57 +00:00
} catch ( err ) {
2018-02-13 14:51:00 +00:00
robot . log . error ( ` ${ botName } - Couldn't fetch the github columns for project: ${ err } ` , ownerName , repoName , project . id )
2018-01-23 18:38:25 +00:00
return
2018-01-22 13:48:57 +00:00
}
} catch ( err ) {
2018-02-13 14:51:00 +00:00
robot . log . error ( ` ${ botName } - Couldn't fetch the github projects for repo: ${ err } ` , ownerName , repoName )
2018-01-23 18:38:25 +00:00
return
}
2018-01-28 08:24:30 +00:00
2018-01-23 18:38:25 +00:00
// Create project card for the PR in the REVIEW column
try {
2018-01-28 08:24:30 +00:00
if ( process . env . DRY _RUN ) {
2018-02-13 14:51:00 +00:00
robot . log . debug ( ` ${ botName } - Would have created card ` , column . id , payload . pull _request . id )
2018-01-28 08:24:30 +00:00
} else {
2018-02-05 16:12:16 +00:00
const ghcardPayload = await github . projects . createProjectCard ( {
2018-01-23 18:38:25 +00:00
column _id : column . id ,
content _type : 'PullRequest' ,
content _id : payload . pull _request . id
} )
2018-01-28 08:24:30 +00:00
2018-02-13 14:51:00 +00:00
robot . log . debug ( ` ${ botName } - Created card: ${ ghcardPayload . data . url } ` , ghcardPayload . data . id )
2018-01-23 18:38:25 +00:00
}
2018-01-28 08:24:30 +00:00
2018-01-23 18:38:25 +00:00
// Send message to Slack
slackHelper . sendMessage ( robot , slackClient , config . slack . notification . room , ` Assigned PR to ${ reviewColumnName } in ${ projectBoardName } project \n ${ payload . pull _request . html _url } ` )
} catch ( err ) {
2018-02-13 14:51:00 +00:00
robot . log . error ( ` ${ botName } - Couldn't create project card for the PR: ${ err } ` , column . id , payload . pull _request . id )
2018-01-22 13:48:57 +00:00
}
2018-01-23 14:27:25 +00:00
}