plr CI - Update PL/R of Late September 2024 * Removed PG 17 betas and replaced with 17 * Upgraded github versions and EDB versions * Cutting edge builds became Debug builds * Cutting edge builds can fail without the build failing * Cleaned up matrix item descriptons * Placed matrix matid in front in many places so I can track the jobs This fail will fail the build. * Scheduled one Windows PG/R dual "cutting edge" build job matrix item to run daily * Replaced "meson tests" using classic "regression t... #762
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: plr CI | |
run-name: plr CI - ${{ github.event.head_commit.message }} | |
on: | |
push: | |
pull_request: | |
workflow_dispatch: | |
jobs: | |
master: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Echo site details | |
run: echo building master | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
- name: checkout postgres | |
run: | | |
sudo apt-get update -qq | |
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys E298A3A825C0D65DFD57CBB651716619E084DAB9 | |
sudo add-apt-repository "deb https://cloud.r-project.org/bin/linux/ubuntu $(lsb_release -cs)-cran40/" | |
sudo apt-get install -qq r-base-dev acl bison flex libssl-dev | |
sudo R --version | |
sudo /etc/init.d/postgresql stop | |
sudo apt-get remove --purge postgresql\* | |
sudo rm -rf /etc/postgresql /var/lib/postgresql | |
git clone --depth=1 https://github.com/postgres/postgres.git | |
pushd postgres | |
./configure | |
make -j4 | |
sudo make install | |
export PATH=/usr/local/pgsql/bin:$PATH | |
initdb -D data | |
pg_ctl -D data -l logfile start | |
popd | |
- name: Script | |
run: | | |
export USE_PGXS=1 | |
export PATH=/usr/local/pgsql/bin:$PATH | |
SHLIB_LINK=-lgcov PG_CPPFLAGS="-fprofile-arcs -ftest-coverage -O0" make | |
# USE_PGXS=1 is not required in Travis, and it is required in Github Actions | |
sudo USE_PGXS=1 PATH=/usr/local/pgsql/bin:$PATH make install | |
psql --version | |
R --version | |
make installcheck || (cat regression.diffs && false) | |
env: | |
USE_PGXS: 1 | |
REL_17_: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Echo site details | |
run: echo building master | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: checkout postgres | |
run: | | |
set -x -v -e | |
sudo apt-get update -qq | |
sudo apt-get install -qq r-base-dev acl bison flex libssl-dev | |
sudo R --version | |
sudo /etc/init.d/postgresql stop | |
sudo apt-get remove --purge postgresql\* | |
sudo rm -rf /etc/postgresql /var/lib/postgresql | |
export RET=$(git ls-remote --tags https://github.com/postgres/postgres.git | cut -c 52- | grep -c 'REL_17_[0-9]') | |
if [ "${RET}" -gt "0" ] | |
then | |
echo -n "Release(s) are found. Taking the last Release . . . " | |
export GITTAG=$(git ls-remote --tags https://github.com/postgres/postgres.git | cut -c 52- | grep -e 'REL_17_[0-9]' | tail -n 1) | |
else | |
echo "Release(s) are not found. Trying Release Candidates." | |
export RET=$(git ls-remote --tags https://github.com/postgres/postgres.git | cut -c 52- | grep -c 'REL_17_RC[0-9]') | |
if [ "${RET}" -gt "0" ] | |
then | |
echo -n "Release Candidate(s) are found. Taking the last Release Candidate . . . " | |
export GITTAG=$(git ls-remote --tags https://github.com/postgres/postgres.git | cut -c 52- | grep -e 'REL_17_RC[0-9]' | tail -n 1) | |
else | |
echo "Release Candidate(s) are not found. Trying Betas." | |
export RET=$(git ls-remote --tags https://github.com/postgres/postgres.git | cut -c 52- | grep -c 'REL_17_BETA[0-9]') | |
if [ "${RET}" -gt "0" ] | |
then | |
echo -n "Beta(s) are found. Taking the last Beta . . . " | |
export GITTAG=$(git ls-remote --tags https://github.com/postgres/postgres.git | cut -c 52- | grep -e 'REL_17_BETA[0-9]' | tail -n 1) | |
else | |
echo "Beta(s) are not found." | |
fi | |
fi | |
fi | |
echo $GITTAG | |
git clone --branch $GITTAG --depth=1 https://github.com/postgres/postgres.git | |
pushd postgres | |
./configure | |
make | |
sudo make install | |
export PATH=/usr/local/pgsql/bin:$PATH | |
initdb -D data | |
pg_ctl -D data -l logfile start | |
popd | |
- name: Script | |
run: | | |
set -x -v -e | |
export USE_PGXS=1 | |
export PATH=/usr/local/pgsql/bin:$PATH | |
SHLIB_LINK=-lgcov PG_CPPFLAGS="-fprofile-arcs -ftest-coverage -O0" make | |
# USE_PGXS=1 is not required in Travis, and it is required in Github Actions | |
sudo USE_PGXS=1 PATH=/usr/local/pgsql/bin:$PATH make install | |
psql --version | |
make installcheck || (cat regression.diffs && false) | |
env: | |
USE_PGXS: 1 | |
build: | |
runs-on: ubuntu-latest | |
env: | |
PG: ${{ matrix.pg }} | |
strategy: | |
matrix: | |
include: | |
# SEEN JUL 2024 | |
# Ubuntu 22.04 ubuntu-latest | |
# https://github.com/actions/runner-images | |
# jammy (22.04, LTS) | |
# https://wiki.postgresql.org/wiki/Apt | |
# https://apt.postgresql.org/pub/repos/apt/dists/ | |
# https://apt.postgresql.org/pub/repos/apt/dists/jammy-pgdg/ | |
# Source: postgresql-?? | |
# https://apt.postgresql.org/pub/repos/apt/dists/jammy-pgdg/main/binary-amd64/Packages | |
- pg: 17 | |
- pg: 16 | |
- pg: 15 | |
- pg: 14 | |
- pg: 13 | |
- pg: 12 | |
- pg: 11 | |
- pg: 10 | |
steps: | |
- name: Echo site details | |
run: echo PG $PG | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Before Script | |
run: | | |
echo Building plr with PostgreSQL $PG | |
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt/ $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list' | |
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add - | |
sudo apt-get update -qq | |
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys E298A3A825C0D65DFD57CBB651716619E084DAB9 | |
sudo add-apt-repository "deb https://cloud.r-project.org/bin/linux/ubuntu $(lsb_release -cs)-cran40/" | |
sudo apt-get install -qq r-base-dev acl | |
sudo /etc/init.d/postgresql stop | |
sudo apt-get remove --purge postgresql\* | |
sudo rm -rf /etc/postgresql /var/lib/postgresql | |
sudo apt-get install postgresql-$PG | |
sudo apt-get install postgresql-server-dev-$PG | |
echo 'local all postgres trust' | sudo tee /etc/postgresql/$PG/main/pg_hba.conf > /dev/null | |
# Builds under "runner" | |
# Github Actions require elevated priviledges | |
sudo setfacl -Rm u:postgres:rwx,d:u:runner:rwx /home/runner | |
sudo pg_ctlcluster $PG main reload | |
- name: Script | |
run: | | |
sudo pg_lsclusters | |
export USE_PGXS=1 | |
SHLIB_LINK=-lgcov PG_CPPFLAGS="-fprofile-arcs -ftest-coverage -O0" make | |
# USE_PGXS=1 is not required in Travis, and it is required in Github Actions | |
sudo USE_PGXS=1 make install | |
/usr/lib/postgresql/$PG/bin/pg_config | |
psql --version | |
R --version | |
make installcheck PGUSER=postgres || (cat regression.diffs && false) | |
- name: After Success | |
# success() returns true, when none of the previous steps have failed or been canceled. | |
if: ${{ success() }} | |
# Uploads code coverage to codecov.io | |
run: bash <(curl -s https://codecov.io/bash) |