X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/eac1212372816e5f6516f5cfd6515358bd32e351..f66fd42c75d104cdde28cc23de02bf4ddaf95d15:/test/mhshow/test-charset diff --git a/test/mhshow/test-charset b/test/mhshow/test-charset index 64c9812b..d8f176d3 100755 --- a/test/mhshow/test-charset +++ b/test/mhshow/test-charset @@ -16,12 +16,31 @@ fi setup_test +check_exit '-eq 1' mhshow - + +require_locale en_US.UTF-8 en_US.UTF8 en_US.utf-8 en_US.utf8 + +skip_param_value_checks=0 +if test "$ICONV_ENABLED" -eq 0; then + text_size=10 +else + text_size=11 + if ! iconv -l | grep EBCDIC-US >/dev/null; then + #### For unknown reasons, the parameter values checks + #### fail on the FreeBSD10 buildbot. It doesn't + #### support EBCDIC-US, which is used by the checks, + #### so use that to detect whether to skip the check. + skip_param_value_checks=1 + fi +fi + expected=$MH_TEST_DIR/$$.expected actual=$MH_TEST_DIR/$$.actual -echo 'mhshow-charset-windows-1252: echo "This is a test"' >> $MH_TEST_DIR/Mail/.mh_profile +echo 'mhshow-charset-windows-1252: echo "This is a test"' >> "$MH" # Write message with bogus quoted-printable data. +start_test 'Write message with bogus quoted-printable data' msgfile=`mhpath new` msgnum=`basename $msgfile` cat > $msgfile < $expected < $actual 2>&1 -check "$expected" "$actual" +run_prog mhshow $msgnum > $actual 2>&1 +check "$expected" "$actual" 'keep first' : bogus quoted-printable data + + +start_test 'locale profile component' +#### Used LC_ALL above, now use locale profile component instead. +printf "locale: $LC_ALL\n" >> "${MH}" +unset LC_ALL + +run_prog mhshow $msgnum > $actual 2>&1 +check "$expected" "$actual" : locale profile component + + +start_test 'Encoded parameter value' +msgfile=`mhpath new` +msgnum=`basename $msgfile` +#### The encoded charset name is really UTF-8 encoded, +#### but say it's UTF-16 to exercise the iconv code, +#### if it's available, in get_param_value(). +cat > $msgfile < $expected < $actual 2>&1 + check "$expected" "$actual" : encoded parameter value +fi + + +start_test 'replacement character in parameter value' +#### The output of this test doesn't show it, but it covers the +#### noiconv: portion of get_param_value(). +cat > $msgfile <<'EOF' +Subject: invalid parameter value charset +MIME-Version: 1.0 +Content-Type: text/plain; charset*=invalid''%0Dus-ascii +EOF + +cat > $expected < $actual 2>&1 + check "$expected" "$actual" +fi + +finish_test exit $failed