
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>
146 lines
5.4 KiB
Python
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)
|