name-hash.c: use new hash map implementation for cache entries
[git/raj.git] / t / t2100-update-cache-badpath.sh
blob2df3fdde8bf665a2b531dd367b70a7a767ee3dbc
1 #!/bin/sh
3 # Copyright (c) 2005 Junio C Hamano
6 test_description='git update-index nonsense-path test.
8 This test creates the following structure in the cache:
10 path0 - a file
11 path1 - a symlink
12 path2/file2 - a file in a directory
13 path3/file3 - a file in a directory
15 and tries to git update-index --add the following:
17 path0/file0 - a file in a directory
18 path1/file1 - a file in a directory
19 path2 - a file
20 path3 - a symlink
22 All of the attempts should fail.
25 . ./test-lib.sh
27 mkdir path2 path3
28 date >path0
29 if test_have_prereq SYMLINKS
30 then
31 ln -s xyzzy path1
32 else
33 date > path1
35 date >path2/file2
36 date >path3/file3
38 test_expect_success \
39 'git update-index --add to add various paths.' \
40 'git update-index --add -- path0 path1 path2/file2 path3/file3'
42 rm -fr path?
44 mkdir path0 path1
45 date >path2
46 if test_have_prereq SYMLINKS
47 then
48 ln -s frotz path3
49 else
50 date > path3
52 date >path0/file0
53 date >path1/file1
55 for p in path0/file0 path1/file1 path2 path3
57 test_expect_success \
58 "git update-index to add conflicting path $p should fail." \
59 "test_must_fail git update-index --add -- $p"
60 done
61 test_done