@@ -7,67 +7,48 @@ test_description='Test the post-checkout hook.'
7
7
. ./test-lib.sh
8
8
9
9
test_expect_success setup '
10
- echo Data for commit0. >a &&
11
- echo Data for commit0. >b &&
12
- git update-index --add a &&
13
- git update-index --add b &&
14
- tree0=$(git write-tree) &&
15
- commit0=$(echo setup | git commit-tree $tree0) &&
16
- git update-ref refs/heads/master $commit0 &&
17
- git clone ./. clone1 &&
18
- git clone ./. clone2 &&
19
- GIT_DIR=clone2/.git git branch new2 &&
20
- echo Data for commit1. >clone2/b &&
21
- GIT_DIR=clone2/.git git add clone2/b &&
22
- GIT_DIR=clone2/.git git commit -m new2
10
+ test_commit one &&
11
+ test_commit two &&
12
+ test_commit three three &&
13
+ mv .git/hooks-disabled .git/hooks
23
14
'
24
15
25
- for clone in 1 2; do
26
- cat > clone${clone} /.git/hooks/post-checkout << 'EOF '
16
+ cat > .git/hooks/post-checkout << 'EOF '
27
17
#!/bin/sh
28
- echo $@ > $GIT_DIR /post-checkout.args
18
+ echo $@ > .git /post-checkout.args
29
19
EOF
30
- chmod u+x clone${clone} /.git/hooks/post-checkout
31
- done
20
+ chmod u+x .git/hooks/post-checkout
32
21
33
22
test_expect_success ' post-checkout runs as expected ' '
34
- GIT_DIR=clone1/.git git checkout master &&
35
- test -e clone1/ .git/post-checkout.args
23
+ git checkout master &&
24
+ test -e .git/post-checkout.args
36
25
'
37
26
38
27
test_expect_success ' post-checkout receives the right arguments with HEAD unchanged ' '
39
- old=$(awk "{print \$1}" clone1/.git/post-checkout.args) &&
40
- new=$(awk "{print \$2}" clone1/.git/post-checkout.args) &&
41
- flag=$(awk "{print \$3}" clone1/.git/post-checkout.args) &&
28
+ read old new flag < .git/post-checkout.args &&
42
29
test $old = $new && test $flag = 1
43
30
'
44
31
45
32
test_expect_success ' post-checkout runs as expected ' '
46
- GIT_DIR=clone1/.git git checkout master &&
47
- test -e clone1/ .git/post-checkout.args
33
+ git checkout master &&
34
+ test -e .git/post-checkout.args
48
35
'
49
36
50
37
test_expect_success ' post-checkout args are correct with git checkout -b ' '
51
- GIT_DIR=clone1/.git git checkout -b new1 &&
52
- old=$(awk "{print \$1}" clone1/.git/post-checkout.args) &&
53
- new=$(awk "{print \$2}" clone1/.git/post-checkout.args) &&
54
- flag=$(awk "{print \$3}" clone1/.git/post-checkout.args) &&
38
+ git checkout -b new1 &&
39
+ read old new flag < .git/post-checkout.args &&
55
40
test $old = $new && test $flag = 1
56
41
'
57
42
58
43
test_expect_success ' post-checkout receives the right args with HEAD changed ' '
59
- GIT_DIR=clone2/.git git checkout new2 &&
60
- old=$(awk "{print \$1}" clone2/.git/post-checkout.args) &&
61
- new=$(awk "{print \$2}" clone2/.git/post-checkout.args) &&
62
- flag=$(awk "{print \$3}" clone2/.git/post-checkout.args) &&
44
+ git checkout two &&
45
+ read old new flag < .git/post-checkout.args &&
63
46
test $old != $new && test $flag = 1
64
47
'
65
48
66
49
test_expect_success ' post-checkout receives the right args when not switching branches ' '
67
- GIT_DIR=clone2/.git git checkout master b &&
68
- old=$(awk "{print \$1}" clone2/.git/post-checkout.args) &&
69
- new=$(awk "{print \$2}" clone2/.git/post-checkout.args) &&
70
- flag=$(awk "{print \$3}" clone2/.git/post-checkout.args) &&
50
+ git checkout master -- three &&
51
+ read old new flag < .git/post-checkout.args &&
71
52
test $old = $new && test $flag = 0
72
53
'
73
54
0 commit comments