fix: handle nothing to commit when autocrlf is set (#1211)
This commit is contained in:
parent
20dac2ed48
commit
2721abb4d0
3 changed files with 22 additions and 6 deletions
11
dist/index.js
vendored
11
dist/index.js
vendored
|
@ -39,6 +39,7 @@ exports.createOrUpdateBranch = exports.tryFetch = exports.getWorkingBaseAndType
|
||||||
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 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';
|
||||||
var WorkingBaseType;
|
var WorkingBaseType;
|
||||||
(function (WorkingBaseType) {
|
(function (WorkingBaseType) {
|
||||||
WorkingBaseType["Branch"] = "branch";
|
WorkingBaseType["Branch"] = "branch";
|
||||||
|
@ -138,7 +139,11 @@ function createOrUpdateBranch(git, commitMessage, base, branch, branchRemoteName
|
||||||
if (signoff) {
|
if (signoff) {
|
||||||
popts.push('--signoff');
|
popts.push('--signoff');
|
||||||
}
|
}
|
||||||
yield git.commit(popts);
|
const commitResult = yield git.commit(popts, true);
|
||||||
|
// 'nothing to commit' can occur when core.autocrlf is set to true
|
||||||
|
if (commitResult.exitCode != 0 && !commitResult.stdout.includes(NOTHING_TO_COMMIT)) {
|
||||||
|
throw new Error(`Unexpected error: ${commitResult.stderr}`);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// Remove uncommitted tracked and untracked changes
|
// Remove uncommitted tracked and untracked changes
|
||||||
yield git.exec(['reset', '--hard']);
|
yield git.exec(['reset', '--hard']);
|
||||||
|
@ -674,7 +679,7 @@ class GitCommandManager {
|
||||||
return yield this.exec(args, allowAllExitCodes);
|
return yield this.exec(args, allowAllExitCodes);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
commit(options) {
|
commit(options, allowAllExitCodes = false) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
const args = ['commit'];
|
const args = ['commit'];
|
||||||
if (this.identityGitOptions) {
|
if (this.identityGitOptions) {
|
||||||
|
@ -683,7 +688,7 @@ class GitCommandManager {
|
||||||
if (options) {
|
if (options) {
|
||||||
args.push(...options);
|
args.push(...options);
|
||||||
}
|
}
|
||||||
yield this.exec(args);
|
return yield this.exec(args, allowAllExitCodes);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
config(configKey, configValue, globalConfig) {
|
config(configKey, configValue, globalConfig) {
|
||||||
|
|
|
@ -4,6 +4,7 @@ import {v4 as uuidv4} from 'uuid'
|
||||||
|
|
||||||
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.'
|
||||||
|
const NOTHING_TO_COMMIT = 'nothing to commit, working tree clean'
|
||||||
|
|
||||||
export enum WorkingBaseType {
|
export enum WorkingBaseType {
|
||||||
Branch = 'branch',
|
Branch = 'branch',
|
||||||
|
@ -134,7 +135,14 @@ export async function createOrUpdateBranch(
|
||||||
if (signoff) {
|
if (signoff) {
|
||||||
popts.push('--signoff')
|
popts.push('--signoff')
|
||||||
}
|
}
|
||||||
await git.commit(popts)
|
const commitResult = await git.commit(popts, true)
|
||||||
|
// 'nothing to commit' can occur when core.autocrlf is set to true
|
||||||
|
if (
|
||||||
|
commitResult.exitCode != 0 &&
|
||||||
|
!commitResult.stdout.includes(NOTHING_TO_COMMIT)
|
||||||
|
) {
|
||||||
|
throw new Error(`Unexpected error: ${commitResult.stderr}`)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Remove uncommitted tracked and untracked changes
|
// Remove uncommitted tracked and untracked changes
|
||||||
|
|
|
@ -53,7 +53,10 @@ export class GitCommandManager {
|
||||||
return await this.exec(args, allowAllExitCodes)
|
return await this.exec(args, allowAllExitCodes)
|
||||||
}
|
}
|
||||||
|
|
||||||
async commit(options?: string[]): Promise<void> {
|
async commit(
|
||||||
|
options?: string[],
|
||||||
|
allowAllExitCodes = false
|
||||||
|
): Promise<GitOutput> {
|
||||||
const args = ['commit']
|
const args = ['commit']
|
||||||
if (this.identityGitOptions) {
|
if (this.identityGitOptions) {
|
||||||
args.unshift(...this.identityGitOptions)
|
args.unshift(...this.identityGitOptions)
|
||||||
|
@ -63,7 +66,7 @@ export class GitCommandManager {
|
||||||
args.push(...options)
|
args.push(...options)
|
||||||
}
|
}
|
||||||
|
|
||||||
await this.exec(args)
|
return await this.exec(args, allowAllExitCodes)
|
||||||
}
|
}
|
||||||
|
|
||||||
async config(
|
async config(
|
||||||
|
|
Loading…
Reference in a new issue