300ba2df11
Change-Id: Ib8e747f91f5277aecc3be01a5e8cee5bc911e823
141 lines
4.8 KiB
Python
141 lines
4.8 KiB
Python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
|
|
# Copyright 2010 United States Government as represented by the
|
|
# Administrator of the National Aeronautics and Space Administration.
|
|
# 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.
|
|
|
|
"""
|
|
Unittets for S3 objectstore clone.
|
|
"""
|
|
|
|
import boto
|
|
import os
|
|
import shutil
|
|
import tempfile
|
|
|
|
from boto import exception as boto_exception
|
|
from boto.s3 import connection as s3
|
|
|
|
from nova import flags
|
|
from nova.objectstore import s3server
|
|
from nova import test
|
|
from nova import wsgi
|
|
|
|
|
|
FLAGS = flags.FLAGS
|
|
|
|
# Create a unique temporary directory. We don't delete after test to
|
|
# allow checking the contents after running tests. Users and/or tools
|
|
# running the tests need to remove the tests directories.
|
|
OSS_TEMPDIR = tempfile.mkdtemp(prefix='test_oss-')
|
|
|
|
# Create bucket/images path
|
|
os.makedirs(os.path.join(OSS_TEMPDIR, 'images'))
|
|
os.makedirs(os.path.join(OSS_TEMPDIR, 'buckets'))
|
|
|
|
|
|
class S3APITestCase(test.TestCase):
|
|
"""Test objectstore through S3 API."""
|
|
|
|
def setUp(self):
|
|
"""Setup users, projects, and start a test server."""
|
|
super(S3APITestCase, self).setUp()
|
|
self.flags(buckets_path=os.path.join(OSS_TEMPDIR, 'buckets'),
|
|
s3_host='127.0.0.1')
|
|
|
|
shutil.rmtree(FLAGS.buckets_path)
|
|
os.mkdir(FLAGS.buckets_path)
|
|
|
|
router = s3server.S3Application(FLAGS.buckets_path)
|
|
self.server = wsgi.Server("S3 Objectstore",
|
|
router,
|
|
host=FLAGS.s3_host,
|
|
port=FLAGS.s3_port)
|
|
self.server.start()
|
|
|
|
if not boto.config.has_section('Boto'):
|
|
boto.config.add_section('Boto')
|
|
|
|
boto.config.set('Boto', 'num_retries', '0')
|
|
conn = s3.S3Connection(aws_access_key_id='fake',
|
|
aws_secret_access_key='fake',
|
|
host=FLAGS.s3_host,
|
|
port=FLAGS.s3_port,
|
|
is_secure=False,
|
|
calling_format=s3.OrdinaryCallingFormat())
|
|
self.conn = conn
|
|
|
|
def get_http_connection(host, is_secure):
|
|
"""Get a new S3 connection, don't attempt to reuse connections."""
|
|
return self.conn.new_http_connection(host, is_secure)
|
|
|
|
self.conn.get_http_connection = get_http_connection
|
|
|
|
def _ensure_no_buckets(self, buckets): # pylint: disable=C0111
|
|
self.assertEquals(len(buckets), 0, "Bucket list was not empty")
|
|
return True
|
|
|
|
def _ensure_one_bucket(self, buckets, name): # pylint: disable=C0111
|
|
self.assertEquals(len(buckets), 1,
|
|
"Bucket list didn't have exactly one element in it")
|
|
self.assertEquals(buckets[0].name, name, "Wrong name")
|
|
return True
|
|
|
|
def test_list_buckets(self):
|
|
"""Make sure we are starting with no buckets."""
|
|
self._ensure_no_buckets(self.conn.get_all_buckets())
|
|
|
|
def test_create_and_delete_bucket(self):
|
|
"""Test bucket creation and deletion."""
|
|
bucket_name = 'testbucket'
|
|
|
|
self.conn.create_bucket(bucket_name)
|
|
self._ensure_one_bucket(self.conn.get_all_buckets(), bucket_name)
|
|
self.conn.delete_bucket(bucket_name)
|
|
self._ensure_no_buckets(self.conn.get_all_buckets())
|
|
|
|
def test_create_bucket_and_key_and_delete_key_again(self):
|
|
"""Test key operations on buckets."""
|
|
bucket_name = 'testbucket'
|
|
key_name = 'somekey'
|
|
key_contents = 'somekey'
|
|
|
|
b = self.conn.create_bucket(bucket_name)
|
|
k = b.new_key(key_name)
|
|
k.set_contents_from_string(key_contents)
|
|
|
|
bucket = self.conn.get_bucket(bucket_name)
|
|
|
|
# make sure the contents are correct
|
|
key = bucket.get_key(key_name)
|
|
self.assertEquals(key.get_contents_as_string(), key_contents,
|
|
"Bad contents")
|
|
|
|
# delete the key
|
|
key.delete()
|
|
|
|
self._ensure_no_buckets(bucket.get_all_keys())
|
|
|
|
def test_unknown_bucket(self):
|
|
bucket_name = 'falalala'
|
|
self.assertRaises(boto_exception.S3ResponseError,
|
|
self.conn.get_bucket,
|
|
bucket_name)
|
|
|
|
def tearDown(self):
|
|
"""Tear down test server."""
|
|
self.server.stop()
|
|
super(S3APITestCase, self).tearDown()
|