t / t5100-mailinfo.shon commit Merge branch 'maint-1.6.0' into maint-1.6.1 (a4d1797)
   1#!/bin/sh
   2#
   3# Copyright (c) 2005 Junio C Hamano
   4#
   5
   6test_description='git mailinfo and git mailsplit test'
   7
   8. ./test-lib.sh
   9
  10test_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'
  15
  16for mail in `echo 00*`
  17do
  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
  26        '
  27done
  28
  29
  30test_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'
  37
  38for mail in `echo rfc2047/00*`
  39do
  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
  48        '
  49done
  50
  51test_expect_success 'respect NULs' '
  52
  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)
  57
  58'
  59
  60test_expect_success 'Preserve NULs out of MIME encoded message' '
  61
  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
  66
  67'
  68
  69test_expect_success 'mailinfo on from header without name works' '
  70
  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
  77
  78'
  79
  80test_done