]> git.ipfire.org Git - thirdparty/git.git/blame - t/t6009-rev-list-parent.sh
Merge branch 'nm/maint-conflicted-submodule-entries'
[thirdparty/git.git] / t / t6009-rev-list-parent.sh
CommitLineData
991c3dc7
JH
1#!/bin/sh
2
6a6ebded 3test_description='ancestor culling and limiting by parent number'
991c3dc7
JH
4
5. ./test-lib.sh
6
6a6ebded
MG
7check_revlist () {
8 rev_list_args="$1" &&
9 shift &&
10 git rev-parse "$@" >expect &&
11 git rev-list $rev_list_args --all >actual &&
12 test_cmp expect actual
13}
14
991c3dc7
JH
15test_expect_success setup '
16
17 touch file &&
18 git add file &&
19
8ee50594 20 test_commit one &&
991c3dc7 21
a48fcd83 22 test_tick=$(($test_tick - 2400)) &&
991c3dc7 23
8ee50594
MG
24 test_commit two &&
25 test_commit three &&
26 test_commit four &&
991c3dc7
JH
27
28 git log --pretty=oneline --abbrev-commit
29'
30
7d004199 31test_expect_success 'one is ancestor of others and should not be shown' '
991c3dc7
JH
32
33 git rev-list one --not four >result &&
34 >expect &&
82ebb0b6 35 test_cmp expect result
991c3dc7
JH
36
37'
38
6a6ebded
MG
39test_expect_success 'setup roots, merges and octopuses' '
40
41 git checkout --orphan newroot &&
42 test_commit five &&
43 git checkout -b sidebranch two &&
44 test_commit six &&
45 git checkout -b anotherbranch three &&
46 test_commit seven &&
47 git checkout -b yetanotherbranch four &&
48 test_commit eight &&
49 git checkout master &&
50 test_merge normalmerge newroot &&
51 test_tick &&
52 git merge -m tripus sidebranch anotherbranch &&
53 git tag tripus &&
54 git checkout -b tetrabranch normalmerge &&
55 test_tick &&
56 git merge -m tetrapus sidebranch anotherbranch yetanotherbranch &&
57 git tag tetrapus &&
58 git checkout master
59'
60
61test_expect_success 'rev-list roots' '
62
63 check_revlist "--max-parents=0" one five
64'
65
66test_expect_success 'rev-list no merges' '
67
68 check_revlist "--max-parents=1" one eight seven six five four three two &&
69 check_revlist "--no-merges" one eight seven six five four three two
70'
71
72test_expect_success 'rev-list no octopuses' '
73
74 check_revlist "--max-parents=2" one normalmerge eight seven six five four three two
75'
76
77test_expect_success 'rev-list no roots' '
78
79 check_revlist "--min-parents=1" tetrapus tripus normalmerge eight seven six four three two
80'
81
82test_expect_success 'rev-list merges' '
83
84 check_revlist "--min-parents=2" tetrapus tripus normalmerge &&
85 check_revlist "--merges" tetrapus tripus normalmerge
86'
87
88test_expect_success 'rev-list octopus' '
89
90 check_revlist "--min-parents=3" tetrapus tripus
91'
92
93test_expect_success 'rev-list ordinary commits' '
94
95 check_revlist "--min-parents=1 --max-parents=1" eight seven six four three two
96'
97
98test_expect_success 'rev-list --merges --no-merges yields empty set' '
99
100 check_revlist "--min-parents=2 --no-merges" &&
101 check_revlist "--merges --no-merges" &&
102 check_revlist "--no-merges --merges"
103'
104
105test_expect_success 'rev-list override and infinities' '
106
107 check_revlist "--min-parents=2 --max-parents=1 --max-parents=3" tripus normalmerge &&
108 check_revlist "--min-parents=1 --min-parents=2 --max-parents=7" tetrapus tripus normalmerge &&
109 check_revlist "--min-parents=2 --max-parents=8" tetrapus tripus normalmerge &&
110 check_revlist "--min-parents=2 --max-parents=-1" tetrapus tripus normalmerge &&
111 check_revlist "--min-parents=2 --no-max-parents" tetrapus tripus normalmerge &&
112 check_revlist "--max-parents=0 --min-parents=1 --no-min-parents" one five
113'
114
482ce70e 115test_expect_success 'dodecapus' '
6a6ebded 116
482ce70e 117 roots= &&
6a6ebded
MG
118 for i in 1 2 3 4 5 6 7 8 9 10 11
119 do
482ce70e
JN
120 git checkout -b root$i five &&
121 test_commit $i &&
122 roots="$roots root$i" ||
123 return
6a6ebded
MG
124 done &&
125 git checkout master &&
126 test_tick &&
482ce70e
JN
127 git merge -m dodecapus $roots &&
128 git tag dodecapus &&
6a6ebded
MG
129
130 check_revlist "--min-parents=4" dodecapus tetrapus &&
131 check_revlist "--min-parents=8" dodecapus &&
132 check_revlist "--min-parents=12" dodecapus &&
133 check_revlist "--min-parents=13" &&
134 check_revlist "--min-parents=4 --max-parents=11" tetrapus
135'
991c3dc7 136test_done