Re: v2.25.0-rc0 test failure on cygwin

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

 



Heh, so the subject and ...

On 02/06/2025 23:33, Ramsay Jones wrote:
> 
> I noticed on Friday, while testing the v2.25.0-rc0 build, that test t6137

.. this should read v2.50.0-rc0. Hmm ...

ATB,
Ramsay Jones

> failed on cygwin:
> 
>   $ tail test-out-2-50-rc0 
>   Test Summary Report
>   -------------------
>   t6137-pathspec-wildcards-literal.sh              (Wstat: 256 (exited 1) Tests: 25 Failed: 11)
>     Failed tests:  2, 7, 9, 11, 14-15, 17, 19, 21, 23, 25
>     Non-zero exit status: 1
>   Files=1023, Tests=30946, 21783 wallclock secs (19.08 usr 42.17 sys + 4031.65 cusr 12965.78 csys = 17058.68 CPU)
>   Result: FAIL
>   make[1]: *** [Makefile:78: prove] Error 1
>   make[1]: Leaving directory '/home/ramsay/git/t'
>   make: *** [Makefile:3286: test] Error 2
>   $ 
> 
> A quick squint at the failing tests made it clear that the failure was
> caused by the cygwin build treating a quoted glob character sequence
> (e.g. '\*') as a directory separator char followed by a glob character.
> 
> To show this, I quickly hacked up a patch which causes the test to pass:
> 
> 
>   diff --git a/abspath.h b/abspath.h
>   index 4653080d5e..a5e30a3033 100644
>   --- a/abspath.h
>   +++ b/abspath.h
>   @@ -27,7 +27,7 @@ char *prefix_filename_except_for_dash(const char *prefix, const char *path);
>    
>    static inline int is_absolute_path(const char *path)
>    {
>   -	return is_dir_sep(path[0]) || has_dos_drive_prefix(path);
>   +	return /*is_dir_sep(path[0])*/ path[0] == '/' || has_dos_drive_prefix(path);
>    }
>    
>    /**
>   diff --git a/path.c b/path.c
>   index 3b598b2847..f000b9ffff 100644
>   --- a/path.c
>   +++ b/path.c
>   @@ -1223,13 +1223,15 @@ int normalize_path_copy_len(char *dst, const char *src, int *prefix_len)
>    	end = src + offset_1st_component(src);
>    	while (src < end) {
>    		char c = *src++;
>   +#ifdef DUMMY
>    		if (is_dir_sep(c))
>    			c = '/';
>   +#endif
>    		*dst++ = c;
>    	}
>    	dst0 = dst;
>    
>   -	while (is_dir_sep(*src))
>   +	while (/*is_dir_sep(*src)*/ *src == '/')
>    		src++;
>    
>    	for (;;) {
>   @@ -1247,10 +1249,10 @@ int normalize_path_copy_len(char *dst, const char *src, int *prefix_len)
>    			if (!src[1]) {
>    				/* (1) */
>    				src++;
>   -			} else if (is_dir_sep(src[1])) {
>   +			} else if (/*is_dir_sep(src[1])*/ src[1] == '/') {
>    				/* (2) */
>    				src += 2;
>   -				while (is_dir_sep(*src))
>   +				while (/*is_dir_sep(*src)*/ *src == '/')
>    					src++;
>    				continue;
>    			} else if (src[1] == '.') {
>   @@ -1258,10 +1260,10 @@ int normalize_path_copy_len(char *dst, const char *src, int *prefix_len)
>    					/* (3) */
>    					src += 2;
>    					goto up_one;
>   -				} else if (is_dir_sep(src[2])) {
>   +				} else if (/*is_dir_sep(src[2])*/ src[2] == '/') {
>    					/* (4) */
>    					src += 3;
>   -					while (is_dir_sep(*src))
>   +					while (/*is_dir_sep(*src)*/ *src == '/')
>    						src++;
>    					goto up_one;
>    				}
>   @@ -1269,11 +1271,11 @@ int normalize_path_copy_len(char *dst, const char *src, int *prefix_len)
>    		}
>    
>    		/* copy up to the next '/', and eat all '/' */
>   -		while ((c = *src++) != '\0' && !is_dir_sep(c))
>   +		while ((c = *src++) != '\0' && !(/*is_dir_sep(c)*/ c == '/'))
>    			*dst++ = c;
>   -		if (is_dir_sep(c)) {
>   +		if (/*is_dir_sep(c)*/ c == '/') {
>    			*dst++ = '/';
>   -			while (is_dir_sep(c))
>   +			while (/*is_dir_sep(c)*/ c == '/')
>    				c = *src++;
>    			src--;
>    		} else if (!c)
> 
> In other words, in 'is_absolute_path()' and 'normalize_path_copy_len()', then
> just disable the '\' character as a path separator! ;)
> 
> This was just to demonstrate the problem, not a serious patch, of course!
> 
> I was away for the weekend and was expecting to see a patch to fix this
> on Gfw when I got back, but to my surprise there has been no mention of
> it on the mailing list (having now waded through the backlog!).
> 
> To be clear, I can not imagine that this test passes on Gfw. However, this
> should have been failing the windows CI for ages, so ... perhaps I don't
> have a sufficiently vivid imagination. :)
> 
> Anyway, the patch below 'fixes' the issue on cygwin.
> 
> Thanks.
> 
> ATB,
> Ramsay Jones
> 
> 
> ---- >8 ----
> From: Ramsay Jones <ramsay@xxxxxxxxxxxxxxxxxxxx>
> Date: Mon, 2 Jun 2025 22:51:33 +0100
> Subject: [PATCH] t6137: disable 'quoted glob' pathspecs on cygwin
> 
> The backslash in a 'quoted glob' character is treated as a directory
> separator character on cygwin, which causes all such tests to fail.
> Skip all such tests on cygwin using the !CYGWIN prerequisite. While
> here, fix a few test titles as well.
> 
> Signed-off-by: Ramsay Jones <ramsay@xxxxxxxxxxxxxxxxxxxx>
> ---
>  t/t6137-pathspec-wildcards-literal.sh | 24 ++++++++++++------------
>  1 file changed, 12 insertions(+), 12 deletions(-)
> 
> diff --git a/t/t6137-pathspec-wildcards-literal.sh b/t/t6137-pathspec-wildcards-literal.sh
> index 20abad5667..229e48282e 100755
> --- a/t/t6137-pathspec-wildcards-literal.sh
> +++ b/t/t6137-pathspec-wildcards-literal.sh
> @@ -39,7 +39,7 @@ test_expect_success 'add wildcard *' '
>  	)
>  '
>  
> -test_expect_success 'add literal \*' '
> +test_expect_success !CYGWIN 'add literal \*' '
>  	git init test-asterisk-literal &&
>  	(
>  		cd test-asterisk-literal &&
> @@ -125,7 +125,7 @@ test_expect_success 'add wildcard f*' '
>  	)
>  '
>  
> -test_expect_success 'add literal f\*' '
> +test_expect_success !CYGWIN 'add literal f\*' '
>  	git init test-f-lit &&
>  	(
>  		cd test-f-lit &&
> @@ -156,7 +156,7 @@ test_expect_success 'add wildcard f**' '
>  	)
>  '
>  
> -test_expect_success 'add literal f\*\*' '
> +test_expect_success !CYGWIN 'add literal f\*\*' '
>  	git init test-fdstar-lit &&
>  	(
>  		cd test-fdstar-lit &&
> @@ -184,7 +184,7 @@ test_expect_success 'add wildcard f?z' '
>  	)
>  '
>  
> -test_expect_success 'add literal \? literal' '
> +test_expect_success !CYGWIN 'add literal \? literal' '
>  	git init test-q-lit &&
>  	(
>  		cd test-q-lit &&
> @@ -227,7 +227,7 @@ test_expect_success 'add wildcard hello?world' '
>  	)
>  '
>  
> -test_expect_success 'add literal hello\?world' '
> +test_expect_success !CYGWIN 'add literal hello\?world' '
>  	git init test-hellolit &&
>  	(
>  		cd test-hellolit &&
> @@ -241,7 +241,7 @@ test_expect_success 'add literal hello\?world' '
>  	)
>  '
>  
> -test_expect_success 'add literal [abc]' '
> +test_expect_success !CYGWIN 'add literal \[abc\]' '
>  	git init test-brackets-lit &&
>  	(
>  		cd test-brackets-lit &&
> @@ -280,7 +280,7 @@ test_expect_success 'commit: wildcard *' '
>  	)
>  '
>  
> -test_expect_success 'commit: literal *' '
> +test_expect_success !CYGWIN 'commit: literal \*' '
>  	git init test-c-asterisk-lit &&
>  	(
>  		cd test-c-asterisk-lit &&
> @@ -313,7 +313,7 @@ test_expect_success 'commit: wildcard f*' '
>  	)
>  '
>  
> -test_expect_success 'commit: literal f\*' '
> +test_expect_success !CYGWIN 'commit: literal f\*' '
>  	git init test-c-flit &&
>  	(
>  		cd test-c-flit &&
> @@ -328,7 +328,7 @@ test_expect_success 'commit: literal f\*' '
>  	)
>  '
>  
> -test_expect_success 'commit: wildcard pathspec limits commit' '
> +test_expect_success 'commit: wildcard f**' '
>  	git init test-c-pathlimit &&
>  	(
>  		cd test-c-pathlimit &&
> @@ -346,7 +346,7 @@ test_expect_success 'commit: wildcard pathspec limits commit' '
>  	)
>  '
>  
> -test_expect_success 'commit: literal f\*\*' '
> +test_expect_success !CYGWIN 'commit: literal f\*\*' '
>  	git init test-c-fdstar-lit &&
>  	(
>  		cd test-c-fdstar-lit &&
> @@ -379,7 +379,7 @@ test_expect_success 'commit: wildcard ?' '
>  	)
>  '
>  
> -test_expect_success 'commit: literal \?' '
> +test_expect_success !CYGWIN 'commit: literal \?' '
>  	git init test-c-qlit &&
>  	(
>  		cd test-c-qlit &&
> @@ -411,7 +411,7 @@ test_expect_success 'commit: wildcard hello?world' '
>  	)
>  '
>  
> -test_expect_success 'commit: literal hello\?world' '
> +test_expect_success !CYGWIN 'commit: literal hello\?world' '
>  	git init test-c-hellolit &&
>  	(
>  		cd test-c-hellolit &&





[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux