Optimize "diff-index --cached" using cache-tree
[git/dscho.git] / t / t5100-mailinfo.sh
blobe70ea94a1368dc045469808d30c717aa2b8bb158
1 #!/bin/sh
3 # Copyright (c) 2005 Junio C Hamano
6 test_description='git mailinfo and git mailsplit test'
8 . ./test-lib.sh
10 test_expect_success 'split sample box' \
11 'git mailsplit -o. "$TEST_DIRECTORY"/t5100/sample.mbox >last &&
12 last=`cat last` &&
13 echo total is $last &&
14 test `cat last` = 13'
16 for mail in `echo 00*`
18 test_expect_success "mailinfo $mail" '
19 git mailinfo -u msg$mail patch$mail <$mail >info$mail &&
20 echo msg &&
21 test_cmp "$TEST_DIRECTORY"/t5100/msg$mail msg$mail &&
22 echo patch &&
23 test_cmp "$TEST_DIRECTORY"/t5100/patch$mail patch$mail &&
24 echo info &&
25 test_cmp "$TEST_DIRECTORY"/t5100/info$mail info$mail
27 done
30 test_expect_success 'split box with rfc2047 samples' \
31 'mkdir rfc2047 &&
32 git mailsplit -orfc2047 "$TEST_DIRECTORY"/t5100/rfc2047-samples.mbox \
33 >rfc2047/last &&
34 last=`cat rfc2047/last` &&
35 echo total is $last &&
36 test `cat rfc2047/last` = 11'
38 for mail in `echo rfc2047/00*`
40 test_expect_success "mailinfo $mail" '
41 git mailinfo -u $mail-msg $mail-patch <$mail >$mail-info &&
42 echo msg &&
43 test_cmp "$TEST_DIRECTORY"/t5100/empty $mail-msg &&
44 echo patch &&
45 test_cmp "$TEST_DIRECTORY"/t5100/empty $mail-patch &&
46 echo info &&
47 test_cmp "$TEST_DIRECTORY"/t5100/rfc2047-info-$(basename $mail) $mail-info
49 done
51 test_expect_success 'respect NULs' '
53 git mailsplit -d3 -o. "$TEST_DIRECTORY"/t5100/nul-plain &&
54 test_cmp "$TEST_DIRECTORY"/t5100/nul-plain 001 &&
55 (cat 001 | git mailinfo msg patch) &&
56 test 4 = $(wc -l < patch)
60 test_expect_success 'Preserve NULs out of MIME encoded message' '
62 git mailsplit -d5 -o. "$TEST_DIRECTORY"/t5100/nul-b64.in &&
63 test_cmp "$TEST_DIRECTORY"/t5100/nul-b64.in 00001 &&
64 git mailinfo msg patch <00001 &&
65 test_cmp "$TEST_DIRECTORY"/t5100/nul-b64.expect patch
69 test_expect_success 'mailinfo on from header without name works' '
71 mkdir info-from &&
72 git mailsplit -oinfo-from "$TEST_DIRECTORY"/t5100/info-from.in &&
73 test_cmp "$TEST_DIRECTORY"/t5100/info-from.in info-from/0001 &&
74 git mailinfo info-from/msg info-from/patch \
75 <info-from/0001 >info-from/out &&
76 test_cmp "$TEST_DIRECTORY"/t5100/info-from.expect info-from/out
80 test_done