Home | History | Annotate | Line # | Download | only in unit-tests
job-output-null.mk revision 1.1
      1 # $NetBSD: job-output-null.mk,v 1.1 2021/04/15 19:02:29 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 .MAKEFLAGS: -j1		# force jobs mode
     11 
     12 all: .PHONY
     13 	# The null byte from the command output is kept as-is.
     14 	# See CollectOutput, which looks like it intended to replace these
     15 	# null bytes with simple spaces.
     16 	@printf 'hello\0world%s\n' ''
     17 
     18 	# Give the parent process a chance to see the above output, but not
     19 	# yet the output from the next printf command.
     20 	@sleep 1
     21 
     22 	# All null bytes from the command output are kept as-is.
     23 	@printf 'hello\0world%s\n' '' '' '' '' '' ''
     24 
     25 	@sleep 1
     26 
     27 	# The null bytes are replaced with spaces since they are not followed
     28 	# by a newline.
     29 	#
     30 	# The three null bytes in a row test whether this output is
     31 	# compressed to a single space like in DebugFailedTarget.  It isn't.
     32 	@printf 'hello\0world\0without\0\0\0newline%s' ', ' ', ' '.'
     33