From 12f2890e47aafafff4f199367fde3ed3eb4774c6 Mon Sep 17 00:00:00 2001 From: Samuel Maldonado Date: Fri, 22 Mar 2024 10:22:32 -0400 Subject: [PATCH] user separate sticky bit command when cleaning up test directories (#491) --- server/autotest_server/__init__.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/server/autotest_server/__init__.py b/server/autotest_server/__init__.py index 6f2ee12d..046b565a 100644 --- a/server/autotest_server/__init__.py +++ b/server/autotest_server/__init__.py @@ -218,6 +218,7 @@ def _run_test_specs( preexec_fn=set_rlimits_before_test, universal_newlines=True, env={**os.environ, **env_vars, **env}, + executable="/bin/bash", ) try: settings_json = json.dumps({**settings, "test_data": test_data}) @@ -254,10 +255,13 @@ def _clear_working_directory(tests_path: str, test_username: str) -> None: Run commands that clear the tests_path working directory """ if test_username != getpass.getuser(): - chmod_cmd = f"sudo -u {test_username} -- bash -c 'chmod -Rf -t ugo+rwX {tests_path}'" + sticky_cmd = f"sudo -u {test_username} -- bash -c 'chmod -Rf -t {tests_path}'" + chmod_cmd = f"sudo -u {test_username} -- bash -c 'chmod -Rf ugo+rwX {tests_path}'" else: - chmod_cmd = f"chmod -Rf -t ugo+rwX {tests_path}" + sticky_cmd = f"chmod -Rf -t {tests_path}" + chmod_cmd = f"chmod -Rf ugo+rwX {tests_path}" + subprocess.run(sticky_cmd, shell=True) subprocess.run(chmod_cmd, shell=True) # be careful not to remove the tests_path dir itself since we have to