2016-12-09 21:30:22 +03:00
|
|
|
import os
|
2017-06-27 12:43:45 +03:00
|
|
|
import unittest
|
2017-06-27 08:42:52 +03:00
|
|
|
from .helpers.ptrack_helpers import ProbackupTest
|
2016-12-09 21:30:22 +03:00
|
|
|
|
|
|
|
|
2017-07-12 17:28:28 +03:00
|
|
|
module_name = 'show'
|
|
|
|
|
2016-12-09 21:30:22 +03:00
|
|
|
|
2017-07-12 17:28:28 +03:00
|
|
|
class OptionTest(ProbackupTest, unittest.TestCase):
|
2017-05-03 14:14:48 +03:00
|
|
|
|
2017-05-22 14:17:43 +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')
|
|
|
|
node = self.make_simple_node(base_dir="{0}/{1}/node".format(module_name, fname),
|
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)
|
2017-05-03 14:14:48 +03:00
|
|
|
node.start()
|
|
|
|
|
|
|
|
self.assertEqual(
|
2017-12-13 11:15:42 +03:00
|
|
|
self.backup_node(backup_dir, 'node', node, options=["--log-level-console=panic"]),
|
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
|
|
|
|
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')
|
|
|
|
node = self.make_simple_node(base_dir="{0}/{1}/node".format(module_name, fname),
|
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)
|
2017-05-03 14:14:48 +03:00
|
|
|
node.start()
|
|
|
|
|
2017-06-20 13:57:23 +03:00
|
|
|
backup_id = self.backup_node(backup_dir, 'node', node)
|
|
|
|
|
|
|
|
# delete file which belong to backup
|
2017-06-27 12:43:45 +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
|
|
|
|
2017-06-20 13:57:23 +03:00
|
|
|
self.validate_pb(backup_dir, 'node', backup_id)
|
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)
|