From 63e618b232c5f1a50e16baa0e685f4e25716f737 Mon Sep 17 00:00:00 2001 From: Alistair Coles Date: Thu, 16 Feb 2023 10:39:30 +0000 Subject: [PATCH] Test x-backend-replication header with POST Add unit test coverage for previously untested use of an x-backend-replication header with a POST request to the object server. Change-Id: I3636f3c51f2eee53f2ef2c76ef2b9204246bdb04 --- test/unit/obj/test_server.py | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/test/unit/obj/test_server.py b/test/unit/obj/test_server.py index 5f022e3c57..ff76e91460 100644 --- a/test/unit/obj/test_server.py +++ b/test/unit/obj/test_server.py @@ -6637,6 +6637,30 @@ class TestObjectController(BaseTestCase): resp = req.get_response(self.object_controller) self.assertEqual(resp.status_int, 404) + # ...unless sending an x-backend-replication header...which lets you + # modify x-delete-at + now += 2 + recreate_test_object(now) + the_time = delete_at_timestamp + 2 + req = Request.blank( + '/sda1/p/a/c/o', + environ={'REQUEST_METHOD': 'POST'}, + headers={'X-Timestamp': normalize_timestamp(the_time), + 'x-backend-replication': 'true', + 'x-delete-at': str(delete_at_timestamp + 100)}) + resp = req.get_response(self.object_controller) + self.assertEqual(resp.status_int, 202) + # ...so the object becomes accessible again even without an + # x-backend-replication header + the_time = delete_at_timestamp + 3 + req = Request.blank( + '/sda1/p/a/c/o', + environ={'REQUEST_METHOD': 'POST'}, + headers={'X-Timestamp': normalize_timestamp(the_time), + 'x-delete-at': str(delete_at_timestamp + 101)}) + resp = req.get_response(self.object_controller) + self.assertEqual(resp.status_int, 202) + def test_DELETE_can_skip_updating_expirer_queue(self): policy = POLICIES.get_by_index(0) test_time = time()