fix: handle ambiguous argument failure on diff stat (#3312)
This commit is contained in:
parent
6073f5434b
commit
8867c4aba1
17
dist/index.js
vendored
17
dist/index.js
vendored
|
@ -46,6 +46,7 @@ exports.buildBranchCommits = buildBranchCommits;
|
||||||
exports.createOrUpdateBranch = createOrUpdateBranch;
|
exports.createOrUpdateBranch = createOrUpdateBranch;
|
||||||
const core = __importStar(__nccwpck_require__(2186));
|
const core = __importStar(__nccwpck_require__(2186));
|
||||||
const uuid_1 = __nccwpck_require__(5840);
|
const uuid_1 = __nccwpck_require__(5840);
|
||||||
|
const utils = __importStar(__nccwpck_require__(918));
|
||||||
const CHERRYPICK_EMPTY = 'The previous cherry-pick is now empty, possibly due to conflict resolution.';
|
const CHERRYPICK_EMPTY = 'The previous cherry-pick is now empty, possibly due to conflict resolution.';
|
||||||
const NOTHING_TO_COMMIT = 'nothing to commit, working tree clean';
|
const NOTHING_TO_COMMIT = 'nothing to commit, working tree clean';
|
||||||
const FETCH_DEPTH_MARGIN = 10;
|
const FETCH_DEPTH_MARGIN = 10;
|
||||||
|
@ -136,9 +137,19 @@ function isEven(git, branch1, branch2) {
|
||||||
// Return true if the specified number of commits on branch1 and branch2 have a diff
|
// Return true if the specified number of commits on branch1 and branch2 have a diff
|
||||||
function commitsHaveDiff(git, branch1, branch2, depth) {
|
function commitsHaveDiff(git, branch1, branch2, depth) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
const diff1 = (yield git.exec(['diff', '--stat', `${branch1}..${branch1}~${depth}`])).stdout.trim();
|
// Some action use cases lead to the depth being a very large number and the diff fails.
|
||||||
const diff2 = (yield git.exec(['diff', '--stat', `${branch2}..${branch2}~${depth}`])).stdout.trim();
|
// I've made this check optional for now because it was a fix for an edge case that is
|
||||||
return diff1 !== diff2;
|
// very rare, anyway.
|
||||||
|
try {
|
||||||
|
const diff1 = (yield git.exec(['diff', '--stat', `${branch1}..${branch1}~${depth}`])).stdout.trim();
|
||||||
|
const diff2 = (yield git.exec(['diff', '--stat', `${branch2}..${branch2}~${depth}`])).stdout.trim();
|
||||||
|
return diff1 !== diff2;
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
core.info('Failed optional check of commits diff; Skipping.');
|
||||||
|
core.debug(utils.getErrorMessage(error));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
function splitLines(multilineString) {
|
function splitLines(multilineString) {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import * as core from '@actions/core'
|
import * as core from '@actions/core'
|
||||||
import {GitCommandManager, Commit} from './git-command-manager'
|
import {GitCommandManager, Commit} from './git-command-manager'
|
||||||
import {v4 as uuidv4} from 'uuid'
|
import {v4 as uuidv4} from 'uuid'
|
||||||
|
import * as utils from './utils'
|
||||||
|
|
||||||
const CHERRYPICK_EMPTY =
|
const CHERRYPICK_EMPTY =
|
||||||
'The previous cherry-pick is now empty, possibly due to conflict resolution.'
|
'The previous cherry-pick is now empty, possibly due to conflict resolution.'
|
||||||
|
@ -131,13 +132,22 @@ async function commitsHaveDiff(
|
||||||
branch2: string,
|
branch2: string,
|
||||||
depth: number
|
depth: number
|
||||||
): Promise<boolean> {
|
): Promise<boolean> {
|
||||||
const diff1 = (
|
// Some action use cases lead to the depth being a very large number and the diff fails.
|
||||||
await git.exec(['diff', '--stat', `${branch1}..${branch1}~${depth}`])
|
// I've made this check optional for now because it was a fix for an edge case that is
|
||||||
).stdout.trim()
|
// very rare, anyway.
|
||||||
const diff2 = (
|
try {
|
||||||
await git.exec(['diff', '--stat', `${branch2}..${branch2}~${depth}`])
|
const diff1 = (
|
||||||
).stdout.trim()
|
await git.exec(['diff', '--stat', `${branch1}..${branch1}~${depth}`])
|
||||||
return diff1 !== diff2
|
).stdout.trim()
|
||||||
|
const diff2 = (
|
||||||
|
await git.exec(['diff', '--stat', `${branch2}..${branch2}~${depth}`])
|
||||||
|
).stdout.trim()
|
||||||
|
return diff1 !== diff2
|
||||||
|
} catch (error) {
|
||||||
|
core.info('Failed optional check of commits diff; Skipping.')
|
||||||
|
core.debug(utils.getErrorMessage(error))
|
||||||
|
return false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function splitLines(multilineString: string): string[] {
|
function splitLines(multilineString: string): string[] {
|
||||||
|
|
Loading…
Reference in a new issue