@@ -238,37 +238,24 @@ jobs:
matrix:
vector:
- jobname: linux-clang
- cc: clang
pool: ubuntu-latest
- jobname: linux-sha256
- cc: clang
os: ubuntu
pool: ubuntu-latest
- jobname: linux-gcc
- cc: gcc
- cc_package: gcc-8
pool: ubuntu-latest
- jobname: linux-TEST-vars
- cc: gcc
os: ubuntu
- cc_package: gcc-8
pool: ubuntu-latest
- jobname: osx-clang
- cc: clang
pool: macos-latest
- jobname: osx-gcc
- cc: gcc
- cc_package: gcc-9
pool: macos-latest
- jobname: linux-gcc-default
- cc: gcc
pool: ubuntu-latest
- jobname: linux-leaks
- cc: gcc
pool: ubuntu-latest
env:
- CC: ${{matrix.vector.cc}}
- CC_PACKAGE: ${{matrix.vector.cc_package}}
jobname: ${{matrix.vector.jobname}}
runs_on_pool: ${{matrix.vector.pool}}
runs-on: ${{matrix.vector.pool}}
@@ -52,7 +52,9 @@ setenv () {
fi
}
-# Clear MAKEFLAGS that may come from the outside world.
+# Clear variables that may come from the outside world.
+CC=
+CC_PACKAGE=
MAKEFLAGS=
# Common make and cmake build options
@@ -64,8 +66,6 @@ MAKEFLAGS="DEVELOPER=$DEVELOPER SKIP_DASHED_BUILT_INS=$SKIP_DASHED_BUILT_INS"
case "$CI_TYPE" in
github-actions)
- CC="${CC:-gcc}"
-
setenv --test GIT_PROVE_OPTS "--timer --jobs 10"
GIT_TEST_OPTS="--verbose-log -x"
MAKEFLAGS="$MAKEFLAGS --jobs=10"
@@ -135,9 +135,16 @@ vs-test)
setenv --test NO_SVN_TESTS YesPlease
;;
linux-gcc)
+ CC=gcc
+ CC_PACKAGE=gcc-8
setenv --test GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME main
;;
+linux-gcc-default)
+ CC=gcc
+ ;;
linux-TEST-vars)
+ CC=gcc
+ CC_PACKAGE=gcc-8
setenv --test GIT_TEST_SPLIT_INDEX yes
setenv --test GIT_TEST_MERGE_ALGORITHM recursive
setenv --test GIT_TEST_FULL_IN_PACK_ARRAY true
@@ -152,13 +159,23 @@ linux-TEST-vars)
setenv --test GIT_TEST_WRITE_REV_INDEX 1
setenv --test GIT_TEST_CHECKOUT_WORKERS 2
;;
+osx-gcc)
+ CC=gcc
+ CC_PACKAGE=gcc-9
+ ;;
+osx-clang)
+ CC=clang
+ ;;
linux-clang)
+ CC=clang
setenv --test GIT_TEST_DEFAULT_HASH sha1
;;
linux-sha256)
+ CC=clang
setenv --test GIT_TEST_DEFAULT_HASH sha256
;;
pedantic)
+ CC=gcc
# Don't run the tests; we only care about whether Git can be
# built.
setenv --build DEVOPTS pedantic
@@ -173,9 +190,11 @@ linux-musl)
MAKEFLAGS="$MAKEFLAGS GIT_TEST_UTF8_LOCALE=C.UTF-8"
;;
linux-leaks)
+ CC=gcc
setenv --build SANITIZE leak
setenv --test GIT_TEST_PASSING_SANITIZE_LEAK true
;;
esac
-setenv --all MAKEFLAGS "$MAKEFLAGS CC=${CC:-cc}"
+MAKEFLAGS="$MAKEFLAGS${CC:+ CC=$CC}"
+setenv --all MAKEFLAGS "$MAKEFLAGS"
Rather than pass a "$CC" and "$CC_PACKAGE" in the environment to be picked up in ci/lib.sh let's instead have ci/lib.sh itself add it directly to MAKEFLAGS. Setting CC=gcc by default made for confusing trace output, and since a preceding change to carry it and others over across "steps" in the GitHub CI it's been even more misleading. E.g. the "win+VS build" job confusingly has CC=gcc set, even though it builds with MSVC. Let's instead reply on the Makefile default of CC=cc, and only override it for those jobs where it's needed. This does mean that we'll need to set it for the "pedantic" job, which previously relied on the default CC=gcc in case "clang" become the default on that platform. This partially reverts my 707d2f2fe86 (CI: use "$runs_on_pool", not "$jobname" to select packages & config, 2021-11-23), i.e. we're now aiming to only set those variables specific jobs need. Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com> --- .github/workflows/main.yml | 13 ------------- ci/lib.sh | 27 +++++++++++++++++++++++---- 2 files changed, 23 insertions(+), 17 deletions(-)