X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/0d3875d020fb17d34918f5e81ee7f87fbc5d1565..2cf4ff9dd2fba77c7f98bbd706b00d2e79a11a3b:/test/mhshow/test-charset diff --git a/test/mhshow/test-charset b/test/mhshow/test-charset index 39f52a67..964e1842 100755 --- a/test/mhshow/test-charset +++ b/test/mhshow/test-charset @@ -16,10 +16,23 @@ fi setup_test -require_locale en_US.utf8 -LC_ALL=en_US.UTF-8; export LC_ALL +check_exit '-eq 1' mhshow - -test "$ICONV_ENABLED" -eq 0 && text_size=10 || text_size=11 +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 + 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 +else + text_size=11 +fi expected=$MH_TEST_DIR/$$.expected actual=$MH_TEST_DIR/$$.actual @@ -27,6 +40,7 @@ actual=$MH_TEST_DIR/$$.actual 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" +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