X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/ad214d52fb2975aabd270de884f892fd1897a5bb..73b87885541e6422e267fa88ba61b7a3133059e0:/test/install-mh/test-version-check?ds=inline diff --git a/test/install-mh/test-version-check b/test/install-mh/test-version-check index f2fbe6c5..66e9076b 100755 --- a/test/install-mh/test-version-check +++ b/test/install-mh/test-version-check @@ -18,32 +18,112 @@ fi setup_test require_prog script +if script -S /bin/sh 'echo OK' /dev/null 2>&1 | egrep 'OK' >/dev/null; then + #### script(1) uses -S to set the shell that it runs. + use_dash_S=1 +else + #### Assume that script(1) uses SHELL environment variable. + use_dash_S=0 +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() { + #### Create a command to use as a shell for script. + cat >"${cmd}" </dev/null & + else + SHELL="${cmd}" script "$actual" >/dev/null & + fi + + wait $! +} actual="$MH_TEST_DIR/test-version-check$$.actual" context="${MH_TEST_DIR}"/Mail/context +version="Version: nmh-${MH_VERSION}" +cmd="${MH_TEST_DIR}/Mail/cmd" - -start_test 'with welcome message' -# Removing Version will trigger the welcome message. +# Removing Version will trigger the welcome message. (setup_test +# inserted it so that other tests wouldn't show it.) grep -v Version "$context" > "$context.NEW" mv -f "$context.NEW" "$context" -# The will command wait for the user to hit return. script seems to do what -# we want, continue, when run in the background. -script -c 'pick last' -f -q "$actual" >/dev/null & -wait $! + + +start_test 'mhparam skips the welcome message' +run_without_input mhparam path +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 +rm "$actual" + + +start_test 'Welcome: disable in profile skips the welcome message' +cp "${MH}" "${MH}-welcome" +printf 'Welcome: disable\n' >> "${MH}-welcome" +# Run the function in subshell instead of augmenting the environment +# for a single command, so that the environment does not retain the +# MH setting. That can happen when run under distcheck, depending +# on the user's shell. +(MH="${MH}-welcome"; run_without_input pick last) +rm "${MH}-welcome" +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 +rm "$actual" + + +start_test 'with welcome message' +run_without_input pick last 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 rm "$actual" -finish_test start_test 'without welcome message' # After running the previous test, this one should not have # the welcome message. -script -c 'pick last' -f -q "$actual" >/dev/null & -wait $! +run_without_input pick last 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 rm "$actual" -finish_test +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 +grep 'Welcome to nmh version ' "$actual" >/dev/null +# And make sure that version did get updated in context. +grep "^${version}$" "${MHCONTEXT}" >/dev/null +rm "$actual" + + +start_test "with MHCONTEXT doesn't welcome if newer" +printf 'Version: nmh-10000.0\n' >"${MHCONTEXT}" +run_without_input pick last +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 +rm "$actual" + + +start_test 'with MHCONTEXT but no version, no welcome and update' +printf '' >"${MHCONTEXT}" +run_without_input pick last +grep 'Welcome to nmh version ' "$actual" >/dev/null && false +# And make sure that version did get updated in context. +grep "^${version}$" "${MHCONTEXT}" >/dev/null +rm "$actual" + + +finish_test exit $failed