 25715419bf
			
		
	
	25715419bf
	
	
	
		
			
			The "linux-clang" and "linux-gcc" jobs both run "make test" twice, but
with different environment variables. Running these in sequence seems
to have been done to work around some constraint on Travis, see
ae59a4e44f (travis: run tests with GIT_TEST_SPLIT_INDEX, 2018-01-07).
By having these run in parallel we'll get jobs that finish much sooner
than they otherwise would have.
We can also simplify the control flow in "ci/run-build-and-tests.sh"
as a result, since we won't run "make test" twice we don't need to run
"make" twice at all, let's default to "make all test" after setting
the variables, and then override it to just "all" for the compile-only
tests.
Add a comment to clarify that new "test" targets should adjust
$MAKE_TARGETS rather than being added after the "case/esac". This
should avoid future confusion where e.g. the compilation-only
"pedantic" target will unexpectedly start running tests. See [1] and
[2].
1. https://lore.kernel.org/git/211122.86ee78yxts.gmgdl@evledraar.gmail.com/
2. https://lore.kernel.org/git/211123.86ilwjujmd.gmgdl@evledraar.gmail.com/
Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
	
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| #
 | |
| # Build and test Git
 | |
| #
 | |
| 
 | |
| . ${0%/*}/lib.sh
 | |
| 
 | |
| case "$CI_OS_NAME" in
 | |
| windows*) cmd //c mklink //j t\\.prove "$(cygpath -aw "$cache_dir/.prove")";;
 | |
| *) ln -s "$cache_dir/.prove" t/.prove;;
 | |
| esac
 | |
| 
 | |
| export MAKE_TARGETS="all test"
 | |
| 
 | |
| case "$jobname" in
 | |
| linux-gcc)
 | |
| 	export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
 | |
| 	;;
 | |
| linux-TEST-vars)
 | |
| 	export GIT_TEST_SPLIT_INDEX=yes
 | |
| 	export GIT_TEST_MERGE_ALGORITHM=recursive
 | |
| 	export GIT_TEST_FULL_IN_PACK_ARRAY=true
 | |
| 	export GIT_TEST_OE_SIZE=10
 | |
| 	export GIT_TEST_OE_DELTA_SIZE=5
 | |
| 	export GIT_TEST_COMMIT_GRAPH=1
 | |
| 	export GIT_TEST_COMMIT_GRAPH_CHANGED_PATHS=1
 | |
| 	export GIT_TEST_MULTI_PACK_INDEX=1
 | |
| 	export GIT_TEST_MULTI_PACK_INDEX_WRITE_BITMAP=1
 | |
| 	export GIT_TEST_ADD_I_USE_BUILTIN=1
 | |
| 	export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=master
 | |
| 	export GIT_TEST_WRITE_REV_INDEX=1
 | |
| 	export GIT_TEST_CHECKOUT_WORKERS=2
 | |
| 	;;
 | |
| linux-clang)
 | |
| 	export GIT_TEST_DEFAULT_HASH=sha1
 | |
| 	;;
 | |
| linux-sha256)
 | |
| 	export GIT_TEST_DEFAULT_HASH=sha256
 | |
| 	;;
 | |
| pedantic)
 | |
| 	# Don't run the tests; we only care about whether Git can be
 | |
| 	# built.
 | |
| 	export DEVOPTS=pedantic
 | |
| 	export MAKE_TARGETS=all
 | |
| 	;;
 | |
| esac
 | |
| 
 | |
| # Any new "test" targets should not go after this "make", but should
 | |
| # adjust $MAKE_TARGETS. Otherwise compilation-only targets above will
 | |
| # start running tests.
 | |
| make $MAKE_TARGETS
 | |
| check_unignored_build_artifacts
 | |
| 
 | |
| save_good_tree
 |