ci: merge scripts which install dependencies

We have two different scripts which install dependencies, one for
dockerized jobs and one for non-dockerized ones. Naturally, these
scripts have quite some duplication. Furthermore, either of these
scripts is missing some test dependencies that the respective other
script has, thus reducing test coverage.

Merge those two scripts such that there is a single source of truth for
test dependencies, only.

Signed-off-by: Patrick Steinhardt <ps@pks.im>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Patrick Steinhardt 2024-04-12 06:44:32 +02:00 committed by Junio C Hamano
parent 2c5c7639e5
commit 9cdeb34b96
4 changed files with 31 additions and 53 deletions

View File

@ -359,7 +359,7 @@ jobs:
if: matrix.vector.jobname != 'linux32' if: matrix.vector.jobname != 'linux32'
- uses: actions/checkout@v1 # cannot be upgraded because Node.js Actions aren't supported in this container - uses: actions/checkout@v1 # cannot be upgraded because Node.js Actions aren't supported in this container
if: matrix.vector.jobname == 'linux32' if: matrix.vector.jobname == 'linux32'
- run: ci/install-docker-dependencies.sh - run: ci/install-dependencies.sh
- run: ci/run-build-and-tests.sh - run: ci/run-build-and-tests.sh
- name: print test failures - name: print test failures
if: failure() && env.FAILED_TEST_ARTIFACTS != '' if: failure() && env.FAILED_TEST_ARTIFACTS != ''

View File

@ -12,7 +12,7 @@ test:linux:
variables: variables:
CUSTOM_PATH: "/custom" CUSTOM_PATH: "/custom"
before_script: before_script:
- ./ci/install-docker-dependencies.sh - ./ci/install-dependencies.sh
script: script:
- useradd builder --create-home - useradd builder --create-home
- chown -R builder "${CI_PROJECT_DIR}" - chown -R builder "${CI_PROJECT_DIR}"
@ -100,7 +100,7 @@ static-analysis:
variables: variables:
jobname: StaticAnalysis jobname: StaticAnalysis
before_script: before_script:
- ./ci/install-docker-dependencies.sh - ./ci/install-dependencies.sh
script: script:
- ./ci/run-static-analysis.sh - ./ci/run-static-analysis.sh
- ./ci/check-directional-formatting.bash - ./ci/check-directional-formatting.bash

View File

