From 63326f2703e5fcd05f10e6025c321ec39592bd4c Mon Sep 17 00:00:00 2001 From: Bryce Gattis <69012021+brycegbrazen@users.noreply.github.com> Date: Sun, 22 Sep 2024 13:35:39 -0500 Subject: [PATCH] Make Powershell correctly return exit codes for aliases (#1778) Fixes issue where powershell plugins were not correctly capturing exit codes when aliased commands failed (#1778) --------- Signed-off-by: brycegbrazen Co-authored-by: Jean-Christophe Morin <38703886+JeanChristopheMorinPerso@users.noreply.github.com> --- src/rez/tests/test_shells.py | 16 ++++++++++++++++ src/rezplugins/shell/_utils/powershell_base.py | 2 +- 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/src/rez/tests/test_shells.py b/src/rez/tests/test_shells.py index 35f7de76e..114497089 100644 --- a/src/rez/tests/test_shells.py +++ b/src/rez/tests/test_shells.py @@ -591,6 +591,22 @@ def _make_alias(ex): out, _ = p.communicate() self.assertEqual(0, p.returncode) + @per_available_shell() + def test_alias_return_code(self, shell): + """Ensure return codes are correct while using aliases.""" + config.override("default_shell", shell) + + def _make_alias(ex): + ex.alias('my_alias', 'hello_world -r 1') + + r = self._create_context(["hello_world"]) + p = r.execute_shell(command='my_alias', + actions_callback=_make_alias, + stdout=subprocess.PIPE) + + out, _ = p.communicate() + self.assertEqual(1, p.returncode) + if __name__ == '__main__': unittest.main() diff --git a/src/rezplugins/shell/_utils/powershell_base.py b/src/rezplugins/shell/_utils/powershell_base.py index f059bb248..bf9d3014d 100644 --- a/src/rezplugins/shell/_utils/powershell_base.py +++ b/src/rezplugins/shell/_utils/powershell_base.py @@ -174,7 +174,7 @@ def _record_shell(ex, files, bind_rez=True, print_msg=False): # only the bool $? var is set. # executor.command( - "if(! $?) {\n" + "if(! $? -or $LASTEXITCODE) {\n" " if ($LASTEXITCODE) {\n" " exit $LASTEXITCODE\n" " }\n"