# Copyright (c) 2015 Rackspace, Inc. # # 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 json import uuid import ddt import mock from poppy.transport.validators import helpers as validators from tests.functional.transport.pecan import base @ddt.ddt class SSLCertificateControllerTest(base.FunctionalTest): def setUp(self): super(SSLCertificateControllerTest, self).setUp() self.project_id = str(uuid.uuid1()) self.service_name = str(uuid.uuid1()) self.flavor_id = str(uuid.uuid1()) # create a mock flavor to be used by new service creations flavor_json = { "id": self.flavor_id, "providers": [ { "provider": "mock", "links": [ { "href": "http://mock.cdn", "rel": "provider_url" } ] } ] } response = self.app.post('/v1.0/flavors', params=json.dumps(flavor_json), headers={ "Content-Type": "application/json", "X-Project-ID": self.project_id}) self.assertEqual(201, response.status_code) @ddt.file_data("data_create_ssl_certificate.json") def test_create_ssl_certificate(self, ssl_certificate_json): validators.is_valid_tld = mock.Mock(return_value=True) # override the hardcoded flavor_id in the ddt file with # a custom one defined in setUp() ssl_certificate_json['flavor_id'] = self.flavor_id # create with good data response = self.app.post('/v1.0/ssl_certificate', params=json.dumps(ssl_certificate_json), headers={ 'Content-Type': 'application/json', 'X-Project-ID': self.project_id}) self.assertEqual(202, response.status_code) def test_get_ssl_certificate_non_existing_domain(self): # get non existing domain domain = 'www.idontexist.com' response = self.app.get('/v1.0/ssl_certificate/{0}'.format(domain), headers={ 'Content-Type': 'application/json', 'X-Project-ID': self.project_id}, expect_errors=True) self.assertEqual(404, response.status_code) def test_get_ssl_certificate_existing_domain(self): validators.is_valid_tld = mock.Mock(return_value=True) domain = 'www.iexist.com' ssl_certificate_json = { "cert_type": "san", "domain_name": domain, "flavor_id": self.flavor_id, "project_id": self.project_id } response = self.app.post('/v1.0/ssl_certificate', params=json.dumps(ssl_certificate_json), headers={ 'Content-Type': 'application/json', 'X-Project-ID': self.project_id}) self.assertEqual(202, response.status_code) # get existing domain with same project_id response = self.app.get('/v1.0/ssl_certificate/{0}'.format(domain), headers={ 'Content-Type': 'application/json', 'X-Project-ID': self.project_id}) response_list = json.loads(response.body.decode("utf-8")) self.assertEqual(200, response.status_code) self.assertEqual(ssl_certificate_json["cert_type"], response_list[0]["cert_type"]) self.assertEqual(ssl_certificate_json["domain_name"], response_list[0]["domain_name"]) self.assertEqual(ssl_certificate_json["flavor_id"], response_list[0]["flavor_id"]) self.assertEqual(ssl_certificate_json["project_id"], response_list[0]["project_id"]) def test_get_ssl_certificate_existing_domain_different_project_id(self): validators.is_valid_tld = mock.Mock(return_value=True) domain = 'www.iexist.com' ssl_certificate_json = { "cert_type": "san", "domain_name": domain, "flavor_id": self.flavor_id, "project_id": self.project_id } response = self.app.post('/v1.0/ssl_certificate', params=json.dumps(ssl_certificate_json), headers={ 'Content-Type': 'application/json', 'X-Project-ID': self.project_id}) self.assertEqual(202, response.status_code) # get existing domain with different project_id response = self.app.get('/v1.0/ssl_certificate/{0}'.format(domain), headers={ 'Content-Type': 'application/json', 'X-Project-ID': str(uuid.uuid4())}) self.assertEqual(200, response.status_code) def test_create_with_invalid_json(self): # create with errorenous data: invalid json data response = self.app.post('/v1.0/ssl_certificate', params="{", headers={ 'Content-Type': 'application/json', 'X-Project-ID': self.project_id}, expect_errors=True) self.assertEqual(400, response.status_code) @ddt.file_data("data_create_ssl_certificate_bad_input_json.json") def test_create_with_bad_input_json(self, ssl_certificate_json): # create with errorenous data response = self.app.post('/v1.0/ssl_certificate', params=json.dumps(ssl_certificate_json), headers={'Content-Type': 'application/json', 'X-Project-ID': self.project_id}, expect_errors=True) self.assertEqual(400, response.status_code) def test_delete_cert(self): # create with errorenous data: invalid json data response = self.app.delete('/v1.0/ssl_certificate/blog.test.com', headers={'X-Project-ID': self.project_id} ) self.assertEqual(202, response.status_code) def test_delete_cert_non_exist(self): # create with errorenous data: invalid json data response = self.app.delete('/v1.0/ssl_certificate/blog.non_exist.com', headers={'X-Project-ID': self.project_id}, expect_errors=True) self.assertEqual(400, response.status_code) def tearDown(self): super(SSLCertificateControllerTest, self).tearDown()