Merge "Test Case to check "swift object expiry""
This commit is contained in:
93
tempest/tests/object_storage/test_object_expiry.py
Normal file
93
tempest/tests/object_storage/test_object_expiry.py
Normal file
@@ -0,0 +1,93 @@
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
|
||||
# Copyright 2012 OpenStack, LLC
|
||||
# All Rights Reserved.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||
# not use this file except in compliance with the License. You may obtain
|
||||
# a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
from nose.plugins.attrib import attr
|
||||
from tempest.common.utils.data_utils import arbitrary_string
|
||||
from tempest.common.utils.data_utils import rand_name
|
||||
from tempest import exceptions
|
||||
from tempest.tests.object_storage import base
|
||||
from time import sleep
|
||||
import unittest2 as unittest
|
||||
|
||||
|
||||
class ObjectExpiryTest(base.BaseObjectTest):
|
||||
|
||||
@classmethod
|
||||
def setUpClass(cls):
|
||||
super(ObjectExpiryTest, cls).setUpClass()
|
||||
|
||||
#Create a container
|
||||
cls.container_name = rand_name(name='TestContainer')
|
||||
cls.container_client.create_container(cls.container_name)
|
||||
|
||||
@classmethod
|
||||
def tearDownClass(cls):
|
||||
"""The test script fails in tear down class
|
||||
as the container contains expired objects (LP bug 1069849).
|
||||
But delete action for the expired object is raising
|
||||
NotFound exception and also non empty container cannot be deleted."""
|
||||
|
||||
#Get list of all object in the container
|
||||
objlist = \
|
||||
cls.container_client.list_all_container_objects(cls.container_name)
|
||||
|
||||
#Attempt to delete every object in the container
|
||||
if objlist:
|
||||
for obj in objlist:
|
||||
resp, _ = cls.object_client.delete_object(cls.container_name,
|
||||
obj['name'])
|
||||
|
||||
#Attempt to delete the container
|
||||
resp, _ = cls.container_client.delete_container(cls.container_name)
|
||||
|
||||
@unittest.skip('Until bug 1069849 is resolved.')
|
||||
@attr(type='regression')
|
||||
def test_get_object_after_expiry_time(self):
|
||||
"""GET object after expiry time"""
|
||||
#TODO(harika-vakadi): Similar test case has to be created for
|
||||
# "X-Delete-At", after this test case works.
|
||||
|
||||
#Create Object
|
||||
object_name = rand_name(name='TestObject')
|
||||
data = arbitrary_string()
|
||||
resp, _ = self.object_client.create_object(self.container_name,
|
||||
object_name, data)
|
||||
|
||||
#Update object metadata with expiry time of 3 seconds
|
||||
metadata = {'X-Delete-After': '3'}
|
||||
resp, _ = \
|
||||
self.object_client.update_object_metadata(self.container_name,
|
||||
object_name, metadata,
|
||||
metadata_prefix='')
|
||||
|
||||
resp, _ = \
|
||||
self.object_client.list_object_metadata(self.container_name,
|
||||
object_name)
|
||||
|
||||
self.assertEqual(resp['status'], '200')
|
||||
self.assertIn('x-delete-at', resp)
|
||||
|
||||
resp, body = self.object_client.get_object(self.container_name,
|
||||
object_name)
|
||||
self.assertEqual(resp['status'], '200')
|
||||
# Check data
|
||||
self.assertEqual(body, data)
|
||||
# Sleep for over 5 seconds, so that object is expired
|
||||
sleep(5)
|
||||
# Verification of raised exception after object gets expired
|
||||
self.assertRaises(exceptions.NotFound, self.object_client.get_object,
|
||||
self.container_name, object_name)
|
||||
Reference in New Issue
Block a user