From 611b726e79962e4e9ef148545c60b9e77cfc637a Mon Sep 17 00:00:00 2001 From: Abhijeet Kasurde Date: Fri, 17 Mar 2023 15:43:17 +0530 Subject: [PATCH] Handle custom project_dir Signed-off-by: Abhijeet Kasurde --- ansible_runner/config/_base.py | 11 ++-- .../projects/project_dir_test/env/envvars | 1 + .../projects/project_dir_test/inventory/inv_1 | 1 + .../project_dir_test/my_project/debug.yml | 6 ++ .../project_dir_test/project/debug.yml | 6 ++ test/integration/test_interface.py | 62 +++++++++++++++++++ test/unit/config/test_runner.py | 4 +- 7 files changed, 86 insertions(+), 5 deletions(-) create mode 100644 test/fixtures/projects/project_dir_test/env/envvars create mode 100644 test/fixtures/projects/project_dir_test/inventory/inv_1 create mode 100644 test/fixtures/projects/project_dir_test/my_project/debug.yml create mode 100644 test/fixtures/projects/project_dir_test/project/debug.yml diff --git a/ansible_runner/config/_base.py b/ansible_runner/config/_base.py index 1c43da075..25d4a9733 100644 --- a/ansible_runner/config/_base.py +++ b/ansible_runner/config/_base.py @@ -120,17 +120,17 @@ def __init__(self, self.artifact_dir = os.path.join(artifact_dir, "{}".format(self.ident)) + self.loader = ArtifactLoader(self.private_data_dir) + if not project_dir: self.project_dir = os.path.join(self.private_data_dir, 'project') else: - self.project_dir = project_dir + self.project_dir = self.loader.abspath(project_dir) self.rotate_artifacts = rotate_artifacts self.fact_cache_type = fact_cache_type self.fact_cache = os.path.join(self.artifact_dir, fact_cache or 'fact_cache') if self.fact_cache_type == 'jsonfile' else None - self.loader = ArtifactLoader(self.private_data_dir) - if self.host_cwd: self.host_cwd = os.path.abspath(self.host_cwd) self.cwd = self.host_cwd @@ -469,10 +469,13 @@ def wrap_args_for_containerization(self, args, execution_mode, cmdline_args): if self.container_workdir: workdir = self.container_workdir elif self.host_cwd is not None and os.path.exists(self.host_cwd): - # mount current host working diretory if passed and exist + # mount current host working directory if passed and exist self._ensure_path_safe_to_mount(self.host_cwd) self._update_volume_mount_paths(new_args, self.host_cwd) workdir = self.host_cwd + elif self.project_dir: + workdir = "/runner/project" + self._update_volume_mount_paths(new_args, self.project_dir, workdir) else: workdir = "/runner/project" diff --git a/test/fixtures/projects/project_dir_test/env/envvars b/test/fixtures/projects/project_dir_test/env/envvars new file mode 100644 index 000000000..c85123e2e --- /dev/null +++ b/test/fixtures/projects/project_dir_test/env/envvars @@ -0,0 +1 @@ +ANSIBLE_DEVEL_WARNING: no diff --git a/test/fixtures/projects/project_dir_test/inventory/inv_1 b/test/fixtures/projects/project_dir_test/inventory/inv_1 new file mode 100644 index 000000000..093f403c6 --- /dev/null +++ b/test/fixtures/projects/project_dir_test/inventory/inv_1 @@ -0,0 +1 @@ +host_1 ansible_connection=local ansible_python_interpreter="{{ ansible_playbook_python }}" diff --git a/test/fixtures/projects/project_dir_test/my_project/debug.yml b/test/fixtures/projects/project_dir_test/my_project/debug.yml new file mode 100644 index 000000000..9f75f2217 --- /dev/null +++ b/test/fixtures/projects/project_dir_test/my_project/debug.yml @@ -0,0 +1,6 @@ +- hosts: all + gather_facts: no + + tasks: + - debug: + msg: "In my_project" diff --git a/test/fixtures/projects/project_dir_test/project/debug.yml b/test/fixtures/projects/project_dir_test/project/debug.yml new file mode 100644 index 000000000..e19899a9f --- /dev/null +++ b/test/fixtures/projects/project_dir_test/project/debug.yml @@ -0,0 +1,6 @@ +- hosts: all + gather_facts: no + + tasks: + - debug: + msg: "In project" diff --git a/test/integration/test_interface.py b/test/integration/test_interface.py index 42a0b53ef..9da23faf1 100644 --- a/test/integration/test_interface.py +++ b/test/integration/test_interface.py @@ -190,6 +190,68 @@ def test_multiple_inventories(project_fixtures): assert 'host_2' in stdout +def test_default_project_dir(project_fixtures): + private_data_dir = project_fixtures / 'project_dir_test' + + res = run( + private_data_dir=private_data_dir, + playbook='debug.yml', + ) + stdout = res.stdout.read() + + assert res.rc == 0, stdout + assert 'In project' in stdout + + +def test_project_dir(project_fixtures): + private_data_dir = project_fixtures / 'project_dir_test' + + res = run( + private_data_dir=private_data_dir, + project_dir='my_project', + playbook='debug.yml', + ) + stdout = res.stdout.read() + + assert res.rc == 0, stdout + assert 'In my_project' in stdout + + +@pytest.mark.test_all_runtimes +def test_default_project_dir_inside_container(project_fixtures, runtime): + private_data_dir = project_fixtures / 'project_dir_test' + + res = run( + private_data_dir=private_data_dir, + playbook='debug.yml', + process_isolation_executable=runtime, + process_isolation=True, + container_image=defaults.default_container_image, + ) + stdout = res.stdout.read() + + assert res.rc == 0, stdout + assert 'In project' in stdout + + +@pytest.mark.test_all_runtimes +def test_project_dir_inside_container(project_fixtures, runtime): + private_data_dir = project_fixtures / 'project_dir_test' + + res = run( + private_data_dir=private_data_dir, + project_dir='my_project', + playbook='debug.yml', + process_isolation_executable=runtime, + process_isolation=True, + container_image=defaults.default_container_image, + ) + stdout = res.stdout.read() + + assert res.rc == 0, stdout + assert 'In my_project' in stdout + + def test_inventory_absolute_path(project_fixtures): private_data_dir = project_fixtures / 'debug' diff --git a/test/unit/config/test_runner.py b/test/unit/config/test_runner.py index 67b662203..de67562d0 100644 --- a/test/unit/config/test_runner.py +++ b/test/unit/config/test_runner.py @@ -746,7 +746,9 @@ def test_containerization_settings(tmp_path, runtime, mocker): else: extra_container_args = [f'--user={os.getuid()}'] - expected_command_start = [runtime, 'run', '--rm', '--tty', '--interactive', '--workdir', '/runner/project'] + \ + expected_command_start = [runtime, 'run', '--rm', '--tty', '--interactive'] + \ + ['-v', '{}/project/:/runner/project/'.format(rc.private_data_dir)] + \ + ['--workdir', '/runner/project'] + \ ['-v', '{}/:/runner/:Z'.format(rc.private_data_dir)] + \ ['-v', '/host1/:/container1/', '-v', '/host2/:/container2/'] + \ ['--env-file', '{}/env.list'.format(rc.artifact_dir)] + \