mirror of
https://github.com/comfyanonymous/ComfyUI.git
synced 2026-05-25 08:27:25 +08:00
test(assets): use real platform paths so containment check works on Windows
Some checks are pending
Python Linting / Run Ruff (push) Waiting to run
Python Linting / Run Pylint (push) Waiting to run
Build package / Build Test (3.10) (push) Waiting to run
Build package / Build Test (3.11) (push) Waiting to run
Build package / Build Test (3.12) (push) Waiting to run
Build package / Build Test (3.13) (push) Waiting to run
Build package / Build Test (3.14) (push) Waiting to run
Some checks are pending
Python Linting / Run Ruff (push) Waiting to run
Python Linting / Run Pylint (push) Waiting to run
Build package / Build Test (3.10) (push) Waiting to run
Build package / Build Test (3.11) (push) Waiting to run
Build package / Build Test (3.12) (push) Waiting to run
Build package / Build Test (3.13) (push) Waiting to run
Build package / Build Test (3.14) (push) Waiting to run
The previous test setup patched os.path.abspath to identity and used a POSIX-style '/output' base, which collided with Windows path separators in os.path.commonpath. Drop the abspath/join patches and use a real tempdir-rooted base so the containment check runs against actual platform paths.
This commit is contained in:
parent
2eb15b6237
commit
1ebbee4522
@ -23,7 +23,12 @@ def _make_register_result(ref_id="ref-id-2"):
|
|||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
def _call(output_ui, *, enable_assets=True, file_exists=True, db_ref=None, register_result=None, directory="/output"):
|
# Platform-appropriate absolute base. tempfile.gettempdir() returns C:\... on
|
||||||
|
# Windows and /tmp on POSIX, so containment via commonpath behaves naturally.
|
||||||
|
_DEFAULT_BASE = os.path.join(__import__("tempfile").gettempdir(), "asset-enrichment-test-base")
|
||||||
|
|
||||||
|
|
||||||
|
def _call(output_ui, *, enable_assets=True, file_exists=True, db_ref=None, register_result=None, directory=_DEFAULT_BASE):
|
||||||
fake_session_cm = MagicMock()
|
fake_session_cm = MagicMock()
|
||||||
fake_session_cm.__enter__ = MagicMock(return_value=MagicMock())
|
fake_session_cm.__enter__ = MagicMock(return_value=MagicMock())
|
||||||
fake_session_cm.__exit__ = MagicMock(return_value=False)
|
fake_session_cm.__exit__ = MagicMock(return_value=False)
|
||||||
@ -41,10 +46,10 @@ def _call(output_ui, *, enable_assets=True, file_exists=True, db_ref=None, regis
|
|||||||
"app.database.db": MagicMock(create_session=MagicMock(return_value=fake_session_cm)),
|
"app.database.db": MagicMock(create_session=MagicMock(return_value=fake_session_cm)),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Only os.path.isfile is patched — abspath/join must run natively so the
|
||||||
|
# containment check sees real platform paths.
|
||||||
with patch.dict("sys.modules", mocked_modules), \
|
with patch.dict("sys.modules", mocked_modules), \
|
||||||
patch("os.path.abspath", side_effect=lambda p: p), \
|
patch("os.path.isfile", return_value=file_exists):
|
||||||
patch("os.path.isfile", return_value=file_exists), \
|
|
||||||
patch("os.path.join", side_effect=os.path.join):
|
|
||||||
import importlib
|
import importlib
|
||||||
import comfy_execution.asset_enrichment as mod
|
import comfy_execution.asset_enrichment as mod
|
||||||
importlib.reload(mod)
|
importlib.reload(mod)
|
||||||
@ -126,7 +131,7 @@ class TestEnrichOutputWithAssets(unittest.TestCase):
|
|||||||
|
|
||||||
mocked_modules = {
|
mocked_modules = {
|
||||||
"comfy.cli_args": MagicMock(args=_make_args(True)),
|
"comfy.cli_args": MagicMock(args=_make_args(True)),
|
||||||
"folder_paths": MagicMock(get_directory_by_type=MagicMock(return_value="/output")),
|
"folder_paths": MagicMock(get_directory_by_type=MagicMock(return_value=_DEFAULT_BASE)),
|
||||||
"app.assets.services.ingest": MagicMock(
|
"app.assets.services.ingest": MagicMock(
|
||||||
register_file_in_place=register_side_effect,
|
register_file_in_place=register_side_effect,
|
||||||
DependencyMissingError=type("DependencyMissingError", (Exception,), {}),
|
DependencyMissingError=type("DependencyMissingError", (Exception,), {}),
|
||||||
@ -145,9 +150,7 @@ class TestEnrichOutputWithAssets(unittest.TestCase):
|
|||||||
}
|
}
|
||||||
|
|
||||||
with patch.dict("sys.modules", mocked_modules), \
|
with patch.dict("sys.modules", mocked_modules), \
|
||||||
patch("os.path.abspath", side_effect=lambda p: p), \
|
patch("os.path.isfile", return_value=True):
|
||||||
patch("os.path.isfile", return_value=True), \
|
|
||||||
patch("os.path.join", side_effect=os.path.join):
|
|
||||||
import importlib
|
import importlib
|
||||||
import comfy_execution.asset_enrichment as mod
|
import comfy_execution.asset_enrichment as mod
|
||||||
importlib.reload(mod)
|
importlib.reload(mod)
|
||||||
@ -180,7 +183,7 @@ class TestEnrichOutputWithAssets(unittest.TestCase):
|
|||||||
register_mock = MagicMock(return_value=_make_register_result())
|
register_mock = MagicMock(return_value=_make_register_result())
|
||||||
mocked_modules = {
|
mocked_modules = {
|
||||||
"comfy.cli_args": MagicMock(args=_make_args(True)),
|
"comfy.cli_args": MagicMock(args=_make_args(True)),
|
||||||
"folder_paths": MagicMock(get_directory_by_type=MagicMock(return_value="/output")),
|
"folder_paths": MagicMock(get_directory_by_type=MagicMock(return_value=_DEFAULT_BASE)),
|
||||||
"app.assets.services.ingest": MagicMock(
|
"app.assets.services.ingest": MagicMock(
|
||||||
register_file_in_place=register_mock,
|
register_file_in_place=register_mock,
|
||||||
DependencyMissingError=type("DependencyMissingError", (Exception,), {}),
|
DependencyMissingError=type("DependencyMissingError", (Exception,), {}),
|
||||||
@ -212,7 +215,7 @@ class TestEnrichOutputWithAssets(unittest.TestCase):
|
|||||||
register_mock = MagicMock(return_value=_make_register_result())
|
register_mock = MagicMock(return_value=_make_register_result())
|
||||||
mocked_modules = {
|
mocked_modules = {
|
||||||
"comfy.cli_args": MagicMock(args=_make_args(True)),
|
"comfy.cli_args": MagicMock(args=_make_args(True)),
|
||||||
"folder_paths": MagicMock(get_directory_by_type=MagicMock(return_value="/output")),
|
"folder_paths": MagicMock(get_directory_by_type=MagicMock(return_value=_DEFAULT_BASE)),
|
||||||
"app.assets.services.ingest": MagicMock(
|
"app.assets.services.ingest": MagicMock(
|
||||||
register_file_in_place=register_mock,
|
register_file_in_place=register_mock,
|
||||||
DependencyMissingError=type("DependencyMissingError", (Exception,), {}),
|
DependencyMissingError=type("DependencyMissingError", (Exception,), {}),
|
||||||
@ -224,7 +227,8 @@ class TestEnrichOutputWithAssets(unittest.TestCase):
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Absolute filename — os.path.join discards earlier components when a later one is absolute.
|
# Absolute filename — os.path.join discards earlier components when a later one is absolute.
|
||||||
output = {"images": [{"filename": "/etc/passwd", "subfolder": "", "type": "output"}]}
|
absolute_filename = os.path.abspath(os.sep + "etc" + os.sep + "passwd")
|
||||||
|
output = {"images": [{"filename": absolute_filename, "subfolder": "", "type": "output"}]}
|
||||||
|
|
||||||
with patch.dict("sys.modules", mocked_modules), \
|
with patch.dict("sys.modules", mocked_modules), \
|
||||||
patch("os.path.isfile", return_value=True):
|
patch("os.path.isfile", return_value=True):
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user