blob: 25f36e2b6786eaa41b4633d377adb8dd1a2269fc [file] [log] [blame]
DR695Hbec8e3f2019-07-19 17:58:45 -04001# Copyright 2019 AT&T Intellectual Property. All rights reserved.
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 implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14
15from robot.api import logger
16from robot.api.deco import keyword
17from robot.libraries.BuiltIn import BuiltIn
18import time
19
20from ONAPLibrary.RequestsHelper import RequestsHelper
DR695H27daa1a2019-07-22 18:20:48 -040021from ONAPLibrary.HTTPKeywords import HTTPKeywords
DR695Hbec8e3f2019-07-19 17:58:45 -040022
23
24class BaseAAIKeywords(object):
25 """The main interface for interacting with AAI. It handles low level stuff like managing the http request library
26 and required fields. """
27
28 def __init__(self):
29 super(BaseAAIKeywords, self).__init__()
30 self.reqs = RequestsHelper()
31 self.builtin = BuiltIn()
DR695H27daa1a2019-07-22 18:20:48 -040032 self.http = HTTPKeywords()
DR695Hbec8e3f2019-07-19 17:58:45 -040033
34 @keyword
35 def run_get_request(self, endpoint, data_path, accept="application/json", auth=None):
36 """Runs an AAI get request"""
DR695H27daa1a2019-07-22 18:20:48 -040037 self.http.disable_warnings()
DR695Hbec8e3f2019-07-19 17:58:45 -040038 resp = self.reqs.get_request("aai", endpoint, data_path, sdc_user=None, accept=accept, auth=auth)
39 self.builtin.should_be_equal_as_strings(resp.status_code, "200")
40 return resp
41
42 @keyword
43 def run_post_request(self, endpoint, data_path, data, accept="application/json", auth=None):
44 """Runs an AAI post request"""
DR695H27daa1a2019-07-22 18:20:48 -040045 self.http.disable_warnings()
DR695Hbec8e3f2019-07-19 17:58:45 -040046 return self.reqs.post_request("aai", endpoint, data_path, data, sdc_user=None, files=None,
47 accept=accept, auth=auth)
48
49 @keyword
50 def run_put_request(self, endpoint, data_path, data, accept="application/json", auth=None):
51 """Runs an AAI post request"""
DR695H27daa1a2019-07-22 18:20:48 -040052 self.http.disable_warnings()
DR695Hbec8e3f2019-07-19 17:58:45 -040053 return self.reqs.put_request("aai", endpoint, data_path, data, sdc_user=None, accept=accept, auth=auth)
54
55 @keyword
56 def run_delete_request(self, endpoint, data_path, resource_version, accept="application/json", auth=None):
57 """Runs an AAI delete request"""
DR695H27daa1a2019-07-22 18:20:48 -040058 self.http.disable_warnings()
DR695Hbec8e3f2019-07-19 17:58:45 -040059 return self.reqs.delete_request("aai", endpoint, data_path + '?resource-version=' + resource_version, data=None,
60 sdc_user=None, accept=accept, auth=auth)
61
62 @keyword
63 def wait_for_node_to_exist(self, endpoint, search_node_type, key, uuid, auth=None):
64 logger.info('Waiting for AAI traversal to complete...')
65 for i in range(30):
66 time.sleep(1)
67 result = self.find_node(endpoint, search_node_type, key, uuid, auth=auth)
68 if result:
69 return result
70
71 error_message = "AAI traversal didn't finish in 30 seconds. Something is wrong. Type {0}, UUID {1}".format(
72 search_node_type, uuid)
73 logger.error(error_message)
74 self.builtin.fail(error_message)
75
76 @keyword
77 def find_node(self, endpoint, search_node_type, key, node_uuid, auth=None):
78 data_path = '/aai/v11/search/nodes-query?search-node-type={0}&filter={1}:EQUALS:{2}'.format(
79 search_node_type, key, node_uuid)
DR695H27daa1a2019-07-22 18:20:48 -040080 self.http.disable_warnings()
DR695Hbec8e3f2019-07-19 17:58:45 -040081 resp = self.reqs.get_request("aai", endpoint, data_path, accept="application/json", auth=auth)
82 response = resp.json()
83 return 'result-data' in response