Skip to content

Commit

Permalink
command.Command._run_local_command(): add environment variable RUNNIN…
Browse files Browse the repository at this point in the history
…G_INSIDE_AUTOMATIX=1

This allows tools and commands to evaluate whether they are running inside
automatix and adjust their behaviour accordingly.
  • Loading branch information
fkusei committed Jul 31, 2024
1 parent 893997d commit e30a097
Showing 1 changed file with 16 additions and 3 deletions.
19 changes: 16 additions & 3 deletions automatix/command.py
Original file line number Diff line number Diff line change
Expand Up @@ -263,15 +263,28 @@ def _build_command(self, path: str) -> str:
return f'. {path}/' + f'; . {path}/'.join(self.env.imports) + '; ' + self.get_resolved_value()

def _run_local_command(self, cmd: str) -> int:
self.env.LOG.debug(f'Executing: {cmd}')
process_environment = os.environ.copy()
process_environment['RUNNING_INSIDE_AUTOMATIX'] = '1'
self.env.LOG.debug(f'Executing: {repr(cmd)} with environment {repr(process_environment)}')
if self.assignment_var:
proc = subprocess.run(cmd, shell=True, executable=SHELL_EXECUTABLE, stdout=subprocess.PIPE)
proc = subprocess.run(
cmd,
env=process_environment,
executable=SHELL_EXECUTABLE,
shell=True,
stdout=subprocess.PIPE,
)
output = proc.stdout.decode(self.env.config["encoding"])
self.env.vars[self.assignment_var] = assigned_value = output.rstrip('\r\n')
hint = ' (trailing newline removed)' if (output.endswith('\n') or output.endswith('\r')) else ''
self.env.LOG.info(f'Variable {self.assignment_var} = "{assigned_value}"{hint}')
else:
proc = subprocess.run(cmd, shell=True, executable=SHELL_EXECUTABLE)
proc = subprocess.run(
cmd,
env=process_environment,
executable=SHELL_EXECUTABLE,
shell=True,
)
return proc.returncode

def _remote_action(self) -> int:
Expand Down

0 comments on commit e30a097

Please # to comment.