Merge branch 'jk/ident-loosen-getpwuid' into maint
[git/gitweb.git] / t / t5704-bundle.sh
blob348d9b3bc7ad3ea512f68b6200481c9f6b90d792
1 #!/bin/sh
3 test_description='some bundle related tests'
4 . ./test-lib.sh
6 test_expect_success 'setup' '
7 test_commit initial &&
8 test_tick &&
9 git tag -m tag tag &&
10 test_commit second &&
11 test_commit third &&
12 git tag -d initial &&
13 git tag -d second &&
14 git tag -d third
17 test_expect_success 'annotated tags can be excluded by rev-list options' '
18 git bundle create bundle --all --since=7.Apr.2005.15:14:00.-0700 &&
19 git ls-remote bundle > output &&
20 grep tag output &&
21 git bundle create bundle --all --since=7.Apr.2005.15:16:00.-0700 &&
22 git ls-remote bundle > output &&
23 ! grep tag output
26 test_expect_success 'die if bundle file cannot be created' '
27 mkdir adir &&
28 test_must_fail git bundle create adir --all
31 test_expect_failure 'bundle --stdin' '
32 echo master | git bundle create stdin-bundle.bdl --stdin &&
33 git ls-remote stdin-bundle.bdl >output &&
34 grep master output
37 test_expect_failure 'bundle --stdin <rev-list options>' '
38 echo master | git bundle create hybrid-bundle.bdl --stdin tag &&
39 git ls-remote hybrid-bundle.bdl >output &&
40 grep master output
43 test_expect_success 'empty bundle file is rejected' '
44 : >empty-bundle &&
45 test_must_fail git fetch empty-bundle
48 # This triggers a bug in older versions where the resulting line (with
49 # --pretty=oneline) was longer than a 1024-char buffer.
50 test_expect_success 'ridiculously long subject in boundary' '
51 : >file4 &&
52 test_tick &&
53 git add file4 &&
54 printf "%01200d\n" 0 | git commit -F - &&
55 test_commit fifth &&
56 git bundle create long-subject-bundle.bdl HEAD^..HEAD &&
57 git bundle list-heads long-subject-bundle.bdl >heads &&
58 test -s heads &&
59 git fetch long-subject-bundle.bdl &&
60 sed -n "/^-/{p;q;}" long-subject-bundle.bdl >boundary &&
61 grep "^-[0-9a-f]\\{40\\} " boundary
64 test_expect_success 'prerequisites with an empty commit message' '
65 : >file1 &&
66 git add file1 &&
67 test_tick &&
68 git commit --allow-empty-message -m "" &&
69 test_commit file2 &&
70 git bundle create bundle HEAD^.. &&
71 git bundle verify bundle
74 test_done