name: postgresql-11-build on: [push] jobs: build: name: pg11-test runs-on: ubuntu-18.04 steps: - name: Clone postgres repository uses: actions/checkout@v2 with: repository: 'postgres/postgres' ref: 'REL_11_STABLE' - name: Install dependencies run: | sudo apt-get update sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt-get install libreadline6-dev systemtap-sdt-dev zlib1g-dev libssl-dev libpam0g-dev python-dev bison flex libipc-run-perl -y docbook-xsl docbook-xsl sudo apt-get install -y libxml2 libxml2-utils libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev libsystemd-dev gettext tcl-dev libperl-dev sudo apt-get install -y pkg-config clang-9 llvm-9 llvm-9-dev libselinux1-dev python-dev python3-dev uuid-dev liblz4-dev sudo rm -rf /var/lib/postgresql/ sudo rm -rf /var/log/postgresql/ sudo rm -rf /etc/postgresql/ sudo rm -rf /usr/lib/postgresql sudo rm -rf /usr/include/postgresql sudo rm -rf /usr/share/postgresql sudo rm -rf /etc/postgresql sudo rm -f /usr/bin/pg_config - name: Create pgsql dir run: mkdir -p /opt/pgsql - name: Build postgres run: | export PATH="/opt/pgsql/bin:$PATH" ./configure '--build=x86_64-linux-gnu' '--prefix=/usr' '--includedir=/usr/include' \ '--mandir=/usr/share/man' '--infodir=/usr/share/info' '--sysconfdir=/etc' \ '--localstatedir=/var' '--disable-silent-rules' '--libdir=/usr/lib/x86_64-linux-gnu' \ 'runstatedir=/run' '--disable-maintainer-mode' '--disable-dependency-tracking' \ '--with-icu' '--with-tcl' '--with-perl' '--with-python' '--with-pam' '--with-openssl' \ '--with-libxml' '--with-libxslt' 'PYTHON=/usr/bin/python3' \ '--mandir=/usr/share/postgresql/11/man' '--docdir=/usr/share/doc/postgresql-doc-11' \ '--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share/' \ '--datadir=/usr/share/postgresql/11' '--bindir=/usr/lib/postgresql/11/bin' \ '--libdir=/usr/lib/x86_64-linux-gnu/' '--libexecdir=/usr/lib/postgresql/' \ '--includedir=/usr/include/postgresql/' '--with-extra-version= (Ubuntu 11.x.pgdg20.04+1)' \ '--enable-nls' '--enable-thread-safety' '--enable-tap-tests' '--enable-debug' \ '--enable-dtrace' '--disable-rpath' '--with-uuid=e2fs' '--with-gnu-ld' \ '--with-pgport=5432' '--with-system-tzdata=/usr/share/zoneinfo' '--with-llvm' \ 'LLVM_CONFIG=/usr/bin/llvm-config-9' 'CLANG=/usr/bin/clang-9' '--with-systemd' \ '--with-selinux' 'MKDIR_P=/bin/mkdir -p' 'PROVE=/usr/bin/prove' 'TAR=/bin/tar' \ 'CFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -fno-omit-frame-pointer' \ 'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' '--with-gssapi' '--with-ldap' \ '--with-includes=/usr/include/mit-krb5' '--with-libs=/usr/lib/mit-krb5' \ '--with-libs=/usr/lib/x86_64-linux-gnu/mit-krb5' 'build_alias=x86_64-linux-gnu' \ 'CPPFLAGS=-Wdate-time -D_FORTIFY_SOURCE=2' 'CXXFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security' make world sudo make install-world - name: Start postgresql cluster run: | /usr/lib/postgresql/11/bin/initdb -D /opt/pgsql/data /usr/lib/postgresql/11/bin/pg_ctl -D /opt/pgsql/data -l logfile start - name: Clone pg_stat_monitor repository uses: actions/checkout@v2 with: path: 'src/pg_stat_monitor' - name: Build pg_stat_monitor run: | export PATH="/usr/lib/postgresql/11/bin:$PATH" sudo cp /usr/lib/postgresql/11/bin/pg_config /usr/bin make USE_PGXS=1 sudo make USE_PGXS=1 install working-directory: src/pg_stat_monitor/ - name: Load pg_stat_monitor library and Restart Server run: | /usr/lib/postgresql/11/bin/pg_ctl -D /opt/pgsql/data -l logfile stop echo "shared_preload_libraries = 'pg_stat_monitor'" >> /opt/pgsql/data/postgresql.conf /usr/lib/postgresql/11/bin/pg_ctl -D /opt/pgsql/data -l logfile start working-directory: src/pg_stat_monitor/ - name: Start pg_stat_monitor_tests run: | make installcheck working-directory: src/pg_stat_monitor/ - name: Report on pg_stat_monitor test fail uses: actions/upload-artifact@v2 if: ${{ failure() }} with: name: Regressions diff and postgresql log path: | src/pg_stat_monitor/regression.diffs src/pg_stat_monitor/logfile retention-days: 1 - name: Start Server installcheck-world tests run: | make installcheck-world - name: Report on installcheck-world test suites fail uses: actions/upload-artifact@v2 if: ${{ failure() }} with: name: Regressions output files of failed testsuite, and postgresql log path: | **/regression.diffs **/regression.out src/pg_stat_monitor/logfile retention-days: 1