From 18ed980ab146fd20ecddc7391a6c8d9414b25255 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9gis=20Behmo?= Date: Thu, 21 Nov 2024 11:11:50 +0100 Subject: [PATCH] feat: get rid of `is_docker_rootless` template filter This filter was used only by Elasticsearch, so we no longer need to include it in Tutor. --- ...121_110954_regis_remove_docker_rootless.md | 1 + tests/test_utils.py | 19 ------------------- tutor/env.py | 1 - tutor/utils.py | 14 -------------- 4 files changed, 1 insertion(+), 34 deletions(-) create mode 100644 changelog.d/20241121_110954_regis_remove_docker_rootless.md diff --git a/changelog.d/20241121_110954_regis_remove_docker_rootless.md b/changelog.d/20241121_110954_regis_remove_docker_rootless.md new file mode 100644 index 0000000000..c5e5b8486e --- /dev/null +++ b/changelog.d/20241121_110954_regis_remove_docker_rootless.md @@ -0,0 +1 @@ +- 💥[Improvement] Get rid of the `is_docker_rootless` template filter, which was used only by Elasticsearch. (by @regisb) diff --git a/tests/test_utils.py b/tests/test_utils.py index 5d5a6428ee..d259da50e8 100644 --- a/tests/test_utils.py +++ b/tests/test_utils.py @@ -242,25 +242,6 @@ def test_is_http(self) -> None: self.assertFalse(utils.is_http("home/user/")) self.assertFalse(utils.is_http("http-home/user/")) - @patch("subprocess.run") - def test_is_docker_rootless(self, mock_run: MagicMock) -> None: - # Mock rootless `docker info` output - utils.is_docker_rootless.cache_clear() - mock_run.return_value.stdout = "some prefix\n rootless foo bar".encode("utf-8") - self.assertTrue(utils.is_docker_rootless()) - - # Mock regular `docker info` output - utils.is_docker_rootless.cache_clear() - mock_run.return_value.stdout = "some prefix, regular docker".encode("utf-8") - self.assertFalse(utils.is_docker_rootless()) - - @patch("subprocess.run") - def test_is_docker_rootless_podman(self, mock_run: MagicMock) -> None: - """Test the `is_docker_rootless` when podman is used or any other error with `docker info`""" - utils.is_docker_rootless.cache_clear() - mock_run.side_effect = subprocess.CalledProcessError(1, "docker info") - self.assertFalse(utils.is_docker_rootless()) - def test_format_table(self) -> None: rows: List[Tuple[str, ...]] = [ ("a", "xyz", "value 1"), diff --git a/tutor/env.py b/tutor/env.py index d67f1ee591..8067533259 100644 --- a/tutor/env.py +++ b/tutor/env.py @@ -66,7 +66,6 @@ def _prepare_environment() -> None: ("HOST_USER_ID", utils.get_user_id()), ("TUTOR_APP", __app__.replace("-", "_")), ("TUTOR_VERSION", __version__), - ("is_docker_rootless", utils.is_docker_rootless), ], ) diff --git a/tutor/utils.py b/tutor/utils.py index 344f7bcfc0..45d4abecd5 100644 --- a/tutor/utils.py +++ b/tutor/utils.py @@ -194,20 +194,6 @@ def docker(*command: str) -> int: return execute("docker", *command) -@lru_cache(maxsize=None) -def is_docker_rootless() -> bool: - """ - A helper function to determine if Docker is running in rootless mode. - - - https://docs.docker.com/engine/security/rootless/ - """ - try: - results = subprocess.run(["docker", "info"], capture_output=True, check=True) - return "rootless" in results.stdout.decode() - except subprocess.CalledProcessError: - return False - - def docker_compose(*command: str) -> int: return execute("docker", "compose", *command)