X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/8a1edeb17377d465644430b29cb04a4fe06d4a3b..42d1984f490da0566a43b9705f02ef820d11d816:/test/format/test-fmtdump diff --git a/test/format/test-fmtdump b/test/format/test-fmtdump index 73fd14de..6cbdfe4f 100755 --- a/test/format/test-fmtdump +++ b/test/format/test-fmtdump @@ -19,6 +19,29 @@ setup_test # Use proper program, likely not the first one on PATH. fmtdump="${MH_LIBEXEC_DIR}/fmtdump" +check_exit '-eq 1' "$fmtdump" - +check_exit '-eq 1' "$fmtdump" -form +check_exit '-eq 1' "$fmtdump" -format +check_exit '-eq 1' "$fmtdump" foo bar +check_exit '-eq 0' "$fmtdump" -format ' + %4{} %(eq) %(getenv) %(decodecomp{}) %(trim{}) %(putaddr) + %(putlit) %(zputlit) %(compval{}) %(num) + %(plus) %(minus) %(multiply) %(divide) %(modulo) + %(charleft) %(kilo) %(kibi) + %(month{}) %(tzone{}) %(day{}) %(weekday{}) %(tws{}) %(pretty{}) + %(sec{}) %(min{}) %(hour{}) %(year{}) %(yday{}) %(wday{}) + %(clock{}) %(rclock{}) %(sday{}) %(dst{}) %(szone{}) + %(date2local{}) %(date2gmt{}) +' +check_exit '-eq 0' "$fmtdump" -format ' + %(addr{}) %(pers{}) %(mbox{}) %(host{}) %(path{}) %(gname{}) + %(note{}) %(proper{}) %(type{}) %(ingrp{}) %(nohost{}) + %(formataddr) %(concataddr) %(getmymbox{}) %(getmyaddr{}) + %<(null)%> %<(gt)%> %<(match)%> %<(amatch)%> + %(null) %(nonnull) %(ne) %(gt) %(match) %(amatch) +' +check_exit '-eq 0' "$fmtdump" -format "`printf '\302\010\014\015\011\177'`" + expected=$MH_TEST_DIR/$$.expected expected_err=$MH_TEST_DIR/$$.expected_err actual=$MH_TEST_DIR/$$.actual @@ -26,6 +49,7 @@ actual_err=$MH_TEST_DIR/$$.actual_err # check -help +start_test "-help" cat >$expected <$actual 2>&1 -check $expected $actual +#### Skip nmh intro text. +"$fmtdump" -help 2>&1 | sed '/^$/,$d' >"$actual" +check "$expected" "$actual" # check -version +start_test "-version" case `$fmtdump -v` in fmtdump\ --*) ;; * ) printf '%s: fmtdump -v generated unexpected output\n' "$0" >&2 @@ -46,9 +72,11 @@ case `$fmtdump -v` in esac # check unknown switch +start_test "unknown switch" run_test "$fmtdump -nonexistent" 'fmtdump: -nonexistent unknown' # check with no switches +start_test "with no switches" cat >$expected < +L2: CHAR ' ' +L3: PARSEDATE, c_name "date", c_type LV_MON, c_name "date", c_type NUMF, width 2, fill '0' CHAR '/' @@ -74,35 +98,35 @@ L5: PARSEDATE, c_name "date", c_type LV_MDAY, c_name "date", c_type NUMF, width 2, fill '0' LS_COMP, comp "date", c_type - IF_S continue else goto L6 + IF_S continue else goto L4 CHAR ' ' - GOTO L7 -L6: CHAR '*' -L7: MYMBOX, c_name "from", c_type + GOTO L5 +L4: CHAR '*' +L5: MYMBOX, c_name "from", c_type LV_COMPFLAG, comp "from", c_type - IF_V_NE 0 continue else goto L8 + IF_V_NE 0 continue else goto L6 LS_COMP, comp "to", c_type - IF_S continue else goto L8 + IF_S continue else goto L6 LIT "To:" PARSEADDR, c_name "to", c_type LS_FRIENDLY, c_name "to", c_type - FT_LS_DECODE + LS_DECODE STRF, width 14, fill ' ' -L8: IF_V_EQ 0 continue else goto L9 +L6: IF_V_EQ 0 continue else goto L7 PARSEADDR, c_name "from", c_type LS_FRIENDLY, c_name "from", c_type - FT_LS_DECODE + LS_DECODE STRF, width 17, fill ' ' -L9: LIT " " +L7: LIT " " LS_COMP, comp "subject" - FT_LS_DECODE + LS_DECODE STR LS_COMP, comp "body" - IF_S continue else goto L10 + IF_S continue else goto L8 LIT "<<" COMP, comp "body" LIT ">>" -L10: CHAR '\n' +L8: CHAR '\n' DONE EOF @@ -110,6 +134,7 @@ run_prog $fmtdump >$actual 2>&1 check $expected $actual # check -form +start_test "-form" cat >$expected < +L2: CHAR ' ' +L3: PARSEDATE, c_name "date", c_type LV_MON, c_name "date", c_type NUMF, width 2, fill '0' CHAR '/' @@ -135,37 +156,37 @@ L5: PARSEDATE, c_name "date", c_type LV_MDAY, c_name "date", c_type NUMF, width 2, fill '0' LS_COMP, comp "date", c_type - IF_S continue else goto L6 + IF_S continue else goto L4 CHAR ' ' - GOTO L7 -L6: CHAR '*' -L7: MYMBOX, c_name "from", c_type + GOTO L5 +L4: CHAR '*' +L5: MYMBOX, c_name "from", c_type LV_COMPFLAG, comp "from", c_type - IF_V_NE 0 continue else goto L8 + IF_V_NE 0 continue else goto L6 LS_COMP, comp "to", c_type - IF_S continue else goto L8 + IF_S continue else goto L6 LIT "To:" PARSEADDR, c_name "to", c_type LS_FRIENDLY, c_name "to", c_type - FT_LS_DECODE - + LS_DECODE + LS_UNQUOTE STRF, width 14, fill ' ' -L8: IF_V_EQ 0 continue else goto L9 +L6: IF_V_EQ 0 continue else goto L7 PARSEADDR, c_name "from", c_type LS_FRIENDLY, c_name "from", c_type - FT_LS_DECODE - + LS_DECODE + LS_UNQUOTE STRF, width 17, fill ' ' -L9: LIT " " +L7: LIT " " LS_COMP, comp "subject" - FT_LS_DECODE + LS_DECODE STR LS_COMP, comp "body" - IF_S continue else goto L10 + IF_S continue else goto L8 LIT "<<" COMP, comp "body" LIT ">>" -L10: CHAR '\n' +L8: CHAR '\n' DONE EOF @@ -173,6 +194,7 @@ run_prog $fmtdump -form "$MH_INST_DIR${nmhetcdir}/scan.default" >$actual 2>&1 check $expected $actual # check -format +start_test "-format" cat >$expected <' >$actual 2>&1 check $expected $actual +finish_test exit ${failed:-0}