Add more tests around ObjectExpirer.round_robin_order

Change-Id: I43b5e8d9513fd0566a61ff585dfdc1dde5b28343
Related-Change: Ibf61eb1f767a48cb457dd494e1f7c12acfd205de
This commit is contained in:
Tim Burke 2018-02-22 10:26:00 -08:00
parent d296ec8be4
commit 6060af8db9

View File

@ -324,44 +324,94 @@ class TestObjectExpirer(TestCase):
'so far' in str(x.logger.get_lines_for_level('info'))) 'so far' in str(x.logger.get_lines_for_level('info')))
def test_round_robin_order(self): def test_round_robin_order(self):
def make_task(delete_at, target):
return {
'task_container': delete_at,
'task_object': delete_at + '-' + target,
'delete_timestamp': Timestamp(delete_at),
'target_path': target,
}
x = expirer.ObjectExpirer(self.conf, logger=self.logger) x = expirer.ObjectExpirer(self.conf, logger=self.logger)
task_con_obj_list = [ task_con_obj_list = [
# objects in 0000 timestamp container # objects in 0000 timestamp container
{'task_container': '0000', 'task_object': '0000-a/c0/o0', make_task('0000', 'a/c0/o0'),
'delete_timestamp': Timestamp('0000'), 'target_path': 'a/c0/o0'}, make_task('0000', 'a/c0/o1'),
{'task_container': '0000', 'task_object': '0000-a/c0/o1',
'delete_timestamp': Timestamp('0000'), 'target_path': 'a/c0/o1'},
# objects in 0001 timestamp container # objects in 0001 timestamp container
{'task_container': '0001', 'task_object': '0001-a/c1/o0', make_task('0001', 'a/c1/o0'),
'delete_timestamp': Timestamp('0001'), 'target_path': 'a/c1/o0'}, make_task('0001', 'a/c1/o1'),
{'task_container': '0001', 'task_object': '0001-a/c1/o1',
'delete_timestamp': Timestamp('0001'), 'target_path': 'a/c1/o1'},
# objects in 0002 timestamp container # objects in 0002 timestamp container
{'task_container': '0002', 'task_object': '0002-a/c2/o0', make_task('0002', 'a/c2/o0'),
'delete_timestamp': Timestamp('0002'), 'target_path': 'a/c2/o0'}, make_task('0002', 'a/c2/o1'),
{'task_container': '0002', 'task_object': '0002-a/c2/o1',
'delete_timestamp': Timestamp('0002'), 'target_path': 'a/c2/o1'},
] ]
result = list(x.round_robin_order(task_con_obj_list)) result = list(x.round_robin_order(task_con_obj_list))
# sorted by poping one object to delete for each target_container # sorted by popping one object to delete for each target_container
expected = [ expected = [
# objects in 0000 timestamp container make_task('0000', 'a/c0/o0'),
{'task_container': '0000', 'task_object': '0000-a/c0/o0', make_task('0001', 'a/c1/o0'),
'delete_timestamp': Timestamp('0000'), 'target_path': 'a/c0/o0'}, make_task('0002', 'a/c2/o0'),
{'task_container': '0001', 'task_object': '0001-a/c1/o0', make_task('0000', 'a/c0/o1'),
'delete_timestamp': Timestamp('0001'), 'target_path': 'a/c1/o0'}, make_task('0001', 'a/c1/o1'),
{'task_container': '0002', 'task_object': '0002-a/c2/o0', make_task('0002', 'a/c2/o1'),
'delete_timestamp': Timestamp('0002'), 'target_path': 'a/c2/o0'},
{'task_container': '0000', 'task_object': '0000-a/c0/o1',
'delete_timestamp': Timestamp('0000'), 'target_path': 'a/c0/o1'},
{'task_container': '0001', 'task_object': '0001-a/c1/o1',
'delete_timestamp': Timestamp('0001'), 'target_path': 'a/c1/o1'},
{'task_container': '0002', 'task_object': '0002-a/c2/o1',
'delete_timestamp': Timestamp('0002'), 'target_path': 'a/c2/o1'},
] ]
self.assertEqual(expected, result) self.assertEqual(expected, result)
# for a given target container, tasks won't necessarily all go in
# the same timestamp container
task_con_obj_list = [
# objects in 0000 timestamp container
make_task('0000', 'a/c0/o0'),
make_task('0000', 'a/c0/o1'),
make_task('0000', 'a/c2/o2'),
make_task('0000', 'a/c2/o3'),
# objects in 0001 timestamp container
make_task('0001', 'a/c0/o2'),
make_task('0001', 'a/c0/o3'),
make_task('0001', 'a/c1/o0'),
make_task('0001', 'a/c1/o1'),
# objects in 0002 timestamp container
make_task('0002', 'a/c2/o0'),
make_task('0002', 'a/c2/o1'),
]
result = list(x.round_robin_order(task_con_obj_list))
# so we go around popping by *target* container, not *task* container
expected = [
make_task('0000', 'a/c0/o0'),
make_task('0001', 'a/c1/o0'),
make_task('0000', 'a/c2/o2'),
make_task('0000', 'a/c0/o1'),
make_task('0001', 'a/c1/o1'),
make_task('0000', 'a/c2/o3'),
make_task('0001', 'a/c0/o2'),
make_task('0002', 'a/c2/o0'),
make_task('0001', 'a/c0/o3'),
make_task('0002', 'a/c2/o1'),
]
self.assertEqual(expected, result)
# all of the work to be done could be for different target containers
task_con_obj_list = [
# objects in 0000 timestamp container
make_task('0000', 'a/c0/o'),
make_task('0000', 'a/c1/o'),
make_task('0000', 'a/c2/o'),
make_task('0000', 'a/c3/o'),
# objects in 0001 timestamp container
make_task('0001', 'a/c4/o'),
make_task('0001', 'a/c5/o'),
make_task('0001', 'a/c6/o'),
make_task('0001', 'a/c7/o'),
# objects in 0002 timestamp container
make_task('0002', 'a/c8/o'),
make_task('0002', 'a/c9/o'),
]
result = list(x.round_robin_order(task_con_obj_list))
# in which case, we kind of hammer the task containers
self.assertEqual(task_con_obj_list, result)
def test_run_once_nothing_to_do(self): def test_run_once_nothing_to_do(self):
x = expirer.ObjectExpirer(self.conf, logger=self.logger) x = expirer.ObjectExpirer(self.conf, logger=self.logger)
x.swift = 'throw error because a string does not have needed methods' x.swift = 'throw error because a string does not have needed methods'