Merge branch 'ad/cygwin-no-backslashes-in-paths'
[git] / t / t2104-update-index-skip-worktree.sh
1 #!/bin/sh
2 #
3 # Copyright (c) 2008 Nguyễn Thái Ngọc Duy
4 #
5
6 test_description='skip-worktree bit test'
7
8 . ./test-lib.sh
9
10 sane_unset GIT_TEST_SPLIT_INDEX
11
12 test_set_index_version () {
13     GIT_INDEX_VERSION="$1"
14     export GIT_INDEX_VERSION
15 }
16
17 test_set_index_version 3
18
19 cat >expect.full <<EOF
20 H 1
21 H 2
22 H sub/1
23 H sub/2
24 EOF
25
26 cat >expect.skip <<EOF
27 S 1
28 H 2
29 S sub/1
30 H sub/2
31 EOF
32
33 test_expect_success 'setup' '
34         mkdir sub &&
35         touch ./1 ./2 sub/1 sub/2 &&
36         git add 1 2 sub/1 sub/2 &&
37         git ls-files -t | test_cmp expect.full -
38 '
39
40 test_expect_success 'index is at version 2' '
41         test "$(test-tool index-version < .git/index)" = 2
42 '
43
44 test_expect_success 'update-index --skip-worktree' '
45         git update-index --skip-worktree 1 sub/1 &&
46         git ls-files -t | test_cmp expect.skip -
47 '
48
49 test_expect_success 'index is at version 3 after having some skip-worktree entries' '
50         test "$(test-tool index-version < .git/index)" = 3
51 '
52
53 test_expect_success 'ls-files -t' '
54         git ls-files -t | test_cmp expect.skip -
55 '
56
57 test_expect_success 'update-index --no-skip-worktree' '
58         git update-index --no-skip-worktree 1 sub/1 &&
59         git ls-files -t | test_cmp expect.full -
60 '
61
62 test_expect_success 'index version is back to 2 when there is no skip-worktree entry' '
63         test "$(test-tool index-version < .git/index)" = 2
64 '
65
66 test_done