X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/6ba5b855ebc737cc46cabfbe799b0c7706f437f4..1d5e6d0340ba258b34b85ccdac4c402ccf4fd51e:/test/mhshow/test-charset diff --git a/test/mhshow/test-charset b/test/mhshow/test-charset index 64c9812b..0b381e11 100755 --- a/test/mhshow/test-charset +++ b/test/mhshow/test-charset @@ -16,12 +16,30 @@ 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 + #### 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 -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 +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 + + +if test $skip_param_value_checks -eq 1; then + finish_test + exit $failed +fi + + +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 + + +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" + +finish_test exit $failed