Merge branch 'es/worktree-repair-copied' into cw/worktrees-relative
[git/gitster.git] / t / t4016-diff-quote.sh
blob5a8d8876831657d93837fe3ccfad141f15119ec9
1 #!/bin/sh
3 # Copyright (c) 2007 Junio C Hamano
6 test_description='Quoting paths in diff output.
9 TEST_PASSES_SANITIZE_LEAK=true
10 . ./test-lib.sh
12 P0='pathname'
13 P1='pathname with HT'
14 P2='pathname with SP'
15 P3='pathname
16 with LF'
17 test_have_prereq !MINGW &&
18 echo 2>/dev/null >"$P1" && test -f "$P1" && rm -f "$P1" || {
19 skip_all='Your filesystem does not allow tabs in filenames'
20 test_done
23 test_expect_success setup '
24 echo P0.0 >"$P0.0" &&
25 echo P0.1 >"$P0.1" &&
26 echo P0.2 >"$P0.2" &&
27 echo P0.3 >"$P0.3" &&
28 echo P1.0 >"$P1.0" &&
29 echo P1.2 >"$P1.2" &&
30 echo P1.3 >"$P1.3" &&
31 git add . &&
32 git commit -m initial &&
33 git mv "$P0.0" "R$P0.0" &&
34 git mv "$P0.1" "R$P1.0" &&
35 git mv "$P0.2" "R$P2.0" &&
36 git mv "$P0.3" "R$P3.0" &&
37 git mv "$P1.0" "R$P0.1" &&
38 git mv "$P1.2" "R$P2.1" &&
39 git mv "$P1.3" "R$P3.1" &&
43 test_expect_success 'setup expected files' '
44 cat >expect <<\EOF
45 rename pathname.1 => "Rpathname\twith HT.0" (100%)
46 rename pathname.3 => "Rpathname\nwith LF.0" (100%)
47 rename "pathname\twith HT.3" => "Rpathname\nwith LF.1" (100%)
48 rename pathname.2 => Rpathname with SP.0 (100%)
49 rename "pathname\twith HT.2" => Rpathname with SP.1 (100%)
50 rename pathname.0 => Rpathname.0 (100%)
51 rename "pathname\twith HT.0" => Rpathname.1 (100%)
52 EOF
55 test_expect_success 'git diff --summary -M HEAD' '
56 git diff --summary -M HEAD >actual &&
57 test_cmp expect actual
60 test_expect_success 'git diff --numstat -M HEAD' '
61 cat >expect <<-\EOF &&
62 0 0 pathname.1 => "Rpathname\twith HT.0"
63 0 0 pathname.3 => "Rpathname\nwith LF.0"
64 0 0 "pathname\twith HT.3" => "Rpathname\nwith LF.1"
65 0 0 pathname.2 => Rpathname with SP.0
66 0 0 "pathname\twith HT.2" => Rpathname with SP.1
67 0 0 pathname.0 => Rpathname.0
68 0 0 "pathname\twith HT.0" => Rpathname.1
69 EOF
70 git diff --numstat -M HEAD >actual &&
71 test_cmp expect actual
74 test_expect_success 'git diff --stat -M HEAD' '
75 cat >expect <<-\EOF &&
76 pathname.1 => "Rpathname\twith HT.0" | 0
77 pathname.3 => "Rpathname\nwith LF.0" | 0
78 "pathname\twith HT.3" => "Rpathname\nwith LF.1" | 0
79 pathname.2 => Rpathname with SP.0 | 0
80 "pathname\twith HT.2" => Rpathname with SP.1 | 0
81 pathname.0 => Rpathname.0 | 0
82 "pathname\twith HT.0" => Rpathname.1 | 0
83 7 files changed, 0 insertions(+), 0 deletions(-)
84 EOF
85 git diff --stat -M HEAD >actual &&
86 test_cmp expect actual
89 test_done