summaryrefslogtreecommitdiffstats
path: root/robotframework-onap
diff options
context:
space:
mode:
Diffstat (limited to 'robotframework-onap')
-rw-r--r--robotframework-onap/ONAPLibrary/HTTPKeywords.py14
-rw-r--r--robotframework-onap/ONAPLibrary/MUSIC.py27
-rw-r--r--robotframework-onap/ONAPLibrary/MUSICKeywords.py68
-rw-r--r--robotframework-onap/eteutils/EteGatherDataListener.py126
4 files changed, 109 insertions, 126 deletions
diff --git a/robotframework-onap/ONAPLibrary/HTTPKeywords.py b/robotframework-onap/ONAPLibrary/HTTPKeywords.py
index 40f9998..f2afe6a 100644
--- a/robotframework-onap/ONAPLibrary/HTTPKeywords.py
+++ b/robotframework-onap/ONAPLibrary/HTTPKeywords.py
@@ -1,3 +1,17 @@
+# Copyright 2019 AT&T Intellectual Property. 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.
+
from six.moves import urllib
from robot.api.deco import keyword
diff --git a/robotframework-onap/ONAPLibrary/MUSIC.py b/robotframework-onap/ONAPLibrary/MUSIC.py
new file mode 100644
index 0000000..29ebd9c
--- /dev/null
+++ b/robotframework-onap/ONAPLibrary/MUSIC.py
@@ -0,0 +1,27 @@
+# Copyright 2019 AT&T Intellectual Property. 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.
+
+from ONAPLibrary.robotlibcore import HybridCore
+from ONAPLibrary.MUSICKeywords import MUSICKeywords
+
+
+class MUSIC(HybridCore):
+ """MUSIC is an ONAP testing library for Robot Framework that provides functionality for interacting with the music
+ component. """
+
+ def __init__(self):
+ self.keyword_implementors = [
+ MUSICKeywords()
+ ]
+ HybridCore.__init__(self, self.keyword_implementors)
diff --git a/robotframework-onap/ONAPLibrary/MUSICKeywords.py b/robotframework-onap/ONAPLibrary/MUSICKeywords.py
new file mode 100644
index 0000000..abceb54
--- /dev/null
+++ b/robotframework-onap/ONAPLibrary/MUSICKeywords.py
@@ -0,0 +1,68 @@
+# Copyright 2019 AT&T Intellectual Property. 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.
+from RequestsLibrary import RequestsLibrary
+from robot.api import logger
+from robot.api.deco import keyword
+from robot.libraries.BuiltIn import BuiltIn
+
+from ONAPLibrary.Utilities import Utilities
+
+
+class MUSICKeywords(object):
+ """MUSIC is an ONAP testing library for Robot Framework that provides functionality for interacting with the serivce
+ orchestrator. """
+
+ def __init__(self):
+ super(MUSICKeywords, self).__init__()
+ self.application_id = "robot-ete"
+ self.uuid = Utilities()
+ self.builtin = BuiltIn()
+
+ @keyword
+ def run_get_request(self, endpoint, data_path, accept="application/json", auth=None):
+ """Runs an MUSIC get request"""
+ resp = self.get_request(endpoint, data_path, accept, auth)
+ return resp
+
+ def get_request(self, endpoint, data_path, accept="application/json", auth=None):
+ """Runs an MUSIC get request"""
+ logger.info("Creating session" + endpoint)
+ RequestsLibrary().create_session("music", endpoint, auth=auth)
+ resp = RequestsLibrary().get_request("music", data_path, headers=self.create_headers(accept))
+ logger.info("Received response from music " + resp.text)
+ return resp
+
+ def create_headers(self, accept="application/json"):
+ """Create the headers that are used by MUSIC"""
+ uuid = self.uuid.generate_uuid4()
+ headers = {
+ "Accept": accept,
+ "Content-Type": "application/json",
+ "X-TransactionId": self.application_id + "-" + uuid,
+ "X-FromAppId": self.application_id
+ }
+ return headers
+
+ def run_health_check(self, endpoint, health_check_path):
+ """Runs MUSIC Health check"""
+ resp = self.run_get_request(endpoint, health_check_path)
+ self.builtin.should_be_equal_as_strings(resp.status_code, "200")
+ self.builtin.should_be_equal_as_strings(resp.json()['status'], "SUCCESS")
+
+ def run_cassandra_connection_check(self, endpoint, health_check_path):
+ """Confirm MUSIC's connection to Cassandra in active"""
+ resp = self.run_get_request(endpoint, health_check_path)
+ self.builtin.should_be_equal_as_strings(resp.status_code, "200")
+ self.builtin.should_be_equal_as_strings(resp.json()['Cassandra'], "Active")
+
diff --git a/robotframework-onap/eteutils/EteGatherDataListener.py b/robotframework-onap/eteutils/EteGatherDataListener.py
deleted file mode 100644
index a99364b..0000000
--- a/robotframework-onap/eteutils/EteGatherDataListener.py
+++ /dev/null
@@ -1,126 +0,0 @@
-import os.path
-import paramiko
-import logging
-from sys import stderr
-
-"""
-EteGatherDataListener implements the ROBOT listener API version 2 and is
-instantiated via the robot cammmand line option
-
- --listener EteGatherDataListener:<jobbumber>:<key filename>
-
-The purpose is to gather and preserve debugging data from each of the application
-VMs when an ETE test fails.
-
-This listener counts the number of test
-cases that have failed and, if > 0 at then end of the robot exection (close()),
-will connect to each application vm and
-
-2. upload the gather_data.sh
-2. execute gather_data.sh
-3. Transfer the resulting zip file to the Robot reports folder
-
-This will enable the Jenkins job to retrieve the debug data along with the
-Robot logs and reports and archive it with the failed job for later retreival.
-
-Note that the gather_data.sh depends upon the application providing
-a /opt/gather_application_data.sh on their respective VMs for the zip file
-to be created.
-"""
-
-
-class EteGatherDataListener(object):
- ROBOT_LIBRARY_SCOPE = 'TEST SUITE'
- ROBOT_LISTENER_API_VERSION = 2
-
- APPLICATIONS = {
- "aai" : "10.0.1.1",
- "appc" : "10.0.2.1",
- "sdc" : "10.0.3.1",
- "dcae" : "10.0.4.1",
- "mso" : "10.0.5.1",
- "policy" : "10.0.6.1",
- "sdnc" : "10.0.7.1",
- "vid" : "10.0.8.1",
- "portal" : "10.0.9.1",
- "message_router" : "10.0.11.1",
- "dcae_pstg00" : "10.0.4.101",
- "dcae_coll00" : "10.0.4.102",
- "dcae_cdap00" : "10.0.4.103",
- "dcae_cdap01" : "10.0.4.104",
- "dcae_cdap02" : "10.0.4.105"
- }
-
- keyfile = ""
- local_gather_data_sh = ""
-
- def __init__(self, job='10', keyfile='/share/config/key.pvt', shell="gather_data.sh"):
- self.tests_passed = 0
- self.tests_failed = 0
- self.output_folder = ''
- self.job = job
- self.folder= ''
- self.keyfile = keyfile
- self.local_gather_data_sh = shell
- print("EteGatherDataListener instantiated")
-
- def end_test(self, name, attrs):
- if attrs['status'] == 'PASS':
- self.tests_passed+=1
- else:
- self.tests_failed+=1
-
- def output_file(self, path):
- if (self.folder != ''):
- return
- self.folder = os.path.dirname(path)
- print((self.folder))
-
- def close(self):
- print("EteGatherDataListener tests failed=" + str(self.tests_failed))
- if (self.tests_failed > 0):
- self.gather_debug_data()
-
- def gather_debug_data(self):
-
- for application in list(self.APPLICATIONS.keys()):
- self.gather_application_data(application, self.APPLICATIONS.get(application))
-
- def gather_application_data(self, application, ip):
- extra = {"_threadid" : 1}
- paramiko.util.log_to_file(self.folder + "/paramiko.log", level=0)
- log = logging.getLogger("paramiko")
- ssh = paramiko.SSHClient()
- try:
- ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
- ssh.connect(ip,username="root", key_filename=self.keyfile)
- except paramiko.SSHException:
- log.error("Connection Failed to " + ip, extra=extra)
- return
- try:
- gather_data_sh = "/tmp/gather_data.sh"
- ftp = ssh.open_sftp()
- ftp.put(self.local_gather_data_sh, gather_data_sh)
- ftp.close()
- stdin, stdout, stderr = ssh.exec_command("/bin/bash "+ gather_data_sh + " " + application + " " + self.job)
- error = stderr.read()
- if (error != ''):
- log.info("stderr:" + error, extra=extra)
- ssh.close()
- return;
- # No error? ASsume we have a file to download.
- out = stdout.read()
- log.info("stdout:" + out, extra=extra)
- filename = application + "_" + self.job + ".tar.gz"
- localzip = self.folder + "/" + filename
- remotezip = "/tmp/gather_data/" + filename
- ftp = ssh.open_sftp()
- ftp.get(remotezip, localzip)
- ftp.close()
- stdin, stdout, stderr = ssh.exec_command("rm -rf " + remotezip);
- ssh.close()
- except paramiko.SSHException:
- ssh.close()
- return
-
-