2018-07-18 14:19:39 +02:00
|
|
|
import os
|
|
|
|
import unittest
|
|
|
|
from .helpers.ptrack_helpers import ProbackupTest, ProbackupException
|
2020-12-02 22:39:26 +02:00
|
|
|
import subprocess
|
|
|
|
from time import sleep
|
2018-07-18 14:19:39 +02:00
|
|
|
|
|
|
|
|
|
|
|
module_name = 'time_stamp'
|
|
|
|
|
2020-12-09 09:50:49 +02:00
|
|
|
class TimeStamp(ProbackupTest, unittest.TestCase):
|
2018-07-18 14:19:39 +02:00
|
|
|
|
|
|
|
def test_start_time_format(self):
|
|
|
|
"""Test backup ID changing after start-time editing in backup.control.
|
|
|
|
We should convert local time in UTC format"""
|
|
|
|
# Create simple node
|
|
|
|
fname = self.id().split('.')[3]
|
2019-04-22 19:52:00 +02:00
|
|
|
node = self.make_simple_node(
|
|
|
|
base_dir="{0}/{1}/node".format(module_name, fname),
|
|
|
|
set_replication=True,
|
|
|
|
initdb_params=['--data-checksums'])
|
|
|
|
|
|
|
|
|
2018-07-18 14:19:39 +02:00
|
|
|
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
|
|
|
|
self.init_pb(backup_dir)
|
|
|
|
self.add_instance(backup_dir, 'node', node)
|
|
|
|
self.set_archiving(backup_dir, 'node', node)
|
|
|
|
node.start()
|
|
|
|
|
|
|
|
backup_id = self.backup_node(backup_dir, 'node', node, options=['--stream', '-j 2'])
|
|
|
|
show_backup = self.show_pb(backup_dir, 'node')
|
|
|
|
|
|
|
|
i = 0
|
|
|
|
while i < 2:
|
|
|
|
with open(os.path.join(backup_dir, "backups", "node", backup_id, "backup.control"), "r+") as f:
|
|
|
|
output = ""
|
|
|
|
for line in f:
|
|
|
|
if line.startswith('start-time') is True:
|
|
|
|
if i == 0:
|
|
|
|
output = output + str(line[:-5])+'+00\''+'\n'
|
|
|
|
else:
|
|
|
|
output = output + str(line[:-5]) + '\'' + '\n'
|
|
|
|
else:
|
|
|
|
output = output + str(line)
|
|
|
|
f.close()
|
|
|
|
|
|
|
|
with open(os.path.join(backup_dir, "backups", "node", backup_id, "backup.control"), "w") as fw:
|
|
|
|
fw.write(output)
|
|
|
|
fw.flush()
|
|
|
|
show_backup = show_backup + self.show_pb(backup_dir, 'node')
|
|
|
|
i += 1
|
|
|
|
|
2020-12-03 11:23:33 +02:00
|
|
|
print(show_backup[1]['id'])
|
|
|
|
print(show_backup[2]['id'])
|
|
|
|
|
2018-07-18 14:19:39 +02:00
|
|
|
self.assertTrue(show_backup[1]['id'] == show_backup[2]['id'], "ERROR: Localtime format using instead of UTC")
|
|
|
|
|
2020-12-03 11:23:33 +02:00
|
|
|
output = self.show_pb(backup_dir, as_json=False, as_text=True)
|
|
|
|
self.assertNotIn("backup ID in control file", output)
|
|
|
|
|
2018-07-18 14:19:39 +02:00
|
|
|
node.stop()
|
|
|
|
# Clean after yourself
|
|
|
|
self.del_test_dir(module_name, fname)
|
2019-08-28 12:10:09 +02:00
|
|
|
|
|
|
|
def test_server_date_style(self):
|
|
|
|
"""Issue #112"""
|
|
|
|
fname = self.id().split('.')[3]
|
|
|
|
node = self.make_simple_node(
|
|
|
|
base_dir="{0}/{1}/node".format(module_name, fname),
|
|
|
|
set_replication=True,
|
|
|
|
initdb_params=['--data-checksums'],
|
2019-11-01 14:23:31 +02:00
|
|
|
pg_options={"datestyle": "GERMAN, DMY"})
|
2019-08-28 12:10:09 +02:00
|
|
|
|
|
|
|
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
|
|
|
|
self.init_pb(backup_dir)
|
|
|
|
self.add_instance(backup_dir, 'node', node)
|
|
|
|
node.start()
|
|
|
|
|
|
|
|
self.backup_node(
|
|
|
|
backup_dir, 'node', node, options=['--stream', '-j 2'])
|
|
|
|
|
|
|
|
# Clean after yourself
|
|
|
|
self.del_test_dir(module_name, fname)
|
2020-12-02 22:39:26 +02:00
|
|
|
|
2020-12-09 09:50:49 +02:00
|
|
|
def test_handling_of_TZ_env_variable(self):
|
2021-01-22 14:56:14 +02:00
|
|
|
"""Issue #284"""
|
2020-12-09 09:50:49 +02:00
|
|
|
fname = self.id().split('.')[3]
|
|
|
|
node = self.make_simple_node(
|
|
|
|
base_dir="{0}/{1}/node".format(module_name, fname),
|
|
|
|
set_replication=True,
|
|
|
|
initdb_params=['--data-checksums'])
|
|
|
|
|
|
|
|
backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup')
|
|
|
|
self.init_pb(backup_dir)
|
|
|
|
self.add_instance(backup_dir, 'node', node)
|
|
|
|
node.start()
|
|
|
|
|
|
|
|
my_env = os.environ.copy()
|
|
|
|
my_env["TZ"] = "America/Detroit"
|
|
|
|
|
|
|
|
self.backup_node(
|
|
|
|
backup_dir, 'node', node, options=['--stream', '-j 2'], env=my_env)
|
|
|
|
|
2020-12-09 10:07:45 +02:00
|
|
|
output = self.show_pb(backup_dir, 'node', as_json=False, as_text=True, env=my_env)
|
|
|
|
|
|
|
|
self.assertNotIn("backup ID in control file", output)
|
2020-12-09 09:50:49 +02:00
|
|
|
|
|
|
|
# Clean after yourself
|
|
|
|
self.del_test_dir(module_name, fname)
|
|
|
|
|
2020-12-02 22:39:26 +02:00
|
|
|
@unittest.skip("skip")
|
|
|
|
# @unittest.expectedFailure
|
|
|
|
def test_dst_timezone_handling(self):
|
|
|
|
"""for manual testing"""
|
|
|
|
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={'autovacuum': 'off'})
|
|
|
|
|
|
|
|
self.init_pb(backup_dir)
|
|
|
|
self.add_instance(backup_dir, 'node', node)
|
|
|
|
self.set_archiving(backup_dir, 'node', node)
|
|
|
|
node.slow_start()
|
|
|
|
|
|
|
|
print(subprocess.Popen(
|
2020-12-03 11:23:33 +02:00
|
|
|
['sudo', 'timedatectl', 'set-timezone', 'America/Detroit'],
|
2020-12-02 22:39:26 +02:00
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate())
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-ntp', 'false'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-time', '2020-05-25 12:00:00'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
# FULL
|
|
|
|
output = self.backup_node(backup_dir, 'node', node, return_id=False)
|
|
|
|
self.assertNotIn("backup ID in control file", output)
|
|
|
|
|
|
|
|
# move to dst
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-time', '2020-10-25 12:00:00'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
# DELTA
|
|
|
|
output = self.backup_node(
|
|
|
|
backup_dir, 'node', node, backup_type='delta', return_id=False)
|
|
|
|
self.assertNotIn("backup ID in control file", output)
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-time', '2020-12-01 12:00:00'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
# DELTA
|
|
|
|
self.backup_node(backup_dir, 'node', node, backup_type='delta')
|
|
|
|
|
|
|
|
output = self.show_pb(backup_dir, as_json=False, as_text=True)
|
|
|
|
self.assertNotIn("backup ID in control file", output)
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-ntp', 'true'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
sleep(10)
|
|
|
|
|
|
|
|
self.backup_node(backup_dir, 'node', node, backup_type='delta')
|
|
|
|
|
|
|
|
output = self.show_pb(backup_dir, as_json=False, as_text=True)
|
|
|
|
self.assertNotIn("backup ID in control file", output)
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-timezone', 'US/Moscow'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
# Clean after yourself
|
|
|
|
self.del_test_dir(module_name, fname)
|
|
|
|
|
|
|
|
@unittest.skip("skip")
|
|
|
|
def test_dst_timezone_handling_backward_compatibilty(self):
|
|
|
|
"""for manual testing"""
|
|
|
|
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={'autovacuum': 'off'})
|
|
|
|
|
|
|
|
self.init_pb(backup_dir)
|
|
|
|
self.add_instance(backup_dir, 'node', node)
|
|
|
|
self.set_archiving(backup_dir, 'node', node)
|
|
|
|
node.slow_start()
|
|
|
|
|
|
|
|
subprocess.Popen(
|
2020-12-03 11:23:33 +02:00
|
|
|
['sudo', 'timedatectl', 'set-timezone', 'America/Detroit'],
|
2020-12-02 22:39:26 +02:00
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-ntp', 'false'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-time', '2020-05-25 12:00:00'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
# FULL
|
|
|
|
self.backup_node(backup_dir, 'node', node, old_binary=True, return_id=False)
|
|
|
|
|
|
|
|
# move to dst
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-time', '2020-10-25 12:00:00'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
# DELTA
|
|
|
|
output = self.backup_node(
|
|
|
|
backup_dir, 'node', node, backup_type='delta', old_binary=True, return_id=False)
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-time', '2020-12-01 12:00:00'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
# DELTA
|
|
|
|
self.backup_node(backup_dir, 'node', node, backup_type='delta')
|
|
|
|
|
|
|
|
output = self.show_pb(backup_dir, as_json=False, as_text=True)
|
|
|
|
self.assertNotIn("backup ID in control file", output)
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-ntp', 'true'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
sleep(10)
|
|
|
|
|
|
|
|
self.backup_node(backup_dir, 'node', node, backup_type='delta')
|
|
|
|
|
|
|
|
output = self.show_pb(backup_dir, as_json=False, as_text=True)
|
|
|
|
self.assertNotIn("backup ID in control file", output)
|
|
|
|
|
|
|
|
subprocess.Popen(
|
|
|
|
['sudo', 'timedatectl', 'set-timezone', 'US/Moscow'],
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.PIPE).communicate()
|
|
|
|
|
|
|
|
# Clean after yourself
|
|
|
|
self.del_test_dir(module_name, fname)
|