Blackify openstack.clustering
Black used with the '-l 79 -S' flags. A future change will ignore this commit in git-blame history by adding a 'git-blame-ignore-revs' file. Change-Id: I4f7bb54ac0e751ab73479cf17f19593f6bc73014 Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
This commit is contained in:
parent
073abda5a9
commit
c2ff7336ce
@ -16,7 +16,6 @@ from openstack import resource
|
|||||||
|
|
||||||
|
|
||||||
class AsyncResource(resource.Resource):
|
class AsyncResource(resource.Resource):
|
||||||
|
|
||||||
def delete(self, session, error_message=None):
|
def delete(self, session, error_message=None):
|
||||||
"""Delete the remote resource based on this instance.
|
"""Delete the remote resource based on this instance.
|
||||||
|
|
||||||
@ -39,6 +38,6 @@ class AsyncResource(resource.Resource):
|
|||||||
location = response.headers['Location']
|
location = response.headers['Location']
|
||||||
action_id = location.split('/')[-1]
|
action_id = location.split('/')[-1]
|
||||||
action = _action.Action.existing(
|
action = _action.Action.existing(
|
||||||
id=action_id,
|
id=action_id, connection=self._connection
|
||||||
connection=self._connection)
|
)
|
||||||
return action
|
return action
|
||||||
|
@ -132,8 +132,9 @@ class Proxy(proxy.Proxy):
|
|||||||
:returns: One :class:`~openstack.clustering.v1.profile.Profile` object
|
:returns: One :class:`~openstack.clustering.v1.profile.Profile` object
|
||||||
or None
|
or None
|
||||||
"""
|
"""
|
||||||
return self._find(_profile.Profile, name_or_id,
|
return self._find(
|
||||||
ignore_missing=ignore_missing)
|
_profile.Profile, name_or_id, ignore_missing=ignore_missing
|
||||||
|
)
|
||||||
|
|
||||||
def get_profile(self, profile):
|
def get_profile(self, profile):
|
||||||
"""Get a single profile.
|
"""Get a single profile.
|
||||||
@ -231,8 +232,9 @@ class Proxy(proxy.Proxy):
|
|||||||
server = self._get_resource(_cluster.Cluster, cluster)
|
server = self._get_resource(_cluster.Cluster, cluster)
|
||||||
return server.force_delete(self)
|
return server.force_delete(self)
|
||||||
else:
|
else:
|
||||||
return self._delete(_cluster.Cluster, cluster,
|
return self._delete(
|
||||||
ignore_missing=ignore_missing)
|
_cluster.Cluster, cluster, ignore_missing=ignore_missing
|
||||||
|
)
|
||||||
|
|
||||||
def find_cluster(self, name_or_id, ignore_missing=True):
|
def find_cluster(self, name_or_id, ignore_missing=True):
|
||||||
"""Find a single cluster.
|
"""Find a single cluster.
|
||||||
@ -246,8 +248,9 @@ class Proxy(proxy.Proxy):
|
|||||||
:returns: One :class:`~openstack.clustering.v1.cluster.Cluster` object
|
:returns: One :class:`~openstack.clustering.v1.cluster.Cluster` object
|
||||||
or None
|
or None
|
||||||
"""
|
"""
|
||||||
return self._find(_cluster.Cluster, name_or_id,
|
return self._find(
|
||||||
ignore_missing=ignore_missing)
|
_cluster.Cluster, name_or_id, ignore_missing=ignore_missing
|
||||||
|
)
|
||||||
|
|
||||||
def get_cluster(self, cluster):
|
def get_cluster(self, cluster):
|
||||||
"""Get a single cluster.
|
"""Get a single cluster.
|
||||||
@ -495,8 +498,9 @@ class Proxy(proxy.Proxy):
|
|||||||
|
|
||||||
:returns: A dictionary containing the list of attribute values.
|
:returns: A dictionary containing the list of attribute values.
|
||||||
"""
|
"""
|
||||||
return self._list(_cluster_attr.ClusterAttr, cluster_id=cluster,
|
return self._list(
|
||||||
path=path)
|
_cluster_attr.ClusterAttr, cluster_id=cluster, path=path
|
||||||
|
)
|
||||||
|
|
||||||
def check_cluster(self, cluster, **params):
|
def check_cluster(self, cluster, **params):
|
||||||
"""Check a cluster.
|
"""Check a cluster.
|
||||||
@ -569,8 +573,9 @@ class Proxy(proxy.Proxy):
|
|||||||
server = self._get_resource(_node.Node, node)
|
server = self._get_resource(_node.Node, node)
|
||||||
return server.force_delete(self)
|
return server.force_delete(self)
|
||||||
else:
|
else:
|
||||||
return self._delete(_node.Node, node,
|
return self._delete(
|
||||||
ignore_missing=ignore_missing)
|
_node.Node, node, ignore_missing=ignore_missing
|
||||||
|
)
|
||||||
|
|
||||||
def find_node(self, name_or_id, ignore_missing=True):
|
def find_node(self, name_or_id, ignore_missing=True):
|
||||||
"""Find a single node.
|
"""Find a single node.
|
||||||
@ -584,8 +589,9 @@ class Proxy(proxy.Proxy):
|
|||||||
:returns: One :class:`~openstack.clustering.v1.node.Node` object
|
:returns: One :class:`~openstack.clustering.v1.node.Node` object
|
||||||
or None.
|
or None.
|
||||||
"""
|
"""
|
||||||
return self._find(_node.Node, name_or_id,
|
return self._find(
|
||||||
ignore_missing=ignore_missing)
|
_node.Node, name_or_id, ignore_missing=ignore_missing
|
||||||
|
)
|
||||||
|
|
||||||
def get_node(self, node, details=False):
|
def get_node(self, node, details=False):
|
||||||
"""Get a single node.
|
"""Get a single node.
|
||||||
@ -755,8 +761,9 @@ class Proxy(proxy.Proxy):
|
|||||||
:returns: A policy object or None.
|
:returns: A policy object or None.
|
||||||
:rtype: :class:`~openstack.clustering.v1.policy.Policy`
|
:rtype: :class:`~openstack.clustering.v1.policy.Policy`
|
||||||
"""
|
"""
|
||||||
return self._find(_policy.Policy, name_or_id,
|
return self._find(
|
||||||
ignore_missing=ignore_missing)
|
_policy.Policy, name_or_id, ignore_missing=ignore_missing
|
||||||
|
)
|
||||||
|
|
||||||
def get_policy(self, policy):
|
def get_policy(self, policy):
|
||||||
"""Get a single policy.
|
"""Get a single policy.
|
||||||
@ -834,8 +841,9 @@ class Proxy(proxy.Proxy):
|
|||||||
:returns: A generator of cluster-policy binding instances.
|
:returns: A generator of cluster-policy binding instances.
|
||||||
"""
|
"""
|
||||||
cluster_id = resource.Resource._get_id(cluster)
|
cluster_id = resource.Resource._get_id(cluster)
|
||||||
return self._list(_cluster_policy.ClusterPolicy, cluster_id=cluster_id,
|
return self._list(
|
||||||
**query)
|
_cluster_policy.ClusterPolicy, cluster_id=cluster_id, **query
|
||||||
|
)
|
||||||
|
|
||||||
def get_cluster_policy(self, cluster_policy, cluster):
|
def get_cluster_policy(self, cluster_policy, cluster):
|
||||||
"""Get a cluster-policy binding.
|
"""Get a cluster-policy binding.
|
||||||
@ -851,8 +859,9 @@ class Proxy(proxy.Proxy):
|
|||||||
:raises: :class:`~openstack.exceptions.ResourceNotFound` when no
|
:raises: :class:`~openstack.exceptions.ResourceNotFound` when no
|
||||||
cluster-policy binding matching the criteria could be found.
|
cluster-policy binding matching the criteria could be found.
|
||||||
"""
|
"""
|
||||||
return self._get(_cluster_policy.ClusterPolicy, cluster_policy,
|
return self._get(
|
||||||
cluster_id=cluster)
|
_cluster_policy.ClusterPolicy, cluster_policy, cluster_id=cluster
|
||||||
|
)
|
||||||
|
|
||||||
def create_receiver(self, **attrs):
|
def create_receiver(self, **attrs):
|
||||||
"""Create a new receiver from attributes.
|
"""Create a new receiver from attributes.
|
||||||
@ -890,8 +899,9 @@ class Proxy(proxy.Proxy):
|
|||||||
|
|
||||||
:returns: ``None``
|
:returns: ``None``
|
||||||
"""
|
"""
|
||||||
self._delete(_receiver.Receiver, receiver,
|
self._delete(
|
||||||
ignore_missing=ignore_missing)
|
_receiver.Receiver, receiver, ignore_missing=ignore_missing
|
||||||
|
)
|
||||||
|
|
||||||
def find_receiver(self, name_or_id, ignore_missing=True):
|
def find_receiver(self, name_or_id, ignore_missing=True):
|
||||||
"""Find a single receiver.
|
"""Find a single receiver.
|
||||||
@ -905,8 +915,9 @@ class Proxy(proxy.Proxy):
|
|||||||
:returns: A receiver object or None.
|
:returns: A receiver object or None.
|
||||||
:rtype: :class:`~openstack.clustering.v1.receiver.Receiver`
|
:rtype: :class:`~openstack.clustering.v1.receiver.Receiver`
|
||||||
"""
|
"""
|
||||||
return self._find(_receiver.Receiver, name_or_id,
|
return self._find(
|
||||||
ignore_missing=ignore_missing)
|
_receiver.Receiver, name_or_id, ignore_missing=ignore_missing
|
||||||
|
)
|
||||||
|
|
||||||
def get_receiver(self, receiver):
|
def get_receiver(self, receiver):
|
||||||
"""Get a single receiver.
|
"""Get a single receiver.
|
||||||
@ -1035,8 +1046,9 @@ class Proxy(proxy.Proxy):
|
|||||||
"""
|
"""
|
||||||
return self._list(_event.Event, **query)
|
return self._list(_event.Event, **query)
|
||||||
|
|
||||||
def wait_for_status(self, res, status, failures=None, interval=2,
|
def wait_for_status(
|
||||||
wait=120):
|
self, res, status, failures=None, interval=2, wait=120
|
||||||
|
):
|
||||||
"""Wait for a resource to be in a particular status.
|
"""Wait for a resource to be in a particular status.
|
||||||
|
|
||||||
:param res: The resource to wait on to reach the specified status.
|
:param res: The resource to wait on to reach the specified status.
|
||||||
@ -1059,7 +1071,8 @@ class Proxy(proxy.Proxy):
|
|||||||
"""
|
"""
|
||||||
failures = [] if failures is None else failures
|
failures = [] if failures is None else failures
|
||||||
return resource.wait_for_status(
|
return resource.wait_for_status(
|
||||||
self, res, status, failures, interval, wait)
|
self, res, status, failures, interval, wait
|
||||||
|
)
|
||||||
|
|
||||||
def wait_for_delete(self, res, interval=2, wait=120):
|
def wait_for_delete(self, res, interval=2, wait=120):
|
||||||
"""Wait for a resource to be deleted.
|
"""Wait for a resource to be deleted.
|
||||||
|
@ -27,8 +27,14 @@ class Action(resource.Resource):
|
|||||||
commit_method = 'PATCH'
|
commit_method = 'PATCH'
|
||||||
|
|
||||||
_query_mapping = resource.QueryParameters(
|
_query_mapping = resource.QueryParameters(
|
||||||
'name', 'action', 'status', 'sort', 'global_project',
|
'name',
|
||||||
'cluster_id', target_id='target')
|
'action',
|
||||||
|
'status',
|
||||||
|
'sort',
|
||||||
|
'global_project',
|
||||||
|
'cluster_id',
|
||||||
|
target_id='target',
|
||||||
|
)
|
||||||
|
|
||||||
# Properties
|
# Properties
|
||||||
#: Name of the action.
|
#: Name of the action.
|
||||||
|
@ -29,7 +29,8 @@ class Cluster(_async_resource.AsyncResource, metadata.MetadataMixin):
|
|||||||
commit_method = 'PATCH'
|
commit_method = 'PATCH'
|
||||||
|
|
||||||
_query_mapping = resource.QueryParameters(
|
_query_mapping = resource.QueryParameters(
|
||||||
'name', 'status', 'sort', 'global_project')
|
'name', 'status', 'sort', 'global_project'
|
||||||
|
)
|
||||||
|
|
||||||
# Properties
|
# Properties
|
||||||
#: The name of the cluster.
|
#: The name of the cluster.
|
||||||
@ -96,9 +97,7 @@ class Cluster(_async_resource.AsyncResource, metadata.MetadataMixin):
|
|||||||
def del_nodes(self, session, nodes, **params):
|
def del_nodes(self, session, nodes, **params):
|
||||||
data = {'nodes': nodes}
|
data = {'nodes': nodes}
|
||||||
data.update(params)
|
data.update(params)
|
||||||
body = {
|
body = {'del_nodes': data}
|
||||||
'del_nodes': data
|
|
||||||
}
|
|
||||||
return self.action(session, body)
|
return self.action(session, body)
|
||||||
|
|
||||||
def replace_nodes(self, session, nodes):
|
def replace_nodes(self, session, nodes):
|
||||||
@ -126,17 +125,13 @@ class Cluster(_async_resource.AsyncResource, metadata.MetadataMixin):
|
|||||||
return self.action(session, body)
|
return self.action(session, body)
|
||||||
|
|
||||||
def resize(self, session, **params):
|
def resize(self, session, **params):
|
||||||
body = {
|
body = {'resize': params}
|
||||||
'resize': params
|
|
||||||
}
|
|
||||||
return self.action(session, body)
|
return self.action(session, body)
|
||||||
|
|
||||||
def policy_attach(self, session, policy_id, **params):
|
def policy_attach(self, session, policy_id, **params):
|
||||||
data = {'policy_id': policy_id}
|
data = {'policy_id': policy_id}
|
||||||
data.update(params)
|
data.update(params)
|
||||||
body = {
|
body = {'policy_attach': data}
|
||||||
'policy_attach': data
|
|
||||||
}
|
|
||||||
return self.action(session, body)
|
return self.action(session, body)
|
||||||
|
|
||||||
def policy_detach(self, session, policy_id):
|
def policy_detach(self, session, policy_id):
|
||||||
@ -150,21 +145,15 @@ class Cluster(_async_resource.AsyncResource, metadata.MetadataMixin):
|
|||||||
def policy_update(self, session, policy_id, **params):
|
def policy_update(self, session, policy_id, **params):
|
||||||
data = {'policy_id': policy_id}
|
data = {'policy_id': policy_id}
|
||||||
data.update(params)
|
data.update(params)
|
||||||
body = {
|
body = {'policy_update': data}
|
||||||
'policy_update': data
|
|
||||||
}
|
|
||||||
return self.action(session, body)
|
return self.action(session, body)
|
||||||
|
|
||||||
def check(self, session, **params):
|
def check(self, session, **params):
|
||||||
body = {
|
body = {'check': params}
|
||||||
'check': params
|
|
||||||
}
|
|
||||||
return self.action(session, body)
|
return self.action(session, body)
|
||||||
|
|
||||||
def recover(self, session, **params):
|
def recover(self, session, **params):
|
||||||
body = {
|
body = {'recover': params}
|
||||||
'recover': params
|
|
||||||
}
|
|
||||||
return self.action(session, body)
|
return self.action(session, body)
|
||||||
|
|
||||||
def op(self, session, operation, **params):
|
def op(self, session, operation, **params):
|
||||||
@ -177,8 +166,7 @@ class Cluster(_async_resource.AsyncResource, metadata.MetadataMixin):
|
|||||||
:returns: A dictionary containing the action ID.
|
:returns: A dictionary containing the action ID.
|
||||||
"""
|
"""
|
||||||
url = utils.urljoin(self.base_path, self.id, 'ops')
|
url = utils.urljoin(self.base_path, self.id, 'ops')
|
||||||
resp = session.post(url,
|
resp = session.post(url, json={operation: params})
|
||||||
json={operation: params})
|
|
||||||
return resp.json()
|
return resp.json()
|
||||||
|
|
||||||
def force_delete(self, session):
|
def force_delete(self, session):
|
||||||
|
@ -23,7 +23,8 @@ class ClusterPolicy(resource.Resource):
|
|||||||
allow_fetch = True
|
allow_fetch = True
|
||||||
|
|
||||||
_query_mapping = resource.QueryParameters(
|
_query_mapping = resource.QueryParameters(
|
||||||
'sort', 'policy_name', 'policy_type', is_enabled='enabled')
|
'sort', 'policy_name', 'policy_type', is_enabled='enabled'
|
||||||
|
)
|
||||||
|
|
||||||
# Properties
|
# Properties
|
||||||
#: ID of the policy object.
|
#: ID of the policy object.
|
||||||
|
@ -24,8 +24,14 @@ class Event(resource.Resource):
|
|||||||
allow_fetch = True
|
allow_fetch = True
|
||||||
|
|
||||||
_query_mapping = resource.QueryParameters(
|
_query_mapping = resource.QueryParameters(
|
||||||
'cluster_id', 'action', 'level', 'sort', 'global_project',
|
'cluster_id',
|
||||||
obj_id='oid', obj_name='oname', obj_type='otype',
|
'action',
|
||||||
|
'level',
|
||||||
|
'sort',
|
||||||
|
'global_project',
|
||||||
|
obj_id='oid',
|
||||||
|
obj_name='oname',
|
||||||
|
obj_type='otype',
|
||||||
)
|
)
|
||||||
|
|
||||||
# Properties
|
# Properties
|
||||||
|
@ -30,8 +30,13 @@ class Node(_async_resource.AsyncResource):
|
|||||||
commit_method = 'PATCH'
|
commit_method = 'PATCH'
|
||||||
|
|
||||||
_query_mapping = resource.QueryParameters(
|
_query_mapping = resource.QueryParameters(
|
||||||
'show_details', 'name', 'sort', 'global_project', 'cluster_id',
|
'show_details',
|
||||||
'status')
|
'name',
|
||||||
|
'sort',
|
||||||
|
'global_project',
|
||||||
|
'cluster_id',
|
||||||
|
'status',
|
||||||
|
)
|
||||||
|
|
||||||
# Properties
|
# Properties
|
||||||
#: The name of the node.
|
#: The name of the node.
|
||||||
@ -98,9 +103,7 @@ class Node(_async_resource.AsyncResource):
|
|||||||
:param session: A session object used for sending request.
|
:param session: A session object used for sending request.
|
||||||
:returns: A dictionary containing the action ID.
|
:returns: A dictionary containing the action ID.
|
||||||
"""
|
"""
|
||||||
body = {
|
body = {'check': params}
|
||||||
'check': params
|
|
||||||
}
|
|
||||||
return self._action(session, body)
|
return self._action(session, body)
|
||||||
|
|
||||||
def recover(self, session, **params):
|
def recover(self, session, **params):
|
||||||
@ -109,9 +112,7 @@ class Node(_async_resource.AsyncResource):
|
|||||||
:param session: A session object used for sending request.
|
:param session: A session object used for sending request.
|
||||||
:returns: A dictionary containing the action ID.
|
:returns: A dictionary containing the action ID.
|
||||||
"""
|
"""
|
||||||
body = {
|
body = {'recover': params}
|
||||||
'recover': params
|
|
||||||
}
|
|
||||||
return self._action(session, body)
|
return self._action(session, body)
|
||||||
|
|
||||||
def op(self, session, operation, **params):
|
def op(self, session, operation, **params):
|
||||||
@ -124,8 +125,7 @@ class Node(_async_resource.AsyncResource):
|
|||||||
:returns: A dictionary containing the action ID.
|
:returns: A dictionary containing the action ID.
|
||||||
"""
|
"""
|
||||||
url = utils.urljoin(self.base_path, self.id, 'ops')
|
url = utils.urljoin(self.base_path, self.id, 'ops')
|
||||||
resp = session.post(url,
|
resp = session.post(url, json={operation: params})
|
||||||
json={operation: params})
|
|
||||||
return resp.json()
|
return resp.json()
|
||||||
|
|
||||||
def adopt(self, session, preview=False, **params):
|
def adopt(self, session, preview=False, **params):
|
||||||
@ -143,7 +143,7 @@ class Node(_async_resource.AsyncResource):
|
|||||||
'identity': params.get('identity'),
|
'identity': params.get('identity'),
|
||||||
'overrides': params.get('overrides'),
|
'overrides': params.get('overrides'),
|
||||||
'type': params.get('type'),
|
'type': params.get('type'),
|
||||||
'snapshot': params.get('snapshot')
|
'snapshot': params.get('snapshot'),
|
||||||
}
|
}
|
||||||
else:
|
else:
|
||||||
path = 'adopt'
|
path = 'adopt'
|
||||||
|
@ -28,7 +28,8 @@ class Policy(resource.Resource):
|
|||||||
commit_method = 'PATCH'
|
commit_method = 'PATCH'
|
||||||
|
|
||||||
_query_mapping = resource.QueryParameters(
|
_query_mapping = resource.QueryParameters(
|
||||||
'name', 'type', 'sort', 'global_project')
|
'name', 'type', 'sort', 'global_project'
|
||||||
|
)
|
||||||
|
|
||||||
# Properties
|
# Properties
|
||||||
#: The name of the policy.
|
#: The name of the policy.
|
||||||
|
@ -28,7 +28,8 @@ class Profile(resource.Resource):
|
|||||||
commit_method = 'PATCH'
|
commit_method = 'PATCH'
|
||||||
|
|
||||||
_query_mapping = resource.QueryParameters(
|
_query_mapping = resource.QueryParameters(
|
||||||
'sort', 'global_project', 'type', 'name')
|
'sort', 'global_project', 'type', 'name'
|
||||||
|
)
|
||||||
|
|
||||||
# Bodyerties
|
# Bodyerties
|
||||||
#: The name of the profile
|
#: The name of the profile
|
||||||
|
@ -28,8 +28,14 @@ class Receiver(resource.Resource):
|
|||||||
commit_method = 'PATCH'
|
commit_method = 'PATCH'
|
||||||
|
|
||||||
_query_mapping = resource.QueryParameters(
|
_query_mapping = resource.QueryParameters(
|
||||||
'name', 'type', 'cluster_id', 'action', 'sort', 'global_project',
|
'name',
|
||||||
user_id='user')
|
'type',
|
||||||
|
'cluster_id',
|
||||||
|
'action',
|
||||||
|
'sort',
|
||||||
|
'global_project',
|
||||||
|
user_id='user',
|
||||||
|
)
|
||||||
|
|
||||||
# Properties
|
# Properties
|
||||||
#: The name of the receiver.
|
#: The name of the receiver.
|
||||||
|
@ -28,9 +28,8 @@ class TestCluster(base.BaseFunctionalTest):
|
|||||||
self.cidr = '10.99.99.0/16'
|
self.cidr = '10.99.99.0/16'
|
||||||
|
|
||||||
self.network, self.subnet = test_network.create_network(
|
self.network, self.subnet = test_network.create_network(
|
||||||
self.conn,
|
self.conn, self.getUniqueString(), self.cidr
|
||||||
self.getUniqueString(),
|
)
|
||||||
self.cidr)
|
|
||||||
self.assertIsNotNone(self.network)
|
self.assertIsNotNone(self.network)
|
||||||
|
|
||||||
profile_attrs = {
|
profile_attrs = {
|
||||||
@ -42,8 +41,10 @@ class TestCluster(base.BaseFunctionalTest):
|
|||||||
'name': self.getUniqueString(),
|
'name': self.getUniqueString(),
|
||||||
'flavor': self.flavor.name,
|
'flavor': self.flavor.name,
|
||||||
'image': self.image.name,
|
'image': self.image.name,
|
||||||
'networks': [{'network': self.network.id}]
|
'networks': [{'network': self.network.id}],
|
||||||
}}}
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
self.profile = self.conn.clustering.create_profile(**profile_attrs)
|
self.profile = self.conn.clustering.create_profile(**profile_attrs)
|
||||||
self.assertIsNotNone(self.profile)
|
self.assertIsNotNone(self.profile)
|
||||||
@ -59,15 +60,16 @@ class TestCluster(base.BaseFunctionalTest):
|
|||||||
|
|
||||||
self.cluster = self.conn.clustering.create_cluster(**cluster_spec)
|
self.cluster = self.conn.clustering.create_cluster(**cluster_spec)
|
||||||
self.conn.clustering.wait_for_status(
|
self.conn.clustering.wait_for_status(
|
||||||
self.cluster, 'ACTIVE',
|
self.cluster, 'ACTIVE', wait=self._wait_for_timeout
|
||||||
wait=self._wait_for_timeout)
|
)
|
||||||
assert isinstance(self.cluster, cluster.Cluster)
|
assert isinstance(self.cluster, cluster.Cluster)
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
if self.cluster:
|
if self.cluster:
|
||||||
self.conn.clustering.delete_cluster(self.cluster.id)
|
self.conn.clustering.delete_cluster(self.cluster.id)
|
||||||
self.conn.clustering.wait_for_delete(
|
self.conn.clustering.wait_for_delete(
|
||||||
self.cluster, wait=self._wait_for_timeout)
|
self.cluster, wait=self._wait_for_timeout
|
||||||
|
)
|
||||||
|
|
||||||
test_network.delete_network(self.conn, self.network, self.subnet)
|
test_network.delete_network(self.conn, self.network, self.subnet)
|
||||||
|
|
||||||
@ -90,7 +92,8 @@ class TestCluster(base.BaseFunctionalTest):
|
|||||||
def test_update(self):
|
def test_update(self):
|
||||||
new_cluster_name = self.getUniqueString()
|
new_cluster_name = self.getUniqueString()
|
||||||
sot = self.conn.clustering.update_cluster(
|
sot = self.conn.clustering.update_cluster(
|
||||||
self.cluster, name=new_cluster_name, profile_only=False)
|
self.cluster, name=new_cluster_name, profile_only=False
|
||||||
|
)
|
||||||
|
|
||||||
time.sleep(2)
|
time.sleep(2)
|
||||||
sot = self.conn.clustering.get_cluster(self.cluster)
|
sot = self.conn.clustering.get_cluster(self.cluster)
|
||||||
@ -98,10 +101,12 @@ class TestCluster(base.BaseFunctionalTest):
|
|||||||
|
|
||||||
def test_delete(self):
|
def test_delete(self):
|
||||||
cluster_delete_action = self.conn.clustering.delete_cluster(
|
cluster_delete_action = self.conn.clustering.delete_cluster(
|
||||||
self.cluster.id)
|
self.cluster.id
|
||||||
|
)
|
||||||
|
|
||||||
self.conn.clustering.wait_for_delete(self.cluster,
|
self.conn.clustering.wait_for_delete(
|
||||||
wait=self._wait_for_timeout)
|
self.cluster, wait=self._wait_for_timeout
|
||||||
|
)
|
||||||
|
|
||||||
action = self.conn.clustering.get_action(cluster_delete_action.id)
|
action = self.conn.clustering.get_action(cluster_delete_action.id)
|
||||||
self.assertEqual(action.target_id, self.cluster.id)
|
self.assertEqual(action.target_id, self.cluster.id)
|
||||||
@ -112,10 +117,12 @@ class TestCluster(base.BaseFunctionalTest):
|
|||||||
|
|
||||||
def test_force_delete(self):
|
def test_force_delete(self):
|
||||||
cluster_delete_action = self.conn.clustering.delete_cluster(
|
cluster_delete_action = self.conn.clustering.delete_cluster(
|
||||||
self.cluster.id, False, True)
|
self.cluster.id, False, True
|
||||||
|
)
|
||||||
|
|
||||||
self.conn.clustering.wait_for_delete(self.cluster,
|
self.conn.clustering.wait_for_delete(
|
||||||
wait=self._wait_for_timeout)
|
self.cluster, wait=self._wait_for_timeout
|
||||||
|
)
|
||||||
|
|
||||||
action = self.conn.clustering.get_action(cluster_delete_action.id)
|
action = self.conn.clustering.get_action(cluster_delete_action.id)
|
||||||
self.assertEqual(action.target_id, self.cluster.id)
|
self.assertEqual(action.target_id, self.cluster.id)
|
||||||
|
@ -23,7 +23,6 @@ EXAMPLE = {
|
|||||||
|
|
||||||
|
|
||||||
class TestVersion(base.TestCase):
|
class TestVersion(base.TestCase):
|
||||||
|
|
||||||
def test_basic(self):
|
def test_basic(self):
|
||||||
sot = version.Version()
|
sot = version.Version()
|
||||||
self.assertEqual('version', sot.resource_key)
|
self.assertEqual('version', sot.resource_key)
|
||||||
|
@ -45,7 +45,6 @@ FAKE = {
|
|||||||
|
|
||||||
|
|
||||||
class TestAction(base.TestCase):
|
class TestAction(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestAction, self).setUp()
|
super(TestAction, self).setUp()
|
||||||
|
|
||||||
|
@ -20,12 +20,11 @@ FAKE = {
|
|||||||
},
|
},
|
||||||
'engine': {
|
'engine': {
|
||||||
'revision': '1.0.0',
|
'revision': '1.0.0',
|
||||||
}
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class TestBuildInfo(base.TestCase):
|
class TestBuildInfo(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestBuildInfo, self).setUp()
|
super(TestBuildInfo, self).setUp()
|
||||||
|
|
||||||
|
@ -65,7 +65,6 @@ FAKE_CREATE_RESP = {
|
|||||||
|
|
||||||
|
|
||||||
class TestCluster(base.TestCase):
|
class TestCluster(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestCluster, self).setUp()
|
super(TestCluster, self).setUp()
|
||||||
|
|
||||||
@ -102,13 +101,17 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual(FAKE['dependents'], sot.dependents)
|
self.assertEqual(FAKE['dependents'], sot.dependents)
|
||||||
self.assertTrue(sot.is_profile_only)
|
self.assertTrue(sot.is_profile_only)
|
||||||
|
|
||||||
self.assertDictEqual({"limit": "limit",
|
self.assertDictEqual(
|
||||||
"marker": "marker",
|
{
|
||||||
"name": "name",
|
"limit": "limit",
|
||||||
"status": "status",
|
"marker": "marker",
|
||||||
"sort": "sort",
|
"name": "name",
|
||||||
"global_project": "global_project"},
|
"status": "status",
|
||||||
sot._query_mapping._mapping)
|
"sort": "sort",
|
||||||
|
"global_project": "global_project",
|
||||||
|
},
|
||||||
|
sot._query_mapping._mapping,
|
||||||
|
)
|
||||||
|
|
||||||
def test_scale_in(self):
|
def test_scale_in(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -120,8 +123,7 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual('', sot.scale_in(sess, 3))
|
self.assertEqual('', sot.scale_in(sess, 3))
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {'scale_in': {'count': 3}}
|
body = {'scale_in': {'count': 3}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_scale_out(self):
|
def test_scale_out(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -133,8 +135,7 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual('', sot.scale_out(sess, 3))
|
self.assertEqual('', sot.scale_out(sess, 3))
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {'scale_out': {'count': 3}}
|
body = {'scale_out': {'count': 3}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_resize(self):
|
def test_resize(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -146,8 +147,7 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual('', sot.resize(sess, foo='bar', zoo=5))
|
self.assertEqual('', sot.resize(sess, foo='bar', zoo=5))
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {'resize': {'foo': 'bar', 'zoo': 5}}
|
body = {'resize': {'foo': 'bar', 'zoo': 5}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_add_nodes(self):
|
def test_add_nodes(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -159,8 +159,7 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual('', sot.add_nodes(sess, ['node-33']))
|
self.assertEqual('', sot.add_nodes(sess, ['node-33']))
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {'add_nodes': {'nodes': ['node-33']}}
|
body = {'add_nodes': {'nodes': ['node-33']}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_del_nodes(self):
|
def test_del_nodes(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -172,8 +171,7 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual('', sot.del_nodes(sess, ['node-11']))
|
self.assertEqual('', sot.del_nodes(sess, ['node-11']))
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {'del_nodes': {'nodes': ['node-11']}}
|
body = {'del_nodes': {'nodes': ['node-11']}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_del_nodes_with_params(self):
|
def test_del_nodes_with_params(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -193,8 +191,7 @@ class TestCluster(base.TestCase):
|
|||||||
'destroy_after_deletion': True,
|
'destroy_after_deletion': True,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_replace_nodes(self):
|
def test_replace_nodes(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -206,8 +203,7 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual('', sot.replace_nodes(sess, {'node-22': 'node-44'}))
|
self.assertEqual('', sot.replace_nodes(sess, {'node-22': 'node-44'}))
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {'replace_nodes': {'nodes': {'node-22': 'node-44'}}}
|
body = {'replace_nodes': {'nodes': {'node-22': 'node-44'}}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_policy_attach(self):
|
def test_policy_attach(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -228,8 +224,7 @@ class TestCluster(base.TestCase):
|
|||||||
'enabled': True,
|
'enabled': True,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_policy_detach(self):
|
def test_policy_detach(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -242,8 +237,7 @@ class TestCluster(base.TestCase):
|
|||||||
|
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {'policy_detach': {'policy_id': 'POLICY'}}
|
body = {'policy_detach': {'policy_id': 'POLICY'}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_policy_update(self):
|
def test_policy_update(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -252,20 +246,12 @@ class TestCluster(base.TestCase):
|
|||||||
resp.json = mock.Mock(return_value='')
|
resp.json = mock.Mock(return_value='')
|
||||||
sess = mock.Mock()
|
sess = mock.Mock()
|
||||||
sess.post = mock.Mock(return_value=resp)
|
sess.post = mock.Mock(return_value=resp)
|
||||||
params = {
|
params = {'enabled': False}
|
||||||
'enabled': False
|
|
||||||
}
|
|
||||||
self.assertEqual('', sot.policy_update(sess, 'POLICY', **params))
|
self.assertEqual('', sot.policy_update(sess, 'POLICY', **params))
|
||||||
|
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {
|
body = {'policy_update': {'policy_id': 'POLICY', 'enabled': False}}
|
||||||
'policy_update': {
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
'policy_id': 'POLICY',
|
|
||||||
'enabled': False
|
|
||||||
}
|
|
||||||
}
|
|
||||||
sess.post.assert_called_once_with(url,
|
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_check(self):
|
def test_check(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -277,8 +263,7 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual('', sot.check(sess))
|
self.assertEqual('', sot.check(sess))
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {'check': {}}
|
body = {'check': {}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_recover(self):
|
def test_recover(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -290,8 +275,7 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual('', sot.recover(sess))
|
self.assertEqual('', sot.recover(sess))
|
||||||
url = 'clusters/%s/actions' % sot.id
|
url = 'clusters/%s/actions' % sot.id
|
||||||
body = {'recover': {}}
|
body = {'recover': {}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_operation(self):
|
def test_operation(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
@ -303,8 +287,7 @@ class TestCluster(base.TestCase):
|
|||||||
self.assertEqual('', sot.op(sess, 'dance', style='tango'))
|
self.assertEqual('', sot.op(sess, 'dance', style='tango'))
|
||||||
url = 'clusters/%s/ops' % sot.id
|
url = 'clusters/%s/ops' % sot.id
|
||||||
body = {'dance': {'style': 'tango'}}
|
body = {'dance': {'style': 'tango'}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_force_delete(self):
|
def test_force_delete(self):
|
||||||
sot = cluster.Cluster(**FAKE)
|
sot = cluster.Cluster(**FAKE)
|
||||||
|
@ -23,15 +23,15 @@ FAKE = {
|
|||||||
|
|
||||||
|
|
||||||
class TestClusterAttr(base.TestCase):
|
class TestClusterAttr(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestClusterAttr, self).setUp()
|
super(TestClusterAttr, self).setUp()
|
||||||
|
|
||||||
def test_basic(self):
|
def test_basic(self):
|
||||||
sot = ca.ClusterAttr()
|
sot = ca.ClusterAttr()
|
||||||
self.assertEqual('cluster_attributes', sot.resources_key)
|
self.assertEqual('cluster_attributes', sot.resources_key)
|
||||||
self.assertEqual('/clusters/%(cluster_id)s/attrs/%(path)s',
|
self.assertEqual(
|
||||||
sot.base_path)
|
'/clusters/%(cluster_id)s/attrs/%(path)s', sot.base_path
|
||||||
|
)
|
||||||
self.assertTrue(sot.allow_list)
|
self.assertTrue(sot.allow_list)
|
||||||
|
|
||||||
def test_instantiate(self):
|
def test_instantiate(self):
|
||||||
|
@ -26,7 +26,6 @@ FAKE = {
|
|||||||
|
|
||||||
|
|
||||||
class TestClusterPolicy(base.TestCase):
|
class TestClusterPolicy(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestClusterPolicy, self).setUp()
|
super(TestClusterPolicy, self).setUp()
|
||||||
|
|
||||||
@ -34,18 +33,21 @@ class TestClusterPolicy(base.TestCase):
|
|||||||
sot = cluster_policy.ClusterPolicy()
|
sot = cluster_policy.ClusterPolicy()
|
||||||
self.assertEqual('cluster_policy', sot.resource_key)
|
self.assertEqual('cluster_policy', sot.resource_key)
|
||||||
self.assertEqual('cluster_policies', sot.resources_key)
|
self.assertEqual('cluster_policies', sot.resources_key)
|
||||||
self.assertEqual('/clusters/%(cluster_id)s/policies',
|
self.assertEqual('/clusters/%(cluster_id)s/policies', sot.base_path)
|
||||||
sot.base_path)
|
|
||||||
self.assertTrue(sot.allow_fetch)
|
self.assertTrue(sot.allow_fetch)
|
||||||
self.assertTrue(sot.allow_list)
|
self.assertTrue(sot.allow_list)
|
||||||
|
|
||||||
self.assertDictEqual({"policy_name": "policy_name",
|
self.assertDictEqual(
|
||||||
"policy_type": "policy_type",
|
{
|
||||||
"is_enabled": "enabled",
|
"policy_name": "policy_name",
|
||||||
"sort": "sort",
|
"policy_type": "policy_type",
|
||||||
"limit": "limit",
|
"is_enabled": "enabled",
|
||||||
"marker": "marker"},
|
"sort": "sort",
|
||||||
sot._query_mapping._mapping)
|
"limit": "limit",
|
||||||
|
"marker": "marker",
|
||||||
|
},
|
||||||
|
sot._query_mapping._mapping,
|
||||||
|
)
|
||||||
|
|
||||||
def test_instantiate(self):
|
def test_instantiate(self):
|
||||||
sot = cluster_policy.ClusterPolicy(**FAKE)
|
sot = cluster_policy.ClusterPolicy(**FAKE)
|
||||||
|
@ -28,16 +28,12 @@ FAKE = {
|
|||||||
'timestamp': '2016-10-10T12:46:36.000000',
|
'timestamp': '2016-10-10T12:46:36.000000',
|
||||||
'user': '5e5bf8027826429c96af157f68dc9072',
|
'user': '5e5bf8027826429c96af157f68dc9072',
|
||||||
'meta_data': {
|
'meta_data': {
|
||||||
"action": {
|
"action": {"created_at": "2019-07-13T13:18:18Z", "outputs": {}}
|
||||||
"created_at": "2019-07-13T13:18:18Z",
|
},
|
||||||
"outputs": {}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class TestEvent(base.TestCase):
|
class TestEvent(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestEvent, self).setUp()
|
super(TestEvent, self).setUp()
|
||||||
|
|
||||||
|
@ -33,12 +33,11 @@ FAKE = {
|
|||||||
'created_at': '2015-10-10T12:46:36.000000',
|
'created_at': '2015-10-10T12:46:36.000000',
|
||||||
'updated_at': '2016-10-10T12:46:36.000000',
|
'updated_at': '2016-10-10T12:46:36.000000',
|
||||||
'init_at': '2015-10-10T12:46:36.000000',
|
'init_at': '2015-10-10T12:46:36.000000',
|
||||||
'tainted': True
|
'tainted': True,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class TestNode(base.TestCase):
|
class TestNode(base.TestCase):
|
||||||
|
|
||||||
def test_basic(self):
|
def test_basic(self):
|
||||||
sot = node.Node()
|
sot = node.Node()
|
||||||
self.assertEqual('node', sot.resource_key)
|
self.assertEqual('node', sot.resource_key)
|
||||||
@ -78,8 +77,7 @@ class TestNode(base.TestCase):
|
|||||||
self.assertEqual('', sot.check(sess))
|
self.assertEqual('', sot.check(sess))
|
||||||
url = 'nodes/%s/actions' % sot.id
|
url = 'nodes/%s/actions' % sot.id
|
||||||
body = {'check': {}}
|
body = {'check': {}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_recover(self):
|
def test_recover(self):
|
||||||
sot = node.Node(**FAKE)
|
sot = node.Node(**FAKE)
|
||||||
@ -91,8 +89,7 @@ class TestNode(base.TestCase):
|
|||||||
self.assertEqual('', sot.recover(sess))
|
self.assertEqual('', sot.recover(sess))
|
||||||
url = 'nodes/%s/actions' % sot.id
|
url = 'nodes/%s/actions' % sot.id
|
||||||
body = {'recover': {}}
|
body = {'recover': {}}
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(url, json=body)
|
||||||
json=body)
|
|
||||||
|
|
||||||
def test_operation(self):
|
def test_operation(self):
|
||||||
sot = node.Node(**FAKE)
|
sot = node.Node(**FAKE)
|
||||||
@ -103,8 +100,9 @@ class TestNode(base.TestCase):
|
|||||||
sess.post = mock.Mock(return_value=resp)
|
sess.post = mock.Mock(return_value=resp)
|
||||||
self.assertEqual('', sot.op(sess, 'dance', style='tango'))
|
self.assertEqual('', sot.op(sess, 'dance', style='tango'))
|
||||||
url = 'nodes/%s/ops' % sot.id
|
url = 'nodes/%s/ops' % sot.id
|
||||||
sess.post.assert_called_once_with(url,
|
sess.post.assert_called_once_with(
|
||||||
json={'dance': {'style': 'tango'}})
|
url, json={'dance': {'style': 'tango'}}
|
||||||
|
)
|
||||||
|
|
||||||
def test_adopt_preview(self):
|
def test_adopt_preview(self):
|
||||||
sot = node.Node.new()
|
sot = node.Node.new()
|
||||||
@ -118,12 +116,11 @@ class TestNode(base.TestCase):
|
|||||||
'identity': 'fake-resource-id',
|
'identity': 'fake-resource-id',
|
||||||
'overrides': {},
|
'overrides': {},
|
||||||
'type': 'os.nova.server-1.0',
|
'type': 'os.nova.server-1.0',
|
||||||
'snapshot': False
|
'snapshot': False,
|
||||||
}
|
}
|
||||||
res = sot.adopt(sess, True, **attrs)
|
res = sot.adopt(sess, True, **attrs)
|
||||||
self.assertEqual({"foo": "bar"}, res)
|
self.assertEqual({"foo": "bar"}, res)
|
||||||
sess.post.assert_called_once_with("nodes/adopt-preview",
|
sess.post.assert_called_once_with("nodes/adopt-preview", json=attrs)
|
||||||
json=attrs)
|
|
||||||
|
|
||||||
def test_adopt(self):
|
def test_adopt(self):
|
||||||
sot = node.Node.new()
|
sot = node.Node.new()
|
||||||
@ -136,8 +133,9 @@ class TestNode(base.TestCase):
|
|||||||
|
|
||||||
res = sot.adopt(sess, False, param="value")
|
res = sot.adopt(sess, False, param="value")
|
||||||
self.assertEqual(sot, res)
|
self.assertEqual(sot, res)
|
||||||
sess.post.assert_called_once_with("nodes/adopt",
|
sess.post.assert_called_once_with(
|
||||||
json={"param": "value"})
|
"nodes/adopt", json={"param": "value"}
|
||||||
|
)
|
||||||
|
|
||||||
def test_force_delete(self):
|
def test_force_delete(self):
|
||||||
sot = node.Node(**FAKE)
|
sot = node.Node(**FAKE)
|
||||||
@ -158,7 +156,6 @@ class TestNode(base.TestCase):
|
|||||||
|
|
||||||
|
|
||||||
class TestNodeDetail(base.TestCase):
|
class TestNodeDetail(base.TestCase):
|
||||||
|
|
||||||
def test_basic(self):
|
def test_basic(self):
|
||||||
sot = node.NodeDetail()
|
sot = node.NodeDetail()
|
||||||
self.assertEqual('/nodes/%(node_id)s?show_details=True', sot.base_path)
|
self.assertEqual('/nodes/%(node_id)s?show_details=True', sot.base_path)
|
||||||
|
@ -28,7 +28,7 @@ FAKE = {
|
|||||||
'grace_period': 60,
|
'grace_period': 60,
|
||||||
'reduce_desired_capacity': False,
|
'reduce_desired_capacity': False,
|
||||||
'destroy_after_deletion': True,
|
'destroy_after_deletion': True,
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
'project': '42d9e9663331431f97b75e25136307ff',
|
'project': '42d9e9663331431f97b75e25136307ff',
|
||||||
'domain': '204ccccd267b40aea871750116b5b184',
|
'domain': '204ccccd267b40aea871750116b5b184',
|
||||||
@ -41,7 +41,6 @@ FAKE = {
|
|||||||
|
|
||||||
|
|
||||||
class TestPolicy(base.TestCase):
|
class TestPolicy(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestPolicy, self).setUp()
|
super(TestPolicy, self).setUp()
|
||||||
|
|
||||||
@ -70,7 +69,6 @@ class TestPolicy(base.TestCase):
|
|||||||
|
|
||||||
|
|
||||||
class TestPolicyValidate(base.TestCase):
|
class TestPolicyValidate(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestPolicyValidate, self).setUp()
|
super(TestPolicyValidate, self).setUp()
|
||||||
|
|
||||||
|
@ -16,20 +16,12 @@ from openstack.tests.unit import base
|
|||||||
|
|
||||||
FAKE = {
|
FAKE = {
|
||||||
'name': 'FAKE_POLICY_TYPE',
|
'name': 'FAKE_POLICY_TYPE',
|
||||||
'schema': {
|
'schema': {'foo': 'bar'},
|
||||||
'foo': 'bar'
|
'support_status': {'1.0': [{'status': 'supported', 'since': '2016.10'}]},
|
||||||
},
|
|
||||||
'support_status': {
|
|
||||||
'1.0': [{
|
|
||||||
'status': 'supported',
|
|
||||||
'since': '2016.10'
|
|
||||||
}]
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class TestPolicyType(base.TestCase):
|
class TestPolicyType(base.TestCase):
|
||||||
|
|
||||||
def test_basic(self):
|
def test_basic(self):
|
||||||
sot = policy_type.PolicyType()
|
sot = policy_type.PolicyType()
|
||||||
self.assertEqual('policy_type', sot.resource_key)
|
self.assertEqual('policy_type', sot.resource_key)
|
||||||
|
@ -28,8 +28,8 @@ FAKE = {
|
|||||||
'flavor': 1,
|
'flavor': 1,
|
||||||
'image': 'cirros-0.3.2-x86_64-uec',
|
'image': 'cirros-0.3.2-x86_64-uec',
|
||||||
'key_name': 'oskey',
|
'key_name': 'oskey',
|
||||||
'name': 'cirros_server'
|
'name': 'cirros_server',
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
'project': '42d9e9663331431f97b75e25136307ff',
|
'project': '42d9e9663331431f97b75e25136307ff',
|
||||||
'domain': '204ccccd267b40aea871750116b5b184',
|
'domain': '204ccccd267b40aea871750116b5b184',
|
||||||
@ -41,7 +41,6 @@ FAKE = {
|
|||||||
|
|
||||||
|
|
||||||
class TestProfile(base.TestCase):
|
class TestProfile(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestProfile, self).setUp()
|
super(TestProfile, self).setUp()
|
||||||
|
|
||||||
@ -72,7 +71,6 @@ class TestProfile(base.TestCase):
|
|||||||
|
|
||||||
|
|
||||||
class TestProfileValidate(base.TestCase):
|
class TestProfileValidate(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestProfileValidate, self).setUp()
|
super(TestProfileValidate, self).setUp()
|
||||||
|
|
||||||
|
@ -17,20 +17,19 @@ from openstack.tests.unit import base
|
|||||||
|
|
||||||
FAKE = {
|
FAKE = {
|
||||||
'name': 'FAKE_PROFILE_TYPE',
|
'name': 'FAKE_PROFILE_TYPE',
|
||||||
'schema': {
|
'schema': {'foo': 'bar'},
|
||||||
'foo': 'bar'
|
|
||||||
},
|
|
||||||
'support_status': {
|
'support_status': {
|
||||||
'1.0': [{
|
'1.0': [
|
||||||
'status': 'supported',
|
{
|
||||||
'since': '2016.10',
|
'status': 'supported',
|
||||||
}]
|
'since': '2016.10',
|
||||||
}
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class TestProfileType(base.TestCase):
|
class TestProfileType(base.TestCase):
|
||||||
|
|
||||||
def test_basic(self):
|
def test_basic(self):
|
||||||
sot = profile_type.ProfileType()
|
sot = profile_type.ProfileType()
|
||||||
self.assertEqual('profile_type', sot.resource_key)
|
self.assertEqual('profile_type', sot.resource_key)
|
||||||
|
@ -36,17 +36,18 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.proxy = _proxy.Proxy(self.session)
|
self.proxy = _proxy.Proxy(self.session)
|
||||||
|
|
||||||
def test_build_info_get(self):
|
def test_build_info_get(self):
|
||||||
self.verify_get(self.proxy.get_build_info, build_info.BuildInfo,
|
self.verify_get(
|
||||||
method_args=[],
|
self.proxy.get_build_info,
|
||||||
expected_kwargs={'requires_id': False})
|
build_info.BuildInfo,
|
||||||
|
method_args=[],
|
||||||
|
expected_kwargs={'requires_id': False},
|
||||||
|
)
|
||||||
|
|
||||||
def test_profile_types(self):
|
def test_profile_types(self):
|
||||||
self.verify_list(self.proxy.profile_types,
|
self.verify_list(self.proxy.profile_types, profile_type.ProfileType)
|
||||||
profile_type.ProfileType)
|
|
||||||
|
|
||||||
def test_profile_type_get(self):
|
def test_profile_type_get(self):
|
||||||
self.verify_get(self.proxy.get_profile_type,
|
self.verify_get(self.proxy.get_profile_type, profile_type.ProfileType)
|
||||||
profile_type.ProfileType)
|
|
||||||
|
|
||||||
def test_policy_types(self):
|
def test_policy_types(self):
|
||||||
self.verify_list(self.proxy.policy_types, policy_type.PolicyType)
|
self.verify_list(self.proxy.policy_types, policy_type.PolicyType)
|
||||||
@ -58,8 +59,9 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.verify_create(self.proxy.create_profile, profile.Profile)
|
self.verify_create(self.proxy.create_profile, profile.Profile)
|
||||||
|
|
||||||
def test_profile_validate(self):
|
def test_profile_validate(self):
|
||||||
self.verify_create(self.proxy.validate_profile,
|
self.verify_create(
|
||||||
profile.ProfileValidate)
|
self.proxy.validate_profile, profile.ProfileValidate
|
||||||
|
)
|
||||||
|
|
||||||
def test_profile_delete(self):
|
def test_profile_delete(self):
|
||||||
self.verify_delete(self.proxy.delete_profile, profile.Profile, False)
|
self.verify_delete(self.proxy.delete_profile, profile.Profile, False)
|
||||||
@ -74,9 +76,12 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.verify_get(self.proxy.get_profile, profile.Profile)
|
self.verify_get(self.proxy.get_profile, profile.Profile)
|
||||||
|
|
||||||
def test_profiles(self):
|
def test_profiles(self):
|
||||||
self.verify_list(self.proxy.profiles, profile.Profile,
|
self.verify_list(
|
||||||
method_kwargs={'limit': 2},
|
self.proxy.profiles,
|
||||||
expected_kwargs={'limit': 2})
|
profile.Profile,
|
||||||
|
method_kwargs={'limit': 2},
|
||||||
|
expected_kwargs={'limit': 2},
|
||||||
|
)
|
||||||
|
|
||||||
def test_profile_update(self):
|
def test_profile_update(self):
|
||||||
self.verify_update(self.proxy.update_profile, profile.Profile)
|
self.verify_update(self.proxy.update_profile, profile.Profile)
|
||||||
@ -95,7 +100,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
"openstack.clustering.v1.cluster.Cluster.force_delete",
|
"openstack.clustering.v1.cluster.Cluster.force_delete",
|
||||||
self.proxy.delete_cluster,
|
self.proxy.delete_cluster,
|
||||||
method_args=["value", False, True],
|
method_args=["value", False, True],
|
||||||
expected_args=[self.proxy])
|
expected_args=[self.proxy],
|
||||||
|
)
|
||||||
|
|
||||||
def test_cluster_find(self):
|
def test_cluster_find(self):
|
||||||
self.verify_find(self.proxy.find_cluster, cluster.Cluster)
|
self.verify_find(self.proxy.find_cluster, cluster.Cluster)
|
||||||
@ -104,16 +110,18 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.verify_get(self.proxy.get_cluster, cluster.Cluster)
|
self.verify_get(self.proxy.get_cluster, cluster.Cluster)
|
||||||
|
|
||||||
def test_clusters(self):
|
def test_clusters(self):
|
||||||
self.verify_list(self.proxy.clusters, cluster.Cluster,
|
self.verify_list(
|
||||||
method_kwargs={'limit': 2},
|
self.proxy.clusters,
|
||||||
expected_kwargs={'limit': 2})
|
cluster.Cluster,
|
||||||
|
method_kwargs={'limit': 2},
|
||||||
|
expected_kwargs={'limit': 2},
|
||||||
|
)
|
||||||
|
|
||||||
def test_cluster_update(self):
|
def test_cluster_update(self):
|
||||||
self.verify_update(self.proxy.update_cluster, cluster.Cluster)
|
self.verify_update(self.proxy.update_cluster, cluster.Cluster)
|
||||||
|
|
||||||
def test_services(self):
|
def test_services(self):
|
||||||
self.verify_list(self.proxy.services,
|
self.verify_list(self.proxy.services, service.Service)
|
||||||
service.Service)
|
|
||||||
|
|
||||||
@mock.patch.object(proxy_base.Proxy, '_find')
|
@mock.patch.object(proxy_base.Proxy, '_find')
|
||||||
def test_resize_cluster(self, mock_find):
|
def test_resize_cluster(self, mock_find):
|
||||||
@ -125,9 +133,11 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
method_args=["FAKE_CLUSTER"],
|
method_args=["FAKE_CLUSTER"],
|
||||||
method_kwargs={'k1': 'v1', 'k2': 'v2'},
|
method_kwargs={'k1': 'v1', 'k2': 'v2'},
|
||||||
expected_args=[self.proxy],
|
expected_args=[self.proxy],
|
||||||
expected_kwargs={'k1': 'v1', 'k2': 'v2'})
|
expected_kwargs={'k1': 'v1', 'k2': 'v2'},
|
||||||
mock_find.assert_called_once_with(cluster.Cluster, "FAKE_CLUSTER",
|
)
|
||||||
ignore_missing=False)
|
mock_find.assert_called_once_with(
|
||||||
|
cluster.Cluster, "FAKE_CLUSTER", ignore_missing=False
|
||||||
|
)
|
||||||
|
|
||||||
def test_resize_cluster_with_obj(self):
|
def test_resize_cluster_with_obj(self):
|
||||||
mock_cluster = cluster.Cluster.new(id='FAKE_CLUSTER')
|
mock_cluster = cluster.Cluster.new(id='FAKE_CLUSTER')
|
||||||
@ -137,15 +147,17 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
method_args=[mock_cluster],
|
method_args=[mock_cluster],
|
||||||
method_kwargs={'k1': 'v1', 'k2': 'v2'},
|
method_kwargs={'k1': 'v1', 'k2': 'v2'},
|
||||||
expected_args=[self.proxy],
|
expected_args=[self.proxy],
|
||||||
expected_kwargs={'k1': 'v1', 'k2': 'v2'})
|
expected_kwargs={'k1': 'v1', 'k2': 'v2'},
|
||||||
|
)
|
||||||
|
|
||||||
def test_collect_cluster_attrs(self):
|
def test_collect_cluster_attrs(self):
|
||||||
self.verify_list(self.proxy.collect_cluster_attrs,
|
self.verify_list(
|
||||||
cluster_attr.ClusterAttr,
|
self.proxy.collect_cluster_attrs,
|
||||||
method_args=['FAKE_ID', 'path.to.attr'],
|
cluster_attr.ClusterAttr,
|
||||||
expected_args=[],
|
method_args=['FAKE_ID', 'path.to.attr'],
|
||||||
expected_kwargs={'cluster_id': 'FAKE_ID',
|
expected_args=[],
|
||||||
'path': 'path.to.attr'})
|
expected_kwargs={'cluster_id': 'FAKE_ID', 'path': 'path.to.attr'},
|
||||||
|
)
|
||||||
|
|
||||||
@mock.patch.object(proxy_base.Proxy, '_get_resource')
|
@mock.patch.object(proxy_base.Proxy, '_get_resource')
|
||||||
def test_cluster_check(self, mock_get):
|
def test_cluster_check(self, mock_get):
|
||||||
@ -155,7 +167,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
"openstack.clustering.v1.cluster.Cluster.check",
|
"openstack.clustering.v1.cluster.Cluster.check",
|
||||||
self.proxy.check_cluster,
|
self.proxy.check_cluster,
|
||||||
method_args=["FAKE_CLUSTER"],
|
method_args=["FAKE_CLUSTER"],
|
||||||
expected_args=[self.proxy])
|
expected_args=[self.proxy],
|
||||||
|
)
|
||||||
mock_get.assert_called_once_with(cluster.Cluster, "FAKE_CLUSTER")
|
mock_get.assert_called_once_with(cluster.Cluster, "FAKE_CLUSTER")
|
||||||
|
|
||||||
@mock.patch.object(proxy_base.Proxy, '_get_resource')
|
@mock.patch.object(proxy_base.Proxy, '_get_resource')
|
||||||
@ -166,7 +179,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
"openstack.clustering.v1.cluster.Cluster.recover",
|
"openstack.clustering.v1.cluster.Cluster.recover",
|
||||||
self.proxy.recover_cluster,
|
self.proxy.recover_cluster,
|
||||||
method_args=["FAKE_CLUSTER"],
|
method_args=["FAKE_CLUSTER"],
|
||||||
expected_args=[self.proxy])
|
expected_args=[self.proxy],
|
||||||
|
)
|
||||||
mock_get.assert_called_once_with(cluster.Cluster, "FAKE_CLUSTER")
|
mock_get.assert_called_once_with(cluster.Cluster, "FAKE_CLUSTER")
|
||||||
|
|
||||||
def test_node_create(self):
|
def test_node_create(self):
|
||||||
@ -183,7 +197,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
"openstack.clustering.v1.node.Node.force_delete",
|
"openstack.clustering.v1.node.Node.force_delete",
|
||||||
self.proxy.delete_node,
|
self.proxy.delete_node,
|
||||||
method_args=["value", False, True],
|
method_args=["value", False, True],
|
||||||
expected_args=[self.proxy])
|
expected_args=[self.proxy],
|
||||||
|
)
|
||||||
|
|
||||||
def test_node_find(self):
|
def test_node_find(self):
|
||||||
self.verify_find(self.proxy.find_node, node.Node)
|
self.verify_find(self.proxy.find_node, node.Node)
|
||||||
@ -198,12 +213,16 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
method_args=['NODE_ID'],
|
method_args=['NODE_ID'],
|
||||||
method_kwargs={'details': True},
|
method_kwargs={'details': True},
|
||||||
expected_args=[node.NodeDetail],
|
expected_args=[node.NodeDetail],
|
||||||
expected_kwargs={'node_id': 'NODE_ID', 'requires_id': False})
|
expected_kwargs={'node_id': 'NODE_ID', 'requires_id': False},
|
||||||
|
)
|
||||||
|
|
||||||
def test_nodes(self):
|
def test_nodes(self):
|
||||||
self.verify_list(self.proxy.nodes, node.Node,
|
self.verify_list(
|
||||||
method_kwargs={'limit': 2},
|
self.proxy.nodes,
|
||||||
expected_kwargs={'limit': 2})
|
node.Node,
|
||||||
|
method_kwargs={'limit': 2},
|
||||||
|
expected_kwargs={'limit': 2},
|
||||||
|
)
|
||||||
|
|
||||||
def test_node_update(self):
|
def test_node_update(self):
|
||||||
self.verify_update(self.proxy.update_node, node.Node)
|
self.verify_update(self.proxy.update_node, node.Node)
|
||||||
@ -216,7 +235,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
"openstack.clustering.v1.node.Node.check",
|
"openstack.clustering.v1.node.Node.check",
|
||||||
self.proxy.check_node,
|
self.proxy.check_node,
|
||||||
method_args=["FAKE_NODE"],
|
method_args=["FAKE_NODE"],
|
||||||
expected_args=[self.proxy])
|
expected_args=[self.proxy],
|
||||||
|
)
|
||||||
mock_get.assert_called_once_with(node.Node, "FAKE_NODE")
|
mock_get.assert_called_once_with(node.Node, "FAKE_NODE")
|
||||||
|
|
||||||
@mock.patch.object(proxy_base.Proxy, '_get_resource')
|
@mock.patch.object(proxy_base.Proxy, '_get_resource')
|
||||||
@ -227,7 +247,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
"openstack.clustering.v1.node.Node.recover",
|
"openstack.clustering.v1.node.Node.recover",
|
||||||
self.proxy.recover_node,
|
self.proxy.recover_node,
|
||||||
method_args=["FAKE_NODE"],
|
method_args=["FAKE_NODE"],
|
||||||
expected_args=[self.proxy])
|
expected_args=[self.proxy],
|
||||||
|
)
|
||||||
mock_get.assert_called_once_with(node.Node, "FAKE_NODE")
|
mock_get.assert_called_once_with(node.Node, "FAKE_NODE")
|
||||||
|
|
||||||
@mock.patch.object(proxy_base.Proxy, '_get_resource')
|
@mock.patch.object(proxy_base.Proxy, '_get_resource')
|
||||||
@ -239,7 +260,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.proxy.adopt_node,
|
self.proxy.adopt_node,
|
||||||
method_kwargs={"preview": False, "foo": "bar"},
|
method_kwargs={"preview": False, "foo": "bar"},
|
||||||
expected_args=[self.proxy],
|
expected_args=[self.proxy],
|
||||||
expected_kwargs={"preview": False, "foo": "bar"})
|
expected_kwargs={"preview": False, "foo": "bar"},
|
||||||
|
)
|
||||||
|
|
||||||
mock_get.assert_called_once_with(node.Node, None)
|
mock_get.assert_called_once_with(node.Node, None)
|
||||||
|
|
||||||
@ -252,7 +274,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.proxy.adopt_node,
|
self.proxy.adopt_node,
|
||||||
method_kwargs={"preview": True, "foo": "bar"},
|
method_kwargs={"preview": True, "foo": "bar"},
|
||||||
expected_args=[self.proxy],
|
expected_args=[self.proxy],
|
||||||
expected_kwargs={"preview": True, "foo": "bar"})
|
expected_kwargs={"preview": True, "foo": "bar"},
|
||||||
|
)
|
||||||
|
|
||||||
mock_get.assert_called_once_with(node.Node, None)
|
mock_get.assert_called_once_with(node.Node, None)
|
||||||
|
|
||||||
@ -275,19 +298,24 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.verify_get(self.proxy.get_policy, policy.Policy)
|
self.verify_get(self.proxy.get_policy, policy.Policy)
|
||||||
|
|
||||||
def test_policies(self):
|
def test_policies(self):
|
||||||
self.verify_list(self.proxy.policies, policy.Policy,
|
self.verify_list(
|
||||||
method_kwargs={'limit': 2},
|
self.proxy.policies,
|
||||||
expected_kwargs={'limit': 2})
|
policy.Policy,
|
||||||
|
method_kwargs={'limit': 2},
|
||||||
|
expected_kwargs={'limit': 2},
|
||||||
|
)
|
||||||
|
|
||||||
def test_policy_update(self):
|
def test_policy_update(self):
|
||||||
self.verify_update(self.proxy.update_policy, policy.Policy)
|
self.verify_update(self.proxy.update_policy, policy.Policy)
|
||||||
|
|
||||||
def test_cluster_policies(self):
|
def test_cluster_policies(self):
|
||||||
self.verify_list(self.proxy.cluster_policies,
|
self.verify_list(
|
||||||
cluster_policy.ClusterPolicy,
|
self.proxy.cluster_policies,
|
||||||
method_args=["FAKE_CLUSTER"],
|
cluster_policy.ClusterPolicy,
|
||||||
expected_args=[],
|
method_args=["FAKE_CLUSTER"],
|
||||||
expected_kwargs={"cluster_id": "FAKE_CLUSTER"})
|
expected_args=[],
|
||||||
|
expected_kwargs={"cluster_id": "FAKE_CLUSTER"},
|
||||||
|
)
|
||||||
|
|
||||||
def test_get_cluster_policy(self):
|
def test_get_cluster_policy(self):
|
||||||
fake_policy = cluster_policy.ClusterPolicy.new(id="FAKE_POLICY")
|
fake_policy = cluster_policy.ClusterPolicy.new(id="FAKE_POLICY")
|
||||||
@ -300,7 +328,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
method_args=[fake_policy, "FAKE_CLUSTER"],
|
method_args=[fake_policy, "FAKE_CLUSTER"],
|
||||||
expected_args=[cluster_policy.ClusterPolicy, fake_policy],
|
expected_args=[cluster_policy.ClusterPolicy, fake_policy],
|
||||||
expected_kwargs={'cluster_id': 'FAKE_CLUSTER'},
|
expected_kwargs={'cluster_id': 'FAKE_CLUSTER'},
|
||||||
expected_result=fake_policy)
|
expected_result=fake_policy,
|
||||||
|
)
|
||||||
|
|
||||||
# Policy ID as input
|
# Policy ID as input
|
||||||
self._verify(
|
self._verify(
|
||||||
@ -308,7 +337,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.proxy.get_cluster_policy,
|
self.proxy.get_cluster_policy,
|
||||||
method_args=["FAKE_POLICY", "FAKE_CLUSTER"],
|
method_args=["FAKE_POLICY", "FAKE_CLUSTER"],
|
||||||
expected_args=[cluster_policy.ClusterPolicy, "FAKE_POLICY"],
|
expected_args=[cluster_policy.ClusterPolicy, "FAKE_POLICY"],
|
||||||
expected_kwargs={"cluster_id": "FAKE_CLUSTER"})
|
expected_kwargs={"cluster_id": "FAKE_CLUSTER"},
|
||||||
|
)
|
||||||
|
|
||||||
# Cluster object as input
|
# Cluster object as input
|
||||||
self._verify(
|
self._verify(
|
||||||
@ -316,7 +346,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.proxy.get_cluster_policy,
|
self.proxy.get_cluster_policy,
|
||||||
method_args=["FAKE_POLICY", fake_cluster],
|
method_args=["FAKE_POLICY", fake_cluster],
|
||||||
expected_args=[cluster_policy.ClusterPolicy, "FAKE_POLICY"],
|
expected_args=[cluster_policy.ClusterPolicy, "FAKE_POLICY"],
|
||||||
expected_kwargs={"cluster_id": fake_cluster})
|
expected_kwargs={"cluster_id": fake_cluster},
|
||||||
|
)
|
||||||
|
|
||||||
def test_receiver_create(self):
|
def test_receiver_create(self):
|
||||||
self.verify_create(self.proxy.create_receiver, receiver.Receiver)
|
self.verify_create(self.proxy.create_receiver, receiver.Receiver)
|
||||||
@ -325,8 +356,9 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.verify_update(self.proxy.update_receiver, receiver.Receiver)
|
self.verify_update(self.proxy.update_receiver, receiver.Receiver)
|
||||||
|
|
||||||
def test_receiver_delete(self):
|
def test_receiver_delete(self):
|
||||||
self.verify_delete(self.proxy.delete_receiver, receiver.Receiver,
|
self.verify_delete(
|
||||||
False)
|
self.proxy.delete_receiver, receiver.Receiver, False
|
||||||
|
)
|
||||||
|
|
||||||
def test_receiver_delete_ignore(self):
|
def test_receiver_delete_ignore(self):
|
||||||
self.verify_delete(self.proxy.delete_receiver, receiver.Receiver, True)
|
self.verify_delete(self.proxy.delete_receiver, receiver.Receiver, True)
|
||||||
@ -338,17 +370,23 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.verify_get(self.proxy.get_receiver, receiver.Receiver)
|
self.verify_get(self.proxy.get_receiver, receiver.Receiver)
|
||||||
|
|
||||||
def test_receivers(self):
|
def test_receivers(self):
|
||||||
self.verify_list(self.proxy.receivers, receiver.Receiver,
|
self.verify_list(
|
||||||
method_kwargs={'limit': 2},
|
self.proxy.receivers,
|
||||||
expected_kwargs={'limit': 2})
|
receiver.Receiver,
|
||||||
|
method_kwargs={'limit': 2},
|
||||||
|
expected_kwargs={'limit': 2},
|
||||||
|
)
|
||||||
|
|
||||||
def test_action_get(self):
|
def test_action_get(self):
|
||||||
self.verify_get(self.proxy.get_action, action.Action)
|
self.verify_get(self.proxy.get_action, action.Action)
|
||||||
|
|
||||||
def test_actions(self):
|
def test_actions(self):
|
||||||
self.verify_list(self.proxy.actions, action.Action,
|
self.verify_list(
|
||||||
method_kwargs={'limit': 2},
|
self.proxy.actions,
|
||||||
expected_kwargs={'limit': 2})
|
action.Action,
|
||||||
|
method_kwargs={'limit': 2},
|
||||||
|
expected_kwargs={'limit': 2},
|
||||||
|
)
|
||||||
|
|
||||||
def test_action_update(self):
|
def test_action_update(self):
|
||||||
self.verify_update(self.proxy.update_action, action.Action)
|
self.verify_update(self.proxy.update_action, action.Action)
|
||||||
@ -357,9 +395,12 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.verify_get(self.proxy.get_event, event.Event)
|
self.verify_get(self.proxy.get_event, event.Event)
|
||||||
|
|
||||||
def test_events(self):
|
def test_events(self):
|
||||||
self.verify_list(self.proxy.events, event.Event,
|
self.verify_list(
|
||||||
method_kwargs={'limit': 2},
|
self.proxy.events,
|
||||||
expected_kwargs={'limit': 2})
|
event.Event,
|
||||||
|
method_kwargs={'limit': 2},
|
||||||
|
expected_kwargs={'limit': 2},
|
||||||
|
)
|
||||||
|
|
||||||
@mock.patch("openstack.resource.wait_for_status")
|
@mock.patch("openstack.resource.wait_for_status")
|
||||||
def test_wait_for(self, mock_wait):
|
def test_wait_for(self, mock_wait):
|
||||||
@ -368,8 +409,9 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
|
|
||||||
self.proxy.wait_for_status(mock_resource, 'ACTIVE')
|
self.proxy.wait_for_status(mock_resource, 'ACTIVE')
|
||||||
|
|
||||||
mock_wait.assert_called_once_with(self.proxy, mock_resource,
|
mock_wait.assert_called_once_with(
|
||||||
'ACTIVE', [], 2, 120)
|
self.proxy, mock_resource, 'ACTIVE', [], 2, 120
|
||||||
|
)
|
||||||
|
|
||||||
@mock.patch("openstack.resource.wait_for_status")
|
@mock.patch("openstack.resource.wait_for_status")
|
||||||
def test_wait_for_params(self, mock_wait):
|
def test_wait_for_params(self, mock_wait):
|
||||||
@ -378,8 +420,9 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
|
|
||||||
self.proxy.wait_for_status(mock_resource, 'ACTIVE', ['ERROR'], 1, 2)
|
self.proxy.wait_for_status(mock_resource, 'ACTIVE', ['ERROR'], 1, 2)
|
||||||
|
|
||||||
mock_wait.assert_called_once_with(self.proxy, mock_resource,
|
mock_wait.assert_called_once_with(
|
||||||
'ACTIVE', ['ERROR'], 1, 2)
|
self.proxy, mock_resource, 'ACTIVE', ['ERROR'], 1, 2
|
||||||
|
)
|
||||||
|
|
||||||
@mock.patch("openstack.resource.wait_for_delete")
|
@mock.patch("openstack.resource.wait_for_delete")
|
||||||
def test_wait_for_delete(self, mock_wait):
|
def test_wait_for_delete(self, mock_wait):
|
||||||
@ -405,7 +448,8 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.proxy.get_cluster_metadata,
|
self.proxy.get_cluster_metadata,
|
||||||
method_args=["value"],
|
method_args=["value"],
|
||||||
expected_args=[self.proxy],
|
expected_args=[self.proxy],
|
||||||
expected_result=cluster.Cluster(id="value", metadata={}))
|
expected_result=cluster.Cluster(id="value", metadata={}),
|
||||||
|
)
|
||||||
|
|
||||||
def test_set_cluster_metadata(self):
|
def test_set_cluster_metadata(self):
|
||||||
kwargs = {"a": "1", "b": "2"}
|
kwargs = {"a": "1", "b": "2"}
|
||||||
@ -415,12 +459,11 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.proxy.set_cluster_metadata,
|
self.proxy.set_cluster_metadata,
|
||||||
method_args=[id],
|
method_args=[id],
|
||||||
method_kwargs=kwargs,
|
method_kwargs=kwargs,
|
||||||
method_result=cluster.Cluster.existing(
|
method_result=cluster.Cluster.existing(id=id, metadata=kwargs),
|
||||||
id=id, metadata=kwargs),
|
|
||||||
expected_args=[self.proxy],
|
expected_args=[self.proxy],
|
||||||
expected_kwargs={'metadata': kwargs},
|
expected_kwargs={'metadata': kwargs},
|
||||||
expected_result=cluster.Cluster.existing(
|
expected_result=cluster.Cluster.existing(id=id, metadata=kwargs),
|
||||||
id=id, metadata=kwargs))
|
)
|
||||||
|
|
||||||
def test_delete_cluster_metadata(self):
|
def test_delete_cluster_metadata(self):
|
||||||
self._verify(
|
self._verify(
|
||||||
@ -428,4 +471,5 @@ class TestClusterProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.proxy.delete_cluster_metadata,
|
self.proxy.delete_cluster_metadata,
|
||||||
expected_result=None,
|
expected_result=None,
|
||||||
method_args=["value", ["key"]],
|
method_args=["value", ["key"]],
|
||||||
expected_args=[self.proxy, "key"])
|
expected_args=[self.proxy, "key"],
|
||||||
|
)
|
||||||
|
@ -26,10 +26,7 @@ FAKE = {
|
|||||||
'created_at': '2015-10-10T12:46:36.000000',
|
'created_at': '2015-10-10T12:46:36.000000',
|
||||||
'updated_at': '2016-10-10T12:46:36.000000',
|
'updated_at': '2016-10-10T12:46:36.000000',
|
||||||
'actor': {},
|
'actor': {},
|
||||||
'params': {
|
'params': {'adjustment_type': 'CHANGE_IN_CAPACITY', 'adjustment': 2},
|
||||||
'adjustment_type': 'CHANGE_IN_CAPACITY',
|
|
||||||
'adjustment': 2
|
|
||||||
},
|
|
||||||
'channel': {
|
'channel': {
|
||||||
'alarm_url': 'http://host:port/webhooks/AN_ID/trigger?V=1',
|
'alarm_url': 'http://host:port/webhooks/AN_ID/trigger?V=1',
|
||||||
},
|
},
|
||||||
@ -40,7 +37,6 @@ FAKE = {
|
|||||||
|
|
||||||
|
|
||||||
class TestReceiver(base.TestCase):
|
class TestReceiver(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestReceiver, self).setUp()
|
super(TestReceiver, self).setUp()
|
||||||
|
|
||||||
|
@ -27,7 +27,6 @@ EXAMPLE = {
|
|||||||
|
|
||||||
|
|
||||||
class TestService(base.TestCase):
|
class TestService(base.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestService, self).setUp()
|
super(TestService, self).setUp()
|
||||||
self.resp = mock.Mock()
|
self.resp = mock.Mock()
|
||||||
|
Loading…
Reference in New Issue
Block a user