Files
freeCodeCamp/labelOpenPrs.js

93 lines
3.5 KiB
JavaScript
Raw Normal View History

2018-11-06 23:04:43 -08:00
require('dotenv').config();
const { owner, repo, fccBaseUrl, prBaseUrl } = require('./constants');
const fs = require('fs');
2018-11-07 20:12:04 -08:00
const formatDate = require('date-fns/format');
2018-11-06 23:04:43 -08:00
const { saveToFile, openJSONFile } = require('./fileFunctions');
const { octokitConfig, octokitAuth } = require('./octokitConfig');
const octokit = require('@octokit/rest')(octokitConfig);
2018-11-07 20:12:04 -08:00
const { getOpenPrs, getPrRange } = require('./getOpenPrs');
2018-11-06 23:04:43 -08:00
const { validLabels } = require('./validLabels');
const { addLabels } = require('./addLabels');
2018-11-09 11:28:50 -08:00
const { guideFolderChecks } = require('./guideFolderChecks');
const { addComment } = require('./addComment');
2018-11-09 21:58:12 -08:00
const { rateLimiter } = require('./utils');
2018-11-06 23:04:43 -08:00
octokit.authenticate(octokitAuth);
2018-11-06 23:04:43 -08:00
const { PrProcessingLog } = require('./prProcessingLog');
const log = new PrProcessingLog();
2018-11-09 15:29:46 -08:00
const prPropsToGet = ['number', 'labels', 'user'];
2018-11-07 20:12:04 -08:00
2018-11-06 23:04:43 -08:00
(async () => {
2018-11-07 20:12:04 -08:00
const { firstPR, lastPR } = await getPrRange();
const { openPRs } = await getOpenPrs(firstPR, lastPR, prPropsToGet);
if (openPRs.length) {
console.log(`# of PRs Retrieved: ${openPRs.length}`);
console.log(`PR Range: ${firstPR} - ${lastPR}`);
const now = formatDate(new Date(), 'YYYY-MM-DDTHHmmss');
const fileName = `data/openprs_${firstPR}-${lastPR}_${now}.json`;
saveToFile(fileName, JSON.stringify(openPRs));
console.log(`Data saved in file: ${fileName}`);
2018-11-06 23:04:43 -08:00
2018-11-07 20:12:04 -08:00
log.start();
console.log('Starting labeling process...');
2018-11-09 20:18:55 -08:00
for (let count = 0; count < openPRs.length; count++) {
let { number, labels, user: { login: username } } = openPRs[count];
const { data: prFiles } = await octokit.pullRequests.getFiles({ owner, repo, number });
2018-11-11 23:52:00 -08:00
log.add(number, 'labels', 'comment');
2018-11-09 20:18:55 -08:00
const labelsToAdd = {}; // holds potential labels to add based on file path
2018-11-07 20:12:04 -08:00
2018-11-09 20:18:55 -08:00
const guideFolderErrorsComment = guideFolderChecks(prFiles, username);
if (guideFolderErrorsComment) {
2018-11-11 23:52:00 -08:00
log.update(number, 'comment', guideFolderErrorsComment);
2018-11-09 21:58:12 -08:00
const result = await addComment(number, guideFolderErrorsComment);
2018-11-12 01:36:54 -08:00
await rateLimiter(1400);
2018-11-09 20:18:55 -08:00
labelsToAdd['status: needs update'] = 1;
}
2018-11-11 23:52:00 -08:00
else {
log.update(number, 'comment', 'not added');
}
2018-11-09 11:28:50 -08:00
2018-11-09 20:18:55 -08:00
const existingLabels = labels.map(({ name }) => name);
2018-11-09 11:28:50 -08:00
2018-11-09 20:18:55 -08:00
prFiles.forEach(({ filename }) => {
/* remove '/challenges' from filename so language variable hold the language */
const filenameReplacement = filename.replace(/^curriculum\/challenges\//, 'curriculum\/');
const regex = /^(docs|curriculum|guide)(?:\/)(arabic|chinese|portuguese|russian|spanish)?\/?/
const [ _, articleType, language ] = filenameReplacement.match(regex) || []; // need an array to pass to labelsAdder
2018-11-09 11:28:50 -08:00
2018-11-09 20:18:55 -08:00
if (articleType && validLabels[articleType]) {
labelsToAdd[validLabels[articleType]] = 1
}
if (language && validLabels[language]) {
labelsToAdd[validLabels[language]] = 1
}
})
/* this next section only adds needed labels which are NOT currently on the PR. */
const newLabels = Object.keys(labelsToAdd).filter(label => !existingLabels.includes(label));
if (newLabels.length) {
2018-11-11 23:52:00 -08:00
log.update(number, 'labels', newLabels);
2018-11-09 20:18:55 -08:00
addLabels(number, newLabels, log);
2018-11-12 01:36:54 -08:00
await rateLimiter(1400);
2018-11-07 20:12:04 -08:00
}
else {
2018-11-11 23:52:00 -08:00
log.update(number, 'labels', 'none added');
2018-11-09 20:18:55 -08:00
}
if (count % 25 === 0) {
log.export()
2018-11-07 20:12:04 -08:00
}
2018-11-09 20:18:55 -08:00
}
2018-11-07 20:12:04 -08:00
}
2018-11-06 23:04:43 -08:00
})()
.then(() => {
log.finish();
console.log('Successfully completed labeling');
})
.catch(err => {
log.finish();
console.log(err)
})