Merge branch 'jc/conflict-marker-size' into maint
[tgit.git] / t / t0003-attributes.sh
blob1c77192eb318d007689089eaf42f4f939c2f9ee4
1 #!/bin/sh
3 test_description=gitattributes
5 . ./test-lib.sh
7 attr_check () {
9 path="$1"
10 expect="$2"
12 git check-attr test -- "$path" >actual &&
13 echo "$path: test: $2" >expect &&
14 test_cmp expect actual
19 test_expect_success 'setup' '
21 mkdir -p a/b/d a/c &&
23 echo "f test=f"
24 echo "a/i test=a/i"
25 ) >.gitattributes &&
27 echo "g test=a/g" &&
28 echo "b/g test=a/b/g"
29 ) >a/.gitattributes &&
31 echo "h test=a/b/h" &&
32 echo "d/* test=a/b/d/*"
33 ) >a/b/.gitattributes
37 test_expect_success 'attribute test' '
39 attr_check f f &&
40 attr_check a/f f &&
41 attr_check a/c/f f &&
42 attr_check a/g a/g &&
43 attr_check a/b/g a/b/g &&
44 attr_check b/g unspecified &&
45 attr_check a/b/h a/b/h &&
46 attr_check a/b/d/g "a/b/d/*"
50 test_expect_success 'attribute test: read paths from stdin' '
52 cat <<EOF > expect
53 f: test: f
54 a/f: test: f
55 a/c/f: test: f
56 a/g: test: a/g
57 a/b/g: test: a/b/g
58 b/g: test: unspecified
59 a/b/h: test: a/b/h
60 a/b/d/g: test: a/b/d/*
61 EOF
63 sed -e "s/:.*//" < expect | git check-attr --stdin test > actual &&
64 test_cmp expect actual
67 test_expect_success 'root subdir attribute test' '
69 attr_check a/i a/i &&
70 attr_check subdir/a/i unspecified
74 test_expect_success 'setup bare' '
76 git clone --bare . bare.git &&
77 cd bare.git
81 test_expect_success 'bare repository: check that .gitattribute is ignored' '
84 echo "f test=f"
85 echo "a/i test=a/i"
86 ) >.gitattributes &&
87 attr_check f unspecified &&
88 attr_check a/f unspecified &&
89 attr_check a/c/f unspecified &&
90 attr_check a/i unspecified &&
91 attr_check subdir/a/i unspecified
95 test_expect_success 'bare repository: test info/attributes' '
98 echo "f test=f"
99 echo "a/i test=a/i"
100 ) >info/attributes &&
101 attr_check f f &&
102 attr_check a/f f &&
103 attr_check a/c/f f &&
104 attr_check a/i a/i &&
105 attr_check subdir/a/i unspecified
109 test_done