Merge branch 'sg/t-helper-gitignore'
[git/raj.git] / t / t3305-notes-fanout.sh
blob831f83d211b8c731558a717bb2b615e414b7022a
1 #!/bin/sh
3 test_description='Test that adding/removing many notes triggers automatic fanout restructuring'
5 . ./test-lib.sh
7 test_expect_success 'creating many notes with git-notes' '
8 num_notes=300 &&
9 i=0 &&
10 while test $i -lt $num_notes
12 i=$(($i + 1)) &&
13 test_tick &&
14 echo "file for commit #$i" > file &&
15 git add file &&
16 git commit -q -m "commit #$i" &&
17 git notes add -m "note #$i" || return 1
18 done
21 test_expect_success 'many notes created correctly with git-notes' '
22 git log | grep "^ " > output &&
23 i=300 &&
24 while test $i -gt 0
26 echo " commit #$i" &&
27 echo " note #$i" &&
28 i=$(($i - 1));
29 done > expect &&
30 test_cmp expect output
33 test_expect_success 'many notes created with git-notes triggers fanout' '
34 # Expect entire notes tree to have a fanout == 1
35 git ls-tree -r --name-only refs/notes/commits |
36 while read path
38 echo $path | grep "^../[0-9a-f]*$" || {
39 echo "Invalid path \"$path\"" &&
40 return 1;
42 done
45 test_expect_success 'deleting most notes with git-notes' '
46 num_notes=250 &&
47 i=0 &&
48 git rev-list HEAD |
49 while test $i -lt $num_notes && read sha1
51 i=$(($i + 1)) &&
52 test_tick &&
53 git notes remove "$sha1" ||
54 exit 1
55 done
58 test_expect_success 'most notes deleted correctly with git-notes' '
59 git log HEAD~250 | grep "^ " > output &&
60 i=50 &&
61 while test $i -gt 0
63 echo " commit #$i" &&
64 echo " note #$i" &&
65 i=$(($i - 1));
66 done > expect &&
67 test_cmp expect output
70 test_expect_success 'deleting most notes triggers fanout consolidation' '
71 # Expect entire notes tree to have a fanout == 0
72 git ls-tree -r --name-only refs/notes/commits |
73 while read path
75 echo $path | grep -v "^../.*" || {
76 echo "Invalid path \"$path\"" &&
77 return 1;
79 done
82 test_done