From 3a658aba698fbe3c3a31f400a84c767e393ee31c Mon Sep 17 00:00:00 2001 From: Hiroshi Miura Date: Sun, 15 Dec 2024 14:10:24 +0900 Subject: [PATCH] chore: rewrite test code without os.system() - mklink is a built-in command of cmd.exe --- tests/test_win32compat.py | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/tests/test_win32compat.py b/tests/test_win32compat.py index dfbd70f0..f23a3632 100644 --- a/tests/test_win32compat.py +++ b/tests/test_win32compat.py @@ -1,6 +1,7 @@ import ctypes import os import pathlib +import subprocess import sys import pytest @@ -63,7 +64,9 @@ def test_hardlink_readlink(tmp_path): hard = tmp_path / "target" / "link" hard.parent.mkdir(parents=True, exist_ok=True) if sys.platform.startswith("win"): - os.system("mklink /H %s %s" % (str(hard), str(target.resolve()))) + cmd_path = r"c:\Windows\System32\cmd.exe" + command = [cmd_path, "/c", "mklink", "/H", str(hard), str(target.resolve())] + subprocess.run(command) else: os.link(str(target.resolve()), str(hard)) assert hard.open("r").read() == "Original" @@ -82,7 +85,9 @@ def test_junction_readlink(tmp_path): f.write("Original") junction = tmp_path / "target" / "link" junction.parent.mkdir(parents=True, exist_ok=True) - os.system("mklink /J %s %s" % (str(junction), str(target.resolve()))) + cmd_path = r"c:\Windows\System32\cmd.exe" + command = [cmd_path, "/c", "mklink", "/J", str(junction), str(target.resolve())] + subprocess.run(command) assert not os.path.islink(str(junction)) assert py7zr.win32compat.is_reparse_point(str(junction)) assert py7zr.win32compat.readlink(str(junction)) == PATH_PREFIX + str(target.resolve())