merge -h: show usage even with corrupt index
Part of a campaign to make sure "git <command> -h" works correctly when run from distractingly bad repositories. [jn: with rewritten log message and tests] Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Jonathan Nieder <jrnieder@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
cbb3167ef8
commit
da53eec688
@ -909,6 +909,8 @@ int cmd_merge(int argc, const char **argv, const char *prefix)
|
||||
const char *best_strategy = NULL, *wt_strategy = NULL;
|
||||
struct commit_list **remotes = &remoteheads;
|
||||
|
||||
if (argc == 2 && !strcmp(argv[1], "-h"))
|
||||
usage_with_options(builtin_merge_usage, builtin_merge_options);
|
||||
if (read_cache_unmerged()) {
|
||||
die_resolve_conflict("merge");
|
||||
}
|
||||
|
@ -144,6 +144,17 @@ test_expect_success 'test option parsing' '
|
||||
test_must_fail git merge
|
||||
'
|
||||
|
||||
test_expect_success 'merge -h with invalid index' '
|
||||
mkdir broken &&
|
||||
(
|
||||
cd broken &&
|
||||
git init &&
|
||||
>.git/index &&
|
||||
test_expect_code 129 git merge -h 2>usage
|
||||
) &&
|
||||
grep "[Uu]sage: git merge" broken/usage
|
||||
'
|
||||
|
||||
test_expect_success 'reject non-strategy with a git-merge-foo name' '
|
||||
test_must_fail git merge -s index c1
|
||||
'
|
||||
|
Loading…
Reference in New Issue
Block a user