X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/97d33c31f4d3fdef03610c1652b5e246184e0097..60052b95778a065760a437859ee9b8a1cc4e39a9:/test/mhshow/test-charset diff --git a/test/mhshow/test-charset b/test/mhshow/test-charset index 9039764f..6c7095ff 100755 --- a/test/mhshow/test-charset +++ b/test/mhshow/test-charset @@ -16,9 +16,22 @@ fi setup_test +check_exit '-eq 1' mhshow - + require_locale en_US.UTF-8 en_US.UTF8 en_US.utf-8 en_US.utf8 -test "$ICONV_ENABLED" -eq 0 && text_size=10 || text_size=11 +skip_param_value_checks=0 +if test "$ICONV_ENABLED" -eq 0; then + text_size=10 +else + text_size=11 + #### 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 check for that. Though that doesn't seem to be + #### the reason. + printf '\xe4' | iconv -f EBCDIC-US -t UTF-8 >/dev/null 2>&1 && + skip_param_value_checks=1 +fi expected=$MH_TEST_DIR/$$.expected actual=$MH_TEST_DIR/$$.actual @@ -26,6 +39,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 < $actual 2>&1 -check "$expected" "$actual" : bogus quoted-printable data +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