ci: Add continuous integration for github repositories via cirrus-ci.
Currently FreeBSD, Linux, macOS and Windows (Visual Studio) are tested. The main goal of this integration is to make it easier to test in-development patches across multiple platforms. This includes improving the testing done automatically by cfbot [1] for commitfest entries. It is *not* the goal to supersede the buildfarm. cirrus-ci [2] was chosen because it was already in use for cfbot, allows using full VMs, has good OS coverage and allows accessing the full test results without authentication (like a github account). It might be worth adding support for further CI providers, particularly ones supporting other git forges, in the future. To keep CI times tolerable, most platforms use pre-generated images. Some platforms use containers, others use full VMs. For instructions on how to enable the CI integration in a repository and further details, see src/tools/ci/README [1] http://cfbot.cputube.org/ [2] https://cirrus-ci.org/ Author: Andres Freund <andres@anarazel.de> Author: Thomas Munro <tmunro@postgresql.org> Author: Melanie Plageman <melanieplageman@gmail.com> Reviewed-By: Melanie Plageman <melanieplageman@gmail.com> Reviewed-By: Justin Pryzby <pryzby@telsasoft.com> Reviewed-By: Thomas Munro <tmunro@postgresql.org> Reviewed-By: Peter Eisentraut <peter.eisentraut@enterprisedb.com> Discussion: https://postgr.es/m/20211001222752.wrz7erzh4cajvgp6@alap3.anarazel.de
This commit is contained in:
parent
5e65df64d6
commit
93d9734946
547
.cirrus.yml
Normal file
547
.cirrus.yml
Normal file
@ -0,0 +1,547 @@
|
||||
# CI configuration file for CI utilizing cirrus-ci.org
|
||||
#
|
||||
# For instructions on how to enable the CI integration in a repository and
|
||||
# further details, see src/tools/ci/README
|
||||
|
||||
|
||||
env:
|
||||
# Source of images / containers
|
||||
GCP_PROJECT: pg-ci-images
|
||||
IMAGE_PROJECT: $GCP_PROJECT
|
||||
CONTAINER_REPO: us-docker.pkg.dev/${GCP_PROJECT}/ci
|
||||
|
||||
# The lower depth accelerates git clone. Use a bit of depth so that
|
||||
# concurrent tasks and retrying older jobs has a chance of working.
|
||||
CIRRUS_CLONE_DEPTH: 500
|
||||
# Useful to be able to analyse what in a script takes long
|
||||
CIRRUS_LOG_TIMESTAMP: true
|
||||
|
||||
CCACHE_MAXSIZE: "250M"
|
||||
|
||||
# target to test, for all but windows
|
||||
CHECK: check-world PROVE_FLAGS=$PROVE_FLAGS
|
||||
CHECKFLAGS: -Otarget
|
||||
PROVE_FLAGS: --timer
|
||||
PGCTLTIMEOUT: 120 # avoids spurious failures during parallel tests
|
||||
TEMP_CONFIG: ${CIRRUS_WORKING_DIR}/src/tools/ci/pg_ci_base.conf
|
||||
PG_TEST_EXTRA: kerberos ldap ssl
|
||||
|
||||
|
||||
# What files to preserve in case tests fail
|
||||
on_failure: &on_failure
|
||||
log_artifacts:
|
||||
path: "**/**.log"
|
||||
type: text/plain
|
||||
regress_diffs_artifacts:
|
||||
path: "**/**.diffs"
|
||||
type: text/plain
|
||||
tap_artifacts:
|
||||
path: "**/regress_log_*"
|
||||
type: text/plain
|
||||
|
||||
|
||||
task:
|
||||
name: FreeBSD - 13
|
||||
|
||||
env:
|
||||
# FreeBSD on GCP is slow when running with larger number of CPUS /
|
||||
# jobs. Using one more job than cpus seems to work best.
|
||||
CPUS: 2
|
||||
BUILD_JOBS: 3
|
||||
TEST_JOBS: 3
|
||||
|
||||
CCACHE_DIR: /tmp/ccache_dir
|
||||
|
||||
only_if: $CIRRUS_CHANGE_MESSAGE !=~ '.*\nci-os-only:.*' || $CIRRUS_CHANGE_MESSAGE =~ '.*\nci-os-only:[^\n]*freebsd.*'
|
||||
|
||||
compute_engine_instance:
|
||||
image_project: $IMAGE_PROJECT
|
||||
image: family/pg-ci-freebsd-13-0
|
||||
platform: freebsd
|
||||
cpu: $CPUS
|
||||
memory: 2G
|
||||
disk: 50
|
||||
|
||||
sysinfo_script: |
|
||||
id
|
||||
uname -a
|
||||
ulimit -a -H && ulimit -a -S
|
||||
export
|
||||
|
||||
ccache_cache:
|
||||
folder: $CCACHE_DIR
|
||||
# Workaround around performance issues due to 32KB block size
|
||||
repartition_script: src/tools/ci/gcp_freebsd_repartition.sh
|
||||
create_user_script: |
|
||||
pw useradd postgres
|
||||
chown -R postgres:postgres .
|
||||
mkdir -p ${CCACHE_DIR}
|
||||
chown -R postgres:postgres ${CCACHE_DIR}
|
||||
setup_cores_script: |
|
||||
mkdir -m 770 /tmp/cores
|
||||
chown root:postgres /tmp/cores
|
||||
sysctl kern.corefile='/tmp/cores/%N.%P.core'
|
||||
|
||||
# NB: Intentionally build without --with-llvm. The freebsd image size is
|
||||
# already large enough to make VM startup slow, and even without llvm
|
||||
# freebsd already takes longer than other platforms except for windows.
|
||||
configure_script: |
|
||||
su postgres <<-EOF
|
||||
./configure \
|
||||
--enable-cassert --enable-debug --enable-tap-tests \
|
||||
--enable-nls \
|
||||
\
|
||||
--with-gssapi \
|
||||
--with-icu \
|
||||
--with-ldap \
|
||||
--with-libxml \
|
||||
--with-libxslt \
|
||||
--with-lz4 \
|
||||
--with-pam \
|
||||
--with-perl \
|
||||
--with-python \
|
||||
--with-ssl=openssl \
|
||||
--with-tcl --with-tclconfig=/usr/local/lib/tcl8.6/ \
|
||||
--with-uuid=bsd \
|
||||
\
|
||||
--with-includes=/usr/local/include \
|
||||
--with-libs=/usr/local/lib \
|
||||
\
|
||||
CC="ccache cc" \
|
||||
CXX="ccache c++" \
|
||||
CFLAGS="-O0 -ggdb"
|
||||
EOF
|
||||
build_script: su postgres -c "gmake -s -j${BUILD_JOBS} world-bin"
|
||||
upload_caches: ccache
|
||||
|
||||
# The use of script avoids make -Otarget complaints about fcntl() on
|
||||
# platforms without support for locking pipes. See also
|
||||
# https://savannah.gnu.org/bugs/?60774
|
||||
# script uses pseudo-ttys, which do support locking.
|
||||
test_world_script:
|
||||
- su postgres -c "time script test.log gmake -s -j${TEST_JOBS} ${CHECK} ${CHECKFLAGS}"
|
||||
|
||||
on_failure:
|
||||
<<: *on_failure
|
||||
cores_script: src/tools/ci/cores_backtrace.sh freebsd /tmp/cores
|
||||
|
||||
|
||||
# configure feature flags, shared between the task running the linux tests and
|
||||
# the CompilerWarnings task
|
||||
LINUX_CONFIGURE_FEATURES: &LINUX_CONFIGURE_FEATURES >-
|
||||
--with-gssapi
|
||||
--with-icu
|
||||
--with-ldap
|
||||
--with-libxml
|
||||
--with-libxslt
|
||||
--with-llvm
|
||||
--with-lz4
|
||||
--with-pam
|
||||
--with-perl
|
||||
--with-python
|
||||
--with-selinux
|
||||
--with-ssl=openssl
|
||||
--with-systemd
|
||||
--with-tcl --with-tclconfig=/usr/lib/tcl8.6/
|
||||
--with-uuid=ossp
|
||||
|
||||
|
||||
task:
|
||||
name: Linux - Debian Bullseye
|
||||
|
||||
env:
|
||||
CPUS: 4
|
||||
BUILD_JOBS: 4
|
||||
TEST_JOBS: 8 # experimentally derived to be a decent choice
|
||||
|
||||
CCACHE_DIR: /tmp/ccache_dir
|
||||
DEBUGINFOD_URLS: "https://debuginfod.debian.net"
|
||||
|
||||
LINUX_CONFIGURE_FEATURES: *LINUX_CONFIGURE_FEATURES
|
||||
|
||||
only_if: $CIRRUS_CHANGE_MESSAGE !=~ '.*\nci-os-only:.*' || $CIRRUS_CHANGE_MESSAGE =~ '.*\nci-os-only:[^\n]*linux.*'
|
||||
|
||||
compute_engine_instance:
|
||||
image_project: $IMAGE_PROJECT
|
||||
image: family/pg-ci-bullseye
|
||||
platform: linux
|
||||
cpu: $CPUS
|
||||
memory: 2G
|
||||
|
||||
ccache_cache:
|
||||
folder: ${CCACHE_DIR}
|
||||
|
||||
sysinfo_script: |
|
||||
id
|
||||
uname -a
|
||||
cat /proc/cmdline
|
||||
ulimit -a -H && ulimit -a -S
|
||||
export
|
||||
create_user_script: |
|
||||
useradd -m postgres
|
||||
chown -R postgres:postgres .
|
||||
mkdir -p ${CCACHE_DIR}
|
||||
chown -R postgres:postgres ${CCACHE_DIR}
|
||||
echo '* - memlock 134217728' > /etc/security/limits.d/postgres.conf
|
||||
su postgres -c "ulimit -l -H && ulimit -l -S"
|
||||
setup_cores_script: |
|
||||
mkdir -m 770 /tmp/cores
|
||||
chown root:postgres /tmp/cores
|
||||
sysctl kernel.core_pattern='/tmp/cores/%e-%s-%p.core'
|
||||
|
||||
configure_script: |
|
||||
su postgres <<-EOF
|
||||
./configure \
|
||||
--enable-cassert --enable-debug --enable-tap-tests \
|
||||
--enable-nls \
|
||||
\
|
||||
${LINUX_CONFIGURE_FEATURES} \
|
||||
\
|
||||
CC="ccache gcc" \
|
||||
CXX="ccache g++" \
|
||||
CLANG="ccache clang" \
|
||||
CFLAGS="-O0 -ggdb" \
|
||||
CXXFLAGS="-O0 -ggdb"
|
||||
EOF
|
||||
build_script: su postgres -c "make -s -j${BUILD_JOBS} world-bin"
|
||||
upload_caches: ccache
|
||||
|
||||
test_world_script: |
|
||||
su postgres <<-EOF
|
||||
ulimit -c unlimited # default is 0
|
||||
make -s ${CHECK} ${CHECKFLAGS} -j${TEST_JOBS}
|
||||
EOF
|
||||
|
||||
on_failure:
|
||||
<<: *on_failure
|
||||
cores_script: src/tools/ci/cores_backtrace.sh linux /tmp/cores
|
||||
|
||||
|
||||
task:
|
||||
name: macOS - Monterey
|
||||
|
||||
env:
|
||||
CPUS: 12 # always get that much for cirrusci macOS instances
|
||||
BUILD_JOBS: $CPUS
|
||||
TEST_JOBS: $CPUS # already fast enough to not be worth tuning
|
||||
|
||||
CIRRUS_WORKING_DIR: ${HOME}/pgsql/
|
||||
CCACHE_DIR: ${HOME}/ccache
|
||||
HOMEBREW_CACHE: ${HOME}/homebrew-cache
|
||||
PERL5LIB: ${HOME}/perl5/lib/perl5
|
||||
|
||||
only_if: $CIRRUS_CHANGE_MESSAGE !=~ '.*\nci-os-only:.*' || $CIRRUS_CHANGE_MESSAGE =~ '.*\nci-os-only:[^\n]*(macos|darwin|osx).*'
|
||||
|
||||
osx_instance:
|
||||
image: monterey-base
|
||||
|
||||
sysinfo_script: |
|
||||
id
|
||||
export
|
||||
ulimit -a -H && ulimit -a -S
|
||||
|
||||
setup_cores_script:
|
||||
- mkdir ${HOME}/cores
|
||||
- sudo sysctl kern.corefile="${HOME}/cores/core.%P"
|
||||
|
||||
perl_cache:
|
||||
folder: ~/perl5
|
||||
cpan_install_script:
|
||||
- perl -mIPC::Run -e 1 || cpan -T IPC::Run
|
||||
- perl -mIO::Pty -e 1 || cpan -T IO::Pty
|
||||
upload_caches: perl
|
||||
|
||||
|
||||
# XXX: Could we instead install homebrew into a cached directory? The
|
||||
# homebrew installation takes a good bit of time every time, even if the
|
||||
# packages do not need to be downloaded.
|
||||
homebrew_cache:
|
||||
folder: $HOMEBREW_CACHE
|
||||
homebrew_install_script: |
|
||||
brew install \
|
||||
ccache \
|
||||
icu4c \
|
||||
krb5 \
|
||||
llvm \
|
||||
lz4 \
|
||||
make \
|
||||
openldap \
|
||||
openssl \
|
||||
python \
|
||||
tcl-tk
|
||||
|
||||
brew cleanup -s # to reduce cache size
|
||||
upload_caches: homebrew
|
||||
|
||||
ccache_cache:
|
||||
folder: $CCACHE_DIR
|
||||
configure_script: |
|
||||
brewpath="/usr/local"
|
||||
INCLUDES="${brewpath}/include:${INCLUDES}"
|
||||
LIBS="${brewpath}/lib:${LIBS}"
|
||||
|
||||
for pkg in icu4c krb5 openldap openssl ; do
|
||||
pkgpath="${brewpath}/opt/${pkg}"
|
||||
INCLUDES="${pkgpath}/include:${INCLUDES}"
|
||||
LIBS="${pkgpath}/lib:${LIBS}"
|
||||
PKG_CONFIG_PATH="${pkgpath}/lib/pkgconfig:${PKG_CONFIG_PATH}"
|
||||
done
|
||||
|
||||
export PKG_CONFIG_PATH
|
||||
|
||||
./configure \
|
||||
--enable-cassert --enable-debug --enable-tap-tests \
|
||||
--enable-nls \
|
||||
\
|
||||
--with-bonjour \
|
||||
--with-gssapi \
|
||||
--with-icu \
|
||||
--with-ldap \
|
||||
--with-libxml \
|
||||
--with-libxslt \
|
||||
--with-lz4 \
|
||||
--with-perl \
|
||||
--with-python \
|
||||
--with-ssl=openssl \
|
||||
--with-tcl --with-tclconfig=${brewpath}/opt/tcl-tk/lib/ \
|
||||
--with-uuid=e2fs \
|
||||
\
|
||||
--prefix=${HOME}/install \
|
||||
--with-includes="${INCLUDES}" \
|
||||
--with-libs="${LIBS}" \
|
||||
\
|
||||
CC="ccache cc" \
|
||||
CXX="ccache c++" \
|
||||
CLANG="ccache ${brewpath}/llvm/bin/ccache" \
|
||||
CFLAGS="-O0 -ggdb" \
|
||||
CXXFLAGS="-O0 -ggdb" \
|
||||
\
|
||||
LLVM_CONFIG=${brewpath}/llvm/bin/llvm-config \
|
||||
PYTHON=python3
|
||||
build_script: gmake -s -j${BUILD_JOBS} world-bin
|
||||
upload_caches: ccache
|
||||
|
||||
test_world_script: |
|
||||
ulimit -c unlimited # default is 0
|
||||
ulimit -n 1024 # default is 256, pretty low
|
||||
# See freebsd use of script for explanation
|
||||
script test.log gmake -s -j${TEST_JOBS} ${CHECK} ${CHECKFLAGS}
|
||||
|
||||
on_failure:
|
||||
<<: *on_failure
|
||||
cores_script: src/tools/ci/cores_backtrace.sh macos "${HOME}/cores"
|
||||
|
||||
|
||||
task:
|
||||
name: Windows - Server 2019, VS 2019
|
||||
|
||||
env:
|
||||
# Half the allowed per-user CPU cores
|
||||
CPUS: 4
|
||||
|
||||
# Our windows infrastructure doesn't have test concurrency above the level
|
||||
# of a single vcregress test target. Due to that, it's useful to run prove
|
||||
# with multiple jobs. For the other tasks it isn't, because two sources
|
||||
# (make and prove) of concurrency can overload machines.
|
||||
#
|
||||
# The concrete choice of 10 is based on a small bit of experimentation and
|
||||
# likely can be improved upon further.
|
||||
PROVE_FLAGS: -j10 --timer
|
||||
|
||||
# The default cirrus working dir is in a directory msbuild complains about
|
||||
CIRRUS_WORKING_DIR: "c:/cirrus"
|
||||
# Avoid re-installing over and over
|
||||
NO_TEMP_INSTALL: 1
|
||||
# git's tar doesn't deal with drive letters, see
|
||||
# https://postgr.es/m/b6782dc3-a7b0-ed56-175f-f8f54cb08d67%40dunslane.net
|
||||
TAR: "c:/windows/system32/tar.exe"
|
||||
# Avoids port conflicts between concurrent tap test runs
|
||||
PG_TEST_USE_UNIX_SOCKETS: 1
|
||||
PG_REGRESS_SOCK_DIR: "c:/cirrus/"
|
||||
# Use parallelism, disable file tracker, we're never going to rebuild...
|
||||
MSBFLAGS: -m -verbosity:minimal /p:TrackFileAccess=false
|
||||
|
||||
only_if: $CIRRUS_CHANGE_MESSAGE !=~ '.*\nci-os-only:.*' || $CIRRUS_CHANGE_MESSAGE =~ '.*\nci-os-only:[^\n]*windows.*'
|
||||
|
||||
windows_container:
|
||||
image: $CONTAINER_REPO/windows_ci_vs_2019:latest
|
||||
cpu: $CPUS
|
||||
memory: 4G
|
||||
|
||||
sysinfo_script: |
|
||||
chcp
|
||||
systeminfo
|
||||
powershell -Command get-psdrive -psprovider filesystem
|
||||
set
|
||||
|
||||
configure_script:
|
||||
# copy errors out when using forward slashes
|
||||
- copy src\tools\ci\windows_build_config.pl src\tools\msvc\config.pl
|
||||
- vcvarsall x64
|
||||
- perl src/tools/msvc/mkvcbuild.pl
|
||||
build_script:
|
||||
- vcvarsall x64
|
||||
- msbuild %MSBFLAGS% pgsql.sln
|
||||
tempinstall_script:
|
||||
# Installation on windows currently only completely works from src/tools/msvc
|
||||
- cd src/tools/msvc && perl install.pl %CIRRUS_WORKING_DIR%/tmp_install
|
||||
|
||||
test_regress_parallel_script:
|
||||
- perl src/tools/msvc/vcregress.pl check parallel
|
||||
startcreate_script:
|
||||
# paths to binaries need backslashes
|
||||
- tmp_install\bin\pg_ctl.exe initdb -D tmp_check/db -l tmp_check/initdb.log
|
||||
- echo include '%TEMP_CONFIG%' >> tmp_check/db/postgresql.conf
|
||||
- tmp_install\bin\pg_ctl.exe start -D tmp_check/db -l tmp_check/postmaster.log
|
||||
test_pl_script:
|
||||
- perl src/tools/msvc/vcregress.pl plcheck
|
||||
test_isolation_script:
|
||||
- perl src/tools/msvc/vcregress.pl isolationcheck
|
||||
test_modules_script:
|
||||
- perl src/tools/msvc/vcregress.pl modulescheck
|
||||
test_contrib_script:
|
||||
- perl src/tools/msvc/vcregress.pl contribcheck
|
||||
stop_script:
|
||||
- tmp_install\bin\pg_ctl.exe stop -D tmp_check/db -l tmp_check/postmaster.log
|
||||
test_ssl_script:
|
||||
- set with_ssl=openssl
|
||||
- perl src/tools/msvc/vcregress.pl taptest ./src/test/ssl/
|
||||
test_subscription_script:
|
||||
- perl src/tools/msvc/vcregress.pl taptest ./src/test/subscription/
|
||||
test_authentication_script:
|
||||
- perl src/tools/msvc/vcregress.pl taptest ./src/test/authentication/
|
||||
test_recovery_script:
|
||||
- perl src/tools/msvc/vcregress.pl recoverycheck
|
||||
test_bin_script:
|
||||
- perl src/tools/msvc/vcregress.pl bincheck
|
||||
test_pg_upgrade_script:
|
||||
- perl src/tools/msvc/vcregress.pl upgradecheck
|
||||
test_ecpg_script:
|
||||
# tries to build additional stuff
|
||||
- vcvarsall x64
|
||||
# References ecpg_regression.proj in the current dir
|
||||
- cd src/tools/msvc
|
||||
- perl vcregress.pl ecpgcheck
|
||||
|
||||
on_failure: *on_failure
|
||||
|
||||
|
||||
task:
|
||||
name: CompilerWarnings
|
||||
|
||||
# To limit unnecessary work only run this once the normal linux test succeeds
|
||||
depends_on:
|
||||
- Linux - Debian Bullseye
|
||||
|
||||
env:
|
||||
CPUS: 4
|
||||
BUILD_JOBS: 4
|
||||
|
||||
# Use larger ccache cache, as this task compiles with multiple compilers /
|
||||
# flag combinations
|
||||
CCACHE_SIZE: "1GB"
|
||||
CCACHE_DIR: "/tmp/ccache_dir"
|
||||
|
||||
LINUX_CONFIGURE_FEATURES: *LINUX_CONFIGURE_FEATURES
|
||||
|
||||
# task that did not run, count as a success, so we need to recheck Linux'
|
||||
# condition here ...
|
||||
only_if: $CIRRUS_CHANGE_MESSAGE !=~ '.*\nci-os-only:.*' || $CIRRUS_CHANGE_MESSAGE =~ '.*\nci-os-only:[^\n]*linux.*'
|
||||
|
||||
container:
|
||||
image: $CONTAINER_REPO/linux_debian_bullseye_ci:latest
|
||||
cpu: $CPUS
|
||||
|
||||
sysinfo_script: |
|
||||
id
|
||||
uname -a
|
||||
cat /proc/cmdline
|
||||
ulimit -a -H && ulimit -a -S
|
||||
gcc -v
|
||||
clang -v
|
||||
export
|
||||
|
||||
ccache_cache:
|
||||
folder: $CCACHE_DIR
|
||||
|
||||
###
|
||||
# Test that code can be built with gcc/clang without warnings
|
||||
###
|
||||
|
||||
setup_script: echo "COPT=-Werror" > src/Makefile.custom
|
||||
|
||||
# Trace probes have a history of getting accidentally broken. Use the
|
||||
# different compilers to build with different combinations of dtrace on/off
|
||||
# and cassert on/off.
|
||||
|
||||
# gcc, cassert off, dtrace on
|
||||
always:
|
||||
gcc_warning_script: |
|
||||
time ./configure \
|
||||
--cache gcc.cache \
|
||||
--enable-dtrace \
|
||||
${LINUX_CONFIGURE_FEATURES} \
|
||||
CC="ccache gcc" CXX="ccache g++" CLANG="ccache clang"
|
||||
make -s -j${BUILD_JOBS} clean
|
||||
time make -s -j${BUILD_JOBS} world-bin
|
||||
|
||||
# gcc, cassert on, dtrace off
|
||||
always:
|
||||
gcc_a_warning_script: |
|
||||
time ./configure \
|
||||
--cache gcc.cache \
|
||||
--enable-cassert \
|
||||
${LINUX_CONFIGURE_FEATURES} \
|
||||
CC="ccache gcc" CXX="ccache g++" CLANG="ccache clang"
|
||||
make -s -j${BUILD_JOBS} clean
|
||||
time make -s -j${BUILD_JOBS} world-bin
|
||||
|
||||
# clang, cassert off, dtrace off
|
||||
always:
|
||||
clang_warning_script: |
|
||||
time ./configure \
|
||||
--cache clang.cache \
|
||||
${LINUX_CONFIGURE_FEATURES} \
|
||||
CC="ccache clang" CXX="ccache clang++" CLANG="ccache clang"
|
||||
make -s -j${BUILD_JOBS} clean
|
||||
time make -s -j${BUILD_JOBS} world-bin
|
||||
|
||||
# clang, cassert on, dtrace on
|
||||
always:
|
||||
clang_a_warning_script: |
|
||||
time ./configure \
|
||||
--cache clang.cache \
|
||||
--enable-cassert \
|
||||
--enable-dtrace \
|
||||
${LINUX_CONFIGURE_FEATURES} \
|
||||
CC="ccache clang" CXX="ccache clang++" CLANG="ccache clang"
|
||||
make -s -j${BUILD_JOBS} clean
|
||||
time make -s -j${BUILD_JOBS} world-bin
|
||||
|
||||
# cross-compile to windows
|
||||
always:
|
||||
mingw_cross_warning_script: |
|
||||
time ./configure \
|
||||
--host=x86_64-w64-mingw32 \
|
||||
--enable-cassert \
|
||||
CC="ccache x86_64-w64-mingw32-gcc" \
|
||||
CXX="ccache x86_64-w64-mingw32-g++"
|
||||
make -s -j${BUILD_JOBS} clean
|
||||
time make -s -j${BUILD_JOBS} world-bin
|
||||
|
||||
###
|
||||
# Verify docs can be built
|
||||
###
|
||||
# XXX: Only do this if there have been changes in doc/ since last build
|
||||
always:
|
||||
docs_build_script: |
|
||||
time ./configure \
|
||||
--cache gcc.cache \
|
||||
CC="ccache gcc" \
|
||||
CXX="ccache g++" \
|
||||
CLANG="ccache clang"
|
||||
make -s -j${BUILD_JOBS} clean
|
||||
time make -s -j${BUILD_JOBS} -C doc
|
||||
|
||||
always:
|
||||
upload_caches: ccache
|
63
src/tools/ci/README
Normal file
63
src/tools/ci/README
Normal file
@ -0,0 +1,63 @@
|
||||
Postgres Continuous Integration (CI)
|
||||
====================================
|
||||
|
||||
Postgres has two forms of CI:
|
||||
|
||||
1) All supported branches in the main postgres repository are continuously
|
||||
tested via the buildfarm. As this covers only the main repository, it
|
||||
cannot be used during development of features.
|
||||
|
||||
For details see https://buildfarm.postgresql.org/
|
||||
|
||||
2) For not yet merged development work, CI can be enabled for some git hosting
|
||||
providers. This allows developers to test patches on a number of platforms
|
||||
before they are merged (or even submitted).
|
||||
|
||||
|
||||
Configuring CI on personal repositories
|
||||
=======================================
|
||||
|
||||
Currently postgres contains CI support utilizing cirrus-ci. cirrus-ci
|
||||
currently is only available for github.
|
||||
|
||||
|
||||
Enabling cirrus-ci in a github repository
|
||||
=========================================
|
||||
|
||||
To enable cirrus-ci on a repository, go to
|
||||
https://github.com/marketplace/cirrus-ci and select "Public
|
||||
Repositories". Then "Install it for free" and "Complete order". The next page
|
||||
allows to configure which repositories cirrus-ci has access to. Choose the
|
||||
relevant repository and "Install".
|
||||
|
||||
See also https://cirrus-ci.org/guide/quick-start/
|
||||
|
||||
Once enabled on a repository, future commits and pull-requests in that
|
||||
repository will automatically trigger CI builds. These are visible from the
|
||||
commit history / PRs, and can also be viewed in the cirrus-ci UI at
|
||||
https://cirrus-ci.com/github/<username>/<reponame>/
|
||||
|
||||
|
||||
Images used for CI
|
||||
==================
|
||||
|
||||
To keep CI times tolerable, most platforms use pre-generated images. Some
|
||||
platforms use containers, others use full VMs. Images for both are generated
|
||||
separately from CI runs, otherwise each git repository that is being tested
|
||||
would need to build its own set of containers, which would be wasteful (both
|
||||
in space and time.
|
||||
|
||||
These images are built, on a daily basis, from the specifications in
|
||||
github.com/anarazel/pg-vm-images/
|
||||
|
||||
|
||||
Controlling CI via commit messages
|
||||
==================================
|
||||
|
||||
The behavior of CI can be controlled by special content in commit
|
||||
messages. Currently the following controls are available:
|
||||
|
||||
- ci-os-only: {(freebsd|linux|macos|windows)}
|
||||
|
||||
Only runs CI on operating systems specified. This can be useful when
|
||||
addressing portability issues affecting only a subset of platforms.
|
50
src/tools/ci/cores_backtrace.sh
Executable file
50
src/tools/ci/cores_backtrace.sh
Executable file
@ -0,0 +1,50 @@
|
||||
#! /bin/sh
|
||||
|
||||
if [ $# -ne 2 ]; then
|
||||
echo "cores_backtrace.sh <os> <directory>"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
os=$1
|
||||
directory=$2
|
||||
|
||||
case $os in
|
||||
freebsd|linux|macos)
|
||||
;;
|
||||
*)
|
||||
echo "unsupported operating system ${os}"
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
|
||||
first=1
|
||||
for corefile in $(find "$directory" -type f) ; do
|
||||
if [ "$first" -eq 1 ]; then
|
||||
first=0
|
||||
else
|
||||
# to make it easier to separate the different crash reports
|
||||
echo -e '\n\n'
|
||||
fi
|
||||
|
||||
if [ "$os" = 'macos' ]; then
|
||||
lldb -c $corefile --batch -o 'thread backtrace all' -o 'quit'
|
||||
else
|
||||
auxv=$(gdb --quiet --core ${corefile} --batch -ex 'info auxv' 2>/dev/null)
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "could not process ${corefile}"
|
||||
continue
|
||||
fi
|
||||
|
||||
if [ "$os" = 'freebsd' ]; then
|
||||
binary=$(echo "$auxv" | grep AT_EXECPATH | perl -pe "s/^.*\"(.*)\"\$/\$1/g")
|
||||
elif [ "$os" = 'linux' ]; then
|
||||
binary=$(echo "$auxv" | grep AT_EXECFN | perl -pe "s/^.*\"(.*)\"\$/\$1/g")
|
||||
else
|
||||
echo 'should not get here'
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "dumping ${corefile} for ${binary}"
|
||||
gdb --batch --quiet -ex "thread apply all bt full" -ex "quit" "$binary" "$corefile" 2>/dev/null
|
||||
fi
|
||||
done
|
28
src/tools/ci/gcp_freebsd_repartition.sh
Executable file
28
src/tools/ci/gcp_freebsd_repartition.sh
Executable file
@ -0,0 +1,28 @@
|
||||
#!/bin/sh
|
||||
|
||||
set -e
|
||||
set -x
|
||||
|
||||
# The default filesystem on freebsd gcp images is very slow to run tests on,
|
||||
# due to its 32KB block size
|
||||
#
|
||||
# XXX: It'd probably better to fix this in the image, using something like
|
||||
# https://people.freebsd.org/~lidl/blog/re-root.html
|
||||
|
||||
# fix backup partition table after resize
|
||||
gpart recover da0
|
||||
gpart show da0
|
||||
# kill swap, so we can delete a partition
|
||||
swapoff -a || true
|
||||
# (apparently we can only have 4!?)
|
||||
gpart delete -i 3 da0
|
||||
gpart add -t freebsd-ufs -l data8k -a 4096 da0
|
||||
gpart show da0
|
||||
newfs -U -b 8192 /dev/da0p3
|
||||
|
||||
# Migrate working directory
|
||||
du -hs $CIRRUS_WORKING_DIR
|
||||
mv $CIRRUS_WORKING_DIR $CIRRUS_WORKING_DIR.orig
|
||||
mkdir $CIRRUS_WORKING_DIR
|
||||
mount -o noatime /dev/da0p3 $CIRRUS_WORKING_DIR
|
||||
cp -r $CIRRUS_WORKING_DIR.orig/* $CIRRUS_WORKING_DIR/
|
14
src/tools/ci/pg_ci_base.conf
Normal file
14
src/tools/ci/pg_ci_base.conf
Normal file
@ -0,0 +1,14 @@
|
||||
# Tends to produce too many core files, taking a long time
|
||||
restart_after_crash = false
|
||||
|
||||
# So that tests using the "manually" started postgres on windows can use
|
||||
# prepared statements
|
||||
max_prepared_transactions = 10
|
||||
|
||||
# Settings that make logs more useful
|
||||
log_autovacuum_min_duration = 0
|
||||
log_checkpoints = true
|
||||
log_connections = true
|
||||
log_disconnections = true
|
||||
log_line_prefix = '%m [%p][%b] %q[%a][%v:%x] '
|
||||
log_lock_waits = true
|
13
src/tools/ci/windows_build_config.pl
Normal file
13
src/tools/ci/windows_build_config.pl
Normal file
@ -0,0 +1,13 @@
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
our $config;
|
||||
|
||||
$config->{"tap_tests"} = 1;
|
||||
$config->{"asserts"} = 1;
|
||||
|
||||
$config->{"openssl"} = "c:/openssl/1.1/";
|
||||
$config->{"perl"} = "c:/strawberry/$ENV{DEFAULT_PERL_VERSION}/perl/";
|
||||
$config->{"python"} = "c:/python/";
|
||||
|
||||
1;
|
Loading…
x
Reference in New Issue
Block a user