Skip to content

Commit

Permalink
Allow to ignore merge conflicts
Browse files Browse the repository at this point in the history
  • Loading branch information
adrian-gomez authored Feb 6, 2020
1 parent f8341cb commit 276657f
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 0 deletions.
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,10 @@ All configuration values, except `GITHUB_TOKEN`, are optional.

* `RETRY_SLEEP`: The amount of time (in milliseconds) that _autoupdate_ should wait between branch update attempts (default: `"300"`).

* `MERGE_CONFLICT_ACTION`: Controls how _autoupdate_ handles a merge conflict when updating a PR. Possible values are:
* `"fail"` (default): _autoupdate_ will report a failure on each PR that has a merge conflict.
* `"ignore"`: _autoupdate_ will silently ignore merge conflicts.

Here's an example workflow file with all of the above options specified:

```yaml
Expand Down
9 changes: 9 additions & 0 deletions src/autoupdater.js
Original file line number Diff line number Diff line change
Expand Up @@ -234,6 +234,8 @@ class AutoUpdater {

const retryCount = this.config.retryCount();
const retrySleep = this.config.retrySleep();
const mergeConflictAction = this.config.mergeConflictAction();

let retries = 0;

while (true) {
Expand All @@ -242,6 +244,13 @@ class AutoUpdater {
await doMerge();
break;
} catch (e) {
if (e.message === "Merge conflict" && mergeConflictAction === "ignore") {
return;
} else if (e.message === "Merge conflict") {
ghCore.error("Merge conflict error trying to update branch");
throw e;
}

ghCore.error(`Caught error trying to update branch: ${e.message}`);

if (retries < retryCount) {
Expand Down
5 changes: 5 additions & 0 deletions src/config-loader.js
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,11 @@ class ConfigLoader {
), 10);
}

mergeConflictAction() {
// one of 'fail' or 'ignore'.
return this.getValue('MERGE_CONFLICT_ACTION', false, 'fail');
}

getValue(key, required = false, defaulVal = null) {
if (key in this.env
&& this.env[key] !== null
Expand Down

0 comments on commit 276657f

Please sign in to comment.