Support datastore version number for configuration
Story: 2008358 Task: 41263 Change-Id: I529a07d50c0659af0c9821a8570f7548e8521805
This commit is contained in:
parent
97e0a940df
commit
589e4ec45a
@ -3,7 +3,8 @@
|
|||||||
"name": "group1",
|
"name": "group1",
|
||||||
"datastore": {
|
"datastore": {
|
||||||
"type": "mysql",
|
"type": "mysql",
|
||||||
"version": "5.7.29"
|
"version": "mysql-5.7",
|
||||||
|
"version_number": "5.7.29"
|
||||||
},
|
},
|
||||||
"values": {
|
"values": {
|
||||||
"connect_timeout": 200
|
"connect_timeout": 200
|
||||||
|
@ -4,7 +4,8 @@
|
|||||||
"updated": "2020-06-16T10:40:50",
|
"updated": "2020-06-16T10:40:50",
|
||||||
"datastore_name": "mysql",
|
"datastore_name": "mysql",
|
||||||
"datastore_version_id": "cf91aa9a-2192-4ec4-b7ce-5cac3b1e7dbe",
|
"datastore_version_id": "cf91aa9a-2192-4ec4-b7ce-5cac3b1e7dbe",
|
||||||
"datastore_version_name": "5.7.29",
|
"datastore_version_name": "mysql-5.7",
|
||||||
|
"datastore_version_number": "5.7.29",
|
||||||
"description": null,
|
"description": null,
|
||||||
"id": "9dcfca0b-d181-4b36-bbf0-09bc47b103ab",
|
"id": "9dcfca0b-d181-4b36-bbf0-09bc47b103ab",
|
||||||
"instance_count": 0,
|
"instance_count": 0,
|
||||||
|
@ -1,16 +1,17 @@
|
|||||||
{
|
{
|
||||||
"configuration": {
|
"configuration": {
|
||||||
"datastore_name": "mysql",
|
"datastore_name": "mysql",
|
||||||
|
"datastore_version_id": "b9f97132-467b-4f8e-b12d-947cfc223ac3",
|
||||||
|
"datastore_version_name": "mysql-5.7",
|
||||||
|
"datastore_version_number": "5.7.29",
|
||||||
"updated": "2015-11-22T19:07:20",
|
"updated": "2015-11-22T19:07:20",
|
||||||
"values": {
|
"values": {
|
||||||
"connect_timeout": 17
|
"connect_timeout": 17
|
||||||
},
|
},
|
||||||
"name": "group1",
|
"name": "group1",
|
||||||
"created": "2015-11-20T20:51:24",
|
"created": "2015-11-20T20:51:24",
|
||||||
"datastore_version_name": "5.6",
|
|
||||||
"instance_count": 1,
|
"instance_count": 1,
|
||||||
"id": "1c8a4fdd-690c-4e6e-b2e1-148b8d738770",
|
"id": "1c8a4fdd-690c-4e6e-b2e1-148b8d738770",
|
||||||
"datastore_version_id": "b9f97132-467b-4f8e-b12d-947cfc223ac3",
|
|
||||||
"description": null
|
"description": null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,13 +1,14 @@
|
|||||||
{
|
{
|
||||||
"configurations": [
|
"configurations": [
|
||||||
{
|
{
|
||||||
"datastore_name": "mysql",
|
|
||||||
"updated": "2015-07-01T16:38:27",
|
"updated": "2015-07-01T16:38:27",
|
||||||
|
"datastore_version_id": "2dc7faa0-efff-4c2b-8cff-bcd949c518a5",
|
||||||
|
"datastore_name": "mysql",
|
||||||
|
"datastore_version_name": "mysql-5.7",
|
||||||
|
"datastore_version_number": "5.7.29",
|
||||||
"name": "group1",
|
"name": "group1",
|
||||||
"created": "2015-07-01T16:38:27",
|
"created": "2015-07-01T16:38:27",
|
||||||
"datastore_version_name": "5.6",
|
|
||||||
"id": "2aa51628-5c42-4086-8682-137caffd2ba6",
|
"id": "2aa51628-5c42-4086-8682-137caffd2ba6",
|
||||||
"datastore_version_id": "2dc7faa0-efff-4c2b-8cff-bcd949c518a5",
|
|
||||||
"description": null
|
"description": null
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -99,12 +99,14 @@ class DetailedConfigurationView(object):
|
|||||||
"created": self.configuration.created,
|
"created": self.configuration.created,
|
||||||
"updated": self.configuration.updated,
|
"updated": self.configuration.updated,
|
||||||
"instance_count":
|
"instance_count":
|
||||||
getattr(self.configuration, "instance_count", 0),
|
getattr(self.configuration, "instance_count", 0),
|
||||||
"datastore_name": self.configuration.datastore.name,
|
"datastore_name": self.configuration.datastore.name,
|
||||||
"datastore_version_id":
|
"datastore_version_id":
|
||||||
self.configuration.datastore_version_id,
|
self.configuration.datastore_version_id,
|
||||||
"datastore_version_name":
|
"datastore_version_name":
|
||||||
self.configuration.datastore_version.name
|
self.configuration.datastore_version.name,
|
||||||
|
"datastore_version_number":
|
||||||
|
self.configuration.datastore_version.version
|
||||||
}
|
}
|
||||||
|
|
||||||
return {"configuration": configuration_dict}
|
return {"configuration": configuration_dict}
|
||||||
|
83
trove/tests/unittests/configuration/test_service.py
Normal file
83
trove/tests/unittests/configuration/test_service.py
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
# Copyright 2020 Catalyst Cloud
|
||||||
|
#
|
||||||
|
# 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 unittest import mock
|
||||||
|
|
||||||
|
from trove.common import cfg
|
||||||
|
from trove.common import wsgi
|
||||||
|
from trove.configuration import models as config_models
|
||||||
|
from trove.configuration import service
|
||||||
|
from trove.datastore import models as ds_models
|
||||||
|
from trove.tests.unittests import trove_testtools
|
||||||
|
from trove.tests.unittests.util import util
|
||||||
|
|
||||||
|
CONF = cfg.CONF
|
||||||
|
|
||||||
|
|
||||||
|
class TestConfigurationsController(trove_testtools.TestCase):
|
||||||
|
@classmethod
|
||||||
|
def setUpClass(cls):
|
||||||
|
util.init_db()
|
||||||
|
|
||||||
|
cls.ds_name = cls.random_name(
|
||||||
|
'datastore', prefix='TestConfigurationsController')
|
||||||
|
ds_models.update_datastore(name=cls.ds_name, default_version=None)
|
||||||
|
cls.ds = ds_models.Datastore.load(cls.ds_name)
|
||||||
|
|
||||||
|
ds_version_name = cls.random_name(
|
||||||
|
'version', prefix='TestConfigurationsController')
|
||||||
|
ds_models.update_datastore_version(
|
||||||
|
cls.ds_name, ds_version_name, 'mysql', '',
|
||||||
|
['trove'], '', 1, version='5.7.29')
|
||||||
|
cls.ds_version = ds_models.DatastoreVersion.load(
|
||||||
|
cls.ds, ds_version_name, version='5.7.29')
|
||||||
|
|
||||||
|
cls.tenant_id = cls.random_uuid()
|
||||||
|
cls.config = config_models.Configuration.create(
|
||||||
|
cls.random_name('configuration'),
|
||||||
|
'', cls.tenant_id, None,
|
||||||
|
cls.ds_version.id)
|
||||||
|
cls.config_id = cls.config.id
|
||||||
|
|
||||||
|
cls.controller = service.ConfigurationsController()
|
||||||
|
|
||||||
|
super(TestConfigurationsController, cls).setUpClass()
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def tearDownClass(cls):
|
||||||
|
util.cleanup_db()
|
||||||
|
|
||||||
|
super(TestConfigurationsController, cls).tearDownClass()
|
||||||
|
|
||||||
|
def test_show(self):
|
||||||
|
req_mock = mock.MagicMock(
|
||||||
|
environ={
|
||||||
|
wsgi.CONTEXT_KEY: mock.MagicMock(project_id=self.tenant_id)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
result = self.controller.show(req_mock, self.tenant_id,
|
||||||
|
self.config_id)
|
||||||
|
data = result.data(None).get('configuration')
|
||||||
|
|
||||||
|
expected = {
|
||||||
|
"id": self.config_id,
|
||||||
|
"name": self.config.name,
|
||||||
|
"description": '',
|
||||||
|
"instance_count": 0,
|
||||||
|
"datastore_name": self.ds_name,
|
||||||
|
"datastore_version_id": self.ds_version.id,
|
||||||
|
"datastore_version_name": self.ds_version.name,
|
||||||
|
"datastore_version_number": self.ds_version.version
|
||||||
|
}
|
||||||
|
|
||||||
|
self.assertDictContains(data, expected)
|
@ -122,3 +122,11 @@ class TestCase(testtools.TestCase):
|
|||||||
@classmethod
|
@classmethod
|
||||||
def random_uuid(cls):
|
def random_uuid(cls):
|
||||||
return str(uuid.uuid4())
|
return str(uuid.uuid4())
|
||||||
|
|
||||||
|
def assertDictContains(self, parent, child):
|
||||||
|
"""Checks whether child dict is a subset of parent.
|
||||||
|
|
||||||
|
assertDictContainsSubset() in standard Python 2.7 has been deprecated
|
||||||
|
since Python 3.2
|
||||||
|
"""
|
||||||
|
self.assertEqual(parent, dict(parent, **child))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user