PG-418: Cleanup workflows in github. (#283)

1- Removed unsupported options from configure.
2- Reformatted files to break lines at 80 charachters.
3- Moved multiple 'apt install' and rm commands into a single one.
4- All workflows use and install llvm + clang version 11.
5- Updated workflows to ubuntu 22.04 where we are building PG server.
6- Added .vscode folder/files to .gitignore file.
pull/284/head
Naeem Akhter 2022-08-01 14:03:10 +05:00 committed by GitHub
parent 326441c530
commit 3bed7e675f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
14 changed files with 399 additions and 346 deletions

View File

@ -4,7 +4,7 @@ on: ["push", "pull_request"]
jobs: jobs:
build: build:
name: coverage-test name: coverage-test
runs-on: ubuntu-latest runs-on: ubuntu-22.04
steps: steps:
- name: Clone postgres repository - name: Clone postgres repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -15,17 +15,18 @@ jobs:
- name: Install dependencies - name: Install dependencies
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
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 postgresql postgresql*
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 libreadline6-dev systemtap-sdt-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 lcov zlib1g-dev libssl-dev libpam0g-dev bison flex \
sudo rm -rf /var/lib/postgresql/ libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
sudo rm -rf /var/log/postgresql/ libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
sudo rm -rf /etc/postgresql/ libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-11 \
sudo rm -rf /usr/lib/postgresql llvm-11 llvm-11-dev libselinux1-dev python3-dev uuid-dev \
sudo rm -rf /usr/include/postgresql liblz4-dev lcov
sudo rm -rf /usr/share/postgresql sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /etc/postgresql /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
/etc/postgresql
sudo rm -f /usr/bin/pg_config sudo rm -f /usr/bin/pg_config
sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN' sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN'
sudo /usr/bin/perl -MCPAN -e 'install String::Util' sudo /usr/bin/perl -MCPAN -e 'install String::Util'
@ -37,35 +38,41 @@ jobs:
- name: Build postgres - name: Build postgres
run: | run: |
export PATH="/opt/pgsql/bin:$PATH" export PATH="/opt/pgsql/bin:$PATH"
./configure '--build=x86_64-linux-gnu' '--prefix=/usr' '--includedir=${prefix}/include' \ ./configure '--build=x86_64-linux-gnu' '--prefix=/usr' \
'--enable-coverage' '--mandir=${prefix}/share/man' '--infodir=${prefix}/share/info' \ '--includedir=${prefix}/include' '--enable-coverage' \
'--sysconfdir=/etc' '--localstatedir=/var' '--disable-silent-rules' \ '--mandir=${prefix}/share/man' '--infodir=${prefix}/share/info' \
'--libdir=${prefix}/lib/x86_64-linux-gnu' \ '--sysconfdir=/etc' '--localstatedir=/var' '--with-icu' \
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--disable-maintainer-mode' \ '--libdir=${prefix}/lib/x86_64-linux-gnu' '--with-tcl' \
'--disable-dependency-tracking' '--with-icu' '--with-tcl' '--with-perl' \ '--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--with-perl' \
'--with-python' '--with-pam' '--with-openssl' '--with-libxml' '--with-libxslt' \ '--with-python' '--with-pam' '--with-openssl' '--with-libxml' \
'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/14/man' \ '--with-libxslt' 'PYTHON=/usr/bin/python3' '--enable-nls' \
'--docdir=/usr/share/doc/postgresql-doc-14' \ '--mandir=/usr/share/postgresql/14/man' '--enable-thread-safety' \
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share/' \ '--docdir=/usr/share/doc/postgresql-doc-14' '--enable-dtrace' \
'--datadir=/usr/share/postgresql/14' '--bindir=/usr/lib/postgresql/14/bin' \ '--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
'--libdir=/usr/lib/x86_64-linux-gnu/' '--libexecdir=/usr/lib/postgresql/' \ '--datadir=/usr/share/postgresql/14' '--with-uuid=e2fs' \
'--includedir=/usr/include/postgresql/' '--with-extra-version= (Ubuntu 2:14-x.focal)' \ '--bindir=/usr/lib/postgresql/14/bin' '--with-gnu-ld' \
'--enable-nls' '--enable-thread-safety' '--enable-tap-tests' '--enable-debug' \ '--libdir=/usr/lib/x86_64-linux-gnu' '--enable-tap-tests' \
'--enable-dtrace' '--disable-rpath' '--with-uuid=e2fs' '--with-gnu-ld' \ '--libexecdir=/usr/lib/postgresql' '--enable-debug' \
'--with-pgport=5432' '--with-system-tzdata=/usr/share/zoneinfo' '--with-llvm' \ '--includedir=/usr/include/postgresql' '--disable-rpath' \
'--with-pgport=5432' '--with-system-tzdata=/usr/share/zoneinfo' \
'--with-llvm''TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' \
'LLVM_CONFIG=/usr/bin/llvm-config-11' 'CLANG=/usr/bin/clang-11' \ 'LLVM_CONFIG=/usr/bin/llvm-config-11' 'CLANG=/usr/bin/clang-11' \
'--with-systemd' '--with-selinux' 'MKDIR_P=/bin/mkdir -p' 'PROVE=/usr/bin/prove' \ '--with-systemd' 'MKDIR_P=/bin/mkdir -p' '--with-selinux' \
'TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' 'CFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -fno-omit-frame-pointer' \ 'PROVE=/usr/bin/prove' '--with-gssapi' '--with-ldap' \
'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' '--with-gssapi' '--with-ldap' \ 'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' \
'build_alias=x86_64-linux-gnu' 'CPPFLAGS=-Wdate-time -D_FORTIFY_SOURCE=2' \ 'build_alias=x86_64-linux-gnu' \
'CPPFLAGS=-Wdate-time -D_FORTIFY_SOURCE=2' \
'CFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -fno-omit-frame-pointer' \
'CXXFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security' 'CXXFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security'
make world make world
sudo make install-world sudo make install-world
- name: Start postgresql cluster - name: Start postgresql cluster
run: | run: |
/usr/lib/postgresql/14/bin/initdb -D /opt/pgsql/data export PATH="/usr/lib/postgresql/14/bin:$PATH"
/usr/lib/postgresql/14/bin/pg_ctl -D /opt/pgsql/data -l logfile start sudo cp /usr/lib/postgresql/14/bin/pg_config /usr/bin
initdb -D /opt/pgsql/data
pg_ctl -D /opt/pgsql/data -l logfile start
- name: Clone pg_stat_monitor repository - name: Clone pg_stat_monitor repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -74,18 +81,18 @@ jobs:
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
export PATH="/usr/lib/postgresql/14/bin:$PATH"
sudo cp /usr/lib/postgresql/14/bin/pg_config /usr/bin
make USE_PGXS=1 make USE_PGXS=1
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Load pg_stat_monitor library and Restart Server - name: Load pg_stat_monitor library and Restart Server
run: | run: |
/usr/lib/postgresql/14/bin/pg_ctl -D /opt/pgsql/data -l logfile stop export PATH="/usr/lib/postgresql/14/bin:$PATH"
echo "shared_preload_libraries = 'pg_stat_monitor'" >> /opt/pgsql/data/postgresql.conf pg_ctl -D /opt/pgsql/data -l logfile stop
/usr/lib/postgresql/14/bin/pg_ctl -D /opt/pgsql/data -l logfile start echo "shared_preload_libraries = 'pg_stat_monitor'" \
working-directory: src/pg_stat_monitor/ >> /opt/pgsql/data/postgresql.conf
pg_ctl -D /opt/pgsql/data -l logfile start
working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests & Run code coverage - name: Start pg_stat_monitor_tests & Run code coverage
run: | run: |
@ -95,7 +102,7 @@ jobs:
gcov -abcfu guc.c gcov -abcfu guc.c
gcov -abcfu hash_query.c gcov -abcfu hash_query.c
sudo chmod -R ugo+rwx *.gcov* sudo chmod -R ugo+rwx *.gcov*
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Upload - name: Upload
uses: codecov/codecov-action@v2 uses: codecov/codecov-action@v2
@ -110,7 +117,7 @@ jobs:
sudo chmod -R ugo+rwx t sudo chmod -R ugo+rwx t
sudo chmod -R ugo+rwx tmp_check sudo chmod -R ugo+rwx tmp_check
exit 2 # regenerate error so that we can upload files in next step exit 2 # regenerate error so that we can upload files in next step
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Upload logs on fail - name: Upload logs on fail
if: ${{ failure() }} if: ${{ failure() }}

View File

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

View File

@ -4,7 +4,7 @@ on: [push]
jobs: jobs:
build: build:
name: pg-11-pgdg-package-test name: pg-11-pgdg-package-test
runs-on: ubuntu-18.04 runs-on: ubuntu-20.04
steps: steps:
- name: Clone pg_stat_monitor repository - name: Clone pg_stat_monitor repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -14,40 +14,42 @@ jobs:
- name: Delete old postgresql files - name: Delete old postgresql files
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
sudo rm -rf /var/lib/postgresql/ postgresql postgresql*
sudo rm -rf /var/log/postgresql/ sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /etc/postgresql/ /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
sudo rm -rf /usr/lib/postgresql /etc/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 sudo rm -f /usr/bin/pg_config
- name: Install PG Distribution Postgresql 11 - name: Install PG Distribution Postgresql 11
run: | run: |
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list' sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt \
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add - $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
sudo wget --quiet -O - \
https://www.postgresql.org/media/keys/ACCC4CF8.asc |
sudo apt-key add -
sudo apt-get -y update sudo apt-get -y update
sudo apt-get -y install postgresql-11 postgresql-server-dev-11 sudo apt-get -y install postgresql-11 postgresql-server-dev-11
- name: Change sources owner to postgres - name: Change src owner to postgres
run: sudo chown -R postgres:postgres src run: |
sudo chown -R postgres:postgres src
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
sudo make USE_PGXS=1 sudo -u postgres bash -c 'make USE_PGXS=1'
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
sudo service postgresql stop sudo service postgresql stop
echo "shared_preload_libraries = 'pg_stat_monitor'" | sudo tee -a /etc/postgresql/11/main/postgresql.conf echo "shared_preload_libraries = 'pg_stat_monitor'" |
sudo tee -a /etc/postgresql/11/main/postgresql.conf
sudo service postgresql start sudo service postgresql start
sudo psql -V sudo psql -V
sudo -u postgres bash -c 'make installcheck USE_PGXS=1' sudo -u postgres bash -c 'make installcheck USE_PGXS=1'
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Report on test fail - name: Report on test fail
uses: actions/upload-artifact@v2 uses: actions/upload-artifact@v2

View File

@ -11,53 +11,54 @@ jobs:
with: with:
path: 'src/pg_stat_monitor' path: 'src/pg_stat_monitor'
- name: Install dependencies - name: Install dependencies
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
sudo apt-get install libreadline6-dev systemtap-sdt-dev zlib1g-dev libssl-dev libpam0g-dev python-dev bison flex libipc-run-perl wget -y postgresql postgresql*
sudo rm -rf /var/lib/postgresql/ sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
sudo rm -rf /var/log/postgresql/ zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
sudo rm -rf /etc/postgresql/ libipc-run-perl wget
sudo rm -rf /usr/lib/postgresql sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /usr/include/postgresql /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
sudo rm -rf /usr/share/postgresql /etc/postgresql
sudo rm -rf /etc/postgresql
sudo rm -f /usr/bin/pg_config sudo rm -f /usr/bin/pg_config
- name: Install percona-release script - name: Install percona-release script
run: | run: |
sudo apt-get -y update sudo apt-get -y update
sudo apt-get -y upgrade sudo apt-get -y upgrade
sudo apt-get -y update
sudo apt-get install -y wget gnupg2 curl lsb-release sudo apt-get install -y wget gnupg2 curl lsb-release
sudo wget https://repo.percona.com/apt/percona-release_latest.generic_all.deb sudo wget \
https://repo.percona.com/apt/percona-release_latest.generic_all.deb
sudo dpkg -i percona-release_latest.generic_all.deb sudo dpkg -i percona-release_latest.generic_all.deb
- name: Install Percona Distribution Postgresql 11 - name: Install Percona Distribution Postgresql 11
run: | run: |
sudo percona-release setup ppg-11 sudo percona-release setup ppg-11
sudo apt-get update -y sudo apt-get update -y
sudo apt-get install -y percona-postgresql-11 percona-postgresql-contrib percona-postgresql-server-dev-all sudo apt-get install -y percona-postgresql-11 \
percona-postgresql-contrib percona-postgresql-server-dev-all
- name: Change sources owner to postgres - name: Change src owner to postgres
run: sudo chown -R postgres:postgres src run: |
sudo chown -R postgres:postgres src
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
sudo make USE_PGXS=1 sudo -u postgres bash -c 'make USE_PGXS=1'
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
sudo service postgresql stop sudo service postgresql stop
echo "shared_preload_libraries = 'pg_stat_monitor'" | sudo tee -a /etc/postgresql/11/main/postgresql.conf echo "shared_preload_libraries = 'pg_stat_monitor'" |
sudo tee -a /etc/postgresql/11/main/postgresql.conf
sudo service postgresql start sudo service postgresql start
sudo psql -V sudo psql -V
sudo -u postgres bash -c 'make installcheck USE_PGXS=1' sudo -u postgres bash -c 'make installcheck USE_PGXS=1'
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Report on test fail - name: Report on test fail
uses: actions/upload-artifact@v2 uses: actions/upload-artifact@v2

View File

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

View File

@ -4,7 +4,7 @@ on: [push]
jobs: jobs:
build: build:
name: pg-12-pgdg-package-test name: pg-12-pgdg-package-test
runs-on: ubuntu-latest runs-on: ubuntu-20.04
steps: steps:
- name: Clone pg_stat_monitor repository - name: Clone pg_stat_monitor repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -14,41 +14,42 @@ jobs:
- name: Delete old postgresql files - name: Delete old postgresql files
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
sudo rm -rf /var/lib/postgresql/ postgresql postgresql*
sudo rm -rf /var/log/postgresql/ sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /etc/postgresql/ /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
sudo rm -rf /usr/lib/postgresql /etc/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 sudo rm -f /usr/bin/pg_config
- name: Install PG Distribution Postgresql 12 - name: Install PG Distribution Postgresql 12
run: | run: |
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list' sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt \
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add - $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
sudo wget --quiet -O - \
https://www.postgresql.org/media/keys/ACCC4CF8.asc |
sudo apt-key add -
sudo apt-get -y update sudo apt-get -y update
sudo apt-get -y install postgresql-12 postgresql-server-dev-12 sudo apt-get -y install postgresql-12 postgresql-server-dev-12
- name: Change sources owner to postgres - name: Change src owner to postgres
run: | run: |
sudo chown -R postgres:postgres src sudo chown -R postgres:postgres src
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
sudo make USE_PGXS=1 sudo -u postgres bash -c 'make USE_PGXS=1'
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
sudo service postgresql stop sudo service postgresql stop
echo "shared_preload_libraries = 'pg_stat_monitor'" | sudo tee -a /etc/postgresql/12/main/postgresql.conf echo "shared_preload_libraries = 'pg_stat_monitor'" |
sudo tee -a /etc/postgresql/12/main/postgresql.conf
sudo service postgresql start sudo service postgresql start
sudo psql -V sudo psql -V
sudo -u postgres bash -c 'make installcheck USE_PGXS=1' sudo -u postgres bash -c 'make installcheck USE_PGXS=1'
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Report on test fail - name: Report on test fail
uses: actions/upload-artifact@v2 uses: actions/upload-artifact@v2

View File

@ -14,31 +14,31 @@ jobs:
- name: Install dependencies - name: Install dependencies
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
sudo apt-get install libreadline6-dev systemtap-sdt-dev zlib1g-dev libssl-dev libpam0g-dev python-dev bison flex libipc-run-perl wget -y postgresql postgresql*
sudo rm -rf /var/lib/postgresql/ sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
sudo rm -rf /var/log/postgresql/ zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
sudo rm -rf /etc/postgresql/ libipc-run-perl wget
sudo rm -rf /usr/lib/postgresql sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /usr/include/postgresql /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
sudo rm -rf /usr/share/postgresql /etc/postgresql
sudo rm -rf /etc/postgresql
sudo rm -f /usr/bin/pg_config sudo rm -f /usr/bin/pg_config
- name: Install percona-release script - name: Install percona-release script
run: | run: |
sudo apt-get -y update sudo apt-get -y update
sudo apt-get -y upgrade sudo apt-get -y upgrade
sudo apt-get -y update
sudo apt-get install -y wget gnupg2 curl lsb-release sudo apt-get install -y wget gnupg2 curl lsb-release
sudo wget https://repo.percona.com/apt/percona-release_latest.generic_all.deb sudo wget \
https://repo.percona.com/apt/percona-release_latest.generic_all.deb
sudo dpkg -i percona-release_latest.generic_all.deb sudo dpkg -i percona-release_latest.generic_all.deb
- name: Install Percona Distribution Postgresql 12 - name: Install Percona Distribution Postgresql 12
run: | run: |
sudo percona-release setup ppg-12 sudo percona-release setup ppg-12
sudo apt-get update -y sudo apt-get update -y
sudo apt-get install -y percona-postgresql-12 percona-postgresql-contrib percona-postgresql-server-dev-all sudo apt-get install -y percona-postgresql-12 \
percona-postgresql-contrib percona-postgresql-server-dev-all
- name: Change src owner to postgres - name: Change src owner to postgres
run: | run: |
@ -46,18 +46,19 @@ jobs:
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
sudo make USE_PGXS=1 sudo -u postgres bash -c 'make USE_PGXS=1'
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
sudo service postgresql stop sudo service postgresql stop
echo "shared_preload_libraries = 'pg_stat_monitor'" | sudo tee -a /etc/postgresql/12/main/postgresql.conf echo "shared_preload_libraries = 'pg_stat_monitor'" |
sudo tee -a /etc/postgresql/12/main/postgresql.conf
sudo service postgresql start sudo service postgresql start
sudo psql -V sudo psql -V
sudo -u postgres bash -c 'make installcheck USE_PGXS=1' sudo -u postgres bash -c 'make installcheck USE_PGXS=1'
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Report on test fail - name: Report on test fail
uses: actions/upload-artifact@v2 uses: actions/upload-artifact@v2

View File

@ -4,7 +4,7 @@ on: [push]
jobs: jobs:
build: build:
name: pg-13-build-test name: pg-13-build-test
runs-on: ubuntu-latest runs-on: ubuntu-22.04
steps: steps:
- name: Clone postgres repository - name: Clone postgres repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -15,17 +15,17 @@ jobs:
- name: Install dependencies - name: Install dependencies
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
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 postgresql postgresql*
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 libreadline6-dev systemtap-sdt-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 zlib1g-dev libssl-dev libpam0g-dev bison flex \
sudo rm -rf /var/lib/postgresql/ libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
sudo rm -rf /var/log/postgresql/ libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
sudo rm -rf /etc/postgresql/ libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-11 \
sudo rm -rf /usr/lib/postgresql llvm-11 llvm-11-dev libselinux1-dev python3-dev uuid-dev liblz4-dev
sudo rm -rf /usr/include/postgresql sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /usr/share/postgresql /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
sudo rm -rf /etc/postgresql /etc/postgresql
sudo rm -f /usr/bin/pg_config sudo rm -f /usr/bin/pg_config
sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN' sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN'
sudo /usr/bin/perl -MCPAN -e 'install String::Util' sudo /usr/bin/perl -MCPAN -e 'install String::Util'
@ -37,35 +37,41 @@ jobs:
- name: Build postgres - name: Build postgres
run: | run: |
export PATH="/opt/pgsql/bin:$PATH" export PATH="/opt/pgsql/bin:$PATH"
./configure '--build=x86_64-linux-gnu' '--prefix=/usr' '--includedir=${prefix}/include' \ ./configure '--build=x86_64-linux-gnu' '--prefix=/usr' \
'--includedir=${prefix}/include' \
'--mandir=${prefix}/share/man' '--infodir=${prefix}/share/info' \ '--mandir=${prefix}/share/man' '--infodir=${prefix}/share/info' \
'--sysconfdir=/etc' '--localstatedir=/var' '--disable-silent-rules' \ '--sysconfdir=/etc' '--localstatedir=/var' '--with-icu' \
'--libdir=${prefix}/lib/x86_64-linux-gnu' \ '--libdir=${prefix}/lib/x86_64-linux-gnu' '--with-perl' \
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--disable-maintainer-mode' \ '--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--enable-debug' \
'--disable-dependency-tracking' '--with-icu' '--with-tcl' '--with-perl' \ '--with-tcl' '--with-pam' '--with-python' '--with-openssl' \
'--with-python' '--with-pam' '--with-openssl' '--with-libxml' '--with-libxslt' \ '--with-libxml' '--with-libxslt' '--enable-tap-tests' \
'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/13/man' \ 'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/13/man' \
'--docdir=/usr/share/doc/postgresql-doc-13' 'AWK=mawk' \ '--docdir=/usr/share/doc/postgresql-doc-13' 'AWK=mawk' \
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share/' \ '--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
'--datadir=/usr/share/postgresql/13' '--bindir=/usr/lib/postgresql/13/bin' \ '--datadir=/usr/share/postgresql/13' '--enable-nls' \
'--libdir=/usr/lib/x86_64-linux-gnu/' '--libexecdir=/usr/lib/postgresql/' \ '--bindir=/usr/lib/postgresql/13/bin' '--enable-dtrace' \
'--includedir=/usr/include/postgresql/' '--with-extra-version= (Ubuntu 2:13-x.focal)' \ '--libdir=/usr/lib/x86_64-linux-gnu' '--disable-rpath' \
'--enable-nls' '--enable-thread-safety' '--enable-tap-tests' '--enable-debug' \ '--libexecdir=/usr/lib/postgresql' '--enable-thread-safety' \
'--enable-dtrace' '--disable-rpath' '--with-uuid=e2fs' '--with-gnu-ld' \ '--includedir=/usr/include/postgresql' 'TAR=/bin/tar' \
'--with-pgport=5432' '--with-system-tzdata=/usr/share/zoneinfo' '--with-llvm' \ '--with-uuid=e2fs' '--with-gnu-ld' 'XSLTPROC=xsltproc --nonet' \
'LLVM_CONFIG=/usr/bin/llvm-config-9' 'CLANG=/usr/bin/clang-9' \ '--with-pgport=5432' '--with-system-tzdata=/usr/share/zoneinfo' \
'--with-systemd' '--with-selinux' 'MKDIR_P=/bin/mkdir -p' 'PROVE=/usr/bin/prove' \ '--with-llvm' 'LLVM_CONFIG=/usr/bin/llvm-config-11' \
'TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' 'CFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -fno-omit-frame-pointer' \ 'CLANG=/usr/bin/clang-11' '--with-systemd' '--with-selinux' \
'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' '--with-gssapi' '--with-ldap' \ 'MKDIR_P=/bin/mkdir -p' 'PROVE=/usr/bin/prove' \
'build_alias=x86_64-linux-gnu' 'CPPFLAGS=-Wdate-time -D_FORTIFY_SOURCE=2' \ 'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' \
'--with-gssapi' '--with-ldap' 'build_alias=x86_64-linux-gnu' \
'CPPFLAGS=-Wdate-time -D_FORTIFY_SOURCE=2' \
'CFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -fno-omit-frame-pointer' \
'CXXFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security' 'CXXFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security'
make world make world
sudo make install-world sudo make install-world
- name: Start postgresql cluster - name: Start postgresql cluster
run: | run: |
/usr/lib/postgresql/13/bin/initdb -D /opt/pgsql/data export PATH="/usr/lib/postgresql/13/bin:$PATH"
/usr/lib/postgresql/13/bin/pg_ctl -D /opt/pgsql/data -l logfile start sudo cp /usr/lib/postgresql/13/bin/pg_config /usr/bin
initdb -D /opt/pgsql/data
pg_ctl -D /opt/pgsql/data -l logfile start
- name: Clone pg_stat_monitor repository - name: Clone pg_stat_monitor repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -74,24 +80,23 @@ jobs:
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
export PATH="/usr/lib/postgresql/13/bin:$PATH"
sudo cp /usr/lib/postgresql/13/bin/pg_config /usr/bin
pg_config
make USE_PGXS=1 make USE_PGXS=1
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Load pg_stat_monitor library and Restart Server - name: Load pg_stat_monitor library and Restart Server
run: | run: |
/usr/lib/postgresql/13/bin/pg_ctl -D /opt/pgsql/data -l logfile stop export PATH="/usr/lib/postgresql/13/bin:$PATH"
echo "shared_preload_libraries = 'pg_stat_monitor'" >> /opt/pgsql/data/postgresql.conf pg_ctl -D /opt/pgsql/data -l logfile stop
/usr/lib/postgresql/13/bin/pg_ctl -D /opt/pgsql/data -l logfile start echo "shared_preload_libraries = 'pg_stat_monitor'" >> \
working-directory: src/pg_stat_monitor/ /opt/pgsql/data/postgresql.conf
pg_ctl -D /opt/pgsql/data -l logfile start
working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
make installcheck make installcheck
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Change dir permissions on fail - name: Change dir permissions on fail
if: ${{ failure() }} if: ${{ failure() }}
@ -99,7 +104,7 @@ jobs:
sudo chmod -R ugo+rwx t sudo chmod -R ugo+rwx t
sudo chmod -R ugo+rwx tmp_check sudo chmod -R ugo+rwx tmp_check
exit 2 # regenerate error so that we can upload files in next step exit 2 # regenerate error so that we can upload files in next step
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Upload logs on fail - name: Upload logs on fail
if: ${{ failure() }} if: ${{ failure() }}
@ -129,7 +134,7 @@ jobs:
uses: actions/upload-artifact@v2 uses: actions/upload-artifact@v2
if: ${{ failure() }} if: ${{ failure() }}
with: with:
name: Regressions output files of failed testsuite, and postgresql log name: Regressions output files of failed testsuite, and pg log
path: | path: |
**/regression.diffs **/regression.diffs
**/regression.out **/regression.out

View File

@ -4,7 +4,7 @@ on: [push]
jobs: jobs:
build: build:
name: pg-13-pgdg-package-test name: pg-13-pgdg-package-test
runs-on: ubuntu-latest runs-on: ubuntu-20.04
steps: steps:
- name: Clone pg_stat_monitor repository - name: Clone pg_stat_monitor repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -14,45 +14,48 @@ jobs:
- name: Delete old postgresql files - name: Delete old postgresql files
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
sudo rm -rf /var/lib/postgresql/ postgresql postgresql*
sudo rm -rf /var/log/postgresql/ sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
sudo rm -rf /etc/postgresql/ zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
sudo rm -rf /usr/lib/postgresql libipc-run-perl wget -y
sudo rm -rf /usr/include/postgresql sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /usr/share/postgresql /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
sudo rm -rf /etc/postgresql /etc/postgresql
sudo rm -f /usr/bin/pg_config sudo rm -f /usr/bin/pg_config
sudo apt-get install libreadline6-dev systemtap-sdt-dev zlib1g-dev libssl-dev libpam0g-dev python-dev bison flex libipc-run-perl wget -y
sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN' sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN'
sudo /usr/bin/perl -MCPAN -e 'install String::Util' sudo /usr/bin/perl -MCPAN -e 'install String::Util'
sudo /usr/bin/perl -MCPAN -e 'install Data::Str2Num' sudo /usr/bin/perl -MCPAN -e 'install Data::Str2Num'
- name: Install PG Distribution Postgresql 13 - name: Install PG Distribution Postgresql 13
run: | run: |
sudo wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add - sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt \
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list' $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
sudo wget --quiet -O - \
https://www.postgresql.org/media/keys/ACCC4CF8.asc |
sudo apt-key add -
sudo apt update sudo apt update
sudo apt -y install postgresql-13 postgresql-server-dev-13 sudo apt -y install postgresql-13 postgresql-server-dev-13
- name: Change sources owner to postgres - name: Change src owner to postgres
run: | run: |
sudo chown -R postgres:postgres src sudo chown -R postgres:postgres src
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
sudo make USE_PGXS=1 sudo -u postgres bash -c 'make USE_PGXS=1'
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
sudo service postgresql stop sudo service postgresql stop
echo "shared_preload_libraries = 'pg_stat_monitor'" | sudo tee -a /etc/postgresql/13/main/postgresql.conf echo "shared_preload_libraries = 'pg_stat_monitor'" |
sudo tee -a /etc/postgresql/13/main/postgresql.conf
sudo service postgresql start sudo service postgresql start
sudo psql -V sudo psql -V
sudo -u postgres bash -c 'make installcheck USE_PGXS=1' sudo -u postgres bash -c 'make installcheck USE_PGXS=1'
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Change dir permissions on fail - name: Change dir permissions on fail
if: ${{ failure() }} if: ${{ failure() }}
@ -60,7 +63,7 @@ jobs:
sudo chmod -R ugo+rwx t sudo chmod -R ugo+rwx t
sudo chmod -R ugo+rwx tmp_check sudo chmod -R ugo+rwx tmp_check
exit 2 # regenerate error so that we can upload files in next step exit 2 # regenerate error so that we can upload files in next step
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Upload logs on fail - name: Upload logs on fail
if: ${{ failure() }} if: ${{ failure() }}

View File

@ -14,16 +14,15 @@ jobs:
- name: Delete old postgresql files - name: Delete old postgresql files
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
sudo rm -rf /var/lib/postgresql/ postgresql postgresql*
sudo rm -rf /var/log/postgresql/ sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
sudo rm -rf /etc/postgresql/ zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
sudo rm -rf /usr/lib/postgresql libipc-run-perl wget
sudo rm -rf /usr/include/postgresql sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /usr/share/postgresql /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
sudo rm -rf /etc/postgresql /etc/postgresql
sudo rm -f /usr/bin/pg_config sudo rm -f /usr/bin/pg_config
sudo apt-get install libreadline6-dev systemtap-sdt-dev zlib1g-dev libssl-dev libpam0g-dev python-dev bison flex libipc-run-perl wget -y
sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN' sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN'
sudo /usr/bin/perl -MCPAN -e 'install String::Util' sudo /usr/bin/perl -MCPAN -e 'install String::Util'
sudo /usr/bin/perl -MCPAN -e 'install Data::Str2Num' sudo /usr/bin/perl -MCPAN -e 'install Data::Str2Num'
@ -32,16 +31,17 @@ jobs:
run: | run: |
sudo apt-get -y update sudo apt-get -y update
sudo apt-get -y upgrade sudo apt-get -y upgrade
sudo apt-get -y update
sudo apt-get install -y wget gnupg2 curl lsb-release sudo apt-get install -y wget gnupg2 curl lsb-release
sudo wget https://repo.percona.com/apt/percona-release_latest.generic_all.deb sudo wget \
https://repo.percona.com/apt/percona-release_latest.generic_all.deb
sudo dpkg -i percona-release_latest.generic_all.deb sudo dpkg -i percona-release_latest.generic_all.deb
- name: Install Percona Distribution Postgresql 13 - name: Install Percona Distribution Postgresql 13
run: | run: |
sudo percona-release setup ppg-13 sudo percona-release setup ppg-13
sudo apt-get update -y sudo apt-get update -y
sudo apt-get install -y percona-postgresql-13 percona-postgresql-contrib percona-postgresql-server-dev-all sudo apt-get install -y percona-postgresql-13 \
percona-postgresql-contrib percona-postgresql-server-dev-all
- name: Change src owner to postgres - name: Change src owner to postgres
run: | run: |
@ -49,18 +49,19 @@ jobs:
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
sudo make USE_PGXS=1 sudo -u postgres bash -c 'make USE_PGXS=1'
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
sudo service postgresql stop sudo service postgresql stop
echo "shared_preload_libraries = 'pg_stat_monitor'" | sudo tee -a /etc/postgresql/13/main/postgresql.conf echo "shared_preload_libraries = 'pg_stat_monitor'" |
sudo tee -a /etc/postgresql/13/main/postgresql.conf
sudo service postgresql start sudo service postgresql start
sudo psql -V sudo psql -V
sudo -u postgres bash -c 'make installcheck USE_PGXS=1' sudo -u postgres bash -c 'make installcheck USE_PGXS=1'
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Change dir permissions on fail - name: Change dir permissions on fail
if: ${{ failure() }} if: ${{ failure() }}
@ -68,7 +69,7 @@ jobs:
sudo chmod -R ugo+rwx t sudo chmod -R ugo+rwx t
sudo chmod -R ugo+rwx tmp_check sudo chmod -R ugo+rwx tmp_check
exit 2 # regenerate error so that we can upload files in next step exit 2 # regenerate error so that we can upload files in next step
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Upload logs on fail - name: Upload logs on fail
if: ${{ failure() }} if: ${{ failure() }}

View File

@ -4,7 +4,7 @@ on: ["push", "pull_request"]
jobs: jobs:
build: build:
name: pg-14-build-test name: pg-14-build-test
runs-on: ubuntu-latest runs-on: ubuntu-22.04
steps: steps:
- name: Clone postgres repository - name: Clone postgres repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -15,17 +15,18 @@ jobs:
- name: Install dependencies - name: Install dependencies
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
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 postgresql postgresql*
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 libreadline6-dev systemtap-sdt-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 zlib1g-dev libssl-dev libpam0g-dev bison flex \
sudo rm -rf /var/lib/postgresql/ libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
sudo rm -rf /var/log/postgresql/ libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
sudo rm -rf /etc/postgresql/ libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-11 \
sudo rm -rf /usr/lib/postgresql llvm-11 llvm-11-dev libselinux1-dev python3-dev \
sudo rm -rf /usr/include/postgresql uuid-dev liblz4-dev
sudo rm -rf /usr/share/postgresql sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /etc/postgresql /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
/etc/postgresql
sudo rm -f /usr/bin/pg_config sudo rm -f /usr/bin/pg_config
sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN' sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN'
sudo /usr/bin/perl -MCPAN -e 'install String::Util' sudo /usr/bin/perl -MCPAN -e 'install String::Util'
@ -37,35 +38,40 @@ jobs:
- name: Build postgres - name: Build postgres
run: | run: |
export PATH="/opt/pgsql/bin:$PATH" export PATH="/opt/pgsql/bin:$PATH"
./configure '--build=x86_64-linux-gnu' '--prefix=/usr' '--includedir=${prefix}/include' \ ./configure '--build=x86_64-linux-gnu' '--prefix=/usr' \
'--mandir=${prefix}/share/man' '--infodir=${prefix}/share/info' \ '--includedir=${prefix}/include' '--mandir=${prefix}/share/man' \
'--sysconfdir=/etc' '--localstatedir=/var' '--disable-silent-rules' \ '--infodir=${prefix}/share/info' '--sysconfdir=/etc' \
'--libdir=${prefix}/lib/x86_64-linux-gnu' \ '--localstatedir=/var' '--libdir=${prefix}/lib/x86_64-linux-gnu' \
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--disable-maintainer-mode' \ '--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--with-icu' \
'--disable-dependency-tracking' '--with-icu' '--with-tcl' '--with-perl' \ '--with-tcl' '--with-perl' '--with-python' '--with-pam' \
'--with-python' '--with-pam' '--with-openssl' '--with-libxml' '--with-libxslt' \ '--with-openssl' '--with-libxml' '--with-libxslt' '--with-ldap' \
'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/14/man' \ 'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/14/man' \
'--docdir=/usr/share/doc/postgresql-doc-14' \ '--docdir=/usr/share/doc/postgresql-doc-14' '--with-pgport=5432' \
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share/' \ '--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
'--datadir=/usr/share/postgresql/14' '--bindir=/usr/lib/postgresql/14/bin' \ '--datadir=/usr/share/postgresql/14' '--with-uuid=e2fs' \
'--libdir=/usr/lib/x86_64-linux-gnu/' '--libexecdir=/usr/lib/postgresql/' \ '--bindir=/usr/lib/postgresql/14/bin' '--enable-tap-tests' \
'--includedir=/usr/include/postgresql/' '--with-extra-version= (Ubuntu 2:14-x.focal)' \ '--libdir=/usr/lib/x86_64-linux-gnu' '--enable-debug' \
'--enable-nls' '--enable-thread-safety' '--enable-tap-tests' '--enable-debug' \ '--libexecdir=/usr/lib/postgresql' '--with-gnu-ld' \
'--enable-dtrace' '--disable-rpath' '--with-uuid=e2fs' '--with-gnu-ld' \ '--includedir=/usr/include/postgresql' '--enable-dtrace' \
'--with-pgport=5432' '--with-system-tzdata=/usr/share/zoneinfo' '--with-llvm' \ '--enable-nls' '--enable-thread-safety' '--disable-rpath' \
'--with-system-tzdata=/usr/share/zoneinfo' '--with-llvm' \
'LLVM_CONFIG=/usr/bin/llvm-config-11' 'CLANG=/usr/bin/clang-11' \ 'LLVM_CONFIG=/usr/bin/llvm-config-11' 'CLANG=/usr/bin/clang-11' \
'--with-systemd' '--with-selinux' 'MKDIR_P=/bin/mkdir -p' 'PROVE=/usr/bin/prove' \ '--with-systemd' '--with-selinux' 'MKDIR_P=/bin/mkdir -p' \
'TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' 'CFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -fno-omit-frame-pointer' \ 'PROVE=/usr/bin/prove' 'TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' \
'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' '--with-gssapi' '--with-ldap' \ 'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' \
'build_alias=x86_64-linux-gnu' 'CPPFLAGS=-Wdate-time -D_FORTIFY_SOURCE=2' \ 'build_alias=x86_64-linux-gnu' '--with-gssapi' \
'CPPFLAGS=-Wdate-time -D_FORTIFY_SOURCE=2' \
'CFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -fno-omit-frame-pointer' \
'CXXFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security' 'CXXFLAGS=-g -O2 -fstack-protector-strong -Wformat -Werror=format-security'
make world make world
sudo make install-world sudo make install-world
- name: Start postgresql cluster - name: Start postgresql cluster
run: | run: |
/usr/lib/postgresql/14/bin/initdb -D /opt/pgsql/data export PATH="/usr/lib/postgresql/14/bin:$PATH"
/usr/lib/postgresql/14/bin/pg_ctl -D /opt/pgsql/data -l logfile start sudo cp /usr/lib/postgresql/14/bin/pg_config /usr/bin
initdb -D /opt/pgsql/data
pg_ctl -D /opt/pgsql/data -l logfile start
- name: Clone pg_stat_monitor repository - name: Clone pg_stat_monitor repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -74,18 +80,18 @@ jobs:
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
export PATH="/usr/lib/postgresql/14/bin:$PATH"
sudo cp /usr/lib/postgresql/14/bin/pg_config /usr/bin
make USE_PGXS=1 make USE_PGXS=1
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Load pg_stat_monitor library and Restart Server - name: Load pg_stat_monitor library and Restart Server
run: | run: |
/usr/lib/postgresql/14/bin/pg_ctl -D /opt/pgsql/data -l logfile stop export PATH="/usr/lib/postgresql/14/bin:$PATH"
echo "shared_preload_libraries = 'pg_stat_monitor'" >> /opt/pgsql/data/postgresql.conf pg_ctl -D /opt/pgsql/data -l logfile stop
/usr/lib/postgresql/14/bin/pg_ctl -D /opt/pgsql/data -l logfile start echo "shared_preload_libraries = 'pg_stat_monitor'" >> \
working-directory: src/pg_stat_monitor/ /opt/pgsql/data/postgresql.conf
pg_ctl -D /opt/pgsql/data -l logfile start
working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
@ -98,7 +104,7 @@ jobs:
sudo chmod -R ugo+rwx t sudo chmod -R ugo+rwx t
sudo chmod -R ugo+rwx tmp_check sudo chmod -R ugo+rwx tmp_check
exit 2 # regenerate error so that we can upload files in next step exit 2 # regenerate error so that we can upload files in next step
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Upload logs on fail - name: Upload logs on fail
if: ${{ failure() }} if: ${{ failure() }}

View File

@ -4,7 +4,7 @@ on: [push]
jobs: jobs:
build: build:
name: pg-14-pgdg-package-test name: pg-14-pgdg-package-test
runs-on: ubuntu-latest runs-on: ubuntu-20.04
steps: steps:
- name: Clone pg_stat_monitor repository - name: Clone pg_stat_monitor repository
uses: actions/checkout@v2 uses: actions/checkout@v2
@ -14,45 +14,47 @@ jobs:
- name: Delete old postgresql files - name: Delete old postgresql files
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
sudo rm -rf /var/lib/postgresql/ postgresql postgresql*
sudo rm -rf /var/log/postgresql/ sudo apt-get install -y libreadline6-dev systemtap-sdt-dev wget \
sudo rm -rf /etc/postgresql/ zlib1g-dev libssl-dev libpam0g-dev bison flex libipc-run-perl
sudo rm -rf /usr/lib/postgresql sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /usr/include/postgresql /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
sudo rm -rf /usr/share/postgresql /etc/postgresql
sudo rm -rf /etc/postgresql
sudo rm -f /usr/bin/pg_config sudo rm -f /usr/bin/pg_config
sudo apt-get install libreadline6-dev systemtap-sdt-dev zlib1g-dev libssl-dev libpam0g-dev python-dev bison flex libipc-run-perl wget -y
sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN' sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN'
sudo /usr/bin/perl -MCPAN -e 'install String::Util' sudo /usr/bin/perl -MCPAN -e 'install String::Util'
sudo /usr/bin/perl -MCPAN -e 'install Data::Str2Num' sudo /usr/bin/perl -MCPAN -e 'install Data::Str2Num'
- name: Install PG Distribution Postgresql 14 - name: Install PG Distribution Postgresql 14
run: | run: |
sudo wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add - sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt \
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list' $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
sudo wget --quiet -O - \
https://www.postgresql.org/media/keys/ACCC4CF8.asc |
sudo apt-key add -
sudo apt update sudo apt update
sudo apt -y install postgresql-14 postgresql-server-dev-14 sudo apt -y install postgresql-14 postgresql-server-dev-14
- name: Change sources owner to postgres - name: Change src owner to postgres
run: | run: |
sudo chown -R postgres:postgres src sudo chown -R postgres:postgres src
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
sudo make USE_PGXS=1 sudo -u postgres bash -c 'make USE_PGXS=1'
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
sudo service postgresql stop sudo service postgresql stop
echo "shared_preload_libraries = 'pg_stat_monitor'" | sudo tee -a /etc/postgresql/14/main/postgresql.conf echo "shared_preload_libraries = 'pg_stat_monitor'" |
sudo tee -a /etc/postgresql/14/main/postgresql.conf
sudo service postgresql start sudo service postgresql start
sudo psql -V sudo psql -V
sudo -u postgres bash -c 'make installcheck USE_PGXS=1' sudo -u postgres bash -c 'make installcheck USE_PGXS=1'
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Change dir permissions on fail - name: Change dir permissions on fail
if: ${{ failure() }} if: ${{ failure() }}
@ -60,7 +62,7 @@ jobs:
sudo chmod -R ugo+rwx t sudo chmod -R ugo+rwx t
sudo chmod -R ugo+rwx tmp_check sudo chmod -R ugo+rwx tmp_check
exit 2 # regenerate error so that we can upload files in next step exit 2 # regenerate error so that we can upload files in next step
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Upload logs on fail - name: Upload logs on fail
if: ${{ failure() }} if: ${{ failure() }}

View File

@ -14,16 +14,15 @@ jobs:
- name: Delete old postgresql files - name: Delete old postgresql files
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt purge postgresql-client-common postgresql-common postgresql postgresql* sudo apt purge postgresql-client-common postgresql-common \
sudo rm -rf /var/lib/postgresql/ postgresql postgresql*
sudo rm -rf /var/log/postgresql/ sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
sudo rm -rf /etc/postgresql/ zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
sudo rm -rf /usr/lib/postgresql libipc-run-perl wget
sudo rm -rf /usr/include/postgresql sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
sudo rm -rf /usr/share/postgresql /usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
sudo rm -rf /etc/postgresql /etc/postgresql
sudo rm -f /usr/bin/pg_config sudo rm -f /usr/bin/pg_config
sudo apt-get install libreadline6-dev systemtap-sdt-dev zlib1g-dev libssl-dev libpam0g-dev python-dev bison flex libipc-run-perl wget -y
sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN' sudo /usr/bin/perl -MCPAN -e 'install IPC::RUN'
sudo /usr/bin/perl -MCPAN -e 'install String::Util' sudo /usr/bin/perl -MCPAN -e 'install String::Util'
sudo /usr/bin/perl -MCPAN -e 'install Data::Str2Num' sudo /usr/bin/perl -MCPAN -e 'install Data::Str2Num'
@ -32,16 +31,17 @@ jobs:
run: | run: |
sudo apt-get -y update sudo apt-get -y update
sudo apt-get -y upgrade sudo apt-get -y upgrade
sudo apt-get -y update
sudo apt-get install -y wget gnupg2 curl lsb-release sudo apt-get install -y wget gnupg2 curl lsb-release
sudo wget https://repo.percona.com/apt/percona-release_latest.generic_all.deb sudo wget \
https://repo.percona.com/apt/percona-release_latest.generic_all.deb
sudo dpkg -i percona-release_latest.generic_all.deb sudo dpkg -i percona-release_latest.generic_all.deb
- name: Install Percona Distribution Postgresql 14 - name: Install Percona Distribution Postgresql 14
run: | run: |
sudo percona-release setup ppg-14 sudo percona-release setup ppg-14
sudo apt-get update -y sudo apt-get update -y
sudo apt-get install -y percona-postgresql-14 percona-postgresql-contrib percona-postgresql-server-dev-all sudo apt-get install -y percona-postgresql-14 \
percona-postgresql-contrib percona-postgresql-server-dev-all
- name: Change src owner to postgres - name: Change src owner to postgres
run: | run: |
@ -49,18 +49,19 @@ jobs:
- name: Build pg_stat_monitor - name: Build pg_stat_monitor
run: | run: |
sudo make USE_PGXS=1 sudo -u postgres bash -c 'make USE_PGXS=1'
sudo make USE_PGXS=1 install sudo make USE_PGXS=1 install
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Start pg_stat_monitor_tests - name: Start pg_stat_monitor_tests
run: | run: |
sudo service postgresql stop sudo service postgresql stop
echo "shared_preload_libraries = 'pg_stat_monitor'" | sudo tee -a /etc/postgresql/14/main/postgresql.conf echo "shared_preload_libraries = 'pg_stat_monitor'" |
sudo tee -a /etc/postgresql/14/main/postgresql.conf
sudo service postgresql start sudo service postgresql start
sudo psql -V sudo psql -V
sudo -u postgres bash -c 'make installcheck USE_PGXS=1' sudo -u postgres bash -c 'make installcheck USE_PGXS=1'
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Change dir permissions on fail - name: Change dir permissions on fail
if: ${{ failure() }} if: ${{ failure() }}
@ -68,7 +69,7 @@ jobs:
sudo chmod -R ugo+rwx t sudo chmod -R ugo+rwx t
sudo chmod -R ugo+rwx tmp_check sudo chmod -R ugo+rwx tmp_check
exit 2 # regenerate error so that we can upload files in next step exit 2 # regenerate error so that we can upload files in next step
working-directory: src/pg_stat_monitor/ working-directory: src/pg_stat_monitor
- name: Upload logs on fail - name: Upload logs on fail
if: ${{ failure() }} if: ${{ failure() }}

4
.gitignore vendored
View File

@ -55,3 +55,7 @@ dkms.conf
## DS_Store ## DS_Store
*.DS_Store *.DS_Store
## .vscode
.vscode/
.vscode/*