mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-25 14:06:27 +00:00
Refactor PR update
This commit is contained in:
parent
052b8aa1bf
commit
4e2e5390fb
2 changed files with 37 additions and 41 deletions
|
@ -67,17 +67,14 @@ module.exports = {
|
||||||
return JSON.parse(new Buffer(res.body.content, 'base64').toString());
|
return JSON.parse(new Buffer(res.body.content, 'base64').toString());
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
getPrNo: function(branchName, state = 'open') {
|
getPr: function(branchName) {
|
||||||
return ghGot(`repos/${config.repoName}/pulls?state=${state}&base=${config.baseBranch}&head=${config.userName}:${branchName}`, {
|
return ghGot(`repos/${config.repoName}/pulls?state=open&base=${config.baseBranch}&head=${config.userName}:${branchName}`, {
|
||||||
token: config.token,
|
token: config.token,
|
||||||
}).then(res => {
|
}).then(res => {
|
||||||
let prNo = 0;
|
if (res.body.length) {
|
||||||
res.body.forEach(function(result) {
|
return res.body[0];
|
||||||
if (result.state === 'open' && result.head.label === `${config.userName}:${branchName}`) {
|
}
|
||||||
prNo = result.number;
|
return null;
|
||||||
}
|
|
||||||
});
|
|
||||||
return prNo;
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
writeFile: function(branchName, oldFileSHA, filePath, fileContents, message) {
|
writeFile: function(branchName, oldFileSHA, filePath, fileContents, message) {
|
||||||
|
|
63
src/index.js
63
src/index.js
|
@ -59,41 +59,45 @@ function updateDependency(depType, depName, currentVersion, nextVersion) {
|
||||||
} else {
|
} else {
|
||||||
prTitle = config.templates.prTitleMinor({ depType, depName, currentVersion, nextVersion, nextVersionMajor });
|
prTitle = config.templates.prTitleMinor({ depType, depName, currentVersion, nextVersion, nextVersionMajor });
|
||||||
}
|
}
|
||||||
|
const prBody = config.templates.prBody({ depName, currentVersion, nextVersion });
|
||||||
|
const commitMessage = config.templates.commitMessage({ depName, currentVersion, nextVersion });
|
||||||
|
|
||||||
// Check if same PR already existed and skip if so
|
// Check if same PR already existed and skip if so
|
||||||
return github.checkForClosedPr(branchName, prTitle).then((prExisted) => {
|
return github.checkForClosedPr(branchName, prTitle).then((prExisted) => {
|
||||||
if (prExisted) {
|
if (prExisted) {
|
||||||
console.log(`${depName}: Skipping due to existing PR found.`);
|
console.log(`${depName}: Skipping due to existing PR found.`);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const prBody = config.templates.prBody({ depName, currentVersion, nextVersion });
|
// Save an API call by attempting to create branch without checking for existence first
|
||||||
return github.createBranch(branchName).catch(error => {
|
return github.createBranch(branchName)
|
||||||
|
.catch(error => {
|
||||||
|
// Check in case it's because the branch already existed
|
||||||
if (error.response.body.message !== 'Reference already exists') {
|
if (error.response.body.message !== 'Reference already exists') {
|
||||||
|
// In this case it means we really do have a problem and can't continue
|
||||||
console.log('Error creating branch: ' + branchName);
|
console.log('Error creating branch: ' + branchName);
|
||||||
console.log(error.response.body);
|
console.log('Response body: ' + error.response.body);
|
||||||
}
|
throw error;
|
||||||
}).then(res => {
|
|
||||||
if (config.verbose) {
|
|
||||||
console.log(`Branch exists (${branchName}), now writing file`);
|
|
||||||
}
|
}
|
||||||
|
}).then(() => {
|
||||||
|
// Retrieve the package.json from this renovate branch
|
||||||
return github.getFile(packageFile, branchName).then(res => {
|
return github.getFile(packageFile, branchName).then(res => {
|
||||||
const oldFileSHA = res.body.sha;
|
const currentSHA = res.body.sha;
|
||||||
let currentFileContent = JSON.parse(new Buffer(res.body.content, 'base64').toString());
|
let currentFileContent = JSON.parse(new Buffer(res.body.content, 'base64').toString());
|
||||||
if (currentFileContent[depType][depName] !== nextVersion) {
|
if (currentFileContent[depType][depName] !== nextVersion) {
|
||||||
// Branch is new, or needs version updated
|
// Branch is new, or needs version updated
|
||||||
|
if (config.verbose) {
|
||||||
|
console.log(`Updating ${depName} to ${nextVersion} in branch ${branchName}`);
|
||||||
|
}
|
||||||
currentFileContent[depType][depName] = nextVersion;
|
currentFileContent[depType][depName] = nextVersion;
|
||||||
const newPackageString = JSON.stringify(currentFileContent, null, 2) + '\n';
|
const newPackageContents = JSON.stringify(currentFileContent, null, 2) + '\n';
|
||||||
|
return github.writeFile(branchName, currentSHA, packageFile, newPackageContents, commitMessage)
|
||||||
var commitMessage = config.templates.commitMessage({ depName, currentVersion, nextVersion });
|
|
||||||
|
|
||||||
return github.writeFile(branchName, oldFileSHA, packageFile, newPackageString, commitMessage)
|
|
||||||
.then(() => {
|
.then(() => {
|
||||||
return createOrUpdatePullRequest(branchName, prTitle, prBody);
|
return createOrUpdatePullRequest(branchName, prTitle, prBody);
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
console.error('Error writing new package file for ' + depName);
|
|
||||||
console.log(err);
|
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
if (config.verbose) {
|
||||||
|
console.log(`${depName} was already up-to-date in branch ${branchName}`);
|
||||||
|
}
|
||||||
// File was up to date. Ensure PR
|
// File was up to date. Ensure PR
|
||||||
return createOrUpdatePullRequest(branchName, prTitle, prBody);
|
return createOrUpdatePullRequest(branchName, prTitle, prBody);
|
||||||
}
|
}
|
||||||
|
@ -106,21 +110,16 @@ function updateDependency(depType, depName, currentVersion, nextVersion) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function createOrUpdatePullRequest(branchName, prTitle, prBody) {
|
function createOrUpdatePullRequest(branchName, prTitle, prBody) {
|
||||||
return github.getPrNo(branchName).then(prNo => {
|
return github.getPr(branchName).then(pr => {
|
||||||
if (prNo) {
|
if (pr) {
|
||||||
// PR already exists - update it
|
if (pr.title === prTitle && pr.body === prBody) {
|
||||||
// Note: PR might be unchanged, so no log message
|
if (config.verbose) {
|
||||||
return github.updatePr(prNo, prTitle, prBody)
|
console.log('PR already up-to-date');
|
||||||
.catch(err => {
|
}
|
||||||
console.error('Error: Failed to update Pull Request: ' + prTitle);
|
} else {
|
||||||
console.log(err);
|
console.log(`Updating PR #${pr.number}`);
|
||||||
});
|
return github.updatePr(pr.number, prTitle, prBody);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return github.createPr(branchName, prTitle, prBody).then(res => {
|
|
||||||
console.log('Created Pull Request: ' + prTitle);
|
|
||||||
}).catch(err => {
|
|
||||||
console.error('Error: Failed to create Pull Request: ' + prTitle);
|
|
||||||
console.log(err);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue