mirror of
https://github.com/postgrespro/pg_probackup.git
synced 2025-01-22 11:44:34 +02:00
d3bbb74d01
With autovacuum enabled tests are unstable. Especially they are unstable if postgresql is running under valgrind and therefore is severely inhibited (and vacuum has time to be triggered).
285 lines
9.5 KiB
Python
285 lines
9.5 KiB
Python
import os
|
|
import unittest
|
|
from .helpers.ptrack_helpers import ProbackupTest, ProbackupException
|
|
|
|
|
|
module_name = 'exclude'
|
|
|
|
|
|
class ExcludeTest(ProbackupTest, unittest.TestCase):
|
|
|
|
# @unittest.skip("skip")
|
|
def test_exclude_temp_files(self):
|
|
"""
|
|
"""
|
|
fname = self.id().split('.')[3]
|
|
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
|
|
node = self.make_simple_node(
|
|
base_dir=os.path.join(module_name, fname, 'node'),
|
|
set_replication=True,
|
|
initdb_params=['--data-checksums'],
|
|
pg_options={
|
|
'logging_collector': 'on',
|
|
'log_filename': 'postgresql.log'})
|
|
|
|
self.init_pb(backup_dir)
|
|
self.add_instance(backup_dir, 'node', node)
|
|
node.slow_start()
|
|
|
|
oid = node.safe_psql(
|
|
'postgres',
|
|
"select oid from pg_database where datname = 'postgres'").rstrip()
|
|
|
|
pgsql_tmp_dir = os.path.join(node.data_dir, 'base', 'pgsql_tmp')
|
|
|
|
os.mkdir(pgsql_tmp_dir)
|
|
|
|
file = os.path.join(pgsql_tmp_dir, 'pgsql_tmp7351.16')
|
|
with open(file, 'w') as f:
|
|
f.write("HELLO")
|
|
f.flush()
|
|
f.close
|
|
|
|
full_id = self.backup_node(
|
|
backup_dir, 'node', node, backup_type='full', options=['--stream'])
|
|
|
|
file = os.path.join(
|
|
backup_dir, 'backups', 'node', full_id,
|
|
'database', 'base', 'pgsql_tmp', 'pgsql_tmp7351.16')
|
|
|
|
self.assertFalse(
|
|
os.path.exists(file),
|
|
"File must be excluded: {0}".format(file))
|
|
|
|
# TODO check temporary tablespaces
|
|
|
|
# Clean after yourself
|
|
self.del_test_dir(module_name, fname)
|
|
|
|
# @unittest.skip("skip")
|
|
# @unittest.expectedFailure
|
|
def test_exclude_temp_tables(self):
|
|
"""
|
|
make node without archiving, create temp table, take full backup,
|
|
check that temp table not present in backup catalogue
|
|
"""
|
|
fname = self.id().split('.')[3]
|
|
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
|
|
node = self.make_simple_node(
|
|
base_dir=os.path.join(module_name, fname, 'node'),
|
|
set_replication=True,
|
|
initdb_params=['--data-checksums'])
|
|
|
|
self.init_pb(backup_dir)
|
|
self.add_instance(backup_dir, 'node', node)
|
|
node.slow_start()
|
|
|
|
with node.connect("postgres") as conn:
|
|
|
|
conn.execute(
|
|
"create temp table test as "
|
|
"select generate_series(0,50050000)::text")
|
|
conn.commit()
|
|
|
|
temp_schema_name = conn.execute(
|
|
"SELECT nspname FROM pg_namespace "
|
|
"WHERE oid = pg_my_temp_schema()")[0][0]
|
|
conn.commit()
|
|
|
|
temp_toast_schema_name = "pg_toast_" + temp_schema_name.replace(
|
|
"pg_", "")
|
|
conn.commit()
|
|
|
|
conn.execute("create index test_idx on test (generate_series)")
|
|
conn.commit()
|
|
|
|
heap_path = conn.execute(
|
|
"select pg_relation_filepath('test')")[0][0]
|
|
conn.commit()
|
|
|
|
index_path = conn.execute(
|
|
"select pg_relation_filepath('test_idx')")[0][0]
|
|
conn.commit()
|
|
|
|
heap_oid = conn.execute("select 'test'::regclass::oid")[0][0]
|
|
conn.commit()
|
|
|
|
toast_path = conn.execute(
|
|
"select pg_relation_filepath('{0}.{1}')".format(
|
|
temp_toast_schema_name, "pg_toast_" + str(heap_oid)))[0][0]
|
|
conn.commit()
|
|
|
|
toast_idx_path = conn.execute(
|
|
"select pg_relation_filepath('{0}.{1}')".format(
|
|
temp_toast_schema_name,
|
|
"pg_toast_" + str(heap_oid) + "_index"))[0][0]
|
|
conn.commit()
|
|
|
|
temp_table_filename = os.path.basename(heap_path)
|
|
temp_idx_filename = os.path.basename(index_path)
|
|
temp_toast_filename = os.path.basename(toast_path)
|
|
temp_idx_toast_filename = os.path.basename(toast_idx_path)
|
|
|
|
self.backup_node(
|
|
backup_dir, 'node', node, backup_type='full', options=['--stream'])
|
|
|
|
for root, dirs, files in os.walk(backup_dir):
|
|
for file in files:
|
|
if file in [
|
|
temp_table_filename, temp_table_filename + ".1",
|
|
temp_idx_filename,
|
|
temp_idx_filename + ".1",
|
|
temp_toast_filename,
|
|
temp_toast_filename + ".1",
|
|
temp_idx_toast_filename,
|
|
temp_idx_toast_filename + ".1"
|
|
]:
|
|
self.assertEqual(
|
|
1, 0,
|
|
"Found temp table file in backup catalogue.\n "
|
|
"Filepath: {0}".format(file))
|
|
|
|
# Clean after yourself
|
|
self.del_test_dir(module_name, fname)
|
|
|
|
# @unittest.skip("skip")
|
|
def test_exclude_unlogged_tables_1(self):
|
|
"""
|
|
make node without archiving, create unlogged table, take full backup,
|
|
alter table to unlogged, take delta backup, restore delta backup,
|
|
check that PGDATA`s are physically the same
|
|
"""
|
|
fname = self.id().split('.')[3]
|
|
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
|
|
node = self.make_simple_node(
|
|
base_dir=os.path.join(module_name, fname, 'node'),
|
|
set_replication=True,
|
|
initdb_params=['--data-checksums'],
|
|
pg_options={
|
|
"shared_buffers": "10MB"})
|
|
|
|
self.init_pb(backup_dir)
|
|
self.add_instance(backup_dir, 'node', node)
|
|
node.slow_start()
|
|
|
|
conn = node.connect()
|
|
with node.connect("postgres") as conn:
|
|
|
|
conn.execute(
|
|
"create unlogged table test as "
|
|
"select generate_series(0,5005000)::text")
|
|
conn.commit()
|
|
|
|
conn.execute("create index test_idx on test (generate_series)")
|
|
conn.commit()
|
|
|
|
self.backup_node(
|
|
backup_dir, 'node', node,
|
|
backup_type='full', options=['--stream'])
|
|
|
|
node.safe_psql('postgres', "alter table test set logged")
|
|
|
|
self.backup_node(
|
|
backup_dir, 'node', node, backup_type='delta',
|
|
options=['--stream']
|
|
)
|
|
|
|
pgdata = self.pgdata_content(node.data_dir)
|
|
|
|
node_restored = self.make_simple_node(
|
|
base_dir=os.path.join(module_name, fname, 'node_restored'))
|
|
|
|
node_restored.cleanup()
|
|
|
|
self.restore_node(
|
|
backup_dir, 'node', node_restored, options=["-j", "4"])
|
|
|
|
# Physical comparison
|
|
pgdata_restored = self.pgdata_content(node_restored.data_dir)
|
|
self.compare_pgdata(pgdata, pgdata_restored)
|
|
|
|
# Clean after yourself
|
|
self.del_test_dir(module_name, fname)
|
|
|
|
# @unittest.skip("skip")
|
|
def test_exclude_log_dir(self):
|
|
"""
|
|
check that by default 'log' and 'pg_log' directories are not backed up
|
|
"""
|
|
fname = self.id().split('.')[3]
|
|
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
|
|
node = self.make_simple_node(
|
|
base_dir=os.path.join(module_name, fname, 'node'),
|
|
set_replication=True,
|
|
initdb_params=['--data-checksums'],
|
|
pg_options={
|
|
'logging_collector': 'on',
|
|
'log_filename': 'postgresql.log'})
|
|
|
|
self.init_pb(backup_dir)
|
|
self.add_instance(backup_dir, 'node', node)
|
|
node.slow_start()
|
|
|
|
self.backup_node(
|
|
backup_dir, 'node', node,
|
|
backup_type='full', options=['--stream'])
|
|
|
|
log_dir = node.safe_psql(
|
|
'postgres',
|
|
'show log_directory').decode('utf-8').rstrip()
|
|
|
|
node.cleanup()
|
|
|
|
self.restore_node(
|
|
backup_dir, 'node', node, options=["-j", "4"])
|
|
|
|
# check that PGDATA/log or PGDATA/pg_log do not exists
|
|
path = os.path.join(node.data_dir, log_dir)
|
|
log_file = os.path.join(path, 'postgresql.log')
|
|
self.assertTrue(os.path.exists(path))
|
|
self.assertFalse(os.path.exists(log_file))
|
|
|
|
# Clean after yourself
|
|
self.del_test_dir(module_name, fname)
|
|
|
|
# @unittest.skip("skip")
|
|
def test_exclude_log_dir_1(self):
|
|
"""
|
|
check that "--backup-pg-log" works correctly
|
|
"""
|
|
fname = self.id().split('.')[3]
|
|
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
|
|
node = self.make_simple_node(
|
|
base_dir=os.path.join(module_name, fname, 'node'),
|
|
set_replication=True,
|
|
initdb_params=['--data-checksums'],
|
|
pg_options={
|
|
'logging_collector': 'on',
|
|
'log_filename': 'postgresql.log'})
|
|
|
|
self.init_pb(backup_dir)
|
|
self.add_instance(backup_dir, 'node', node)
|
|
node.slow_start()
|
|
|
|
log_dir = node.safe_psql(
|
|
'postgres',
|
|
'show log_directory').decode('utf-8').rstrip()
|
|
|
|
self.backup_node(
|
|
backup_dir, 'node', node,
|
|
backup_type='full', options=['--stream', '--backup-pg-log'])
|
|
|
|
node.cleanup()
|
|
|
|
self.restore_node(
|
|
backup_dir, 'node', node, options=["-j", "4"])
|
|
|
|
# check that PGDATA/log or PGDATA/pg_log do not exists
|
|
path = os.path.join(node.data_dir, log_dir)
|
|
log_file = os.path.join(path, 'postgresql.log')
|
|
self.assertTrue(os.path.exists(path))
|
|
self.assertTrue(os.path.exists(log_file))
|
|
|
|
# Clean after yourself
|
|
self.del_test_dir(module_name, fname)
|