blob: c7b5f9392e098c76c092d8818101a7507bcad8e9 [file] [log] [blame]
Sergey Lukjanov3bc60e92013-12-10 16:40:50 +04001# Copyright (c) 2013 Mirantis Inc.
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
12# implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15
16import json
17
18from tempest.common import rest_client
Matthew Treinish684d8992014-01-30 16:27:40 +000019from tempest import config
20
21CONF = config.CONF
Sergey Lukjanov3bc60e92013-12-10 16:40:50 +040022
23
24class DataProcessingClient(rest_client.RestClient):
Andrea Frittoli8bbdb162014-01-06 11:06:13 +000025 def __init__(self, auth_provider):
26 super(DataProcessingClient, self).__init__(auth_provider)
Matthew Treinish684d8992014-01-30 16:27:40 +000027 self.service = CONF.data_processing.catalog_type
Sergey Lukjanov3bc60e92013-12-10 16:40:50 +040028
29 @classmethod
30 def _request_and_parse(cls, req_fun, uri, res_name, *args, **kwargs):
31 """Make a request using specified req_fun and parse response.
32
33 It returns pair: resp and parsed resource(s) body.
34 """
Sergey Lukjanov3bc60e92013-12-10 16:40:50 +040035 resp, body = req_fun(uri, headers={
36 'Content-Type': 'application/json'
37 }, *args, **kwargs)
38 body = json.loads(body)
39 return resp, body[res_name]
40
41 def list_node_group_templates(self):
42 """List all node group templates for a user."""
43
44 uri = 'node-group-templates'
45 return self._request_and_parse(self.get, uri, 'node_group_templates')
46
47 def get_node_group_template(self, tmpl_id):
48 """Returns the details of a single node group template."""
49
Yaroslav Lobankov93aa8192014-04-01 20:03:25 +040050 uri = 'node-group-templates/%s' % tmpl_id
Sergey Lukjanov3bc60e92013-12-10 16:40:50 +040051 return self._request_and_parse(self.get, uri, 'node_group_template')
52
53 def create_node_group_template(self, name, plugin_name, hadoop_version,
54 node_processes, flavor_id,
55 node_configs=None, **kwargs):
56 """Creates node group template with specified params.
57
58 It supports passing additional params using kwargs and returns created
59 object.
60 """
Yaroslav Lobankov93aa8192014-04-01 20:03:25 +040061 uri = 'node-group-templates'
Sergey Lukjanov3bc60e92013-12-10 16:40:50 +040062 body = kwargs.copy()
63 body.update({
64 'name': name,
65 'plugin_name': plugin_name,
66 'hadoop_version': hadoop_version,
67 'node_processes': node_processes,
68 'flavor_id': flavor_id,
69 'node_configs': node_configs or dict(),
70 })
71 return self._request_and_parse(self.post, uri, 'node_group_template',
72 body=json.dumps(body))
73
74 def delete_node_group_template(self, tmpl_id):
75 """Deletes the specified node group template by id."""
76
Yaroslav Lobankov93aa8192014-04-01 20:03:25 +040077 uri = 'node-group-templates/%s' % tmpl_id
Sergey Lukjanov3bc60e92013-12-10 16:40:50 +040078 return self.delete(uri)
Sergey Lukjanovdad26cc2014-02-06 19:58:31 +040079
80 def list_plugins(self):
81 """List all enabled plugins."""
82
83 uri = 'plugins'
84 return self._request_and_parse(self.get, uri, 'plugins')
85
86 def get_plugin(self, plugin_name, plugin_version=None):
87 """Returns the details of a single plugin."""
88
Yaroslav Lobankov93aa8192014-04-01 20:03:25 +040089 uri = 'plugins/%s' % plugin_name
Sergey Lukjanovdad26cc2014-02-06 19:58:31 +040090 if plugin_version:
91 uri += '/%s' % plugin_version
92 return self._request_and_parse(self.get, uri, 'plugin')
Yaroslav Lobankov93aa8192014-04-01 20:03:25 +040093
94 def list_cluster_templates(self):
95 """List all cluster templates for a user."""
96
97 uri = 'cluster-templates'
98 return self._request_and_parse(self.get, uri, 'cluster_templates')
99
100 def get_cluster_template(self, tmpl_id):
101 """Returns the details of a single cluster template."""
102
103 uri = 'cluster-templates/%s' % tmpl_id
104 return self._request_and_parse(self.get, uri, 'cluster_template')
105
106 def create_cluster_template(self, name, plugin_name, hadoop_version,
107 node_groups, cluster_configs=None,
108 **kwargs):
109 """Creates cluster template with specified params.
110
111 It supports passing additional params using kwargs and returns created
112 object.
113 """
114 uri = 'cluster-templates'
115 body = kwargs.copy()
116 body.update({
117 'name': name,
118 'plugin_name': plugin_name,
119 'hadoop_version': hadoop_version,
120 'node_groups': node_groups,
121 'cluster_configs': cluster_configs or dict(),
122 })
123 return self._request_and_parse(self.post, uri, 'cluster_template',
124 body=json.dumps(body))
125
126 def delete_cluster_template(self, tmpl_id):
127 """Deletes the specified cluster template by id."""
128
129 uri = 'cluster-templates/%s' % tmpl_id
130 return self.delete(uri)