From: Dmitry Kurochkin Date: Thu, 17 Nov 2011 13:05:55 +0000 (+0400) Subject: test: set EMACS_SERVER variable only after dtach(1) was successfully started X-Git-Tag: 0.11_rc1~93 X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=commitdiff_plain;h=9d5b521472d1ac401ca2667d1261b641bef208cb test: set EMACS_SERVER variable only after dtach(1) was successfully started Otherwise, we can set the EMACS_SERVER and return with an error. And subsequent calls to test_emacs would assume that emacs server is running. --- diff --git a/test/test-lib.sh b/test/test-lib.sh index 0735b5c9..20fa195e 100644 --- a/test/test-lib.sh +++ b/test/test-lib.sh @@ -845,16 +845,17 @@ EOF test_emacs () { if [ -z "$EMACS_SERVER" ]; then - EMACS_SERVER="notmuch-test-suite-$$" + server_name="notmuch-test-suite-$$" # start a detached session with an emacs server # user's TERM is given to dtach which assumes a minimally # VT100-compatible terminal -- and emacs inherits that TERM=$ORIGINAL_TERM dtach -n "$TEST_TMPDIR/emacs-dtach-socket.$$" \ sh -c "stty rows 24 cols 80; exec '$TMP_DIRECTORY/run_emacs' \ --no-window-system \ - --eval '(setq server-name \"$EMACS_SERVER\")' \ + --eval '(setq server-name \"$server_name\")' \ --eval '(server-start)' \ --eval '(orphan-watchdog $$)'" || return + EMACS_SERVER="$server_name" # wait until the emacs server is up until test_emacs '()' 2>/dev/null; do sleep 1