| |
@@ -0,0 +1,74 @@
|
| |
+ #!/bin/bash
|
| |
+ # vim: dict+=/usr/share/beakerlib/dictionary.vim cpt=.,w,b,u,t,i,k
|
| |
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| |
+ #
|
| |
+ # runtest.sh of /CoreOS/postgresql/Sanity/pgaudit
|
| |
+ # Description: Sanity test for pgaudit extension
|
| |
+ # Author: Honza Horak <hhorak@redhat.com>
|
| |
+ #
|
| |
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| |
+ #
|
| |
+ # Copyright (c) 2015 Red Hat, Inc.
|
| |
+ #
|
| |
+ # This program is free software: you can redistribute it and/or
|
| |
+ # modify it under the terms of the GNU General Public License as
|
| |
+ # published by the Free Software Foundation, either version 2 of
|
| |
+ # the License, or (at your option) any later version.
|
| |
+ #
|
| |
+ # This program is distributed in the hope that it will be
|
| |
+ # useful, but WITHOUT ANY WARRANTY; without even the implied
|
| |
+ # warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
| |
+ # PURPOSE. See the GNU General Public License for more details.
|
| |
+ #
|
| |
+ # You should have received a copy of the GNU General Public License
|
| |
+ # along with this program. If not, see http://www.gnu.org/licenses/.
|
| |
+ #
|
| |
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| |
+
|
| |
+ # Include Beaker environment
|
| |
+ . /usr/share/beakerlib/beakerlib.sh || exit 1
|
| |
+
|
| |
+ PACKAGE="postgresql"
|
| |
+ PACKAGE_AUDIT="pgaudit"
|
| |
+
|
| |
+ rlJournalStart
|
| |
+ rlPhaseStart FAIL "Setup"
|
| |
+ rlRun "rlImport database/postgresql"
|
| |
+ PGDATA="$(postgresqlGetDataDir)";
|
| |
+ PACKAGES="$PACKAGES ${postgresqlPackagePrefix}${PACKAGE_AUDIT} \
|
| |
+ ${postgresqlPackagePrefix}${PACKAGE} \
|
| |
+ ${postgresqlPackagePrefix}${PACKAGE}-server";
|
| |
+ for PACKAGE in $PACKAGES; do
|
| |
+ rlAssertRpm $PACKAGE
|
| |
+ done
|
| |
+ rlRun "postgresqlStop";
|
| |
+ [[ -d ${postgresqlDataDir} ]] && rlFileBackup "${postgresqlDataDir}"
|
| |
+ rlRun "postgresqlCleanup"
|
| |
+ rlRun "postgresqlStart"
|
| |
+ rlRun "sed -i -e \"s/#shared_preload_libraries = ''/shared_preload_libraries = 'pgaudit'/\" ${PGDATA}/postgresql.conf" 0 "Adding pgaudit to the shared_preload_libraries in the config file ..."
|
| |
+ rlRun "postgresqlStop";
|
| |
+ rlRun "postgresqlStart"
|
| |
+ rlPhaseEnd
|
| |
+
|
| |
+ rlPhaseStartTest
|
| |
+ rlRun "postgresqlQuery \"DROP EXTENSION IF EXISTS pgaudit;\"";
|
| |
+ rlRun "postgresqlQuery \"CREATE EXTENSION pgaudit;\"" 0;
|
| |
+ rlRun "postgresqlQuery \"SET pgaudit.log = 'read, ddl';
|
| |
+ DROP TABLE IF EXISTS account;
|
| |
+ CREATE TABLE account (id int, name text, password text, description text);
|
| |
+ INSERT INTO account (id, name, password, description) VALUES (1, 'user1', 'HASH1', 'blah, blah');\"" 0;
|
| |
+ rlRun "postgresqlQuery \"SELECT * FROM account;\"" 0;
|
| |
+ rlAssertGrep 'AUDIT: SESSION,.*,.*,DDL,DROP TABLE,,,DROP TABLE IF EXISTS account' ${postgresqlLogDir}/postgresql*.log -E
|
| |
+ rlAssertGrep 'AUDIT: SESSION,.*,.*,DDL,CREATE TABLE,TABLE,public.account,"CREATE TABLE account' ${postgresqlLogDir}/postgresql*.log -E
|
| |
+ cat ${postgresqlLogDir}/postgresql*.log
|
| |
+ rlRun "postgresqlQuery \"DROP TABLE IF EXISTS account;\"" 0;
|
| |
+ rlRun "postgresqlQuery \"DROP EXTENSION IF EXISTS pgaudit;\"";
|
| |
+ rlPhaseEnd
|
| |
+
|
| |
+ rlPhaseStart WARN "Cleanup";
|
| |
+ rm -f $rlRun_LOG;
|
| |
+ rlRun "postgresqlCleanup";
|
| |
+ rlFileRestore;
|
| |
+ rlPhaseEnd
|
| |
+ rlJournalPrintText
|
| |
+ rlJournalEnd
|
| |
Obsoletes #4 that cannot be merged any more because the target branch was removed.