X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/bed6327e0962c95394b530b7b1ebc40e2af28320..f66fd42c75d104cdde28cc23de02bf4ddaf95d15:/test/mhshow/test-charset diff --git a/test/mhshow/test-charset b/test/mhshow/test-charset index 52a75c51..d8f176d3 100755 --- a/test/mhshow/test-charset +++ b/test/mhshow/test-charset @@ -16,9 +16,23 @@ 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 + 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 @@ -69,5 +83,68 @@ 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