blob: 40db3087b285a05067fe51c505e98774cb8c21a4 (
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
#!/usr/bin/perl
use strict;
use warnings;
# this is hardcoded; change it if needed
use lib "src/lib";
use Gitolite::Test;
# VREFs - part 2
# ----------------------------------------------------------------------
try "plan 72";
put "../gitolite-admin/conf/gitolite.conf", "
\@gfoo = foo
\@lead = u1
\@senior_devs = u2 u3
\@junior_devs = u4 u5 u6
repo \@gfoo
RW+ = \@all
RW+ VREF/COUNT/2/NO_SIGNOFF = \@lead
- VREF/COUNT/2/NO_SIGNOFF = \@all
- VREF/COUNT/10/NEWFILES = \@junior_devs
- VREF/FILETYPE/AUTOGENERATED = \@all
";
try "
ADMIN_PUSH vr2a
cd ..
# setup
[ -d foo ]; !ok
CLONE u1 foo; ok; /Cloning into/
/You appear to have cloned an empty/
cd foo; ok
[ -d .git ]; ok
# u1 push 15 new files
tc a b c d e f g h i j k l m n o
ok; /d8c0392/
PUSH u1 master; ok; /new branch.*master -. master/
# u2 push 2 new 10 old without signoff
tc a b c d e f g h i j u2a u2b
ok; /6787ac9/
PUSH u2; ok; /d8c0392..6787ac9.*master -. master/
# u2 fail to push 3 new files without signoff
tc u2c u2d u2e; ok; /a74562b/
PUSH u2; !ok; /W VREF/COUNT/2/NO_SIGNOFF foo u2 DENIED by VREF/COUNT/2/NO_SIGNOFF/
/top commit message should include the text .3 new files signed-off by: tester.example.com./
/hook declined/
/remote rejected/
# u2 push 15 new files with signoff
tc u2f u2g u2h u2i u2j u2k u2l u2m u2n u2o u2p u2q
ok; /8dd31aa/
git commit --allow-empty -m '15 new files signed-off by: tester\@example.com'
ok; /.master 6126489. 15 new files signed-off by: tester.example.com/
PUSH u2; ok; /6787ac9..6126489.*master -. master/
# u4 push 2 new 10 old files without signoff
tc u4a u4b a b c d e f g h i j
ok; /76c5593/
PUSH u4; ok; /6126489..76c5593.*master -. master/
# u4 fail push 3 new files withoug signoff
tc u4c u4d u4e; ok; /2a84398/
PUSH u4; !ok; /W VREF/COUNT/2/NO_SIGNOFF foo u4 DENIED by VREF/COUNT/2/NO_SIGNOFF/
/top commit message should include the text .3 new files signed-off by: tester.example.com./
/hook declined/
/remote rejected/
# u4 push 10 new 5 old with signoff
tc u4f u4g u4h u4i u4j u4k u4l a b c d e
ok; /09b646a/
git commit --allow-empty -m '10 new files signed-off by: tester\@example.com'
ok; /.master 47f84b0. 10 new files signed-off by: tester.example.com/
PUSH u4; ok; /76c5593..47f84b0.*master -. master/
# u4 fail push 11 new files even with signoff
tc u4ab u4ac u4ad u4ae u4af u4ag u4ah u4ai u4aj u4ak u4al
ok; /90e7344/
git commit --allow-empty -m '11 new files signed-off by: tester\@example.com'
ok; /.master 1f36537. 11 new files signed-off by: tester.example.com/
PUSH u4; !ok; /W VREF/COUNT/10/NEWFILES foo u4 DENIED by VREF/COUNT/10/NEWFILES/
/too many new files in this push/
/hook declined/
/remote rejected/
# test AUTOGENERATED vref
glt fetch u1 origin; ok;
reset-h origin/master; ok;
tc not-really.java; ok; /0f88b2e/
PUSH u4; ok; /47f84b0..0f88b2e.*master -. master/
";
put "|cat >> not-really.java", "
Generated by the protocol buffer compiler. DO NOT EDIT
";
try "
commit -am pbc; ok; /b2df6ef/
PUSH u4; !ok; /W VREF/FILETYPE/AUTOGENERATED foo u4 DENIED by VREF/FILETYPE/AUTOGENERATED/
/hook declined/
/remote rejected/
";
|