Files
python-troveclient/troveclient/tests/test_clusters.py
Marcin Piwowarczyk 9e737a2cf8 Support configuration groups for clusters
Handles API part implemented in change:
I7c0a22c6a0287128d0c37e100589c78173fd9c1a

So far passing configuration group was possible only for single instance
deployment.

As the trove api now already supports configuration attach and detach
for clusters, we are able to handle it in client.

Configuration will be applied to each cluster instance.

Partially implements: blueprint cluster-configuration-groups
Change-Id: Ic0840c995cbc34203c76494d7ba522f3e17141a7
Signed-off-by: Marcin Piwowarczyk <m.piwowarczy@samsung.com>
2018-08-07 08:25:39 +02:00

146 lines
5.4 KiB
Python

# Copyright (c) 2014 eBay Software Foundation
# 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.
import mock
import testtools
from troveclient import base
from troveclient.v1 import clusters
"""
Unit tests for clusters.py
"""
class ClusterTest(testtools.TestCase):
def setUp(self):
super(ClusterTest, self).setUp()
def tearDown(self):
super(ClusterTest, self).tearDown()
@mock.patch.object(clusters.Cluster, '__init__', return_value=None)
def test___repr__(self, mock_init):
cluster = clusters.Cluster()
cluster.name = "cluster-1"
self.assertEqual('<Cluster: cluster-1>', cluster.__repr__())
@mock.patch.object(clusters.Cluster, '__init__', return_value=None)
def test_delete(self, mock_init):
cluster = clusters.Cluster()
cluster.manager = mock.Mock()
db_delete_mock = mock.Mock(return_value=None)
cluster.manager.delete = db_delete_mock
cluster.delete()
self.assertEqual(1, db_delete_mock.call_count)
class ClustersTest(testtools.TestCase):
def setUp(self):
super(ClustersTest, self).setUp()
def tearDown(self):
super(ClustersTest, self).tearDown()
@mock.patch.object(clusters.Clusters, '__init__', return_value=None)
def get_clusters(self, mock_init):
clusters_test = clusters.Clusters()
clusters_test.api = mock.Mock()
clusters_test.api.client = mock.Mock()
clusters_test.resource_class = mock.Mock(return_value="cluster-1")
return clusters_test
def test_create(self):
def side_effect_func(path, body, resp_key):
return path, body, resp_key
clusters_test = self.get_clusters()
clusters_test._create = mock.Mock(side_effect=side_effect_func)
instances = [{'flavor-id': 11, 'volume': 2}]
locality = 'affinity'
extended_properties = {
'num_configsvr': 5,
'num_mongos': 7,
'configsvr_volume_size': 11,
'configsvr_volume_type': 'foo_type',
'mongos_volume_size': 12,
'mongos_volume_type': 'bar_type'}
configuration = 'test-config'
path, body, resp_key = clusters_test.create("test-name", "datastore",
"datastore-version",
instances, locality,
extended_properties,
configuration)
self.assertEqual("/clusters", path)
self.assertEqual("cluster", resp_key)
self.assertEqual("test-name", body["cluster"]["name"])
self.assertEqual("datastore", body["cluster"]["datastore"]["type"])
self.assertEqual("datastore-version",
body["cluster"]["datastore"]["version"])
self.assertEqual(instances, body["cluster"]["instances"])
self.assertEqual(locality, body["cluster"]["locality"])
self.assertEqual(extended_properties,
body["cluster"]["extended_properties"])
self.assertEqual(configuration, body["cluster"]["configuration"])
def test_list(self):
page_mock = mock.Mock()
clusters_test = self.get_clusters()
clusters_test._paginated = page_mock
limit = "test-limit"
marker = "test-marker"
clusters_test.list(limit, marker)
page_mock.assert_called_with("/clusters", "clusters", limit, marker)
@mock.patch.object(base, 'getid', return_value="cluster1")
def test_get(self, mock_id):
def side_effect_func(path, inst):
return path, inst
clusters_test = self.get_clusters()
clusters_test._get = mock.Mock(side_effect=side_effect_func)
self.assertEqual(('/clusters/cluster1', 'cluster'),
clusters_test.get(1))
def test_upgrade(self):
resp = mock.Mock()
resp.status_code = 200
body = None
clusters_test = self.get_clusters()
clusters_test.api.client.post = mock.Mock(return_value=(resp, body))
clusters_test.upgrade('cluster1', '5.6')
resp.status_code = 500
self.assertRaises(Exception, clusters_test.upgrade, 'cluster1', '5.6')
def test_delete(self):
resp = mock.Mock()
resp.status_code = 200
body = None
clusters_test = self.get_clusters()
clusters_test.api.client.delete = mock.Mock(return_value=(resp, body))
clusters_test.delete('cluster1')
resp.status_code = 500
self.assertRaises(Exception, clusters_test.delete, 'cluster1')
class ClusterStatusTest(testtools.TestCase):
def test_constants(self):
self.assertEqual("ACTIVE", clusters.ClusterStatus.ACTIVE)
self.assertEqual("BUILD", clusters.ClusterStatus.BUILD)
self.assertEqual("FAILED", clusters.ClusterStatus.FAILED)
self.assertEqual("SHUTDOWN", clusters.ClusterStatus.SHUTDOWN)