Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/make/unit-tests make(1): avoid race condition in tes...



details:   https://anonhg.NetBSD.org/src/rev/96adcc149655
branches:  trunk
changeset: 956970:96adcc149655
user:      rillig <rillig%NetBSD.org@localhost>
date:      Thu Nov 12 21:54:52 2020 +0000

description:
make(1): avoid race condition in test opt-debug-jobs

Thanks sjg for finding this and suggesting the fix.

diffstat:

 usr.bin/make/unit-tests/opt-debug-jobs.exp |  2 ++
 usr.bin/make/unit-tests/opt-debug-jobs.mk  |  9 ++++++++-
 2 files changed, 10 insertions(+), 1 deletions(-)

diffs (32 lines):

diff -r 5523b5253836 -r 96adcc149655 usr.bin/make/unit-tests/opt-debug-jobs.exp
--- a/usr.bin/make/unit-tests/opt-debug-jobs.exp        Thu Nov 12 20:16:20 2020 +0000
+++ b/usr.bin/make/unit-tests/opt-debug-jobs.exp        Thu Nov 12 21:54:52 2020 +0000
@@ -10,6 +10,8 @@
 echo ": 'single' and \"double\" quotes"
 { : 'single' and "double" quotes 
 } || exit $?
+{ sleep 1 
+} || exit $?
 Running all
        Command: sh 
 JobExec(all): pid <pid> added to jobs table
diff -r 5523b5253836 -r 96adcc149655 usr.bin/make/unit-tests/opt-debug-jobs.mk
--- a/usr.bin/make/unit-tests/opt-debug-jobs.mk Thu Nov 12 20:16:20 2020 +0000
+++ b/usr.bin/make/unit-tests/opt-debug-jobs.mk Thu Nov 12 21:54:52 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: opt-debug-jobs.mk,v 1.4 2020/10/05 19:27:48 rillig Exp $
+# $NetBSD: opt-debug-jobs.mk,v 1.5 2020/11/12 21:54:52 rillig Exp $
 #
 # Tests for the -dj command line option, which adds debug logging about
 # running jobs in multiple shells.
@@ -24,3 +24,10 @@
        # This allows to copy and paste the whole command, without having
        # to unescape anything.
        : 'single' and "double" quotes
+
+       # Avoid a race condition in the debug output.  Without sleeping,
+       # it is not guaranteed that the two lines "exited/stopped" and
+       # "JobFinish" are output earlier than the stdout of the actual shell
+       # commands.  The '@' prefix avoids that this final command gets into
+       # another race condition with the "exited/stopped" line.
+       @sleep 1



Home | Main Index | Thread Index | Old Index