@ -5,6 +5,8 @@
. ${0%/*}/lib.sh . ${0%/*}/lib.sh
begin_group "Install dependencies"
P4WHENCE=https://cdist2.perforce.com/perforce/r21.2 P4WHENCE=https://cdist2.perforce.com/perforce/r21.2
LFSWHENCE=https://github.com/github/git-lfs/releases/download/v$LINUX_GIT_LFS_VERSION LFSWHENCE=https://github.com/github/git-lfs/releases/download/v$LINUX_GIT_LFS_VERSION
@ -20,14 +22,27 @@ then
fi fi
case "$distro" in case "$distro" in
alpine-*)
apk add --update shadow sudo build-base curl-dev openssl-dev expat-dev gettext \
pcre2-dev python3 musl-libintl perl-utils ncurses \
apache2 apache2-http2 apache2-proxy apache2-ssl apache2-webdav apr-util-dbd_sqlite3 \
bash cvs gnupg perl-cgi perl-dbd-sqlite >/dev/null
;;
fedora-*)
dnf -yq update >/dev/null &&
dnf -yq install make gcc findutils diffutils perl python3 gettext zlib-devel expat-devel openssl-devel curl-devel pcre2-devel >/dev/null
;;
ubuntu-*) ubuntu-*)
# Required so that apt doesn't wait for user input on certain packages.
export DEBIAN_FRONTEND=noninteractive
sudo apt-get -q update sudo apt-get -q update
sudo apt-get -q -y install \ sudo apt-get -q -y install \
language-pack-is libsvn-perl apache2 \ language-pack-is libsvn-perl apache2 cvs cvsps git gnupg subversion \
make libssl-dev libcurl4-openssl-dev libexpat-dev \ make libssl-dev libcurl4-openssl-dev libexpat-dev wget sudo \
tcl tk gettext zlib1g-dev perl-modules liberror-perl libauthen-sasl-perl \ tcl tk gettext zlib1g-dev perl-modules liberror-perl libauthen-sasl-perl \
libemail-valid-perl libio-socket-ssl-perl libnet-smtp-ssl-perl \ libemail-valid-perl libio-socket-ssl-perl libnet-smtp-ssl-perl libdbd-sqlite3-perl libcgi-pm-perl \
$CC_PACKAGE $PYTHON_PACKAGE ${CC_PACKAGE:-${CC:-gcc}} $PYTHON_PACKAGE
mkdir --parents "$CUSTOM_PATH" mkdir --parents "$CUSTOM_PATH"
wget --quiet --directory-prefix="$CUSTOM_PATH" \ wget --quiet --directory-prefix="$CUSTOM_PATH" \
@ -39,6 +54,13 @@ ubuntu-*)
-C "$CUSTOM_PATH" --strip-components=1 "git-lfs-$LINUX_GIT_LFS_VERSION/git-lfs" -C "$CUSTOM_PATH" --strip-components=1 "git-lfs-$LINUX_GIT_LFS_VERSION/git-lfs"
rm "git-lfs-linux-amd64-$LINUX_GIT_LFS_VERSION.tar.gz" rm "git-lfs-linux-amd64-$LINUX_GIT_LFS_VERSION.tar.gz"
;; ;;
ubuntu32-*)
sudo linux32 --32bit i386 sh -c '
apt update >/dev/null &&
apt install -y build-essential libcurl4-openssl-dev \
libssl-dev libexpat-dev gettext python >/dev/null
'
;;
macos-*) macos-*)
export HOMEBREW_NO_AUTO_UPDATE=1 HOMEBREW_NO_INSTALL_CLEANUP=1 export HOMEBREW_NO_AUTO_UPDATE=1 HOMEBREW_NO_INSTALL_CLEANUP=1
# Uncomment this if you want to run perf tests: # Uncomment this if you want to run perf tests:
@ -98,3 +120,5 @@ then
else else
echo >&2 "WARNING: git-lfs wasn't installed, see above for clues why" echo >&2 "WARNING: git-lfs wasn't installed, see above for clues why"
fi fi
end_group "Install dependencies"

View File

@ -1,46 +0,0 @@
#!/bin/sh
#
# Install dependencies required to build and test Git inside container
#
. ${0%/*}/lib.sh
begin_group "Install dependencies"
case "$jobname" in
linux32)
linux32 --32bit i386 sh -c '
apt update >/dev/null &&
apt install -y build-essential libcurl4-openssl-dev \
libssl-dev libexpat-dev gettext python >/dev/null
'
;;
linux-musl)
apk add --update shadow sudo build-base curl-dev openssl-dev expat-dev gettext \
pcre2-dev python3 musl-libintl perl-utils ncurses \
apache2 apache2-http2 apache2-proxy apache2-ssl apache2-webdav apr-util-dbd_sqlite3 \
bash cvs gnupg perl-cgi perl-dbd-sqlite >/dev/null
;;
linux-*|StaticAnalysis)
# Required so that apt doesn't wait for user input on certain packages.
export DEBIAN_FRONTEND=noninteractive
apt update -q &&
apt install -q -y sudo git make language-pack-is libsvn-perl apache2 libssl-dev \
libcurl4-openssl-dev libexpat-dev tcl tk gettext zlib1g-dev \
perl-modules liberror-perl libauthen-sasl-perl libemail-valid-perl \
libdbd-sqlite3-perl libio-socket-ssl-perl libnet-smtp-ssl-perl ${CC_PACKAGE:-${CC:-gcc}} \
apache2 cvs cvsps gnupg libcgi-pm-perl subversion
if test "$jobname" = StaticAnalysis
then
apt install -q -y coccinelle
fi
;;
pedantic)
dnf -yq update >/dev/null &&
dnf -yq install make gcc findutils diffutils perl python3 gettext zlib-devel expat-devel openssl-devel curl-devel pcre2-devel >/dev/null
;;
esac
end_group "Install dependencies"