1
0
mirror of https://github.com/postgrespro/pg_probackup.git synced 2025-01-22 11:44:34 +02:00
pg_probackup/tests/show_test.py

204 lines
6.9 KiB
Python
Raw Normal View History

import os
2017-06-27 12:43:45 +03:00
import unittest
2018-01-28 04:36:27 +03:00
from .helpers.ptrack_helpers import ProbackupTest, ProbackupException
2017-07-12 17:28:28 +03:00
module_name = 'show'
2017-07-12 17:28:28 +03:00
class OptionTest(ProbackupTest, unittest.TestCase):
2017-05-03 14:14:48 +03:00
# @unittest.skip("skip")
# @unittest.expectedFailure
2017-06-20 13:57:23 +03:00
def test_show_1(self):
2017-05-03 14:14:48 +03:00
"""Status DONE and OK"""
fname = self.id().split('.')[3]
2017-07-12 17:28:28 +03:00
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
2018-01-28 04:36:27 +03:00
node = self.make_simple_node(
base_dir=os.path.join(module_name, fname, 'node'),
2017-05-03 14:14:48 +03:00
initdb_params=['--data-checksums'],
pg_options={'wal_level': 'replica'})
2017-06-20 13:57:23 +03:00
self.init_pb(backup_dir)
self.add_instance(backup_dir, 'node', node)
self.set_archiving(backup_dir, 'node', node)
2018-12-25 17:48:49 +03:00
node.slow_start()
2017-05-03 14:14:48 +03:00
self.assertEqual(
2018-01-28 04:36:27 +03:00
self.backup_node(
backup_dir, 'node', node,
2018-09-06 20:46:32 +03:00
options=["--log-level-console=off"]),
2017-05-03 14:14:48 +03:00
None
)
2017-06-27 08:42:52 +03:00
self.assertIn("OK", self.show_pb(backup_dir, 'node', as_text=True))
# Clean after yourself
2017-07-12 17:28:28 +03:00
self.del_test_dir(module_name, fname)
2017-05-03 14:14:48 +03:00
2018-06-02 20:35:37 +03:00
# @unittest.skip("skip")
# @unittest.expectedFailure
def test_show_json(self):
"""Status DONE and OK"""
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'),
2018-06-02 20:35:37 +03:00
initdb_params=['--data-checksums'],
pg_options={'wal_level': 'replica'})
2018-06-02 20:35:37 +03:00
self.init_pb(backup_dir)
self.add_instance(backup_dir, 'node', node)
self.set_archiving(backup_dir, 'node', node)
2018-12-25 17:48:49 +03:00
node.slow_start()
2018-06-02 20:35:37 +03:00
self.assertEqual(
self.backup_node(
backup_dir, 'node', node,
2018-09-06 20:46:32 +03:00
options=["--log-level-console=off"]),
2018-06-02 20:35:37 +03:00
None
)
self.backup_node(backup_dir, 'node', node)
self.assertIn("OK", self.show_pb(backup_dir, 'node', as_text=True))
# Clean after yourself
self.del_test_dir(module_name, fname)
2017-06-20 13:57:23 +03:00
# @unittest.skip("skip")
2017-05-03 14:14:48 +03:00
def test_corrupt_2(self):
"""Status CORRUPT"""
fname = self.id().split('.')[3]
2017-07-12 17:28:28 +03:00
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
2018-01-28 04:36:27 +03:00
node = self.make_simple_node(
base_dir=os.path.join(module_name, fname, 'node'),
2017-05-03 14:14:48 +03:00
initdb_params=['--data-checksums'],
pg_options={'wal_level': 'replica'})
2017-06-20 13:57:23 +03:00
self.init_pb(backup_dir)
self.add_instance(backup_dir, 'node', node)
self.set_archiving(backup_dir, 'node', node)
2018-12-25 17:48:49 +03:00
node.slow_start()
2017-05-03 14:14:48 +03:00
2017-06-20 13:57:23 +03:00
backup_id = self.backup_node(backup_dir, 'node', node)
# delete file which belong to backup
2018-01-28 04:36:27 +03:00
file = os.path.join(
backup_dir, "backups", "node",
backup_id, "database", "postgresql.conf")
2017-06-20 13:57:23 +03:00
os.remove(file)
2017-05-03 14:14:48 +03:00
2018-01-28 04:36:27 +03:00
try:
self.validate_pb(backup_dir, 'node', backup_id)
# we should die here because exception is what we expect to happen
self.assertEqual(
1, 0,
"Expecting Error because backup corrupted.\n"
" Output: {0} \n CMD: {1}".format(
repr(self.output), self.cmd
)
)
except ProbackupException as e:
self.assertIn(
'data files are corrupted\n',
e.message,
'\n Unexpected Error Message: {0}\n'
' CMD: {1}'.format(repr(e.message), self.cmd)
)
2017-06-27 08:42:52 +03:00
self.assertIn("CORRUPT", self.show_pb(backup_dir, as_text=True))
# Clean after yourself
2017-07-12 17:28:28 +03:00
self.del_test_dir(module_name, fname)
# @unittest.skip("skip")
def test_no_control_file(self):
"""backup.control doesn't exist"""
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'),
initdb_params=['--data-checksums'],
pg_options={'wal_level': 'replica'})
self.init_pb(backup_dir)
self.add_instance(backup_dir, 'node', node)
self.set_archiving(backup_dir, 'node', node)
2018-12-25 17:48:49 +03:00
node.slow_start()
backup_id = self.backup_node(backup_dir, 'node', node)
# delete backup.control file
file = os.path.join(
backup_dir, "backups", "node",
backup_id, "backup.control")
os.remove(file)
self.assertIn(
'Control file "{0}" doesn\'t exist'.format(file),
self.show_pb(backup_dir, 'node', as_text=True, as_json=False))
# Clean after yourself
self.del_test_dir(module_name, fname)
# @unittest.skip("skip")
def test_empty_control_file(self):
"""backup.control is empty"""
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'),
initdb_params=['--data-checksums'],
pg_options={'wal_level': 'replica'})
self.init_pb(backup_dir)
self.add_instance(backup_dir, 'node', node)
self.set_archiving(backup_dir, 'node', node)
2018-12-25 17:48:49 +03:00
node.slow_start()
backup_id = self.backup_node(backup_dir, 'node', node)
# truncate backup.control file
file = os.path.join(
backup_dir, "backups", "node",
backup_id, "backup.control")
fd = open(file, 'w')
fd.close()
self.assertIn(
'Control file "{0}" is empty'.format(file),
self.show_pb(backup_dir, 'node', as_text=True, as_json=False))
# Clean after yourself
self.del_test_dir(module_name, fname)
# @unittest.skip("skip")
# @unittest.expectedFailure
def test_corrupt_control_file(self):
"""backup.control contains invalid option"""
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'),
initdb_params=['--data-checksums'],
pg_options={'wal_level': 'replica'})
self.init_pb(backup_dir)
self.add_instance(backup_dir, 'node', node)
self.set_archiving(backup_dir, 'node', node)
2018-12-25 17:48:49 +03:00
node.slow_start()
backup_id = self.backup_node(backup_dir, 'node', node)
# corrupt backup.control file
file = os.path.join(
backup_dir, "backups", "node",
backup_id, "backup.control")
fd = open(file, 'a')
fd.write("statuss = OK")
fd.close()
2018-11-28 21:19:10 +03:00
self.assertIn(
'WARNING: Invalid option "statuss" in file'.format(file),
self.show_pb(backup_dir, 'node', as_json=False, as_text=True))
# Clean after yourself
self.del_test_dir(module_name, fname)