Coverage for airflow.operators.bash_operator : 44%
Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
|
""" Execute a Bash script, command or set of commands.
:param bash_command: The command, set of commands or reference to a bash script (must be '.sh') to be executed. :type bash_command: string :param env: If env is not None, it must be a mapping that defines the environment variables for the new process; these are used instead of inheriting the current process environment, which is the default behavior. :type env: dict """
self, bash_command, xcom_push=False, env=None, *args, **kwargs): """ If xcom_push is True, the last line written to stdout will also be pushed to an XCom when the bash command completes. """
""" Execute the bash command in a temporary directory which will be cleaned afterwards """ bash_command = self.bash_command logging.info("tmp dir root location: \n" + gettempdir()) with TemporaryDirectory(prefix='airflowtmp') as tmp_dir: with NamedTemporaryFile(dir=tmp_dir, prefix=self.task_id) as f:
f.write(bytes(bash_command, 'utf_8')) f.flush() fname = f.name script_location = tmp_dir + "/" + fname logging.info("Temporary script " "location :{0}".format(script_location)) logging.info("Running command: " + bash_command) sp = Popen( ['bash', fname], stdout=PIPE, stderr=STDOUT, cwd=tmp_dir, env=self.env)
self.sp = sp
logging.info("Output:") line = '' for line in iter(sp.stdout.readline, b''): logging.info(line.strip()) sp.wait() logging.info("Command exited with " "return code {0}".format(sp.returncode))
if sp.returncode: raise AirflowException("Bash command failed")
if self.xcom_push: return str(line.strip())
logging.info('Sending SIGTERM signal to bash subprocess') self.sp.terminate() |