summaryrefslogtreecommitdiff
path: root/t/t0050-filesystem.sh
blob: 3fbad77811e3782523e83dfdd58fe5308f237771 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#!/bin/sh
 
test_description='Various filesystem issues'
 
. ./test-lib.sh
 
auml=`printf '\xc3\xa4'`
aumlcdiar=`printf '\x61\xcc\x88'`
 
test_expect_success 'see if we expect ' '
 
	test_case=test_expect_success
	test_unicode=test_expect_success
	mkdir junk &&
	echo good >junk/CamelCase &&
	echo bad >junk/camelcase &&
	if test "$(cat junk/CamelCase)" != good
	then
		test_case=test_expect_failure
		say "will test on a case insensitive filesystem"
	fi &&
	rm -fr junk &&
	mkdir junk &&
	>junk/"$auml" &&
	case "$(cd junk && echo *)" in
	"$aumlcdiar")
		test_unicode=test_expect_failure
		say "will test on a unicode corrupting filesystem"
		;;
	*)	;;
	esac &&
	rm -fr junk
'
 
test_expect_success "setup case tests" '
 
	touch camelcase &&
	git add camelcase &&
	git commit -m "initial" &&
	git tag initial &&
	git checkout -b topic &&
	git mv camelcase tmp &&
	git mv tmp CamelCase &&
	git commit -m "rename" &&
	git checkout -f master
 
'
 
$test_case 'rename (case change)' '
 
	git mv camelcase CamelCase &&
	git commit -m "rename"
 
'
 
$test_case 'merge (case change)' '
 
	git reset --hard initial &&
	git merge topic
 
'
 
test_expect_success "setup unicode normalization tests" '
 
  test_create_repo unicode &&
  cd unicode &&
  touch "$aumlcdiar" &&
  git add "$aumlcdiar" &&
  git commit -m initial
  git tag initial &&
  git checkout -b topic &&
  git mv $aumlcdiar tmp &&
  git mv tmp "$auml" &&
  git commit -m rename &&
  git checkout -f master
 
'
 
$test_unicode 'rename (silent unicode normalization)' '
 
 git mv "$aumlcdiar" "$auml" &&
 git commit -m rename
 
'
 
$test_unicode 'merge (silent unicode normalization)' '
 
 git reset --hard initial &&
 git merge topic
 
'
 
test_done