Spaces:
Running
on
Zero
Running
on
Zero
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 | |
def mock_yaml_content(): | |
return { | |
'test_config': { | |
'base_path': '~/App/', | |
'checkpoints': 'subfolder1', | |
} | |
} | |
def mock_expanded_home(): | |
return '/home/user' | |
def yaml_config_with_appdata(): | |
return """ | |
test_config: | |
base_path: '%APPDATA%/ComfyUI' | |
checkpoints: 'models/checkpoints' | |
""" | |
def mock_yaml_content_appdata(yaml_config_with_appdata): | |
return yaml.safe_load(yaml_config_with_appdata) | |
def mock_expandvars_appdata(): | |
mock = Mock() | |
mock.side_effect = lambda path: path.replace('%APPDATA%', 'C:/Users/TestUser/AppData/Roaming') | |
return mock | |
def mock_add_model_folder_path(): | |
return Mock() | |
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 | |
def mock_yaml_safe_load(mock_yaml_content): | |
return Mock(return_value=mock_yaml_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 = [ | |
('checkpoints', os.path.join(mock_expanded_home, 'App', 'subfolder1'), False), | |
] | |
assert mock_add_model_folder_path.call_count == len(expected_calls) | |
# 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): | |
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] | |
# 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') | |
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 = [ | |
('checkpoints', os.path.join(expected_base_path, 'models/checkpoints'), False), | |
] | |
assert mock_add_model_folder_path.call_count == len(expected_calls) | |
# 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 | |