2024-09-10 04:33:44 +00:00
|
|
|
import pytest
|
|
|
|
import yaml
|
|
|
|
import os
|
|
|
|
from unittest.mock import Mock, patch, mock_open
|
|
|
|
|
|
|
|
from utils.extra_config import load_extra_path_config
|
|
|
|
import folder_paths
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def mock_yaml_content():
|
|
|
|
return {
|
|
|
|
'test_config': {
|
|
|
|
'base_path': '~/App/',
|
|
|
|
'checkpoints': 'subfolder1',
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def mock_expanded_home():
|
|
|
|
return '/home/user'
|
|
|
|
|
2024-09-12 05:52:06 +00:00
|
|
|
@pytest.fixture
|
|
|
|
def yaml_config_with_appdata():
|
|
|
|
return """
|
|
|
|
test_config:
|
|
|
|
base_path: '%APPDATA%/ComfyUI'
|
|
|
|
checkpoints: 'models/checkpoints'
|
|
|
|
"""
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def mock_yaml_content_appdata(yaml_config_with_appdata):
|
|
|
|
return yaml.safe_load(yaml_config_with_appdata)
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def mock_expandvars_appdata():
|
|
|
|
mock = Mock()
|
|
|
|
mock.side_effect = lambda path: path.replace('%APPDATA%', 'C:/Users/TestUser/AppData/Roaming')
|
|
|
|
return mock
|
|
|
|
|
2024-09-10 04:33:44 +00:00
|
|
|
@pytest.fixture
|
|
|
|
def mock_add_model_folder_path():
|
|
|
|
return Mock()
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def mock_expanduser(mock_expanded_home):
|
|
|
|
def _expanduser(path):
|
|
|
|
if path.startswith('~/'):
|
|
|
|
return os.path.join(mock_expanded_home, path[2:])
|
|
|
|
return path
|
|
|
|
return _expanduser
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def mock_yaml_safe_load(mock_yaml_content):
|
|
|
|
return Mock(return_value=mock_yaml_content)
|
|
|
|
|
|
|
|
@patch('builtins.open', new_callable=mock_open, read_data="dummy file content")
|
|
|
|
def test_load_extra_model_paths_expands_userpath(
|
|
|
|
mock_file,
|
|
|
|
monkeypatch,
|
|
|
|
mock_add_model_folder_path,
|
|
|
|
mock_expanduser,
|
|
|
|
mock_yaml_safe_load,
|
|
|
|
mock_expanded_home
|
|
|
|
):
|
|
|
|
# Attach mocks used by load_extra_path_config
|
|
|
|
monkeypatch.setattr(folder_paths, 'add_model_folder_path', mock_add_model_folder_path)
|
|
|
|
monkeypatch.setattr(os.path, 'expanduser', mock_expanduser)
|
|
|
|
monkeypatch.setattr(yaml, 'safe_load', mock_yaml_safe_load)
|
|
|
|
|
|
|
|
dummy_yaml_file_name = 'dummy_path.yaml'
|
|
|
|
load_extra_path_config(dummy_yaml_file_name)
|
|
|
|
|
|
|
|
expected_calls = [
|
2024-09-19 12:59:55 +00:00
|
|
|
('checkpoints', os.path.join(mock_expanded_home, 'App', 'subfolder1'), False),
|
2024-09-10 04:33:44 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
assert mock_add_model_folder_path.call_count == len(expected_calls)
|
2024-12-28 10:22:21 +00:00
|
|
|
|
2024-09-10 04:33:44 +00:00
|
|
|
# Check if add_model_folder_path was called with the correct arguments
|
|
|
|
for actual_call, expected_call in zip(mock_add_model_folder_path.call_args_list, expected_calls):
|
2024-09-22 09:01:39 +00:00
|
|
|
assert actual_call.args[0] == expected_call[0]
|
|
|
|
assert os.path.normpath(actual_call.args[1]) == os.path.normpath(expected_call[1]) # Normalize and check the path to check on multiple OS.
|
|
|
|
assert actual_call.args[2] == expected_call[2]
|
2024-09-10 04:33:44 +00:00
|
|
|
|
|
|
|
# Check if yaml.safe_load was called
|
|
|
|
mock_yaml_safe_load.assert_called_once()
|
|
|
|
|
|
|
|
# Check if open was called with the correct file path
|
|
|
|
mock_file.assert_called_once_with(dummy_yaml_file_name, 'r')
|
2024-09-12 05:52:06 +00:00
|
|
|
|
|
|
|
@patch('builtins.open', new_callable=mock_open)
|
|
|
|
def test_load_extra_model_paths_expands_appdata(
|
|
|
|
mock_file,
|
|
|
|
monkeypatch,
|
|
|
|
mock_add_model_folder_path,
|
|
|
|
mock_expandvars_appdata,
|
|
|
|
yaml_config_with_appdata,
|
|
|
|
mock_yaml_content_appdata
|
|
|
|
):
|
|
|
|
# Set the mock_file to return yaml with appdata as a variable
|
|
|
|
mock_file.return_value.read.return_value = yaml_config_with_appdata
|
|
|
|
|
|
|
|
# Attach mocks
|
|
|
|
monkeypatch.setattr(folder_paths, 'add_model_folder_path', mock_add_model_folder_path)
|
|
|
|
monkeypatch.setattr(os.path, 'expandvars', mock_expandvars_appdata)
|
|
|
|
monkeypatch.setattr(yaml, 'safe_load', Mock(return_value=mock_yaml_content_appdata))
|
|
|
|
|
|
|
|
# Mock expanduser to do nothing (since we're not testing it here)
|
|
|
|
monkeypatch.setattr(os.path, 'expanduser', lambda x: x)
|
|
|
|
|
|
|
|
dummy_yaml_file_name = 'dummy_path.yaml'
|
|
|
|
load_extra_path_config(dummy_yaml_file_name)
|
|
|
|
|
|
|
|
expected_base_path = 'C:/Users/TestUser/AppData/Roaming/ComfyUI'
|
|
|
|
expected_calls = [
|
2024-09-19 12:59:55 +00:00
|
|
|
('checkpoints', os.path.join(expected_base_path, 'models/checkpoints'), False),
|
2024-09-12 05:52:06 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
assert mock_add_model_folder_path.call_count == len(expected_calls)
|
2024-12-28 10:22:21 +00:00
|
|
|
|
2024-09-12 05:52:06 +00:00
|
|
|
# Check the base path variable was expanded
|
|
|
|
for actual_call, expected_call in zip(mock_add_model_folder_path.call_args_list, expected_calls):
|
|
|
|
assert actual_call.args == expected_call
|
|
|
|
|
|
|
|
# Verify that expandvars was called
|
|
|
|
assert mock_expandvars_appdata.called
|