Merge "Allow host URL for versions to be configurable"

This commit is contained in:
Zuul 2018-02-22 05:10:55 +00:00 committed by Gerrit Code Review
commit 0d555bf85a
3 changed files with 52 additions and 2 deletions

View File

@ -44,6 +44,15 @@ path_opts = [
help='Directory where the Trove python module is installed.'), help='Directory where the Trove python module is installed.'),
] ]
versions_opts = [
cfg.StrOpt('public_endpoint', default=None,
help='Public URL to use for versions endpoint. The default '
'is None, which will use the request\'s host_url '
'attribute to populate the URL base. If Trove is '
'operating behind a proxy, you will want to change '
'this to represent the proxy\'s URL.')
]
common_opts = [ common_opts = [
cfg.IPOpt('bind_host', default='0.0.0.0', cfg.IPOpt('bind_host', default='0.0.0.0',
help='IP address the API server will listen on.'), help='IP address the API server will listen on.'),
@ -1523,6 +1532,7 @@ rpcapi_cap_opts = [
CONF = cfg.CONF CONF = cfg.CONF
CONF.register_opts(path_opts) CONF.register_opts(path_opts)
CONF.register_opts(versions_opts)
CONF.register_opts(common_opts) CONF.register_opts(common_opts)
CONF.register_opts(database_opts, 'database') CONF.register_opts(database_opts, 'database')

View File

@ -14,7 +14,9 @@
# under the License. # under the License.
from mock import Mock from mock import Mock
import webob
from trove.common import cfg
from trove.tests.unittests import trove_testtools from trove.tests.unittests import trove_testtools
from trove.versions import BaseVersion from trove.versions import BaseVersion
from trove.versions import Version from trove.versions import Version
@ -41,6 +43,10 @@ class VersionsControllerTest(trove_testtools.TestCase):
self.assertIsNotNone(self.controller, self.assertIsNotNone(self.controller,
"VersionsController instance was None") "VersionsController instance was None")
def tearDown(self):
super(VersionsControllerTest, self).tearDown()
cfg.CONF.clear_override('public_endpoint')
def test_index_json(self): def test_index_json(self):
request = Mock() request = Mock()
result = self.controller.index(request) result = self.controller.index(request)
@ -66,6 +72,23 @@ class VersionsControllerTest(trove_testtools.TestCase):
self.assertEqual('2012-08-01T00:00:00Z', json_data['updated'], self.assertEqual('2012-08-01T00:00:00Z', json_data['updated'],
'Version updated value is incorrect') 'Version updated value is incorrect')
def test_index_json_with_public_endpoint(self):
cfg.CONF.set_override('public_endpoint', "https://example.com:8779")
req = webob.Request.blank('/')
resp = self.controller.index(req)
result = resp.data('application/json')['versions']
expected = [
{
'status': 'CURRENT',
'updated': '2012-08-01T00:00:00Z',
'id': 'v1.0',
'links': [{
'href': 'https://example.com:8779/v1.0/',
'rel': 'self'}]
}
]
self.assertEqual(expected, result)
def test_show_json(self): def test_show_json(self):
request = Mock() request = Mock()
request.url_version = '1.0' request.url_version = '1.0'
@ -84,6 +107,22 @@ class VersionsControllerTest(trove_testtools.TestCase):
"Version updated was not '2012-08-01T00:00:00Z'") "Version updated was not '2012-08-01T00:00:00Z'")
self.assertEqual('v1.0', version['id'], "Version id was not 'v1.0'") self.assertEqual('v1.0', version['id'], "Version id was not 'v1.0'")
def test_show_json_with_public_endpoint(self):
cfg.CONF.set_override('public_endpoint', "https://example.com:8779")
req = webob.Request.blank('/')
req.url_version = '1.0'
resp = self.controller.show(req)
result = resp.data('application/json')['version']
expected = {
'status': 'CURRENT',
'updated': '2012-08-01T00:00:00Z',
'id': 'v1.0',
'links': [{
'href': 'https://example.com:8779/',
'rel': 'self'}]
}
self.assertEqual(expected, result)
class BaseVersionTestCase(trove_testtools.TestCase): class BaseVersionTestCase(trove_testtools.TestCase):

View File

@ -16,9 +16,10 @@
import os import os
import routes import routes
from trove.common import cfg
from trove.common import wsgi from trove.common import wsgi
CONF = cfg.CONF
VERSIONS = { VERSIONS = {
"1.0": { "1.0": {
"id": "v1.0", "id": "v1.0",
@ -56,7 +57,7 @@ class BaseVersion(object):
def __init__(self, id, status, base_url, updated): def __init__(self, id, status, base_url, updated):
self.id = id self.id = id
self.status = status self.status = status
self.base_url = base_url self.base_url = CONF.public_endpoint or base_url
self.updated = updated self.updated = updated
def data(self): def data(self):