mirror of
https://github.com/percona/pg_stat_monitor.git
synced 2026-02-04 05:56:21 +00:00
Debug
This commit is contained in:
95
.github/workflows/check.yml
vendored
95
.github/workflows/check.yml
vendored
@@ -1,95 +0,0 @@
|
|||||||
name: Checks
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
cppcheck:
|
|
||||||
name: Cppcheck
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 5
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout sources
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Checkout cppcheck sources
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
repository: "danmar/cppcheck"
|
|
||||||
ref: "2.13.4"
|
|
||||||
path: src/cppcheck
|
|
||||||
|
|
||||||
- name: Build and install cppcheck
|
|
||||||
working-directory: src/cppcheck
|
|
||||||
run: |
|
|
||||||
mkdir build
|
|
||||||
cd build
|
|
||||||
cmake ..
|
|
||||||
cmake --build .
|
|
||||||
sudo cmake --install .
|
|
||||||
|
|
||||||
- name: Execute linter check with cppcheck
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
set -x
|
|
||||||
cppcheck --enable=all --inline-suppr --template='{file}:{line},{severity},{id},{message}' --error-exitcode=1 --suppress=missingIncludeSystem --suppress=missingInclude --suppress=unmatchedSuppression:pg_stat_monitor.c --check-config .
|
|
||||||
|
|
||||||
format:
|
|
||||||
name: Format
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 5
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Clone postgres repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
repository: 'postgres/postgres'
|
|
||||||
ref: 'REL_17_STABLE'
|
|
||||||
|
|
||||||
- name: Checkout sources
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'contrib/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Configure postgres
|
|
||||||
run: ./configure
|
|
||||||
|
|
||||||
- name: Install perltidy
|
|
||||||
run: sudo cpan -T SHANCOCK/Perl-Tidy-20230309.tar.gz
|
|
||||||
|
|
||||||
- name: Install pg_bsd_indent
|
|
||||||
working-directory: src/tools/pg_bsd_indent
|
|
||||||
run: sudo make install
|
|
||||||
|
|
||||||
- name: Add pg_bsd_indent and pgindent to path
|
|
||||||
run: |
|
|
||||||
echo "/usr/local/pgsql/bin" >> $GITHUB_PATH
|
|
||||||
echo "${{ github.workspace }}/src/tools/pgindent" >> $GITHUB_PATH
|
|
||||||
|
|
||||||
- name: Format sources
|
|
||||||
working-directory: contrib/pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
make update-typedefs
|
|
||||||
make indent
|
|
||||||
|
|
||||||
- name: Check files are formatted and no source code changes
|
|
||||||
working-directory: contrib/pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
git status
|
|
||||||
git diff --exit-code
|
|
||||||
|
|
||||||
license:
|
|
||||||
name: License
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 5
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout sources
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
|
|
||||||
- name: Check license headers
|
|
||||||
uses: apache/skywalking-eyes/header@61275cc80d0798a405cb070f7d3a8aaf7cf2c2c1 # v0.8.0
|
|
||||||
with:
|
|
||||||
token: "" # Prevent comments
|
|
||||||
149
.github/workflows/code-coverage-test.yml
vendored
149
.github/workflows/code-coverage-test.yml
vendored
@@ -1,149 +0,0 @@
|
|||||||
name: code-coverage-test
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: coverage-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Clone postgres repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
repository: 'postgres/postgres'
|
|
||||||
ref: 'REL_15_STABLE'
|
|
||||||
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex \
|
|
||||||
libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
|
|
||||||
libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
|
|
||||||
libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-11 \
|
|
||||||
llvm-11 llvm-11-dev libselinux1-dev python3-dev uuid-dev \
|
|
||||||
liblz4-dev lcov
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- 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=${prefix}/include' '--enable-coverage' \
|
|
||||||
'--mandir=${prefix}/share/man' '--infodir=${prefix}/share/info' \
|
|
||||||
'--sysconfdir=/etc' '--localstatedir=/var' '--with-icu' \
|
|
||||||
'--libdir=${prefix}/lib/x86_64-linux-gnu' '--with-tcl' \
|
|
||||||
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--with-perl' \
|
|
||||||
'--with-python' '--with-pam' '--with-openssl' '--with-libxml' \
|
|
||||||
'--with-libxslt' 'PYTHON=/usr/bin/python3' '--enable-nls' \
|
|
||||||
'--mandir=/usr/share/postgresql/15/man' '--enable-thread-safety' \
|
|
||||||
'--docdir=/usr/share/doc/postgresql-doc-15' '--enable-dtrace' \
|
|
||||||
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
|
|
||||||
'--datadir=/usr/share/postgresql/15' '--with-uuid=e2fs' \
|
|
||||||
'--bindir=/usr/lib/postgresql/15/bin' '--with-gnu-ld' \
|
|
||||||
'--libdir=/usr/lib/x86_64-linux-gnu' '--enable-tap-tests' \
|
|
||||||
'--libexecdir=/usr/lib/postgresql' '--enable-debug' \
|
|
||||||
'--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' \
|
|
||||||
'--with-systemd' 'MKDIR_P=/bin/mkdir -p' '--with-selinux' \
|
|
||||||
'PROVE=/usr/bin/prove' '--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' \
|
|
||||||
'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
|
|
||||||
sudo make install-world
|
|
||||||
|
|
||||||
- name: Start postgresql cluster
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/15/bin:$PATH"
|
|
||||||
sudo cp /usr/lib/postgresql/15/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
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
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: |
|
|
||||||
export PATH="/usr/lib/postgresql/15/bin:$PATH"
|
|
||||||
pg_ctl -D /opt/pgsql/data -l logfile stop
|
|
||||||
echo "shared_preload_libraries = '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
|
|
||||||
run: |
|
|
||||||
make installcheck
|
|
||||||
/usr/lib/postgresql/15/bin/psql -d postgres -p 5432 -c "\list"
|
|
||||||
gcov -abcfu pg_stat_monitor.c
|
|
||||||
gcov -abcfu guc.c
|
|
||||||
gcov -abcfu hash_query.c
|
|
||||||
sudo chmod -R ugo+rwx *.gcov*
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload
|
|
||||||
uses: codecov/codecov-action@671740ac38dd9b0130fbe1cec585b89eea48d3de # v5.5.2
|
|
||||||
with:
|
|
||||||
verbose: true
|
|
||||||
token: ${{ secrets.CODECOV_TOKEN }}
|
|
||||||
working-directory: ./src/pg_stat_monitor
|
|
||||||
files: ./pg_stat_monitor.c.gcov,./hash_query.c.gcov,./guc.c.gcov
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
37
.github/workflows/pgxn-release.yml
vendored
37
.github/workflows/pgxn-release.yml
vendored
@@ -1,37 +0,0 @@
|
|||||||
name: PGXN
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
inputs:
|
|
||||||
version:
|
|
||||||
description: 'Version to release'
|
|
||||||
required: true
|
|
||||||
type: string
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
release:
|
|
||||||
name: Release
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 10
|
|
||||||
container: pgxn/pgxn-tools
|
|
||||||
steps:
|
|
||||||
- name: Validate version tag
|
|
||||||
run: '[[ ${{ inputs.version }} =~ ^[0-9]+.[0-9]+.[0-9]+ ]]'
|
|
||||||
shell: bash
|
|
||||||
|
|
||||||
- name: Check out
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
ref: '${{ inputs.version }}'
|
|
||||||
|
|
||||||
- name: Bundle
|
|
||||||
id: bundle
|
|
||||||
run: pgxn-bundle
|
|
||||||
|
|
||||||
- name: Upload
|
|
||||||
env:
|
|
||||||
PGXN_USERNAME: percona
|
|
||||||
PGXN_PASSWORD: ${{ secrets.PGXN_PERCONA }}
|
|
||||||
run: pgxn-release
|
|
||||||
2
.github/workflows/pmm-integration.yaml
vendored
2
.github/workflows/pmm-integration.yaml
vendored
@@ -25,7 +25,7 @@ jobs:
|
|||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
||||||
with:
|
with:
|
||||||
repository: Percona-Lab/qa-integration
|
repository: Percona-Lab/qa-integration
|
||||||
ref: main
|
ref: cleanup
|
||||||
path: qa-integration
|
path: qa-integration
|
||||||
|
|
||||||
- name: Clone PMM UI tests
|
- name: Clone PMM UI tests
|
||||||
|
|||||||
151
.github/workflows/postgresql-13-build.yml
vendored
151
.github/workflows/postgresql-13-build.yml
vendored
@@ -1,151 +0,0 @@
|
|||||||
name: postgresql-13-build
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-13-build-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone postgres repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
repository: 'postgres/postgres'
|
|
||||||
ref: 'REL_13_STABLE'
|
|
||||||
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex \
|
|
||||||
libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
|
|
||||||
libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
|
|
||||||
libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-11 \
|
|
||||||
llvm-11 llvm-11-dev libselinux1-dev python3-dev uuid-dev liblz4-dev
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- 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=${prefix}/include' \
|
|
||||||
'--mandir=${prefix}/share/man' '--infodir=${prefix}/share/info' \
|
|
||||||
'--sysconfdir=/etc' '--localstatedir=/var' '--with-icu' \
|
|
||||||
'--libdir=${prefix}/lib/x86_64-linux-gnu' '--with-perl' \
|
|
||||||
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--enable-debug' \
|
|
||||||
'--with-tcl' '--with-pam' '--with-python' '--with-openssl' \
|
|
||||||
'--with-libxml' '--with-libxslt' '--enable-tap-tests' \
|
|
||||||
'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/13/man' \
|
|
||||||
'--docdir=/usr/share/doc/postgresql-doc-13' 'AWK=mawk' \
|
|
||||||
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
|
|
||||||
'--datadir=/usr/share/postgresql/13' '--enable-nls' \
|
|
||||||
'--bindir=/usr/lib/postgresql/13/bin' '--enable-dtrace' \
|
|
||||||
'--libdir=/usr/lib/x86_64-linux-gnu' '--disable-rpath' \
|
|
||||||
'--libexecdir=/usr/lib/postgresql' '--enable-thread-safety' \
|
|
||||||
'--includedir=/usr/include/postgresql' 'TAR=/bin/tar' \
|
|
||||||
'--with-uuid=e2fs' '--with-gnu-ld' 'XSLTPROC=xsltproc --nonet' \
|
|
||||||
'--with-pgport=5432' '--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' \
|
|
||||||
'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'
|
|
||||||
make world
|
|
||||||
sudo make install-world
|
|
||||||
|
|
||||||
- name: Start postgresql cluster
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/13/bin:$PATH"
|
|
||||||
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
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
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: |
|
|
||||||
export PATH="/usr/lib/postgresql/13/bin:$PATH"
|
|
||||||
pg_ctl -D /opt/pgsql/data -l logfile stop
|
|
||||||
echo "shared_preload_libraries = '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: |
|
|
||||||
make installcheck
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
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@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
if: ${{ failure() }}
|
|
||||||
with:
|
|
||||||
name: Regressions output files of failed testsuite, and pg log
|
|
||||||
path: |
|
|
||||||
**/regression.diffs
|
|
||||||
**/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
retention-days: 3
|
|
||||||
98
.github/workflows/postgresql-13-pgdg-package.yml
vendored
98
.github/workflows/postgresql-13-pgdg-package.yml
vendored
@@ -1,98 +0,0 @@
|
|||||||
name: postgresql-13-pgdg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-13-pgdg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
|
|
||||||
libipc-run-perl wget -y
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install PG Distribution Postgresql 13
|
|
||||||
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 wget --quiet -O - \
|
|
||||||
https://www.postgresql.org/media/keys/ACCC4CF8.asc |
|
|
||||||
sudo apt-key add -
|
|
||||||
sudo apt update
|
|
||||||
sudo apt -y install postgresql-13 postgresql-server-dev-13
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/13/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
111
.github/workflows/postgresql-13-ppg-package.yml
vendored
111
.github/workflows/postgresql-13-ppg-package.yml
vendored
@@ -1,111 +0,0 @@
|
|||||||
name: postgresql-13-ppg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-13-ppg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
|
|
||||||
libipc-run-perl wget
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install percona-release script
|
|
||||||
run: |
|
|
||||||
sudo apt-get -y update
|
|
||||||
sudo apt-get -y upgrade
|
|
||||||
sudo apt-get install -y wget gnupg2 curl lsb-release
|
|
||||||
sudo wget \
|
|
||||||
https://repo.percona.com/apt/percona-release_latest.generic_all.deb
|
|
||||||
sudo dpkg -i percona-release_latest.generic_all.deb
|
|
||||||
|
|
||||||
- name: Install Percona Distribution Postgresql 13 & Extensions
|
|
||||||
run: |
|
|
||||||
sudo percona-release setup ppg-13
|
|
||||||
sudo apt-get update -y
|
|
||||||
sudo apt-get install -y percona-postgresql-13 \
|
|
||||||
percona-postgresql-contrib percona-postgresql-server-dev-all \
|
|
||||||
percona-pgpool2 libpgpool2 percona-postgresql-13-pgaudit \
|
|
||||||
percona-postgresql-13-pgaudit-dbgsym percona-postgresql-13-repack \
|
|
||||||
percona-postgresql-13-repack-dbgsym percona-pgaudit13-set-user \
|
|
||||||
percona-pgaudit13-set-user-dbgsym percona-postgresql-13-postgis-3 \
|
|
||||||
percona-postgresql-13-postgis-3-scripts \
|
|
||||||
percona-postgresql-postgis-scripts percona-postgresql-postgis \
|
|
||||||
percona-postgis
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/13/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
151
.github/workflows/postgresql-14-build.yml
vendored
151
.github/workflows/postgresql-14-build.yml
vendored
@@ -1,151 +0,0 @@
|
|||||||
name: postgresql-14-build
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-14-build-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone postgres repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
repository: 'postgres/postgres'
|
|
||||||
ref: 'REL_14_STABLE'
|
|
||||||
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex \
|
|
||||||
libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
|
|
||||||
libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
|
|
||||||
libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-11 \
|
|
||||||
llvm-11 llvm-11-dev libselinux1-dev python3-dev \
|
|
||||||
uuid-dev liblz4-dev
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- 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=${prefix}/include' '--mandir=${prefix}/share/man' \
|
|
||||||
'--infodir=${prefix}/share/info' '--sysconfdir=/etc' \
|
|
||||||
'--localstatedir=/var' '--libdir=${prefix}/lib/x86_64-linux-gnu' \
|
|
||||||
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--with-icu' \
|
|
||||||
'--with-tcl' '--with-perl' '--with-python' '--with-pam' \
|
|
||||||
'--with-openssl' '--with-libxml' '--with-libxslt' '--with-ldap' \
|
|
||||||
'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/14/man' \
|
|
||||||
'--docdir=/usr/share/doc/postgresql-doc-14' '--with-pgport=5432' \
|
|
||||||
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
|
|
||||||
'--datadir=/usr/share/postgresql/14' '--with-uuid=e2fs' \
|
|
||||||
'--bindir=/usr/lib/postgresql/14/bin' '--enable-tap-tests' \
|
|
||||||
'--libdir=/usr/lib/x86_64-linux-gnu' '--enable-debug' \
|
|
||||||
'--libexecdir=/usr/lib/postgresql' '--with-gnu-ld' \
|
|
||||||
'--includedir=/usr/include/postgresql' '--enable-dtrace' \
|
|
||||||
'--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' \
|
|
||||||
'--with-systemd' '--with-selinux' 'MKDIR_P=/bin/mkdir -p' \
|
|
||||||
'PROVE=/usr/bin/prove' 'TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' \
|
|
||||||
'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' \
|
|
||||||
'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'
|
|
||||||
make world
|
|
||||||
sudo make install-world
|
|
||||||
|
|
||||||
- name: Start postgresql cluster
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/14/bin:$PATH"
|
|
||||||
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
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
make USE_PGXS=1
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Configure and Restart Server
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/14/bin:$PATH"
|
|
||||||
pg_ctl -D /opt/pgsql/data -l logfile stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" >> \
|
|
||||||
/opt/pgsql/data/postgresql.conf
|
|
||||||
echo "compute_query_id = regress" >> /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: |
|
|
||||||
make installcheck
|
|
||||||
working-directory: src/pg_stat_monitor/
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
|
|
||||||
- name: Start Server installcheck-world tests
|
|
||||||
run: make installcheck-world
|
|
||||||
|
|
||||||
- name: Report on installcheck-world test suites fail
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
if: ${{ failure() }}
|
|
||||||
with:
|
|
||||||
name: Regressions output files of failed testsuite, and pg log
|
|
||||||
path: |
|
|
||||||
**/regression.diffs
|
|
||||||
**/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
retention-days: 3
|
|
||||||
97
.github/workflows/postgresql-14-pgdg-package.yml
vendored
97
.github/workflows/postgresql-14-pgdg-package.yml
vendored
@@ -1,97 +0,0 @@
|
|||||||
name: postgresql-14-pgdg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-14-pgdg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev wget \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex libipc-run-perl
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install PG Distribution Postgresql 14
|
|
||||||
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 wget --quiet -O - \
|
|
||||||
https://www.postgresql.org/media/keys/ACCC4CF8.asc |
|
|
||||||
sudo apt-key add -
|
|
||||||
sudo apt update
|
|
||||||
sudo apt -y install postgresql-14 postgresql-server-dev-14
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/14/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
111
.github/workflows/postgresql-14-ppg-package.yml
vendored
111
.github/workflows/postgresql-14-ppg-package.yml
vendored
@@ -1,111 +0,0 @@
|
|||||||
name: postgresql-14-ppg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-14-ppg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
|
|
||||||
libipc-run-perl wget
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install percona-release script
|
|
||||||
run: |
|
|
||||||
sudo apt-get -y update
|
|
||||||
sudo apt-get -y upgrade
|
|
||||||
sudo apt-get install -y wget gnupg2 curl lsb-release
|
|
||||||
sudo wget \
|
|
||||||
https://repo.percona.com/apt/percona-release_latest.generic_all.deb
|
|
||||||
sudo dpkg -i percona-release_latest.generic_all.deb
|
|
||||||
|
|
||||||
- name: Install Percona Distribution Postgresql 14 & Extensions
|
|
||||||
run: |
|
|
||||||
sudo percona-release setup ppg-14
|
|
||||||
sudo apt-get update -y
|
|
||||||
sudo apt-get install -y percona-postgresql-14 \
|
|
||||||
percona-postgresql-contrib percona-postgresql-server-dev-all \
|
|
||||||
percona-pgpool2 libpgpool2 percona-postgresql-14-pgaudit \
|
|
||||||
percona-postgresql-14-pgaudit-dbgsym percona-postgresql-14-repack \
|
|
||||||
percona-postgresql-14-repack-dbgsym percona-pgaudit14-set-user \
|
|
||||||
percona-pgaudit14-set-user-dbgsym percona-postgresql-14-postgis-3 \
|
|
||||||
percona-postgresql-14-postgis-3-scripts \
|
|
||||||
percona-postgresql-postgis-scripts percona-postgresql-postgis \
|
|
||||||
percona-postgis
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/14/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
151
.github/workflows/postgresql-15-build.yml
vendored
151
.github/workflows/postgresql-15-build.yml
vendored
@@ -1,151 +0,0 @@
|
|||||||
name: postgresql-15-build
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-15-build-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone postgres repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
repository: 'postgres/postgres'
|
|
||||||
ref: 'REL_15_STABLE'
|
|
||||||
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex \
|
|
||||||
libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
|
|
||||||
libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
|
|
||||||
libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-11 \
|
|
||||||
llvm-11 llvm-11-dev libselinux1-dev python3-dev \
|
|
||||||
uuid-dev liblz4-dev
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- 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=${prefix}/include' '--mandir=${prefix}/share/man' \
|
|
||||||
'--infodir=${prefix}/share/info' '--sysconfdir=/etc' \
|
|
||||||
'--localstatedir=/var' '--libdir=${prefix}/lib/x86_64-linux-gnu' \
|
|
||||||
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--with-icu' \
|
|
||||||
'--with-tcl' '--with-perl' '--with-python' '--with-pam' \
|
|
||||||
'--with-openssl' '--with-libxml' '--with-libxslt' '--with-ldap' \
|
|
||||||
'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/15/man' \
|
|
||||||
'--docdir=/usr/share/doc/postgresql-doc-15' '--with-pgport=5432' \
|
|
||||||
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
|
|
||||||
'--datadir=/usr/share/postgresql/15' '--with-uuid=e2fs' \
|
|
||||||
'--bindir=/usr/lib/postgresql/15/bin' '--enable-tap-tests' \
|
|
||||||
'--libdir=/usr/lib/x86_64-linux-gnu' '--enable-debug' \
|
|
||||||
'--libexecdir=/usr/lib/postgresql' '--with-gnu-ld' \
|
|
||||||
'--includedir=/usr/include/postgresql' '--enable-dtrace' \
|
|
||||||
'--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' \
|
|
||||||
'--with-systemd' '--with-selinux' 'MKDIR_P=/bin/mkdir -p' \
|
|
||||||
'PROVE=/usr/bin/prove' 'TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' \
|
|
||||||
'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' \
|
|
||||||
'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'
|
|
||||||
make world
|
|
||||||
sudo make install-world
|
|
||||||
|
|
||||||
- name: Start postgresql cluster
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/15/bin:$PATH"
|
|
||||||
sudo cp /usr/lib/postgresql/15/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
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
make USE_PGXS=1
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Configure and Restart Server
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/15/bin:$PATH"
|
|
||||||
pg_ctl -D /opt/pgsql/data -l logfile stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" >> \
|
|
||||||
/opt/pgsql/data/postgresql.conf
|
|
||||||
echo "compute_query_id = regress" >> /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: |
|
|
||||||
make installcheck
|
|
||||||
working-directory: src/pg_stat_monitor/
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
|
|
||||||
- name: Start Server installcheck-world tests
|
|
||||||
run: make installcheck-world
|
|
||||||
|
|
||||||
- name: Report on installcheck-world test suites fail
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
if: ${{ failure() }}
|
|
||||||
with:
|
|
||||||
name: Regressions output files of failed testsuite, and pg log
|
|
||||||
path: |
|
|
||||||
**/regression.diffs
|
|
||||||
**/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
retention-days: 3
|
|
||||||
97
.github/workflows/postgresql-15-pgdg-package.yml
vendored
97
.github/workflows/postgresql-15-pgdg-package.yml
vendored
@@ -1,97 +0,0 @@
|
|||||||
name: postgresql-15-pgdg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-15-pgdg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev wget \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex libipc-run-perl
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install PG Distribution Postgresql 15
|
|
||||||
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 wget --quiet -O - \
|
|
||||||
https://www.postgresql.org/media/keys/ACCC4CF8.asc |
|
|
||||||
sudo apt-key add -
|
|
||||||
sudo apt update
|
|
||||||
sudo apt -y install postgresql-15 postgresql-server-dev-15
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/15/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
111
.github/workflows/postgresql-15-ppg-package.yml
vendored
111
.github/workflows/postgresql-15-ppg-package.yml
vendored
@@ -1,111 +0,0 @@
|
|||||||
name: postgresql-15-ppg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-15-ppg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
|
|
||||||
libipc-run-perl wget
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install percona-release script
|
|
||||||
run: |
|
|
||||||
sudo apt-get -y update
|
|
||||||
sudo apt-get -y upgrade
|
|
||||||
sudo apt-get install -y wget gnupg2 curl lsb-release
|
|
||||||
sudo wget \
|
|
||||||
https://repo.percona.com/apt/percona-release_latest.generic_all.deb
|
|
||||||
sudo dpkg -i percona-release_latest.generic_all.deb
|
|
||||||
|
|
||||||
- name: Install Percona Distribution Postgresql 15 & Extensions
|
|
||||||
run: |
|
|
||||||
sudo percona-release setup ppg-15
|
|
||||||
sudo apt-get update -y
|
|
||||||
sudo apt-get install -y percona-postgresql-15 \
|
|
||||||
percona-postgresql-contrib percona-postgresql-server-dev-all \
|
|
||||||
percona-pgpool2 libpgpool2 percona-postgresql-15-pgaudit \
|
|
||||||
percona-postgresql-15-pgaudit-dbgsym percona-postgresql-15-repack \
|
|
||||||
percona-postgresql-15-repack-dbgsym percona-pgaudit15-set-user \
|
|
||||||
percona-pgaudit15-set-user-dbgsym percona-postgresql-15-postgis-3 \
|
|
||||||
percona-postgresql-15-postgis-3-scripts \
|
|
||||||
percona-postgresql-postgis-scripts percona-postgresql-postgis \
|
|
||||||
percona-postgis
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/15/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
151
.github/workflows/postgresql-16-build.yml
vendored
151
.github/workflows/postgresql-16-build.yml
vendored
@@ -1,151 +0,0 @@
|
|||||||
name: postgresql-16-build
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-16-build-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone postgres repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
repository: 'postgres/postgres'
|
|
||||||
ref: 'REL_16_STABLE'
|
|
||||||
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex \
|
|
||||||
libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
|
|
||||||
libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
|
|
||||||
libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-11 \
|
|
||||||
llvm-11 llvm-11-dev libselinux1-dev python3-dev \
|
|
||||||
uuid-dev liblz4-dev
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- 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=${prefix}/include' '--mandir=${prefix}/share/man' \
|
|
||||||
'--infodir=${prefix}/share/info' '--sysconfdir=/etc' \
|
|
||||||
'--localstatedir=/var' '--libdir=${prefix}/lib/x86_64-linux-gnu' \
|
|
||||||
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--with-icu' \
|
|
||||||
'--with-tcl' '--with-perl' '--with-python' '--with-pam' \
|
|
||||||
'--with-openssl' '--with-libxml' '--with-libxslt' '--with-ldap' \
|
|
||||||
'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/16/man' \
|
|
||||||
'--docdir=/usr/share/doc/postgresql-doc-16' '--with-pgport=5432' \
|
|
||||||
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
|
|
||||||
'--datadir=/usr/share/postgresql/16' '--with-uuid=e2fs' \
|
|
||||||
'--bindir=/usr/lib/postgresql/16/bin' '--enable-tap-tests' \
|
|
||||||
'--libdir=/usr/lib/x86_64-linux-gnu' '--enable-debug' \
|
|
||||||
'--libexecdir=/usr/lib/postgresql' '--with-gnu-ld' \
|
|
||||||
'--includedir=/usr/include/postgresql' '--enable-dtrace' \
|
|
||||||
'--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' \
|
|
||||||
'--with-systemd' '--with-selinux' 'MKDIR_P=/bin/mkdir -p' \
|
|
||||||
'PROVE=/usr/bin/prove' 'TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' \
|
|
||||||
'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' \
|
|
||||||
'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'
|
|
||||||
make world
|
|
||||||
sudo make install-world
|
|
||||||
|
|
||||||
- name: Start postgresql cluster
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/16/bin:$PATH"
|
|
||||||
sudo cp /usr/lib/postgresql/16/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
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
make USE_PGXS=1
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Configure and Restart Server
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/16/bin:$PATH"
|
|
||||||
pg_ctl -D /opt/pgsql/data -l logfile stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" >> \
|
|
||||||
/opt/pgsql/data/postgresql.conf
|
|
||||||
echo "compute_query_id = regress" >> /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: |
|
|
||||||
make installcheck
|
|
||||||
working-directory: src/pg_stat_monitor/
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
|
|
||||||
- name: Start Server installcheck-world tests
|
|
||||||
run: make installcheck-world
|
|
||||||
|
|
||||||
- name: Report on installcheck-world test suites fail
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
if: ${{ failure() }}
|
|
||||||
with:
|
|
||||||
name: Regressions output files of failed testsuite, and pg log
|
|
||||||
path: |
|
|
||||||
**/regression.diffs
|
|
||||||
**/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
retention-days: 3
|
|
||||||
97
.github/workflows/postgresql-16-pgdg-package.yml
vendored
97
.github/workflows/postgresql-16-pgdg-package.yml
vendored
@@ -1,97 +0,0 @@
|
|||||||
name: postgresql-16-pgdg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-16-pgdg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev wget \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex libipc-run-perl
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install PG Distribution Postgresql 16
|
|
||||||
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 wget --quiet -O - \
|
|
||||||
https://www.postgresql.org/media/keys/ACCC4CF8.asc |
|
|
||||||
sudo apt-key add -
|
|
||||||
sudo apt update
|
|
||||||
sudo apt -y install postgresql-16 postgresql-server-dev-16
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/16/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
111
.github/workflows/postgresql-16-ppg-package.yml
vendored
111
.github/workflows/postgresql-16-ppg-package.yml
vendored
@@ -1,111 +0,0 @@
|
|||||||
name: postgresql-16-ppg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-16-ppg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev python3-dev bison flex \
|
|
||||||
libipc-run-perl wget
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install percona-release script
|
|
||||||
run: |
|
|
||||||
sudo apt-get -y update
|
|
||||||
sudo apt-get -y upgrade
|
|
||||||
sudo apt-get install -y wget gnupg2 curl lsb-release
|
|
||||||
sudo wget \
|
|
||||||
https://repo.percona.com/apt/percona-release_latest.generic_all.deb
|
|
||||||
sudo dpkg -i percona-release_latest.generic_all.deb
|
|
||||||
|
|
||||||
- name: Install Percona Distribution Postgresql 16 & Extensions
|
|
||||||
run: |
|
|
||||||
sudo percona-release setup ppg-16
|
|
||||||
sudo apt-get update -y
|
|
||||||
sudo apt-get install -y percona-postgresql-16 \
|
|
||||||
percona-postgresql-contrib percona-postgresql-server-dev-all \
|
|
||||||
percona-pgpool2 libpgpool2 percona-postgresql-16-pgaudit \
|
|
||||||
percona-postgresql-16-pgaudit-dbgsym percona-postgresql-16-repack \
|
|
||||||
percona-postgresql-16-repack-dbgsym percona-pgaudit16-set-user \
|
|
||||||
percona-pgaudit16-set-user-dbgsym percona-postgresql-16-postgis-3 \
|
|
||||||
percona-postgresql-16-postgis-3-scripts \
|
|
||||||
percona-postgresql-postgis-scripts percona-postgresql-postgis \
|
|
||||||
percona-postgis
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/16/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
151
.github/workflows/postgresql-17-build.yml
vendored
151
.github/workflows/postgresql-17-build.yml
vendored
@@ -1,151 +0,0 @@
|
|||||||
name: postgresql-17-build
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-17-build-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone postgres repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
repository: 'postgres/postgres'
|
|
||||||
ref: 'REL_17_STABLE'
|
|
||||||
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex \
|
|
||||||
libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
|
|
||||||
libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
|
|
||||||
libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-11 \
|
|
||||||
llvm-11 llvm-11-dev libselinux1-dev python3-dev \
|
|
||||||
uuid-dev liblz4-dev
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- 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=${prefix}/include' '--mandir=${prefix}/share/man' \
|
|
||||||
'--infodir=${prefix}/share/info' '--sysconfdir=/etc' \
|
|
||||||
'--localstatedir=/var' '--libdir=${prefix}/lib/x86_64-linux-gnu' \
|
|
||||||
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--with-icu' \
|
|
||||||
'--with-tcl' '--with-perl' '--with-python' '--with-pam' \
|
|
||||||
'--with-openssl' '--with-libxml' '--with-libxslt' '--with-ldap' \
|
|
||||||
'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/17/man' \
|
|
||||||
'--docdir=/usr/share/doc/postgresql-doc-17' '--with-pgport=5432' \
|
|
||||||
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
|
|
||||||
'--datadir=/usr/share/postgresql/17' '--with-uuid=e2fs' \
|
|
||||||
'--bindir=/usr/lib/postgresql/17/bin' '--enable-tap-tests' \
|
|
||||||
'--libdir=/usr/lib/x86_64-linux-gnu' '--enable-debug' \
|
|
||||||
'--libexecdir=/usr/lib/postgresql' '--with-gnu-ld' \
|
|
||||||
'--includedir=/usr/include/postgresql' '--enable-dtrace' \
|
|
||||||
'--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' \
|
|
||||||
'--with-systemd' '--with-selinux' 'MKDIR_P=/bin/mkdir -p' \
|
|
||||||
'PROVE=/usr/bin/prove' 'TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' \
|
|
||||||
'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' \
|
|
||||||
'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'
|
|
||||||
make world
|
|
||||||
sudo make install-world
|
|
||||||
|
|
||||||
- name: Start postgresql cluster
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/17/bin:$PATH"
|
|
||||||
sudo cp /usr/lib/postgresql/17/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
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
make USE_PGXS=1
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Configure and Restart Server
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/17/bin:$PATH"
|
|
||||||
pg_ctl -D /opt/pgsql/data -l logfile stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" >> \
|
|
||||||
/opt/pgsql/data/postgresql.conf
|
|
||||||
echo "compute_query_id = regress" >> /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: |
|
|
||||||
make installcheck
|
|
||||||
working-directory: src/pg_stat_monitor/
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
|
|
||||||
- name: Start Server installcheck-world tests
|
|
||||||
run: make installcheck-world
|
|
||||||
|
|
||||||
- name: Report on installcheck-world test suites fail
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
if: ${{ failure() }}
|
|
||||||
with:
|
|
||||||
name: Regressions output files of failed testsuite, and pg log
|
|
||||||
path: |
|
|
||||||
**/regression.diffs
|
|
||||||
**/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
retention-days: 3
|
|
||||||
97
.github/workflows/postgresql-17-pgdg-package.yml
vendored
97
.github/workflows/postgresql-17-pgdg-package.yml
vendored
@@ -1,97 +0,0 @@
|
|||||||
name: postgresql-17-pgdg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-17-pgdg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev wget \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex libipc-run-perl
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install PG Distribution Postgresql 17
|
|
||||||
run: |
|
|
||||||
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt \
|
|
||||||
$(lsb_release -cs)-pgdg main 17" > /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 -y install postgresql-17 postgresql-server-dev-17
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/17/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
151
.github/workflows/postgresql-18-build.yml
vendored
151
.github/workflows/postgresql-18-build.yml
vendored
@@ -1,151 +0,0 @@
|
|||||||
name: postgresql-18-build
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-18-build-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone postgres repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
repository: 'postgres/postgres'
|
|
||||||
ref: 'REL_18_STABLE'
|
|
||||||
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex \
|
|
||||||
libipc-run-perl -y docbook-xsl docbook-xsl libxml2 libxml2-utils \
|
|
||||||
libxml2-dev libxslt-dev xsltproc libkrb5-dev libldap2-dev \
|
|
||||||
libsystemd-dev gettext tcl-dev libperl-dev pkg-config clang-14 \
|
|
||||||
llvm-14 llvm-14-dev libselinux1-dev python3-dev \
|
|
||||||
uuid-dev liblz4-dev
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- 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=${prefix}/include' '--mandir=${prefix}/share/man' \
|
|
||||||
'--infodir=${prefix}/share/info' '--sysconfdir=/etc' \
|
|
||||||
'--localstatedir=/var' '--libdir=${prefix}/lib/x86_64-linux-gnu' \
|
|
||||||
'--libexecdir=${prefix}/lib/x86_64-linux-gnu' '--with-icu' \
|
|
||||||
'--with-tcl' '--with-perl' '--with-python' '--with-pam' \
|
|
||||||
'--with-openssl' '--with-libxml' '--with-libxslt' '--with-ldap' \
|
|
||||||
'PYTHON=/usr/bin/python3' '--mandir=/usr/share/postgresql/18/man' \
|
|
||||||
'--docdir=/usr/share/doc/postgresql-doc-18' '--with-pgport=5432' \
|
|
||||||
'--sysconfdir=/etc/postgresql-common' '--datarootdir=/usr/share' \
|
|
||||||
'--datadir=/usr/share/postgresql/18' '--with-uuid=e2fs' \
|
|
||||||
'--bindir=/usr/lib/postgresql/18/bin' '--enable-tap-tests' \
|
|
||||||
'--libdir=/usr/lib/x86_64-linux-gnu' '--enable-debug' \
|
|
||||||
'--libexecdir=/usr/lib/postgresql' '--with-gnu-ld' \
|
|
||||||
'--includedir=/usr/include/postgresql' '--enable-dtrace' \
|
|
||||||
'--enable-nls' '--enable-thread-safety' '--disable-rpath' \
|
|
||||||
'--with-system-tzdata=/usr/share/zoneinfo' '--with-llvm' \
|
|
||||||
'LLVM_CONFIG=/usr/bin/llvm-config-14' 'CLANG=/usr/bin/clang-14' \
|
|
||||||
'--with-systemd' '--with-selinux' 'MKDIR_P=/bin/mkdir -p' \
|
|
||||||
'PROVE=/usr/bin/prove' 'TAR=/bin/tar' 'XSLTPROC=xsltproc --nonet' \
|
|
||||||
'LDFLAGS=-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' \
|
|
||||||
'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'
|
|
||||||
make world
|
|
||||||
sudo make install-world
|
|
||||||
|
|
||||||
- name: Start postgresql cluster
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/18/bin:$PATH"
|
|
||||||
sudo cp /usr/lib/postgresql/18/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
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
make USE_PGXS=1
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Configure and Restart Server
|
|
||||||
run: |
|
|
||||||
export PATH="/usr/lib/postgresql/18/bin:$PATH"
|
|
||||||
pg_ctl -D /opt/pgsql/data -l logfile stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" >> \
|
|
||||||
/opt/pgsql/data/postgresql.conf
|
|
||||||
echo "compute_query_id = regress" >> /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: |
|
|
||||||
make installcheck
|
|
||||||
working-directory: src/pg_stat_monitor/
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
|
|
||||||
- name: Start Server installcheck-world tests
|
|
||||||
run: make installcheck-world
|
|
||||||
|
|
||||||
- name: Report on installcheck-world test suites fail
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
if: ${{ failure() }}
|
|
||||||
with:
|
|
||||||
name: Regressions output files of failed testsuite, and pg log
|
|
||||||
path: |
|
|
||||||
**/regression.diffs
|
|
||||||
**/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
retention-days: 3
|
|
||||||
97
.github/workflows/postgresql-18-pgdg-package.yml
vendored
97
.github/workflows/postgresql-18-pgdg-package.yml
vendored
@@ -1,97 +0,0 @@
|
|||||||
name: postgresql-18-pgdg-package
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
tags:
|
|
||||||
- '[0-9]+.[0-9]+.[0-9]+*'
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
name: pg-18-pgdg-package-test
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- name: Clone pg_stat_monitor repository
|
|
||||||
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
||||||
with:
|
|
||||||
path: 'src/pg_stat_monitor'
|
|
||||||
|
|
||||||
- name: Delete old postgresql files
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt purge postgresql-client-common postgresql-common \
|
|
||||||
postgresql postgresql*
|
|
||||||
sudo apt-get install -y libreadline6-dev systemtap-sdt-dev wget \
|
|
||||||
zlib1g-dev libssl-dev libpam0g-dev bison flex libipc-run-perl
|
|
||||||
sudo rm -rf /var/lib/postgresql /var/log/postgresql /etc/postgresql \
|
|
||||||
/usr/lib/postgresql /usr/include/postgresql /usr/share/postgresql \
|
|
||||||
/etc/postgresql
|
|
||||||
sudo rm -f /usr/bin/pg_config
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install IPC::Run'
|
|
||||||
sudo /usr/bin/perl -MCPAN -e 'install Text::Trim'
|
|
||||||
|
|
||||||
- name: Install PG Distribution Postgresql 18
|
|
||||||
run: |
|
|
||||||
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt \
|
|
||||||
$(lsb_release -cs)-pgdg main 18" > /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 -y install postgresql-18 postgresql-server-dev-18
|
|
||||||
|
|
||||||
- name: Change src owner to postgres
|
|
||||||
run: |
|
|
||||||
sudo chmod o+rx ~
|
|
||||||
sudo chown -R postgres:postgres src
|
|
||||||
|
|
||||||
- name: Build pg_stat_monitor
|
|
||||||
run: |
|
|
||||||
sudo -u postgres bash -c 'make USE_PGXS=1'
|
|
||||||
sudo make USE_PGXS=1 install
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Start pg_stat_monitor_tests
|
|
||||||
run: |
|
|
||||||
sudo service postgresql stop
|
|
||||||
echo "shared_preload_libraries = 'pg_stat_monitor'" |
|
|
||||||
sudo tee -a /etc/postgresql/18/main/postgresql.conf
|
|
||||||
sudo service postgresql start
|
|
||||||
sudo psql -V
|
|
||||||
export PG_TEST_PORT_DIR=${GITHUB_WORKSPACE}/src/pg_stat_monitor
|
|
||||||
echo $PG_TEST_PORT_DIR
|
|
||||||
sudo -E -u postgres bash -c 'make installcheck USE_PGXS=1'
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Change dir permissions on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
run: |
|
|
||||||
sudo chmod -R ugo+rwx t
|
|
||||||
sudo chmod -R ugo+rwx tmp_check
|
|
||||||
exit 2 # regenerate error so that we can upload files in next step
|
|
||||||
working-directory: src/pg_stat_monitor
|
|
||||||
|
|
||||||
- name: Upload logs on fail
|
|
||||||
if: ${{ failure() }}
|
|
||||||
uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
||||||
with:
|
|
||||||
name: Regressions diff and postgresql log
|
|
||||||
path: |
|
|
||||||
src/pg_stat_monitor/regression.diffs
|
|
||||||
src/pg_stat_monitor/regression.out
|
|
||||||
src/pg_stat_monitor/logfile
|
|
||||||
src/pg_stat_monitor/t/results/
|
|
||||||
src/pg_stat_monitor/tmp_check/log/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/*
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/archives/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/backup/
|
|
||||||
!src/pg_stat_monitor/tmp_check/**/pgdata/
|
|
||||||
if-no-files-found: warn
|
|
||||||
retention-days: 3
|
|
||||||
Reference in New Issue
Block a user