f1d742f32a
Fix various things so the functional tests will work under python3: - A hashlib.md5() can only be update()d with an encoded string in py3. - There's no dict.iteritems(), change to dict.items() (which is already an iterator). - Open temp files with 'w+' mode rather than the default 'w+b' (as an alternative to encoding all the write and expected-read payloads as bytes). - (This is a weird one) Explicitly raise SkipTest from unittest (rather than unittest2, which is where cls.skipException landed). Not sure why this is busted, but this moves the ball. Change-Id: Ic9b2b47848a600e87a3674289ae7ae8c3e091fee
92 lines
3.5 KiB
Python
92 lines
3.5 KiB
Python
# 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.
|
|
|
|
import os
|
|
import tempfile
|
|
import uuid
|
|
|
|
from openstackclient.tests.functional.object.v1 import common
|
|
|
|
BASIC_LIST_HEADERS = ['Name']
|
|
CONTAINER_FIELDS = ['account', 'container', 'x-trans-id']
|
|
OBJECT_FIELDS = ['object', 'container', 'etag']
|
|
|
|
|
|
class ObjectTests(common.ObjectStoreTests):
|
|
"""Functional tests for Object Store object commands"""
|
|
|
|
CONTAINER_NAME = uuid.uuid4().hex
|
|
|
|
def setUp(self):
|
|
super(ObjectTests, self).setUp()
|
|
# Skip tests if no object-store is present
|
|
if not self.haz_object_store:
|
|
self.skipTest("No object-store service present")
|
|
|
|
def test_object(self):
|
|
with tempfile.NamedTemporaryFile(mode='w+') as f:
|
|
f.write('test content')
|
|
f.flush()
|
|
self._test_object(f.name)
|
|
|
|
def _test_object(self, object_file):
|
|
raw_output = self.openstack('container create ' + self.CONTAINER_NAME)
|
|
items = self.parse_listing(raw_output)
|
|
self.assert_show_fields(items, CONTAINER_FIELDS)
|
|
|
|
raw_output = self.openstack('container list')
|
|
items = self.parse_listing(raw_output)
|
|
self.assert_table_structure(items, BASIC_LIST_HEADERS)
|
|
|
|
self.openstack('container show ' + self.CONTAINER_NAME)
|
|
# TODO(stevemar): Assert returned fields
|
|
|
|
self.openstack('container save ' + self.CONTAINER_NAME)
|
|
# TODO(stevemar): Assert returned fields
|
|
|
|
raw_output = self.openstack('object create %s %s' %
|
|
(self.CONTAINER_NAME, object_file))
|
|
items = self.parse_listing(raw_output)
|
|
self.assert_show_fields(items, OBJECT_FIELDS)
|
|
|
|
raw_output = self.openstack('object list %s' % self.CONTAINER_NAME)
|
|
items = self.parse_listing(raw_output)
|
|
self.assert_table_structure(items, BASIC_LIST_HEADERS)
|
|
|
|
self.openstack('object save %s %s' %
|
|
(self.CONTAINER_NAME, object_file))
|
|
# TODO(stevemar): Assert returned fields
|
|
|
|
tmp_file = 'tmp.txt'
|
|
self.addCleanup(os.remove, tmp_file)
|
|
self.openstack('object save %s %s --file %s' %
|
|
(self.CONTAINER_NAME, object_file, tmp_file))
|
|
# TODO(stevemar): Assert returned fields
|
|
|
|
raw_output = self.openstack('object save %s %s --file -' %
|
|
(self.CONTAINER_NAME, object_file))
|
|
self.assertEqual(raw_output, 'test content')
|
|
|
|
self.openstack('object show %s %s' %
|
|
(self.CONTAINER_NAME, object_file))
|
|
# TODO(stevemar): Assert returned fields
|
|
|
|
raw_output = self.openstack('object delete %s %s' %
|
|
(self.CONTAINER_NAME, object_file))
|
|
self.assertEqual(0, len(raw_output))
|
|
|
|
self.openstack('object create %s %s' %
|
|
(self.CONTAINER_NAME, object_file))
|
|
raw_output = self.openstack('container delete -r %s' %
|
|
self.CONTAINER_NAME)
|
|
self.assertEqual(0, len(raw_output))
|