mirror of
https://github.com/git/git
synced 2024-11-05 01:58:18 +00:00
Merge branch 'gt/test-commit-o-i-options'
A few tests to "git commit -o <pathspec>" and "git commit -i <pathspec>" has been added. * gt/test-commit-o-i-options: t7501: add tests for --amend --signoff t7501: add tests for --include and --only
This commit is contained in:
commit
2be9ccf23e
1 changed files with 96 additions and 2 deletions
|
@ -3,8 +3,7 @@
|
|||
# Copyright (c) 2007 Kristian Høgsberg <krh@redhat.com>
|
||||
#
|
||||
|
||||
# FIXME: Test the various index usages, -i and -o, test reflog,
|
||||
# signoff
|
||||
# FIXME: Test the various index usages, test reflog
|
||||
|
||||
test_description='git commit'
|
||||
GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
|
||||
|
@ -92,6 +91,34 @@ test_expect_success '--long fails with nothing to commit' '
|
|||
test_must_fail git commit -m initial --long
|
||||
'
|
||||
|
||||
test_expect_success 'fail to commit untracked file (even with --include/--only)' '
|
||||
echo content >baz &&
|
||||
error="error: pathspec .baz. did not match any file(s) known to git" &&
|
||||
|
||||
test_must_fail git commit -m "baz" baz 2>err &&
|
||||
test_grep -e "$error" err &&
|
||||
|
||||
test_must_fail git commit --only -m "baz" baz 2>err &&
|
||||
test_grep -e "$error" err &&
|
||||
|
||||
# TODO: as for --include, the below command will fail because
|
||||
# nothing is staged. If something was staged, it would not fail
|
||||
# even though the provided pathspec does not match any tracked
|
||||
# path. (However, the untracked paths that match the pathspec are
|
||||
# not committed and only the staged changes get committed.)
|
||||
# In either cases, no error is returned to stderr like in (--only
|
||||
# and without --only/--include) cases. In a similar manner,
|
||||
# "git add -u baz" also does not error out.
|
||||
#
|
||||
# Therefore, the below test is just to document the current behavior
|
||||
# and is not an endorsement to the current behavior, and we may
|
||||
# want to fix this. And when that happens, this test should be
|
||||
# updated accordingly.
|
||||
|
||||
test_must_fail git commit --include -m "baz" baz 2>err &&
|
||||
test_must_be_empty err
|
||||
'
|
||||
|
||||
test_expect_success 'setup: non-initial commit' '
|
||||
echo bongo bongo bongo >file &&
|
||||
git commit -m next -a
|
||||
|
@ -117,6 +144,51 @@ test_expect_success '--long with stuff to commit returns ok' '
|
|||
git commit -m next -a --long
|
||||
'
|
||||
|
||||
for opt in "" "-o" "--only"
|
||||
do
|
||||
test_expect_success 'exclude additional staged changes when given pathspec' '
|
||||
echo content >>file &&
|
||||
echo content >>baz &&
|
||||
git add baz &&
|
||||
git commit $opt -m "file" file &&
|
||||
|
||||
git diff --name-only >actual &&
|
||||
test_must_be_empty actual &&
|
||||
|
||||
test_write_lines baz >expect &&
|
||||
git diff --name-only --cached >actual &&
|
||||
test_cmp expect actual &&
|
||||
|
||||
test_write_lines file >expect &&
|
||||
git diff --name-only HEAD^ HEAD >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
done
|
||||
|
||||
test_expect_success '-i/--include includes staged changes' '
|
||||
echo content >>file &&
|
||||
echo content >>baz &&
|
||||
git add file &&
|
||||
|
||||
# baz is in the index, therefore, it will be committed
|
||||
git commit --include -m "file and baz" baz &&
|
||||
|
||||
git diff --name-only HEAD >remaining &&
|
||||
test_must_be_empty remaining &&
|
||||
|
||||
test_write_lines baz file >expect &&
|
||||
git diff --name-only HEAD^ HEAD >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success '--include and --only do not mix' '
|
||||
test_when_finished "git reset --hard" &&
|
||||
echo content >>file &&
|
||||
echo content >>baz &&
|
||||
test_must_fail git commit --include --only -m "file baz" file baz 2>actual &&
|
||||
test_grep -e "fatal: options .-i/--include. and .-o/--only. cannot be used together" actual
|
||||
'
|
||||
|
||||
test_expect_success 'commit message from non-existing file' '
|
||||
echo more bongo: bongo bongo bongo bongo >file &&
|
||||
test_must_fail git commit -F gah -a
|
||||
|
@ -389,6 +461,28 @@ test_expect_success 'amend commit to fix date' '
|
|||
|
||||
'
|
||||
|
||||
test_expect_success 'amend commit to add signoff' '
|
||||
|
||||
test_commit "msg" file content &&
|
||||
git commit --amend --signoff &&
|
||||
test_commit_message HEAD <<-EOF
|
||||
msg
|
||||
|
||||
Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success 'amend does not add signoff if it already exists' '
|
||||
|
||||
test_commit --signoff "tenor" file newcontent &&
|
||||
git commit --amend --signoff &&
|
||||
test_commit_message HEAD <<-EOF
|
||||
tenor
|
||||
|
||||
Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success 'commit mentions forced date in output' '
|
||||
git commit --amend --date=2010-01-02T03:04:05 >output &&
|
||||
grep "Date: *Sat Jan 2 03:04:05 2010" output
|
||||
|
|
Loading…
Reference in a new issue