- # TODO: download vpp_api_test output file
- # self._delete_files(node, remote_file_path, remote_file_out)
-
- def scp_and_execute_script(self, vat_name, node, timeout=15, json_out=True):
- """Copy vat_name script to node, execute it and return result.
-
- :param vat_name: Name of the vat script file.
- Full path and name of the script is required.
- :param node: Node to execute the VAT script on.
- :param timeout: Seconds to allow the script to run.
- :param json_out: Require JSON output.
- :type vat_name: str
- :type node: dict
- :type timeout: int
- :type json_out: bool
- :returns: Status code, stdout and stderr of executed VAT script.
- :rtype: tuple
- :raises RuntimeError: If VAT script execution failed.
- """
-
- ssh = SSH()
- try:
- ssh.connect(node)
- except:
- raise SSHException("Cannot open SSH connection to execute VAT "
- "command(s) from template {0}".format(vat_name))
-
- ssh.scp(vat_name, vat_name)
-
- cmd = "sudo -S {vat} {json} in {input} script".format(
- json="json" if json_out is True else "",
- vat=Constants.VAT_BIN_NAME,
- input=vat_name)
-
- with open(vat_name, 'r') as tmp_f:
- VatHistory.add_to_vat_history(node, tmp_f.read())
-
- try:
- (ret_code, stdout, stderr) = ssh.exec_command(cmd, timeout)
- except SSHTimeout:
- logger.error("VAT script execution timeout: {0}".format(cmd))
- raise
- except:
- raise RuntimeError("VAT script execution failed: {0}".format(cmd))
-
- self._ret_code = ret_code
- self._stdout = stdout
- self._stderr = stderr
-
- self._delete_files(node, vat_name)
-
- def scp_and_execute_cli_script(self, fname, node, timeout=15,
- json_out=True):
- """Copy vat_name script to node, execute it and return result.
-
- :param fname: Name of the VPP script file.
- Full path and name of the script is required.
- :param node: Node to execute the VPP script on.
- :param timeout: Seconds to allow the script to run.
- :param json_out: Require JSON output.
- :type fname: str
- :type node: dict
- :type timeout: int
- :type json_out: bool
- :returns: Status code, stdout and stderr of executed CLI script.
- :rtype: tuple
- :raises RuntimeError: If CLI script execution failed.
- """
-
- ssh = SSH()
- try:
- ssh.connect(node)
- except:
- raise SSHException("Cannot open SSH connection to execute CLI "
- "command(s) from template {0}".format(fname))
-
- ssh.scp(fname, fname)
-
- cmd = "{vat} {json}".format(json="json" if json_out is True else "",
- vat=Constants.VAT_BIN_NAME)
- cmd_input = "exec exec {0}".format(fname)
-
- VatHistory.add_to_vat_history(node, cmd_input)
- with open(fname, 'r') as tmp_f:
- VatHistory.add_to_vat_history(node, tmp_f.read())
-
- try:
- (ret_code, stdout, stderr) = ssh.exec_command_sudo(cmd, cmd_input,
- timeout)
- except SSHTimeout:
- logger.error("CLI script execution timeout: {0}{1}".
- format(cmd, "<<< " + cmd_input if cmd_input else ""))
- raise
- except:
- raise RuntimeError("CLI script execution failed: {0}{1}".format(
- cmd, "<<< " + cmd_input if cmd_input else ""))
-
- self._ret_code = ret_code
- self._stdout = stdout
- self._stderr = stderr
-
- self._delete_files(node, fname)
-
- def execute_script_json_out(self, vat_name, node, timeout=15):