2016-01-13 07:57:51 +02:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
#============================================================================
|
|
|
|
# This is a test script for delete command of pg_arman.
|
|
|
|
#============================================================================
|
|
|
|
|
|
|
|
# Load common rules
|
|
|
|
. sql/common.sh delete
|
|
|
|
|
|
|
|
init_backup
|
|
|
|
echo '###### DELETE COMMAND TEST-0001 ######'
|
|
|
|
echo '###### delete full backups ######'
|
2016-01-14 08:19:38 +02:00
|
|
|
pg_arman backup -B ${BACKUP_PATH} -b full -p ${TEST_PGPORT} -d postgres --quiet
|
2016-03-28 16:22:24 +02:00
|
|
|
FIRST_BACKUP_DATE=$(get_time_last_backup)
|
2016-01-13 07:57:51 +02:00
|
|
|
pgbench -p ${TEST_PGPORT} >> ${TEST_BASE}/pgbench.log 2>&1
|
2016-01-14 08:19:38 +02:00
|
|
|
pg_arman backup -B ${BACKUP_PATH} -b full -p ${TEST_PGPORT} -d postgres --quiet
|
2016-03-28 16:22:24 +02:00
|
|
|
SECOND_BACKUP_DATE=$(get_time_last_backup)
|
2016-01-13 07:57:51 +02:00
|
|
|
pgbench -p ${TEST_PGPORT} >> ${TEST_BASE}/pgbench.log 2>&1
|
2016-01-14 08:19:38 +02:00
|
|
|
pg_arman backup -B ${BACKUP_PATH} -b full -p ${TEST_PGPORT} -d postgres --quiet
|
2016-03-28 16:22:24 +02:00
|
|
|
THIRD_BACKUP_DATE=$(get_time_last_backup)
|
2016-01-13 07:57:51 +02:00
|
|
|
pg_arman validate -B ${BACKUP_PATH} --quiet
|
|
|
|
|
|
|
|
echo "try to delete the oldest backup"
|
|
|
|
pg_arman -B ${BACKUP_PATH} delete ${SECOND_BACKUP_DATE} > /dev/null 2>&1
|
|
|
|
pg_arman show -B ${BACKUP_PATH} > ${TEST_BASE}/TEST-0001.out.1 2>&1
|
|
|
|
pg_arman show -a -B ${BACKUP_PATH} > ${TEST_BASE}/TEST-0001.out.2 2>&1
|
|
|
|
grep -c OK ${TEST_BASE}/TEST-0001.out.1
|
|
|
|
grep -c DELETED ${TEST_BASE}/TEST-0001.out.2
|
|
|
|
NUM_OF_DELETED_BACKUPS=`grep DELETED ${TEST_BASE}/TEST-0001.out.2 | wc -l | sed 's/^ *//'`
|
|
|
|
echo "Number of deleted backups should be 1, is it so?: ${NUM_OF_DELETED_BACKUPS}"
|
|
|
|
|
|
|
|
init_backup
|
|
|
|
echo '###### DELETE COMMAND TEST-0002 ######'
|
|
|
|
echo '###### keep backups which are necessary for recovery ######'
|
2016-01-14 08:19:38 +02:00
|
|
|
pg_arman backup -B ${BACKUP_PATH} -b full -p ${TEST_PGPORT} -d postgres --quiet
|
2016-03-28 16:22:24 +02:00
|
|
|
FIRST_BACKUP_DATE=$(get_time_last_backup)
|
2016-01-13 07:57:51 +02:00
|
|
|
pgbench -p ${TEST_PGPORT} >> ${TEST_BASE}/pgbench.log 2>&1
|
2016-01-14 08:19:38 +02:00
|
|
|
pg_arman backup -B ${BACKUP_PATH} -b full -p ${TEST_PGPORT} -d postgres --quiet
|
2016-03-28 16:22:24 +02:00
|
|
|
SECOND_BACKUP_DATE=$(get_time_last_backup)
|
2016-01-13 07:57:51 +02:00
|
|
|
pg_arman validate -B ${BACKUP_PATH} --quiet
|
|
|
|
pgbench -p ${TEST_PGPORT} >> ${TEST_BASE}/pgbench.log 2>&1
|
2016-01-14 08:19:38 +02:00
|
|
|
pg_arman backup -B ${BACKUP_PATH} -b page -p ${TEST_PGPORT} -d postgres --quiet
|
2016-03-28 16:22:24 +02:00
|
|
|
THIRD_BACKUP_DATE=$(get_time_last_backup)
|
2016-01-13 07:57:51 +02:00
|
|
|
pg_arman validate -B ${BACKUP_PATH} --quiet
|
2016-01-14 08:19:38 +02:00
|
|
|
pg_arman backup -B ${BACKUP_PATH} -b full -p ${TEST_PGPORT} -d postgres --quiet
|
2016-03-28 16:22:24 +02:00
|
|
|
FOURTH_BACKUP_DATE=$(get_time_last_backup)
|
2016-01-13 07:57:51 +02:00
|
|
|
pg_arman validate -B ${BACKUP_PATH} --quiet
|
|
|
|
|
|
|
|
echo "try to delete before third backup"
|
|
|
|
pg_arman delete -B ${BACKUP_PATH} ${THIRD_BACKUP_DATE} > /dev/null 2>&1
|
|
|
|
pg_arman show -B ${BACKUP_PATH} > ${TEST_BASE}/TEST-0002.out.1 2>&1
|
|
|
|
pg_arman show -a -B ${BACKUP_PATH} > ${TEST_BASE}/TEST-0002.out.2 2>&1
|
|
|
|
grep -c OK ${TEST_BASE}/TEST-0002.out.1
|
|
|
|
grep -c DELETED ${TEST_BASE}/TEST-0002.out.2
|
|
|
|
NUM_OF_DELETED_BACKUPS=`grep DELETED ${TEST_BASE}/TEST-0002.out.2 | wc -l | sed 's/^ *//'`
|
|
|
|
echo "Number of deleted backups should be 1, is it so?: ${NUM_OF_DELETED_BACKUPS}"
|
|
|
|
|
|
|
|
init_backup
|
|
|
|
# clean up the temporal test data
|
|
|
|
pg_ctl stop -m immediate > /dev/null 2>&1
|
|
|
|
rm -fr ${PGDATA_PATH}
|
|
|
|
rm -fr ${BACKUP_PATH}
|
|
|
|
rm -fr ${ARCLOG_PATH}
|
|
|
|
rm -fr ${SRVLOG_PATH}
|
|
|
|
rm -fr ${TBLSPC_PATH}
|