- 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):