
Fixing the standard things when making code py27/p35 compatible. Also, removing the logging of the passed value of an HTTP header. If the value could not be encoded to log, then there are Tracebacks that showed up with Python 3.5. Since the value can be passed by a user, it should either be scrubbed before logging or not logged, to prevent possible content injection in the log stream. Change-Id: I8df1553acb6c7e5f75a1b50f024dc032ca982a93
209 lines
7.4 KiB
Python
209 lines
7.4 KiB
Python
# Copyright (c) 2016 IBM
|
|
#
|
|
# 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 oslo_serialization import jsonutils
|
|
from testtools import testcase
|
|
import uuid
|
|
|
|
from barbican.tests import utils
|
|
from functionaltests.api import base
|
|
from functionaltests.api.v1.behaviors import secret_behaviors
|
|
from functionaltests.api.v1.behaviors import secretmeta_behaviors
|
|
from functionaltests.api.v1.models import secret_models
|
|
|
|
|
|
@utils.parameterized_test_case
|
|
class SecretMetadataTestCase(base.TestCase):
|
|
def setUp(self):
|
|
super(SecretMetadataTestCase, self).setUp()
|
|
self.secret_behaviors = secret_behaviors.SecretBehaviors(self.client)
|
|
self.behaviors = secretmeta_behaviors.SecretMetadataBehaviors(
|
|
self.client)
|
|
|
|
self.default_secret_create_all_none_data = {
|
|
"name": None,
|
|
"expiration": None,
|
|
"algorithm": None,
|
|
"bit_length": None,
|
|
"mode": None,
|
|
"payload": None,
|
|
"payload_content_type": None,
|
|
"payload_content_encoding": None,
|
|
}
|
|
|
|
self.valid_metadata = {
|
|
"metadata": {
|
|
"latitude": "30.393805",
|
|
"longitude": "-97.724077"
|
|
}
|
|
}
|
|
|
|
self.invalid_metadata = {
|
|
"metadataaaaaaaa": {
|
|
"latitude": "30.393805",
|
|
"longitude": "-97.724077"
|
|
}
|
|
}
|
|
|
|
self.valid_metadatum_key = 'access-limit'
|
|
self.valid_metadatum = {
|
|
'key': self.valid_metadatum_key,
|
|
'value': '2'
|
|
}
|
|
|
|
def tearDown(self):
|
|
self.secret_behaviors.delete_all_created_secrets()
|
|
super(SecretMetadataTestCase, self).tearDown()
|
|
|
|
@testcase.attr('positive')
|
|
def test_secret_metadata_create(self):
|
|
test_model = secret_models.SecretModel(
|
|
**self.default_secret_create_all_none_data)
|
|
|
|
resp, secret_ref = self.secret_behaviors.create_secret(test_model)
|
|
self.assertEqual(201, resp.status_code)
|
|
|
|
meta_resp, metadata_ref = self.behaviors.create_or_update_metadata(
|
|
secret_ref, self.valid_metadata)
|
|
|
|
self.assertEqual(201, meta_resp.status_code)
|
|
self.assertEqual(secret_ref + '/metadata', metadata_ref)
|
|
|
|
@testcase.attr('negative')
|
|
def test_secret_metadata_create_no_secret(self):
|
|
secret_ref = 'http://localhost:9311/secrets/%s' % uuid.uuid4().hex
|
|
|
|
meta_resp, metadata_ref = self.behaviors.create_or_update_metadata(
|
|
secret_ref, self.invalid_metadata)
|
|
|
|
self.assertEqual(404, meta_resp.status_code)
|
|
|
|
@testcase.attr('positive')
|
|
def test_secret_metadata_get(self):
|
|
test_model = secret_models.SecretModel(
|
|
**self.default_secret_create_all_none_data)
|
|
|
|
resp, secret_ref = self.secret_behaviors.create_secret(test_model)
|
|
self.assertEqual(201, resp.status_code)
|
|
|
|
meta_resp, metadata_ref = self.behaviors.create_or_update_metadata(
|
|
secret_ref, self.valid_metadata)
|
|
|
|
self.assertEqual(201, meta_resp.status_code)
|
|
self.assertEqual(secret_ref + '/metadata', metadata_ref)
|
|
|
|
get_resp = self.behaviors.get_metadata(secret_ref)
|
|
self.assertEqual(200, get_resp.status_code)
|
|
self.assertEqual(jsonutils.loads(get_resp.content),
|
|
self.valid_metadata)
|
|
|
|
@testcase.attr('negative')
|
|
def test_secret_metadata_get_no_secret(self):
|
|
secret_ref = 'http://localhost:9311/secrets/%s' % uuid.uuid4().hex
|
|
|
|
get_resp = self.behaviors.get_metadata(secret_ref)
|
|
self.assertEqual(404, get_resp.status_code)
|
|
|
|
@testcase.attr('positive')
|
|
def test_secret_metadatum_create(self):
|
|
test_model = secret_models.SecretModel(
|
|
**self.default_secret_create_all_none_data)
|
|
|
|
resp, secret_ref = self.secret_behaviors.create_secret(test_model)
|
|
self.assertEqual(201, resp.status_code)
|
|
|
|
meta_resp, metadata_ref = self.behaviors.create_metadatum(
|
|
secret_ref, self.valid_metadatum)
|
|
|
|
self.assertEqual(201, meta_resp.status_code)
|
|
|
|
@testcase.attr('positive')
|
|
def test_secret_metadatum_update(self):
|
|
test_model = secret_models.SecretModel(
|
|
**self.default_secret_create_all_none_data)
|
|
|
|
resp, secret_ref = self.secret_behaviors.create_secret(test_model)
|
|
self.assertEqual(201, resp.status_code)
|
|
|
|
meta_resp, metadata_ref = self.behaviors.create_metadatum(
|
|
secret_ref, self.valid_metadatum)
|
|
|
|
self.assertEqual(201, meta_resp.status_code)
|
|
|
|
updated_meta = {
|
|
'key': self.valid_metadatum_key,
|
|
'value': '10'
|
|
}
|
|
|
|
put_resp = self.behaviors.update_metadatum(
|
|
secret_ref, self.valid_metadatum_key, updated_meta)
|
|
|
|
self.assertEqual(200, put_resp.status_code)
|
|
|
|
@testcase.attr('positive')
|
|
def test_secret_metadatum_get(self):
|
|
test_model = secret_models.SecretModel(
|
|
**self.default_secret_create_all_none_data)
|
|
|
|
resp, secret_ref = self.secret_behaviors.create_secret(test_model)
|
|
self.assertEqual(201, resp.status_code)
|
|
|
|
meta_resp, metadata_ref = self.behaviors.create_metadatum(
|
|
secret_ref, self.valid_metadatum)
|
|
|
|
self.assertEqual(201, meta_resp.status_code)
|
|
|
|
get_resp = self.behaviors.get_metadatum(secret_ref,
|
|
self.valid_metadatum_key)
|
|
self.assertEqual(200, get_resp.status_code)
|
|
self.assertEqual(jsonutils.loads(get_resp.content),
|
|
self.valid_metadatum)
|
|
|
|
@testcase.attr('negative')
|
|
def test_secret_metadatum_get_wrong_key(self):
|
|
test_model = secret_models.SecretModel(
|
|
**self.default_secret_create_all_none_data)
|
|
|
|
resp, secret_ref = self.secret_behaviors.create_secret(test_model)
|
|
self.assertEqual(201, resp.status_code)
|
|
|
|
meta_resp, metadata_ref = self.behaviors.create_metadatum(
|
|
secret_ref, self.valid_metadatum)
|
|
|
|
self.assertEqual(201, meta_resp.status_code)
|
|
|
|
get_resp = self.behaviors.get_metadatum(secret_ref,
|
|
'other_key')
|
|
self.assertEqual(404, get_resp.status_code)
|
|
|
|
@testcase.attr('positive')
|
|
def test_secret_metadatum_delete(self):
|
|
test_model = secret_models.SecretModel(
|
|
**self.default_secret_create_all_none_data)
|
|
|
|
resp, secret_ref = self.secret_behaviors.create_secret(test_model)
|
|
self.assertEqual(201, resp.status_code)
|
|
|
|
meta_resp, metadata_ref = self.behaviors.create_metadatum(
|
|
secret_ref, self.valid_metadatum)
|
|
|
|
self.assertEqual(201, meta_resp.status_code)
|
|
|
|
get_resp = self.behaviors.get_metadatum(secret_ref,
|
|
self.valid_metadatum_key)
|
|
self.assertEqual(200, get_resp.status_code)
|
|
delete_resp = self.behaviors.delete_metadatum(secret_ref,
|
|
self.valid_metadatum_key)
|
|
self.assertEqual(204, delete_resp.status_code)
|