Home | History | Annotate | Line # | Download | only in unit-tests
job-output-null.mk revision 1.3
      1 # $NetBSD: job-output-null.mk,v 1.3 2021/09/12 10:26:49 rillig Exp $
      2 #
      3 # Test how null bytes in the output of a command are handled.  Make processes
      4 # them using null-terminated strings, which may cut off some of the output.
      5 #
      6 # As of 2021-04-15, make handles null bytes from the child process
      7 # inconsistently.  It's an edge case though since typically the child
      8 # processes output text.
      9 
     10 # Note: The printf commands used in this test must only use a single format
     11 # string, without parameters.  This is because it is implementation-dependent
     12 # how many times the command 'printf "fmt%s" "" "" ""' calls write(2).
     13 #
     14 #	NetBSD /bin/sh		1 x write("fmtfmtfmt")
     15 #	Dash			1 x write("fmtfmtfmt")
     16 #	NetBSD /bin/ksh		3 x write("fmt") (via /bin/printf)
     17 #	Bash 5			3 x write("fmt")
     18 #
     19 # In the latter case the output may arrive in parts, which in this test makes
     20 # a crucial difference since the outcome of the test depends on whether there
     21 # is a '\n' in each of the blocks from the output.
     22 
     23 .MAKEFLAGS: -j1		# force jobs mode
     24 
     25 all: .PHONY
     26 	# The null byte from the command output is kept as-is.
     27 	# See CollectOutput, which looks like it intended to replace these
     28 	# null bytes with simple spaces.
     29 	@printf '1\0trailing\n'
     30 
     31 	# Give the parent process a chance to see the above output, but not
     32 	# yet the output from the next printf command.
     33 	@sleep 1
     34 
     35 	# All null bytes from the command output are kept as-is.
     36 	@printf '2a\0trailing\n''2b\0trailing\n''2c\0trailing\n'
     37 
     38 	@sleep 1
     39 
     40 	# The null bytes are replaced with spaces since they are not followed
     41 	# by a newline.
     42 	#
     43 	# The three null bytes in a row test whether this output is
     44 	# compressed to a single space like in DebugFailedTarget.  It isn't.
     45 	@printf '3a\0without\0\0\0newline, 3b\0without\0\0\0newline.'
     46