Browse Source

Merge branch 'md/test-cleanup'

Various test scripts have been updated for style and also correct
handling of exit status of various commands.

* md/test-cleanup:
  tests: order arguments to git-rev-list properly
  t9109: don't swallow Git errors upstream of pipes
  tests: don't swallow Git errors upstream of pipes
  t/*: fix ordering of expected/observed arguments
  tests: standardize pipe placement
  Documentation: add shell guidelines
  t/README: reformat Do, Don't, Keep in mind lists
maint
Junio C Hamano 6 years ago
parent
commit
f2e2136ad7
  1. 18
      Documentation/CodingGuidelines
  2. 69
      t/README
  3. 9
      t/lib-gpg.sh
  4. 2
      t/t0000-basic.sh
  5. 4
      t/t0021-conversion.sh
  6. 8
      t/t1006-cat-file.sh
  7. 9
      t/t1300-config.sh
  8. 4
      t/t1303-wacky-config.sh
  9. 2
      t/t2101-update-index-reupdate.sh
  10. 2
      t/t3200-branch.sh
  11. 4
      t/t3320-notes-merge-worktrees.sh
  12. 8
      t/t3400-rebase.sh
  13. 6
      t/t3417-rebase-whitespace-fix.sh
  14. 4
      t/t3702-add-edit.sh
  15. 8
      t/t3903-stash.sh
  16. 2
      t/t3905-stash-include-untracked.sh
  17. 2
      t/t4025-hunk-header.sh
  18. 6
      t/t4117-apply-reject.sh
  19. 30
      t/t4124-apply-ws-rule.sh
  20. 2
      t/t4138-apply-ws-expansion.sh
  21. 360
      t/t5317-pack-objects-filter-objects.sh
  22. 2
      t/t5318-commit-graph.sh
  23. 7
      t/t5500-fetch-pack.sh
  24. 50
      t/t5616-partial-clone.sh
  25. 14
      t/t5701-git-serve.sh
  26. 14
      t/t5702-protocol-v2.sh
  27. 12
      t/t6023-merge-file.sh
  28. 4
      t/t6027-merge-binary.sh
  29. 2
      t/t6031-merge-filemode.sh
  30. 237
      t/t6112-rev-list-filters-objects.sh
  31. 4
      t/t7201-co.sh
  32. 8
      t/t7406-submodule-update.sh
  33. 2
      t/t7800-difftool.sh
  34. 2
      t/t9100-git-svn-basic.sh
  35. 34
      t/t9101-git-svn-props.sh
  36. 6
      t/t9133-git-svn-nested-git-repo.sh
  37. 2
      t/t9600-cvsimport.sh
  38. 4
      t/t9603-cvsimport-patchsets.sh
  39. 4
      t/t9604-cvsimport-timestamps.sh

18
Documentation/CodingGuidelines

@ -118,6 +118,24 @@ For shell scripts specifically (not exhaustive): @@ -118,6 +118,24 @@ For shell scripts specifically (not exhaustive):
do this
fi

- If a command sequence joined with && or || or | spans multiple
lines, put each command on a separate line and put && and || and |
operators at the end of each line, rather than the start. This
means you don't need to use \ to join lines, since the above
operators imply the sequence isn't finished.

(incorrect)
grep blob verify_pack_result \
| awk -f print_1.awk \
| sort >actual &&
...

(correct)
grep blob verify_pack_result |
awk -f print_1.awk |
sort >actual &&
...

- We prefer "test" over "[ ... ]".

- We do not write the noiseword "function" in front of shell

69
t/README

@ -401,13 +401,13 @@ This test harness library does the following things: @@ -401,13 +401,13 @@ This test harness library does the following things:
consistently when command line arguments --verbose (or -v),
--debug (or -d), and --immediate (or -i) is given.

Do's, don'ts & things to keep in mind
-------------------------------------
Do's & don'ts
-------------

Here are a few examples of things you probably should and shouldn't do
when writing tests.

Do:
Here are the "do's:"

- Put all code inside test_expect_success and other assertions.

@ -452,16 +452,21 @@ Do: @@ -452,16 +452,21 @@ Do:
Windows, where the shell (MSYS bash) mangles absolute path names.
For details, see the commit message of 4114156ae9.

Don't:
- Remember that inside the <script> part, the standard output and
standard error streams are discarded, and the test harness only
reports "ok" or "not ok" to the end user running the tests. Under
--verbose, they are shown to help debug the tests.

And here are the "don'ts:"

- exit() within a <script> part.
- Don't exit() within a <script> part.

The harness will catch this as a programming error of the test.
Use test_done instead if you need to stop the tests early (see
"Skipping tests" below).

- use '! git cmd' when you want to make sure the git command exits
with failure in a controlled way by calling "die()". Instead,
- Don't use '! git cmd' when you want to make sure the git command
exits with failure in a controlled way by calling "die()". Instead,
use 'test_must_fail git cmd'. This will signal a failure if git
dies in an unexpected way (e.g. segfault).

@ -469,8 +474,35 @@ Don't: @@ -469,8 +474,35 @@ Don't:
platform commands; just use '! cmd'. We are not in the business
of verifying that the world given to us sanely works.

- use perl without spelling it as "$PERL_PATH". This is to help our
friends on Windows where the platform Perl often adds CR before
- Don't feed the output of a git command to a pipe, as in:

git -C repo ls-files |
xargs -n 1 basename |
grep foo

which will discard git's exit code and may mask a crash. In the
above example, all exit codes are ignored except grep's.

Instead, write the output of that command to a temporary
file with ">" or assign it to a variable with "x=$(git ...)" rather
than pipe it.

- Don't use command substitution in a way that discards git's exit
code. When assigning to a variable, the exit code is not discarded,
e.g.:

x=$(git cat-file -p $sha) &&
...

is OK because a crash in "git cat-file" will cause the "&&" chain
to fail, but:

test "refs/heads/foo" = "$(git symbolic-ref HEAD)"

is not OK and a crash in git could go undetected.

- Don't use perl without spelling it as "$PERL_PATH". This is to help
our friends on Windows where the platform Perl often adds CR before
the end of line, and they bundle Git with a version of Perl that
does not do so, whose path is specified with $PERL_PATH. Note that we
provide a "perl" function which uses $PERL_PATH under the hood, so
@ -478,17 +510,17 @@ Don't: @@ -478,17 +510,17 @@ Don't:
(but you do, for example, on a shebang line or in a sub script
created via "write_script").

- use sh without spelling it as "$SHELL_PATH", when the script can
be misinterpreted by broken platform shell (e.g. Solaris).
- Don't use sh without spelling it as "$SHELL_PATH", when the script
can be misinterpreted by broken platform shell (e.g. Solaris).

- chdir around in tests. It is not sufficient to chdir to
- Don't chdir around in tests. It is not sufficient to chdir to
somewhere and then chdir back to the original location later in
the test, as any intermediate step can fail and abort the test,
causing the next test to start in an unexpected directory. Do so
inside a subshell if necessary.

- save and verify the standard error of compound commands, i.e. group
commands, subshells, and shell functions (except test helper
- Don't save and verify the standard error of compound commands, i.e.
group commands, subshells, and shell functions (except test helper
functions like 'test_must_fail') like this:

( cd dir && git cmd ) 2>error &&
@ -503,7 +535,7 @@ Don't: @@ -503,7 +535,7 @@ Don't:
( cd dir && git cmd 2>../error ) &&
test_cmp expect error

- Break the TAP output
- Don't break the TAP output

The raw output from your test may be interpreted by a TAP harness. TAP
harnesses will ignore everything they don't know about, but don't step
@ -523,13 +555,6 @@ Don't: @@ -523,13 +555,6 @@ Don't:
but the best indication is to just run the tests with prove(1),
it'll complain if anything is amiss.

Keep in mind:

- Inside the <script> part, the standard output and standard error
streams are discarded, and the test harness only reports "ok" or
"not ok" to the end user running the tests. Under --verbose, they
are shown to help debugging the tests.


Skipping tests
--------------

9
t/lib-gpg.sh

@ -57,9 +57,12 @@ then @@ -57,9 +57,12 @@ then
echo | gpgsm --homedir "${GNUPGHOME}" 2>/dev/null \
--passphrase-fd 0 --pinentry-mode loopback \
--import "$TEST_DIRECTORY"/lib-gpg/gpgsm_cert.p12 &&
gpgsm --homedir "${GNUPGHOME}" 2>/dev/null -K \
| grep fingerprint: | cut -d" " -f4 | tr -d '\n' > \
${GNUPGHOME}/trustlist.txt &&

gpgsm --homedir "${GNUPGHOME}" 2>/dev/null -K |
grep fingerprint: |
cut -d" " -f4 |
tr -d '\n' >"${GNUPGHOME}/trustlist.txt" &&

echo " S relax" >> ${GNUPGHOME}/trustlist.txt &&
(gpgconf --kill gpg-agent >/dev/null 2>&1 || : ) &&
echo hello | gpgsm --homedir "${GNUPGHOME}" >/dev/null \

2
t/t0000-basic.sh

@ -1097,7 +1097,7 @@ test_expect_success 'validate git diff-files output for a know cache/work tree s @@ -1097,7 +1097,7 @@ test_expect_success 'validate git diff-files output for a know cache/work tree s
:120000 120000 $(test_oid subp3s) $ZERO_OID M path3/subp3/file3sym
EOF
git diff-files >current &&
test_cmp current expected
test_cmp expected current
'

test_expect_success 'git update-index --refresh should succeed' '

4
t/t0021-conversion.sh

@ -166,10 +166,10 @@ test_expect_success expanded_in_repo ' @@ -166,10 +166,10 @@ test_expect_success expanded_in_repo '
rm -f expanded-keywords expanded-keywords-crlf &&

git checkout -- expanded-keywords &&
test_cmp expanded-keywords expected-output &&
test_cmp expected-output expanded-keywords &&

git checkout -- expanded-keywords-crlf &&
test_cmp expanded-keywords-crlf expected-output-crlf
test_cmp expected-output-crlf expanded-keywords-crlf
'

# The use of %f in a filter definition is expanded to the path to

8
t/t1006-cat-file.sh

@ -220,8 +220,8 @@ test_expect_success "--batch-check for a non-existent hash" ' @@ -220,8 +220,8 @@ test_expect_success "--batch-check for a non-existent hash" '
test "0000000000000000000000000000000000000042 missing
0000000000000000000000000000000000000084 missing" = \
"$( ( echo 0000000000000000000000000000000000000042;
echo_without_newline 0000000000000000000000000000000000000084; ) \
| git cat-file --batch-check)"
echo_without_newline 0000000000000000000000000000000000000084; ) |
git cat-file --batch-check)"
'

test_expect_success "--batch for an existent and a non-existent hash" '
@ -229,8 +229,8 @@ test_expect_success "--batch for an existent and a non-existent hash" ' @@ -229,8 +229,8 @@ test_expect_success "--batch for an existent and a non-existent hash" '
$tag_content
0000000000000000000000000000000000000000 missing" = \
"$( ( echo $tag_sha1;
echo_without_newline 0000000000000000000000000000000000000000; ) \
| git cat-file --batch)"
echo_without_newline 0000000000000000000000000000000000000000; ) |
git cat-file --batch)"
'

test_expect_success "--batch-check for an empty line" '

9
t/t1300-config.sh

@ -1001,7 +1001,7 @@ EOF @@ -1001,7 +1001,7 @@ EOF

test_expect_success 'value continued on next line' '
git config --list > result &&
test_cmp result expect
test_cmp expect result
'

cat > .git/config <<\EOF
@ -1770,8 +1770,9 @@ test_expect_success '--show-origin stdin with file include' ' @@ -1770,8 +1770,9 @@ test_expect_success '--show-origin stdin with file include' '
cat >expect <<-EOF &&
file:$INCLUDE_DIR/stdin.include include
EOF
echo "[include]path=\"$INCLUDE_DIR\"/stdin.include" \
| git config --show-origin --includes --file - user.stdin >output &&
echo "[include]path=\"$INCLUDE_DIR\"/stdin.include" |
git config --show-origin --includes --file - user.stdin >output &&

test_cmp expect output
'

@ -1881,7 +1882,7 @@ test_expect_success '--replace-all does not invent newlines' ' @@ -1881,7 +1882,7 @@ test_expect_success '--replace-all does not invent newlines' '
Qkey = b
EOF
git config --replace-all abc.key b &&
test_cmp .git/config expect
test_cmp expect .git/config
'

test_done

4
t/t1303-wacky-config.sh

@ -14,7 +14,7 @@ setup() { @@ -14,7 +14,7 @@ setup() {
check() {
echo "$2" >expected
git config --get "$1" >actual 2>&1
test_cmp actual expected
test_cmp expected actual
}

# 'check section.key regex value' verifies that the entry for
@ -22,7 +22,7 @@ check() { @@ -22,7 +22,7 @@ check() {
check_regex() {
echo "$3" >expected
git config --get "$1" "$2" >actual 2>&1
test_cmp actual expected
test_cmp expected actual
}

test_expect_success 'modify same key' '

2
t/t2101-update-index-reupdate.sh

@ -73,7 +73,7 @@ test_expect_success 'update-index --update from subdir' ' @@ -73,7 +73,7 @@ test_expect_success 'update-index --update from subdir' '
100644 $(git hash-object dir1/file3) 0 dir1/file3
100644 $file2 0 file2
EOF
test_cmp current expected
test_cmp expected current
'

test_expect_success 'update-index --update with pathspec' '

2
t/t3200-branch.sh

@ -1221,7 +1221,7 @@ test_expect_success 'use --edit-description' ' @@ -1221,7 +1221,7 @@ test_expect_success 'use --edit-description' '
EOF
EDITOR=./editor git branch --edit-description &&
echo "New contents" >expect &&
test_cmp EDITOR_OUTPUT expect
test_cmp expect EDITOR_OUTPUT
'

test_expect_success 'detect typo in branch name when using --edit-description' '

4
t/t3320-notes-merge-worktrees.sh

@ -44,7 +44,7 @@ test_expect_success 'merge z into y fails and sets NOTES_MERGE_REF' ' @@ -44,7 +44,7 @@ test_expect_success 'merge z into y fails and sets NOTES_MERGE_REF' '
git config core.notesRef refs/notes/y &&
test_must_fail git notes merge z &&
echo "ref: refs/notes/y" >expect &&
test_cmp .git/NOTES_MERGE_REF expect
test_cmp expect .git/NOTES_MERGE_REF
'

test_expect_success 'merge z into y while mid-merge in another workdir fails' '
@ -66,7 +66,7 @@ test_expect_success 'merge z into x while mid-merge on y succeeds' ' @@ -66,7 +66,7 @@ test_expect_success 'merge z into x while mid-merge on y succeeds' '
grep -v "A notes merge into refs/notes/x is already in-progress in" out
) &&
echo "ref: refs/notes/x" >expect &&
test_cmp .git/worktrees/worktree2/NOTES_MERGE_REF expect
test_cmp expect .git/worktrees/worktree2/NOTES_MERGE_REF
'

test_done

8
t/t3400-rebase.sh

@ -183,13 +183,13 @@ test_expect_success 'cherry-picked commits and fork-point work together' ' @@ -183,13 +183,13 @@ test_expect_success 'cherry-picked commits and fork-point work together' '
test_commit final_B B "Final B" &&
git rebase &&
echo Amended >expect &&
test_cmp A expect &&
test_cmp expect A &&
echo "Final B" >expect &&
test_cmp B expect &&
test_cmp expect B &&
echo C >expect &&
test_cmp C expect &&
test_cmp expect C &&
echo D >expect &&
test_cmp D expect
test_cmp expect D
'

test_expect_success 'rebase -q is quiet' '

6
t/t3417-rebase-whitespace-fix.sh

@ -55,7 +55,7 @@ test_expect_success 'blank line at end of file; extend at end of file' ' @@ -55,7 +55,7 @@ test_expect_success 'blank line at end of file; extend at end of file' '
git add file && git commit -m second &&
git rebase --whitespace=fix HEAD^^ &&
git diff --exit-code HEAD^:file expect-first &&
test_cmp file expect-second
test_cmp expect-second file
'

# prepare third revision of "file"
@ -82,7 +82,7 @@ test_expect_success 'two blanks line at end of file; extend at end of file' ' @@ -82,7 +82,7 @@ test_expect_success 'two blanks line at end of file; extend at end of file' '
cp third file && git add file && git commit -m third &&
git rebase --whitespace=fix HEAD^^ &&
git diff --exit-code HEAD^:file expect-second &&
test_cmp file expect-third
test_cmp expect-third file
'

test_expect_success 'same, but do not remove trailing spaces' '
@ -120,7 +120,7 @@ test_expect_success 'at beginning of file' ' @@ -120,7 +120,7 @@ test_expect_success 'at beginning of file' '
done >> file &&
git commit -m more file &&
git rebase --whitespace=fix HEAD^^ &&
test_cmp file expect-beginning
test_cmp expect-beginning file
'

test_done

4
t/t3702-add-edit.sh

@ -110,10 +110,10 @@ test_expect_success 'add -e' ' @@ -110,10 +110,10 @@ test_expect_success 'add -e' '
cp second-part file &&
git add -e &&
test_cmp second-part file &&
test_cmp orig-patch expected-patch &&
test_cmp expected-patch orig-patch &&
git diff --cached >actual &&
grep -v index actual >out &&
test_cmp out expected
test_cmp expected out

'


8
t/t3903-stash.sh

@ -36,7 +36,7 @@ EOF @@ -36,7 +36,7 @@ EOF
test_expect_success 'parents of stash' '
test $(git rev-parse stash^) = $(git rev-parse HEAD) &&
git diff stash^2..stash > output &&
test_cmp output expect
test_cmp expect output
'

test_expect_success 'applying bogus stash does nothing' '
@ -210,9 +210,9 @@ test_expect_success 'stash branch' ' @@ -210,9 +210,9 @@ test_expect_success 'stash branch' '
test refs/heads/stashbranch = $(git symbolic-ref HEAD) &&
test $(git rev-parse HEAD) = $(git rev-parse master^) &&
git diff --cached > output &&
test_cmp output expect &&
test_cmp expect output &&
git diff > output &&
test_cmp output expect1 &&
test_cmp expect1 output &&
git add file &&
git commit -m alternate\ second &&
git diff master..stashbranch > output &&
@ -710,7 +710,7 @@ test_expect_success 'stash where working directory contains "HEAD" file' ' @@ -710,7 +710,7 @@ test_expect_success 'stash where working directory contains "HEAD" file' '
git diff-index --cached --quiet HEAD &&
test "$(git rev-parse stash^)" = "$(git rev-parse HEAD)" &&
git diff stash^..stash > output &&
test_cmp output expect
test_cmp expect output
'

test_expect_success 'store called with invalid commit' '

2
t/t3905-stash-include-untracked.sh

@ -142,7 +142,7 @@ test_expect_success 'stash save --include-untracked removed files' ' @@ -142,7 +142,7 @@ test_expect_success 'stash save --include-untracked removed files' '
rm -f file &&
git stash save --include-untracked &&
echo 1 > expect &&
test_cmp file expect
test_cmp expect file
'

rm -f expect

2
t/t4025-hunk-header.sh

@ -37,7 +37,7 @@ test_expect_success 'hunk header truncation with an overly long line' ' @@ -37,7 +37,7 @@ test_expect_success 'hunk header truncation with an overly long line' '
echo " A $N$N$N$N$N$N$N$N$N2" &&
echo " L $N$N$N$N$N$N$N$N$N1"
) >expected &&
test_cmp actual expected
test_cmp expected actual

'


6
t/t4117-apply-reject.sh

@ -72,7 +72,7 @@ test_expect_success 'apply with --reject should fail but update the file' ' @@ -72,7 +72,7 @@ test_expect_success 'apply with --reject should fail but update the file' '
rm -f file1.rej file2.rej &&

test_must_fail git apply --reject patch.1 &&
test_cmp file1 expected &&
test_cmp expected file1 &&

cat file1.rej &&
test_path_is_missing file2.rej
@ -85,7 +85,7 @@ test_expect_success 'apply with --reject should fail but update the file' ' @@ -85,7 +85,7 @@ test_expect_success 'apply with --reject should fail but update the file' '

test_must_fail git apply --reject patch.2 >rejects &&
test_path_is_missing file1 &&
test_cmp file2 expected &&
test_cmp expected file2 &&

cat file2.rej &&
test_path_is_missing file1.rej
@ -99,7 +99,7 @@ test_expect_success 'the same test with --verbose' ' @@ -99,7 +99,7 @@ test_expect_success 'the same test with --verbose' '

test_must_fail git apply --reject --verbose patch.2 >rejects &&
test_path_is_missing file1 &&
test_cmp file2 expected &&
test_cmp expected file2 &&

cat file2.rej &&
test_path_is_missing file1.rej

30
t/t4124-apply-ws-rule.sh

@ -313,9 +313,9 @@ test_expect_success 'applying beyond EOF requires one non-blank context line' ' @@ -313,9 +313,9 @@ test_expect_success 'applying beyond EOF requires one non-blank context line' '
{ echo a; echo; } >one &&
cp one expect &&
test_must_fail git apply --whitespace=fix patch &&
test_cmp one expect &&
test_cmp expect one &&
test_must_fail git apply --ignore-space-change --whitespace=fix patch &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'tons of blanks at EOF should not apply' '
@ -342,10 +342,10 @@ test_expect_success 'missing blank line at end with --whitespace=fix' ' @@ -342,10 +342,10 @@ test_expect_success 'missing blank line at end with --whitespace=fix' '
cp one saved-one &&
test_must_fail git apply patch &&
git apply --whitespace=fix patch &&
test_cmp one expect &&
test_cmp expect one &&
mv saved-one one &&
git apply --ignore-space-change --whitespace=fix patch &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'two missing blank lines at end with --whitespace=fix' '
@ -360,11 +360,11 @@ test_expect_success 'two missing blank lines at end with --whitespace=fix' ' @@ -360,11 +360,11 @@ test_expect_success 'two missing blank lines at end with --whitespace=fix' '
cp no-blank-lines one &&
test_must_fail git apply patch &&
git apply --whitespace=fix patch &&
test_cmp one expect &&
test_cmp expect one &&
mv no-blank-lines one &&
test_must_fail git apply patch &&
git apply --ignore-space-change --whitespace=fix patch &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'missing blank line at end, insert before end, --whitespace=fix' '
@ -376,7 +376,7 @@ test_expect_success 'missing blank line at end, insert before end, --whitespace= @@ -376,7 +376,7 @@ test_expect_success 'missing blank line at end, insert before end, --whitespace=
echo a >one &&
test_must_fail git apply patch &&
git apply --whitespace=fix patch &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'shrink file with tons of missing blanks at end of file' '
@ -392,10 +392,10 @@ test_expect_success 'shrink file with tons of missing blanks at end of file' ' @@ -392,10 +392,10 @@ test_expect_success 'shrink file with tons of missing blanks at end of file' '
cp no-blank-lines one &&
test_must_fail git apply patch &&
git apply --whitespace=fix patch &&
test_cmp one expect &&
test_cmp expect one &&
mv no-blank-lines one &&
git apply --ignore-space-change --whitespace=fix patch &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'missing blanks at EOF must only match blank lines' '
@ -427,7 +427,7 @@ test_expect_success 'missing blank line should match context line with spaces' ' @@ -427,7 +427,7 @@ test_expect_success 'missing blank line should match context line with spaces' '
git add one &&

git apply --whitespace=fix patch &&
test_cmp one expect
test_cmp expect one
'

sed -e's/Z//' >one <<EOF
@ -447,7 +447,7 @@ test_expect_success 'same, but with the --ignore-space-option' ' @@ -447,7 +447,7 @@ test_expect_success 'same, but with the --ignore-space-option' '

git checkout-index -f one &&
git apply --ignore-space-change --whitespace=fix patch &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'same, but with CR-LF line endings && cr-at-eol set' '
@ -464,7 +464,7 @@ test_expect_success 'same, but with CR-LF line endings && cr-at-eol set' ' @@ -464,7 +464,7 @@ test_expect_success 'same, but with CR-LF line endings && cr-at-eol set' '
mv save-one one &&

git apply --ignore-space-change --whitespace=fix patch &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'CR-LF line endings && add line && text=auto' '
@ -478,7 +478,7 @@ test_expect_success 'CR-LF line endings && add line && text=auto' ' @@ -478,7 +478,7 @@ test_expect_success 'CR-LF line endings && add line && text=auto' '
mv save-one one &&
echo "one text=auto" >.gitattributes &&
git apply patch &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'CR-LF line endings && change line && text=auto' '
@ -491,7 +491,7 @@ test_expect_success 'CR-LF line endings && change line && text=auto' ' @@ -491,7 +491,7 @@ test_expect_success 'CR-LF line endings && change line && text=auto' '
mv save-one one &&
echo "one text=auto" >.gitattributes &&
git apply patch &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'LF in repo, CRLF in worktree && change line && text=auto' '
@ -503,7 +503,7 @@ test_expect_success 'LF in repo, CRLF in worktree && change line && text=auto' ' @@ -503,7 +503,7 @@ test_expect_success 'LF in repo, CRLF in worktree && change line && text=auto' '
echo "one text=auto" >.gitattributes &&
git -c core.eol=CRLF apply patch &&
printf "b\r\n" >expect &&
test_cmp one expect
test_cmp expect one
'

test_expect_success 'whitespace=fix to expand' '

2
t/t4138-apply-ws-expansion.sh

@ -114,7 +114,7 @@ for t in 1 2 3 4 @@ -114,7 +114,7 @@ for t in 1 2 3 4
do
test_expect_success 'apply with ws expansion (t=$t)' '
git apply patch$t.patch &&
test_cmp test-$t expect-$t
test_cmp expect-$t test-$t
'
done


360
t/t5317-pack-objects-filter-objects.sh

@ -21,17 +21,21 @@ test_expect_success 'setup r1' ' @@ -21,17 +21,21 @@ test_expect_success 'setup r1' '

test_expect_success 'verify blob count in normal packfile' '
git -C r1 ls-files -s file.1 file.2 file.3 file.4 file.5 \
| awk -f print_2.awk \
| sort >expected &&
>ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r1 pack-objects --rev --stdout >all.pack <<-EOF &&
HEAD
EOF
git -C r1 index-pack ../all.pack &&
git -C r1 verify-pack -v ../all.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r1 verify-pack -v ../all.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify blob:none packfile has no blobs' '
@ -39,24 +43,28 @@ test_expect_success 'verify blob:none packfile has no blobs' ' @@ -39,24 +43,28 @@ test_expect_success 'verify blob:none packfile has no blobs' '
HEAD
EOF
git -C r1 index-pack ../filter.pack &&
git -C r1 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&

git -C r1 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

nr=$(wc -l <observed) &&
test 0 -eq $nr
'

test_expect_success 'verify normal and blob:none packfiles have same commits/trees' '
git -C r1 verify-pack -v ../all.pack \
| grep -E "commit|tree" \
| awk -f print_1.awk \
| sort >expected &&
git -C r1 verify-pack -v ../filter.pack \
| grep -E "commit|tree" \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected
git -C r1 verify-pack -v ../all.pack >verify_result &&
grep -E "commit|tree" verify_result |
awk -f print_1.awk |
sort >expected &&

git -C r1 verify-pack -v ../filter.pack >verify_result &&
grep -E "commit|tree" verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

# Test blob:limit=<n>[kmg] filter.
@ -75,18 +83,21 @@ test_expect_success 'setup r2' ' @@ -75,18 +83,21 @@ test_expect_success 'setup r2' '
'

test_expect_success 'verify blob count in normal packfile' '
git -C r2 ls-files -s large.1000 large.10000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 ls-files -s large.1000 large.10000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 pack-objects --rev --stdout >all.pack <<-EOF &&
HEAD
EOF
git -C r2 index-pack ../all.pack &&
git -C r2 verify-pack -v ../all.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r2 verify-pack -v ../all.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify blob:limit=500 omits all blobs' '
@ -94,10 +105,12 @@ test_expect_success 'verify blob:limit=500 omits all blobs' ' @@ -94,10 +105,12 @@ test_expect_success 'verify blob:limit=500 omits all blobs' '
HEAD
EOF
git -C r2 index-pack ../filter.pack &&
git -C r2 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&

git -C r2 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

nr=$(wc -l <observed) &&
test 0 -eq $nr
'
@ -107,100 +120,119 @@ test_expect_success 'verify blob:limit=1000' ' @@ -107,100 +120,119 @@ test_expect_success 'verify blob:limit=1000' '
HEAD
EOF
git -C r2 index-pack ../filter.pack &&
git -C r2 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&

git -C r2 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

nr=$(wc -l <observed) &&
test 0 -eq $nr
'

test_expect_success 'verify blob:limit=1001' '
git -C r2 ls-files -s large.1000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 ls-files -s large.1000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 pack-objects --rev --stdout --filter=blob:limit=1001 >filter.pack <<-EOF &&
HEAD
EOF
git -C r2 index-pack ../filter.pack &&
git -C r2 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r2 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify blob:limit=10001' '
git -C r2 ls-files -s large.1000 large.10000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 ls-files -s large.1000 large.10000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 pack-objects --rev --stdout --filter=blob:limit=10001 >filter.pack <<-EOF &&
HEAD
EOF
git -C r2 index-pack ../filter.pack &&
git -C r2 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r2 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify blob:limit=1k' '
git -C r2 ls-files -s large.1000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 ls-files -s large.1000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 pack-objects --rev --stdout --filter=blob:limit=1k >filter.pack <<-EOF &&
HEAD
EOF
git -C r2 index-pack ../filter.pack &&
git -C r2 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r2 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify explicitly specifying oversized blob in input' '
git -C r2 ls-files -s large.1000 large.10000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 ls-files -s large.1000 large.10000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 pack-objects --rev --stdout --filter=blob:limit=1k >filter.pack <<-EOF &&
HEAD
$(git -C r2 rev-parse HEAD:large.10000)
EOF
git -C r2 index-pack ../filter.pack &&
git -C r2 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r2 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify blob:limit=1m' '
git -C r2 ls-files -s large.1000 large.10000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 ls-files -s large.1000 large.10000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 pack-objects --rev --stdout --filter=blob:limit=1m >filter.pack <<-EOF &&
HEAD
EOF
git -C r2 index-pack ../filter.pack &&
git -C r2 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r2 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify normal and blob:limit packfiles have same commits/trees' '
git -C r2 verify-pack -v ../all.pack \
| grep -E "commit|tree" \
| awk -f print_1.awk \
| sort >expected &&
git -C r2 verify-pack -v ../filter.pack \
| grep -E "commit|tree" \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected
git -C r2 verify-pack -v ../all.pack >verify_result &&
grep -E "commit|tree" verify_result |
awk -f print_1.awk |
sort >expected &&

git -C r2 verify-pack -v ../filter.pack >verify_result &&
grep -E "commit|tree" verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

# Test sparse:path=<path> filter.
@ -225,71 +257,85 @@ test_expect_success 'setup r3' ' @@ -225,71 +257,85 @@ test_expect_success 'setup r3' '

test_expect_success 'verify blob count in normal packfile' '
git -C r3 ls-files -s sparse1 sparse2 dir1/sparse1 dir1/sparse2 \
| awk -f print_2.awk \
| sort >expected &&
>ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r3 pack-objects --rev --stdout >all.pack <<-EOF &&
HEAD
EOF
git -C r3 index-pack ../all.pack &&
git -C r3 verify-pack -v ../all.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r3 verify-pack -v ../all.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify sparse:path=pattern1' '
git -C r3 ls-files -s dir1/sparse1 dir1/sparse2 \
| awk -f print_2.awk \
| sort >expected &&
git -C r3 ls-files -s dir1/sparse1 dir1/sparse2 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r3 pack-objects --rev --stdout --filter=sparse:path=../pattern1 >filter.pack <<-EOF &&
HEAD
EOF
git -C r3 index-pack ../filter.pack &&
git -C r3 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r3 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify normal and sparse:path=pattern1 packfiles have same commits/trees' '
git -C r3 verify-pack -v ../all.pack \
| grep -E "commit|tree" \
| awk -f print_1.awk \
| sort >expected &&
git -C r3 verify-pack -v ../filter.pack \
| grep -E "commit|tree" \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected
git -C r3 verify-pack -v ../all.pack >verify_result &&
grep -E "commit|tree" verify_result |
awk -f print_1.awk |
sort >expected &&

git -C r3 verify-pack -v ../filter.pack >verify_result &&
grep -E "commit|tree" verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify sparse:path=pattern2' '
git -C r3 ls-files -s sparse1 dir1/sparse1 \
| awk -f print_2.awk \
| sort >expected &&
git -C r3 ls-files -s sparse1 dir1/sparse1 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r3 pack-objects --rev --stdout --filter=sparse:path=../pattern2 >filter.pack <<-EOF &&
HEAD
EOF
git -C r3 index-pack ../filter.pack &&
git -C r3 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r3 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify normal and sparse:path=pattern2 packfiles have same commits/trees' '
git -C r3 verify-pack -v ../all.pack \
| grep -E "commit|tree" \
| awk -f print_1.awk \
| sort >expected &&
git -C r3 verify-pack -v ../filter.pack \
| grep -E "commit|tree" \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected
git -C r3 verify-pack -v ../all.pack >verify_result &&
grep -E "commit|tree" verify_result |
awk -f print_1.awk |
sort >expected &&

git -C r3 verify-pack -v ../filter.pack >verify_result &&
grep -E "commit|tree" verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

# Test sparse:oid=<oid-ish> filter.
@ -313,48 +359,58 @@ test_expect_success 'setup r4' ' @@ -313,48 +359,58 @@ test_expect_success 'setup r4' '

test_expect_success 'verify blob count in normal packfile' '
git -C r4 ls-files -s pattern sparse1 sparse2 dir1/sparse1 dir1/sparse2 \
| awk -f print_2.awk \
| sort >expected &&
>ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r4 pack-objects --rev --stdout >all.pack <<-EOF &&
HEAD
EOF
git -C r4 index-pack ../all.pack &&
git -C r4 verify-pack -v ../all.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r4 verify-pack -v ../all.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify sparse:oid=OID' '
git -C r4 ls-files -s dir1/sparse1 dir1/sparse2 \
| awk -f print_2.awk \
| sort >expected &&
git -C r4 ls-files -s dir1/sparse1 dir1/sparse2 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

oid=$(git -C r4 ls-files -s pattern | awk -f print_2.awk) &&
git -C r4 pack-objects --rev --stdout --filter=sparse:oid=$oid >filter.pack <<-EOF &&
HEAD
EOF
git -C r4 index-pack ../filter.pack &&
git -C r4 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r4 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify sparse:oid=oid-ish' '
git -C r4 ls-files -s dir1/sparse1 dir1/sparse2 \
| awk -f print_2.awk \
| sort >expected &&
git -C r4 ls-files -s dir1/sparse1 dir1/sparse2 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r4 pack-objects --rev --stdout --filter=sparse:oid=master:pattern >filter.pack <<-EOF &&
HEAD
EOF
git -C r4 index-pack ../filter.pack &&
git -C r4 verify-pack -v ../filter.pack \
| grep blob \
| awk -f print_1.awk \
| sort >observed &&
test_cmp observed expected

git -C r4 verify-pack -v ../filter.pack >verify_result &&
grep blob verify_result |
awk -f print_1.awk |
sort >observed &&

test_cmp expected observed
'

# Delete some loose objects and use pack-objects, but WITHOUT any filtering.
@ -362,8 +418,10 @@ test_expect_success 'verify sparse:oid=oid-ish' ' @@ -362,8 +418,10 @@ test_expect_success 'verify sparse:oid=oid-ish' '

test_expect_success 'setup r1 - delete loose blobs' '
git -C r1 ls-files -s file.1 file.2 file.3 file.4 file.5 \
| awk -f print_2.awk \
| sort >expected &&
>ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

for id in `cat expected | sed "s|..|&/|"`
do
rm r1/.git/objects/$id

2
t/t5318-commit-graph.sh

@ -36,7 +36,7 @@ test_expect_success 'create commits and repack' ' @@ -36,7 +36,7 @@ test_expect_success 'create commits and repack' '
graph_git_two_modes() {
git -c core.commitGraph=true $1 >output
git -c core.commitGraph=false $1 >expect
test_cmp output expect
test_cmp expect output
}

graph_git_behavior() {

7
t/t5500-fetch-pack.sh

@ -50,8 +50,11 @@ pull_to_client () { @@ -50,8 +50,11 @@ pull_to_client () {
case "$heads" in *B*)
git update-ref refs/heads/B "$BTIP";;
esac &&
git symbolic-ref HEAD refs/heads/$(echo $heads \
| sed -e "s/^\(.\).*$/\1/") &&

git symbolic-ref HEAD refs/heads/$(
echo $heads |
sed -e "s/^\(.\).*$/\1/"
) &&

git fsck --full &&


50
t/t5616-partial-clone.sh

@ -34,10 +34,12 @@ test_expect_success 'setup bare clone for server' ' @@ -34,10 +34,12 @@ test_expect_success 'setup bare clone for server' '
# confirm partial clone was registered in the local config.
test_expect_success 'do partial clone 1' '
git clone --no-checkout --filter=blob:none "file://$(pwd)/srv.bare" pc1 &&
git -C pc1 rev-list HEAD --quiet --objects --missing=print \
| awk -f print_1.awk \
| sed "s/?//" \
| sort >observed.oids &&

git -C pc1 rev-list --quiet --objects --missing=print HEAD >revs &&
awk -f print_1.awk revs |
sed "s/?//" |
sort >observed.oids &&

test_cmp expect_1.oids observed.oids &&
test "$(git -C pc1 config --local core.repositoryformatversion)" = "1" &&
test "$(git -C pc1 config --local extensions.partialclone)" = "origin" &&
@ -46,10 +48,10 @@ test_expect_success 'do partial clone 1' ' @@ -46,10 +48,10 @@ test_expect_success 'do partial clone 1' '

# checkout master to force dynamic object fetch of blobs at HEAD.
test_expect_success 'verify checkout with dynamic object fetch' '
git -C pc1 rev-list HEAD --quiet --objects --missing=print >observed &&
git -C pc1 rev-list --quiet --objects --missing=print HEAD >observed &&
test_line_count = 4 observed &&
git -C pc1 checkout master &&
git -C pc1 rev-list HEAD --quiet --objects --missing=print >observed &&
git -C pc1 rev-list --quiet --objects --missing=print HEAD >observed &&
test_line_count = 0 observed
'

@ -72,7 +74,8 @@ test_expect_success 'push new commits to server' ' @@ -72,7 +74,8 @@ test_expect_success 'push new commits to server' '
# have the new blobs.
test_expect_success 'partial fetch inherits filter settings' '
git -C pc1 fetch origin &&
git -C pc1 rev-list master..origin/master --quiet --objects --missing=print >observed &&
git -C pc1 rev-list --quiet --objects --missing=print \
master..origin/master >observed &&
test_line_count = 5 observed
'

@ -80,7 +83,8 @@ test_expect_success 'partial fetch inherits filter settings' ' @@ -80,7 +83,8 @@ test_expect_success 'partial fetch inherits filter settings' '
# we should only get 1 new blob (for the file in origin/master).
test_expect_success 'verify diff causes dynamic object fetch' '
git -C pc1 diff master..origin/master -- file.1.txt &&
git -C pc1 rev-list master..origin/master --quiet --objects --missing=print >observed &&
git -C pc1 rev-list --quiet --objects --missing=print \
master..origin/master >observed &&
test_line_count = 4 observed
'

@ -89,7 +93,8 @@ test_expect_success 'verify diff causes dynamic object fetch' ' @@ -89,7 +93,8 @@ test_expect_success 'verify diff causes dynamic object fetch' '
test_expect_success 'verify blame causes dynamic object fetch' '
git -C pc1 blame origin/master -- file.1.txt >observed.blame &&
test_cmp expect.blame observed.blame &&
git -C pc1 rev-list master..origin/master --quiet --objects --missing=print >observed &&
git -C pc1 rev-list --quiet --objects --missing=print \
master..origin/master >observed &&
test_line_count = 0 observed
'

@ -109,7 +114,8 @@ test_expect_success 'push new commits to server for file.2.txt' ' @@ -109,7 +114,8 @@ test_expect_success 'push new commits to server for file.2.txt' '
# Verify we have all the new blobs.
test_expect_success 'override inherited filter-spec using --no-filter' '
git -C pc1 fetch --no-filter origin &&
git -C pc1 rev-list master..origin/master --quiet --objects --missing=print >observed &&
git -C pc1 rev-list --quiet --objects --missing=print \
master..origin/master >observed &&
test_line_count = 0 observed
'

@ -130,16 +136,22 @@ test_expect_success 'push new commits to server for file.3.txt' ' @@ -130,16 +136,22 @@ test_expect_success 'push new commits to server for file.3.txt' '
# perhaps combined with a command in dry-run mode.
test_expect_success 'manual prefetch of missing objects' '
git -C pc1 fetch --filter=blob:none origin &&
git -C pc1 rev-list master..origin/master --quiet --objects --missing=print \
| awk -f print_1.awk \
| sed "s/?//" \
| sort >observed.oids &&

git -C pc1 rev-list --quiet --objects --missing=print \
master..origin/master >revs &&
awk -f print_1.awk revs |
sed "s/?//" |
sort >observed.oids &&

test_line_count = 6 observed.oids &&
git -C pc1 fetch-pack --stdin "file://$(pwd)/srv.bare" <observed.oids &&
git -C pc1 rev-list master..origin/master --quiet --objects --missing=print \
| awk -f print_1.awk \
| sed "s/?//" \
| sort >observed.oids &&

git -C pc1 rev-list --quiet --objects --missing=print \
master..origin/master >revs &&
awk -f print_1.awk revs |
sed "s/?//" |
sort >observed.oids &&

test_line_count = 0 observed.oids
'

@ -194,7 +206,7 @@ test_expect_success 'upon cloning, check that all refs point to objects' ' @@ -194,7 +206,7 @@ test_expect_success 'upon cloning, check that all refs point to objects' '

# Craft a packfile not including that blob.
git -C "$SERVER" rev-parse HEAD |
git -C "$SERVER" pack-objects --stdout >incomplete.pack &&
git -C "$SERVER" pack-objects --stdout >incomplete.pack &&

# Replace the existing packfile with the crafted one. The protocol
# requires that the packfile be sent in sideband 1, hence the extra

14
t/t5701-git-serve.sh

@ -16,7 +16,7 @@ test_expect_success 'test capability advertisement' ' @@ -16,7 +16,7 @@ test_expect_success 'test capability advertisement' '

git serve --advertise-capabilities >out &&
test-tool pkt-line unpack <out >actual &&
test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'stateless-rpc flag does not list capabilities' '
@ -89,7 +89,7 @@ test_expect_success 'basics of ls-refs' ' @@ -89,7 +89,7 @@ test_expect_success 'basics of ls-refs' '

git serve --stateless-rpc <in >out &&
test-tool pkt-line unpack <out >actual &&
test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'basic ref-prefixes' '
@ -109,7 +109,7 @@ test_expect_success 'basic ref-prefixes' ' @@ -109,7 +109,7 @@ test_expect_success 'basic ref-prefixes' '

git serve --stateless-rpc <in >out &&
test-tool pkt-line unpack <out >actual &&
test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'refs/heads prefix' '
@ -129,7 +129,7 @@ test_expect_success 'refs/heads prefix' ' @@ -129,7 +129,7 @@ test_expect_success 'refs/heads prefix' '

git serve --stateless-rpc <in >out &&
test-tool pkt-line unpack <out >actual &&
test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'peel parameter' '
@ -150,7 +150,7 @@ test_expect_success 'peel parameter' ' @@ -150,7 +150,7 @@ test_expect_success 'peel parameter' '

git serve --stateless-rpc <in >out &&
test-tool pkt-line unpack <out >actual &&
test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'symrefs parameter' '
@ -171,7 +171,7 @@ test_expect_success 'symrefs parameter' ' @@ -171,7 +171,7 @@ test_expect_success 'symrefs parameter' '

git serve --stateless-rpc <in >out &&
test-tool pkt-line unpack <out >actual &&
test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'sending server-options' '
@ -191,7 +191,7 @@ test_expect_success 'sending server-options' ' @@ -191,7 +191,7 @@ test_expect_success 'sending server-options' '

git serve --stateless-rpc <in >out &&
test-tool pkt-line unpack <out >actual &&
test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'unexpected lines are not allowed in fetch request' '

14
t/t5702-protocol-v2.sh

@ -29,7 +29,7 @@ test_expect_success 'list refs with git:// using protocol v2' ' @@ -29,7 +29,7 @@ test_expect_success 'list refs with git:// using protocol v2' '
grep "git< version 2" log &&

git ls-remote --symref "$GIT_DAEMON_URL/parent" >expect &&
test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'ref advertisment is filtered with ls-remote using protocol v2' '
@ -42,7 +42,7 @@ test_expect_success 'ref advertisment is filtered with ls-remote using protocol @@ -42,7 +42,7 @@ test_expect_success 'ref advertisment is filtered with ls-remote using protocol
$(git -C "$daemon_parent" rev-parse refs/heads/master)$(printf "\t")refs/heads/master
EOF

test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'clone with git:// using protocol v2' '
@ -138,7 +138,7 @@ test_expect_success 'list refs with file:// using protocol v2' ' @@ -138,7 +138,7 @@ test_expect_success 'list refs with file:// using protocol v2' '
grep "git< version 2" log &&

git ls-remote --symref "file://$(pwd)/file_parent" >expect &&
test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'ref advertisment is filtered with ls-remote using protocol v2' '
@ -151,7 +151,7 @@ test_expect_success 'ref advertisment is filtered with ls-remote using protocol @@ -151,7 +151,7 @@ test_expect_success 'ref advertisment is filtered with ls-remote using protocol
$(git -C file_parent rev-parse refs/heads/master)$(printf "\t")refs/heads/master
EOF

test_cmp actual expect
test_cmp expect actual
'

test_expect_success 'server-options are sent when using ls-remote' '
@ -164,7 +164,7 @@ test_expect_success 'server-options are sent when using ls-remote' ' @@ -164,7 +164,7 @@ test_expect_success 'server-options are sent when using ls-remote' '
$(git -C file_parent rev-parse refs/heads/master)$(printf "\t")refs/heads/master
EOF

test_cmp actual expect &&
test_cmp expect actual &&
grep "server-option=hello" log &&
grep "server-option=world" log
'
@ -271,7 +271,7 @@ test_expect_success 'partial clone' ' @@ -271,7 +271,7 @@ test_expect_success 'partial clone' '
grep "version 2" trace &&

# Ensure that the old version of the file is missing
git -C client rev-list master --quiet --objects --missing=print \
git -C client rev-list --quiet --objects --missing=print master \
>observed.oids &&
grep "$(git -C server rev-parse message1:a.txt)" observed.oids &&

@ -297,7 +297,7 @@ test_expect_success 'partial fetch' ' @@ -297,7 +297,7 @@ test_expect_success 'partial fetch' '
grep "version 2" trace &&

# Ensure that the old version of the file is missing
git -C client rev-list other --quiet --objects --missing=print \
git -C client rev-list --quiet --objects --missing=print other \
>observed.oids &&
grep "$(git -C server rev-parse message1:a.txt)" observed.oids &&


12
t/t6023-merge-file.sh

@ -99,7 +99,7 @@ EOF @@ -99,7 +99,7 @@ EOF
printf "propter nomen suum." >> expect.txt

test_expect_success "merge does not add LF away of change" \
"test_cmp test3.txt expect.txt"
"test_cmp expect.txt test3.txt"

cp test.txt backup.txt
test_expect_success "merge with conflicts" \
@ -122,7 +122,7 @@ non timebo mala, quoniam tu mecum es: @@ -122,7 +122,7 @@ non timebo mala, quoniam tu mecum es:
virga tua et baculus tuus ipsa me consolata sunt.
EOF

test_expect_success "expected conflict markers" "test_cmp test.txt expect.txt"
test_expect_success "expected conflict markers" "test_cmp expect.txt test.txt"

cp backup.txt test.txt

@ -138,7 +138,7 @@ non timebo mala, quoniam tu mecum es: @@ -138,7 +138,7 @@ non timebo mala, quoniam tu mecum es:
virga tua et baculus tuus ipsa me consolata sunt.
EOF
test_expect_success "merge conflicting with --ours" \
"git merge-file --ours test.txt orig.txt new3.txt && test_cmp test.txt expect.txt"
"git merge-file --ours test.txt orig.txt new3.txt && test_cmp expect.txt test.txt"
cp backup.txt test.txt

cat > expect.txt << EOF
@ -154,7 +154,7 @@ non timebo mala, quoniam tu mecum es: @@ -154,7 +154,7 @@ non timebo mala, quoniam tu mecum es:
virga tua et baculus tuus ipsa me consolata sunt.
EOF
test_expect_success "merge conflicting with --theirs" \
"git merge-file --theirs test.txt orig.txt new3.txt && test_cmp test.txt expect.txt"
"git merge-file --theirs test.txt orig.txt new3.txt && test_cmp expect.txt test.txt"
cp backup.txt test.txt

cat > expect.txt << EOF
@ -171,7 +171,7 @@ non timebo mala, quoniam tu mecum es: @@ -171,7 +171,7 @@ non timebo mala, quoniam tu mecum es:
virga tua et baculus tuus ipsa me consolata sunt.
EOF
test_expect_success "merge conflicting with --union" \
"git merge-file --union test.txt orig.txt new3.txt && test_cmp test.txt expect.txt"
"git merge-file --union test.txt orig.txt new3.txt && test_cmp expect.txt test.txt"
cp backup.txt test.txt

test_expect_success "merge with conflicts, using -L" \
@ -195,7 +195,7 @@ virga tua et baculus tuus ipsa me consolata sunt. @@ -195,7 +195,7 @@ virga tua et baculus tuus ipsa me consolata sunt.
EOF

test_expect_success "expected conflict markers, with -L" \
"test_cmp test.txt expect.txt"
"test_cmp expect.txt test.txt"

sed "s/ tu / TU /" < new1.txt > new5.txt
test_expect_success "conflict in removed tail" \

4
t/t6027-merge-binary.sh

@ -45,7 +45,7 @@ test_expect_success resolve ' @@ -45,7 +45,7 @@ test_expect_success resolve '
false
else
git ls-files -s >current
test_cmp current expect
test_cmp expect current
fi
'

@ -60,7 +60,7 @@ test_expect_success recursive ' @@ -60,7 +60,7 @@ test_expect_success recursive '
false
else
git ls-files -s >current
test_cmp current expect
test_cmp expect current
fi
'


2
t/t6031-merge-filemode.sh

@ -61,7 +61,7 @@ do_both_modes () { @@ -61,7 +61,7 @@ do_both_modes () {
git checkout -f a2 &&
test_must_fail git merge -s $strategy b2 &&
git ls-files -u >actual &&
test_cmp actual expect &&
test_cmp expect actual &&
git ls-files -s file2 | grep ^100755
'


237
t/t6112-rev-list-filters-objects.sh

@ -21,24 +21,31 @@ test_expect_success 'setup r1' ' @@ -21,24 +21,31 @@ test_expect_success 'setup r1' '

test_expect_success 'verify blob:none omits all 5 blobs' '
git -C r1 ls-files -s file.1 file.2 file.3 file.4 file.5 \
| awk -f print_2.awk \
| sort >expected &&
git -C r1 rev-list HEAD --quiet --objects --filter-print-omitted --filter=blob:none \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
>ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r1 rev-list --quiet --objects --filter-print-omitted \
--filter=blob:none HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify emitted+omitted == all' '
git -C r1 rev-list HEAD --objects \
| awk -f print_1.awk \
| sort >expected &&
git -C r1 rev-list HEAD --objects --filter-print-omitted --filter=blob:none \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
git -C r1 rev-list --objects HEAD >revs &&
awk -f print_1.awk revs |
sort >expected &&

git -C r1 rev-list --objects --filter-print-omitted --filter=blob:none \
HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'


@ -58,65 +65,82 @@ test_expect_success 'setup r2' ' @@ -58,65 +65,82 @@ test_expect_success 'setup r2' '
'

test_expect_success 'verify blob:limit=500 omits all blobs' '
git -C r2 ls-files -s large.1000 large.10000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 rev-list HEAD --quiet --objects --filter-print-omitted --filter=blob:limit=500 \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
git -C r2 ls-files -s large.1000 large.10000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 rev-list --quiet --objects --filter-print-omitted \
--filter=blob:limit=500 HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify emitted+omitted == all' '
git -C r2 rev-list HEAD --objects \
| awk -f print_1.awk \
| sort >expected &&
git -C r2 rev-list HEAD --objects --filter-print-omitted --filter=blob:limit=500 \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
git -C r2 rev-list --objects HEAD >revs &&
awk -f print_1.awk revs |
sort >expected &&

git -C r2 rev-list --objects --filter-print-omitted \
--filter=blob:limit=500 HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify blob:limit=1000' '
git -C r2 ls-files -s large.1000 large.10000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 rev-list HEAD --quiet --objects --filter-print-omitted --filter=blob:limit=1000 \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
git -C r2 ls-files -s large.1000 large.10000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 rev-list --quiet --objects --filter-print-omitted \
--filter=blob:limit=1000 HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify blob:limit=1001' '
git -C r2 ls-files -s large.10000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 rev-list HEAD --quiet --objects --filter-print-omitted --filter=blob:limit=1001 \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
git -C r2 ls-files -s large.10000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 rev-list --quiet --objects --filter-print-omitted \
--filter=blob:limit=1001 HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify blob:limit=1k' '
git -C r2 ls-files -s large.10000 \
| awk -f print_2.awk \
| sort >expected &&
git -C r2 rev-list HEAD --quiet --objects --filter-print-omitted --filter=blob:limit=1k \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
git -C r2 ls-files -s large.10000 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r2 rev-list --quiet --objects --filter-print-omitted \
--filter=blob:limit=1k HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify blob:limit=1m' '
git -C r2 rev-list HEAD --quiet --objects --filter-print-omitted --filter=blob:limit=1m \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
git -C r2 rev-list --quiet --objects --filter-print-omitted \
--filter=blob:limit=1m HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_must_be_empty observed
'

@ -141,25 +165,31 @@ test_expect_success 'setup r3' ' @@ -141,25 +165,31 @@ test_expect_success 'setup r3' '
'

test_expect_success 'verify sparse:path=pattern1 omits top-level files' '
git -C r3 ls-files -s sparse1 sparse2 \
| awk -f print_2.awk \
| sort >expected &&
git -C r3 rev-list HEAD --quiet --objects --filter-print-omitted --filter=sparse:path=../pattern1 \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
git -C r3 ls-files -s sparse1 sparse2 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r3 rev-list --quiet --objects --filter-print-omitted \
--filter=sparse:path=../pattern1 HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify sparse:path=pattern2 omits both sparse2 files' '
git -C r3 ls-files -s sparse2 dir1/sparse2 \
| awk -f print_2.awk \
| sort >expected &&
git -C r3 rev-list HEAD --quiet --objects --filter-print-omitted --filter=sparse:path=../pattern2 \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
git -C r3 ls-files -s sparse2 dir1/sparse2 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r3 rev-list --quiet --objects --filter-print-omitted \
--filter=sparse:path=../pattern2 HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

# Test sparse:oid=<oid-ish> filter.
@ -173,26 +203,33 @@ test_expect_success 'setup r3 part 2' ' @@ -173,26 +203,33 @@ test_expect_success 'setup r3 part 2' '
'

test_expect_success 'verify sparse:oid=OID omits top-level files' '
git -C r3 ls-files -s pattern sparse1 sparse2 \
| awk -f print_2.awk \
| sort >expected &&
git -C r3 ls-files -s pattern sparse1 sparse2 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

oid=$(git -C r3 ls-files -s pattern | awk -f print_2.awk) &&
git -C r3 rev-list HEAD --quiet --objects --filter-print-omitted --filter=sparse:oid=$oid \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected

git -C r3 rev-list --quiet --objects --filter-print-omitted \
--filter=sparse:oid=$oid HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'verify sparse:oid=oid-ish omits top-level files' '
git -C r3 ls-files -s pattern sparse1 sparse2 \
| awk -f print_2.awk \
| sort >expected &&
git -C r3 rev-list HEAD --quiet --objects --filter-print-omitted --filter=sparse:oid=master:pattern \
| awk -f print_1.awk \
| sed "s/~//" \
| sort >observed &&
test_cmp observed expected
git -C r3 ls-files -s pattern sparse1 sparse2 >ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

git -C r3 rev-list --quiet --objects --filter-print-omitted \
--filter=sparse:oid=master:pattern HEAD >revs &&
awk -f print_1.awk revs |
sed "s/~//" |
sort >observed &&

test_cmp expected observed
'

# Delete some loose objects and use rev-list, but WITHOUT any filtering.
@ -200,17 +237,21 @@ test_expect_success 'verify sparse:oid=oid-ish omits top-level files' ' @@ -200,17 +237,21 @@ test_expect_success 'verify sparse:oid=oid-ish omits top-level files' '

test_expect_success 'rev-list W/ --missing=print' '
git -C r1 ls-files -s file.1 file.2 file.3 file.4 file.5 \
| awk -f print_2.awk \
| sort >expected &&
>ls_files_result &&
awk -f print_2.awk ls_files_result |
sort >expected &&

for id in `cat expected | sed "s|..|&/|"`
do
rm r1/.git/objects/$id
done &&
git -C r1 rev-list --quiet HEAD --missing=print --objects \
| awk -f print_1.awk \
| sed "s/?//" \
| sort >observed &&
test_cmp observed expected

git -C r1 rev-list --quiet --missing=print --objects HEAD >revs &&
awk -f print_1.awk revs |
sed "s/?//" |
sort >observed &&

test_cmp expected observed
'

test_expect_success 'rev-list W/O --missing fails' '

4
t/t7201-co.sh

@ -160,7 +160,7 @@ test_expect_success 'checkout -m with merge conflict' ' @@ -160,7 +160,7 @@ test_expect_success 'checkout -m with merge conflict' '
git diff master:one :3:uno |
sed -e "1,/^@@/d" -e "/^ /d" -e "s/^-/d/" -e "s/^+/a/" >current &&
fill d2 aT d7 aS >expect &&
test_cmp current expect &&
test_cmp expect current &&
git diff --cached two >current &&
test_must_be_empty current
'
@ -174,7 +174,7 @@ test_expect_success 'format of merge conflict from checkout -m' ' @@ -174,7 +174,7 @@ test_expect_success 'format of merge conflict from checkout -m' '

git ls-files >current &&
fill same two two two >expect &&
test_cmp current expect &&
test_cmp expect current &&

cat <<-EOF >expect &&
<<<<<<< simple

8
t/t7406-submodule-update.sh

@ -789,7 +789,7 @@ test_expect_success 'submodule add places git-dir in superprojects git-dir' ' @@ -789,7 +789,7 @@ test_expect_success 'submodule add places git-dir in superprojects git-dir' '
(cd .git/modules/deeper/submodule &&
git log > ../../../../actual
) &&
test_cmp actual expected
test_cmp expected actual
)
'

@ -807,7 +807,7 @@ test_expect_success 'submodule update places git-dir in superprojects git-dir' ' @@ -807,7 +807,7 @@ test_expect_success 'submodule update places git-dir in superprojects git-dir' '
(cd .git/modules/deeper/submodule &&
git log > ../../../../actual
) &&
test_cmp actual expected
test_cmp expected actual
)
'

@ -827,7 +827,7 @@ test_expect_success 'submodule add places git-dir in superprojects git-dir recur @@ -827,7 +827,7 @@ test_expect_success 'submodule add places git-dir in superprojects git-dir recur
git add deeper/submodule &&
git commit -m "update submodule" &&
git push origin : &&
test_cmp actual expected
test_cmp expected actual
)
'

@ -874,7 +874,7 @@ test_expect_success 'submodule update places git-dir in superprojects git-dir re @@ -874,7 +874,7 @@ test_expect_success 'submodule update places git-dir in superprojects git-dir re
(cd .git/modules/submodule/modules/subsubmodule &&
git log > ../../../../../actual
) &&
test_cmp actual expected
test_cmp expected actual
)
'


2
t/t7800-difftool.sh

@ -557,7 +557,7 @@ test_expect_success SYMLINKS 'difftool --dir-diff --symlink without unstaged cha @@ -557,7 +557,7 @@ test_expect_success SYMLINKS 'difftool --dir-diff --symlink without unstaged cha
EOF
git difftool --dir-diff --symlink \
--extcmd "./.git/CHECK_SYMLINKS" branch HEAD &&
test_cmp actual expect
test_cmp expect actual
'

write_script modify-right-file <<\EOF

2
t/t9100-git-svn-basic.sh

@ -221,7 +221,7 @@ tree d667270a1f7b109f5eb3aaea21ede14b56bfdd6e @@ -221,7 +221,7 @@ tree d667270a1f7b109f5eb3aaea21ede14b56bfdd6e
tree 8f51f74cf0163afc9ad68a4b1537288c4558b5a4
EOF

test_expect_success POSIXPERM,SYMLINKS "$name" "test_cmp a expected"
test_expect_success POSIXPERM,SYMLINKS "$name" "test_cmp expected a"

test_expect_success 'exit if remote refs are ambigious' '
git config --add svn-remote.svn.fetch \

34
t/t9101-git-svn-props.sh

@ -174,7 +174,8 @@ test_expect_success 'test create-ignore' " @@ -174,7 +174,8 @@ test_expect_success 'test create-ignore' "
cmp ./deeply/.gitignore create-ignore.expect &&
cmp ./deeply/nested/.gitignore create-ignore.expect &&
cmp ./deeply/nested/directory/.gitignore create-ignore.expect &&
git ls-files -s | grep gitignore | cmp - create-ignore-index.expect
git ls-files -s >ls_files_result &&
grep gitignore ls_files_result | cmp - create-ignore-index.expect
"

cat >prop.expect <<\EOF
@ -189,17 +190,21 @@ EOF @@ -189,17 +190,21 @@ EOF
# This test can be improved: since all the svn:ignore contain the same
# pattern, it can pass even though the propget did not execute on the
# right directory.
test_expect_success 'test propget' "
git svn propget svn:ignore . | cmp - prop.expect &&
test_expect_success 'test propget' '
test_propget () {
git svn propget $1 $2 >actual &&
cmp $3 actual
} &&
test_propget svn:ignore . prop.expect &&
cd deeply &&
git svn propget svn:ignore . | cmp - ../prop.expect &&
git svn propget svn:entry:committed-rev nested/directory/.keep \
| cmp - ../prop2.expect &&
git svn propget svn:ignore .. | cmp - ../prop.expect &&
git svn propget svn:ignore nested/ | cmp - ../prop.expect &&
git svn propget svn:ignore ./nested | cmp - ../prop.expect &&
git svn propget svn:ignore .././deeply/nested | cmp - ../prop.expect
"
test_propget svn:ignore . ../prop.expect &&
test_propget svn:entry:committed-rev nested/directory/.keep \
../prop2.expect &&
test_propget svn:ignore .. ../prop.expect &&
test_propget svn:ignore nested/ ../prop.expect &&
test_propget svn:ignore ./nested ../prop.expect &&
test_propget svn:ignore .././deeply/nested ../prop.expect
'

cat >prop.expect <<\EOF
Properties on '.':
@ -218,8 +223,11 @@ Properties on 'nested/directory/.keep': @@ -218,8 +223,11 @@ Properties on 'nested/directory/.keep':
EOF

test_expect_success 'test proplist' "
git svn proplist . | cmp - prop.expect &&
git svn proplist nested/directory/.keep | cmp - prop2.expect
git svn proplist . >actual &&
cmp prop.expect actual &&

git svn proplist nested/directory/.keep >actual &&
cmp prop2.expect actual
"

test_done

6
t/t9133-git-svn-nested-git-repo.sh

@ -45,7 +45,7 @@ test_expect_success 'update git svn-cloned repo' ' @@ -45,7 +45,7 @@ test_expect_success 'update git svn-cloned repo' '
git svn rebase &&
echo a > expect &&
echo b >> expect &&
test_cmp a expect &&
test_cmp expect a &&
rm expect
)
'
@ -69,7 +69,7 @@ test_expect_success 'update git svn-cloned repo' ' @@ -69,7 +69,7 @@ test_expect_success 'update git svn-cloned repo' '
git svn rebase &&
echo a > expect &&
echo b >> expect &&
test_cmp a expect &&
test_cmp expect a &&
rm expect
)
'
@ -93,7 +93,7 @@ test_expect_success 'update git svn-cloned repo again' ' @@ -93,7 +93,7 @@ test_expect_success 'update git svn-cloned repo again' '
echo a > expect &&
echo b >> expect &&
echo c >> expect &&
test_cmp a expect &&
test_cmp expect a &&
rm expect
)
'

2
t/t9600-cvsimport.sh

@ -148,7 +148,7 @@ test_expect_success PERL 'import from a CVS working tree' ' @@ -148,7 +148,7 @@ test_expect_success PERL 'import from a CVS working tree' '
git cvsimport -a -z0 &&
echo 1 >expect &&
git log -1 --pretty=format:%s%n >actual &&
test_cmp actual expect
test_cmp expect actual
)

'

4
t/t9603-cvsimport-patchsets.sh

@ -29,11 +29,11 @@ test_expect_failure PERL 'import with criss cross times on revisions' ' @@ -29,11 +29,11 @@ test_expect_failure PERL 'import with criss cross times on revisions' '
Rev 3
Rev 2
Rev 1" > expect-master &&
test_cmp actual-master expect-master &&
test_cmp expect-master actual-master &&

echo "Rev 5 Branch A Wed Mar 11 19:09:10 2009 +0000
Rev 4 Branch A Wed Mar 11 19:03:52 2009 +0000" > expect-A &&
test_cmp actual-A expect-A
test_cmp expect-A actual-A
'

test_done

4
t/t9604-cvsimport-timestamps.sh

@ -31,7 +31,7 @@ test_expect_success PERL 'check timestamps are UTC (TZ=CST6CDT)' ' @@ -31,7 +31,7 @@ test_expect_success PERL 'check timestamps are UTC (TZ=CST6CDT)' '
Rev 2 2005-02-01 00:00:00 +0000
Rev 1 2005-01-01 00:00:00 +0000
EOF
test_cmp actual-1 expect-1
test_cmp expect-1 actual-1
'

test_expect_success PERL 'check timestamps with author-specific timezones' '
@ -65,7 +65,7 @@ test_expect_success PERL 'check timestamps with author-specific timezones' ' @@ -65,7 +65,7 @@ test_expect_success PERL 'check timestamps with author-specific timezones' '
Rev 2 2005-01-31 18:00:00 -0600 User Two
Rev 1 2005-01-01 00:00:00 +0000 User One
EOF
test_cmp actual-2 expect-2
test_cmp expect-2 actual-2
'

test_done

Loading…
Cancel
Save