X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/d1506bc0824ad871cd0e694ad834188fe2fc6269..7545be37e6306c01f2906f8f81ccc54e8f54ec46:/test/install-mh/test-version-check diff --git a/test/install-mh/test-version-check b/test/install-mh/test-version-check index 16bbcfef..2f26e5af 100755 --- a/test/install-mh/test-version-check +++ b/test/install-mh/test-version-check @@ -6,9 +6,6 @@ # ###################################################### -test -t 0 && echo stdin # ???? -test -t 1 && echo stdout # ???? -test -t 2 && echo stderr # ???? set -e if test -z "${MH_OBJ_DIR}"; then @@ -20,27 +17,15 @@ fi setup_test -require_prog script -#### FreeBSD script, e.g., doesn't use -c to identify a command to run. -if script -c 'echo OK' /dev/null 2>&1 | egrep 'OK' >/dev/null; then - script_command_opt='-c' -else - script_command_opt='' +if test ! -t 0 || test ! -t 1 || test ! -t 2; then + test_skip 'must be connected to terminal' fi -#### Run a command but don't wait for user input. script(1) seems to do -#### what we want by not waiting when run in the background. -run_without_input() { - if [ "$script_command_opt" = -c ]; then - #### -c takes single argument with command + arguments. - script -q -f -c "$*" "$actual" >/dev/null & - else - #### E.g., FreeBSD. Don't combine command arguments. - script -q -t 0 "$actual" "$@" >/dev/null & - fi - - wait $! -} +require_prog script +#### Use minimal arguments to script(1), i.e., just the file in +#### which to save the output. We do pipe input to script, which is +#### discouraged by the NOTES and BUGS sections of its man page. +#### But that seems to work. actual="$MH_TEST_DIR/test-version-check$$.actual" context="${MH_TEST_DIR}"/Mail/context @@ -53,7 +38,7 @@ mv -f "$context.NEW" "$context" start_test 'mhparam skips the welcome message' -run_without_input mhparam path +printf 'mhparam path\nexit\n' | script "$actual" >/dev/null grep 'Welcome to nmh version ' "$actual" >/dev/null && false # Make sure that version wasn't added to context. grep "^${version}$" "${MH_TEST_DIR}/Mail/context" >/dev/null && false @@ -63,7 +48,7 @@ rm "$actual" start_test 'Welcome: disable in profile skips the welcome message' cp "${MH}" "${MH}-welcome" printf 'Welcome: disable\n' >> "${MH}-welcome" -(MH="${MH}-welcome" run_without_input pick last) +(printf 'pick last\nexit\n' | MH="${MH}-welcome" script "$actual" >/dev/null) grep 'Welcome to nmh version ' "$actual" >/dev/null && false # Make sure that version wasn't added to context. grep "^${version}$" "${MH_TEST_DIR}/Mail/context" >/dev/null && false @@ -71,7 +56,7 @@ rm "$actual" start_test 'with welcome message' -run_without_input pick last +printf 'pick last\nexit\n' | script "$actual" >/dev/null grep 'Welcome to nmh version ' "$actual" >/dev/null # Make sure that version was added to context. grep "^${version}$" "${MH_TEST_DIR}/Mail/context" >/dev/null @@ -81,7 +66,7 @@ rm "$actual" start_test 'without welcome message' # After running the previous test, this one should not have # the welcome message. -run_without_input pick last +printf 'pick last\nexit\n' | script "$actual" >/dev/null grep 'Welcome to nmh version ' "$actual" >/dev/null && false # Make sure that version is still in context. grep "^${version}$" "${MH_TEST_DIR}/Mail/context" >/dev/null @@ -91,7 +76,7 @@ rm "$actual" start_test 'with MHCONTEXT, welcome only if older' MHCONTEXT="${MH_TEST_DIR}/Mail/context2"; export MHCONTEXT printf 'Version: nmh-1.5\n' >"${MHCONTEXT}" -run_without_input pick last +printf 'pick last\nexit\n' | script "$actual" >/dev/null grep 'Welcome to nmh version ' "$actual" >/dev/null # And make sure that version did get updated in context. grep "^${version}$" "${MHCONTEXT}" >/dev/null @@ -100,7 +85,7 @@ rm "$actual" start_test "with MHCONTEXT doesn't welcome if newer" printf 'Version: nmh-10000.0\n' >"${MHCONTEXT}" -run_without_input pick last +printf 'pick last\nexit\n' | script "$actual" >/dev/null grep 'Welcome to nmh version ' "$actual" >/dev/null && false # And make sure that version didn't get updated in context. grep '^Version: nmh-10000.0$' "${MHCONTEXT}" >/dev/null @@ -109,7 +94,7 @@ rm "$actual" start_test 'with MHCONTEXT but no version, no welcome and update' printf '' >"${MHCONTEXT}" -run_without_input pick last +printf 'pick last\nexit\n' | script "$actual" >/dev/null grep 'Welcome to nmh version ' "$actual" >/dev/null && false # And make sure that version did get updated in context. grep "^${version}$" "${MHCONTEXT}" >/dev/null