2023-09-22 22:44:10 +00:00
|
|
|
import contextlib
|
|
|
|
from pathlib import Path
|
|
|
|
from typing import Optional, Union
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
import torch
|
|
|
|
|
2024-07-02 19:26:08 +00:00
|
|
|
from invokeai.app.services.model_manager.model_manager_base import ModelManagerServiceBase
|
2024-02-17 16:45:32 +00:00
|
|
|
from invokeai.app.services.model_records import UnknownModelException
|
2024-07-02 20:48:33 +00:00
|
|
|
from invokeai.backend.model_manager import BaseModelType, ModelType, SubModelType
|
|
|
|
from invokeai.backend.model_manager.load.load_base import LoadedModel
|
2023-09-22 22:44:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope="session")
|
|
|
|
def torch_device():
|
|
|
|
return "cuda" if torch.cuda.is_available() else "cpu"
|
|
|
|
|
|
|
|
|
|
|
|
def install_and_load_model(
|
2024-02-17 16:45:32 +00:00
|
|
|
model_manager: ModelManagerServiceBase,
|
2023-09-22 22:44:10 +00:00
|
|
|
model_path_id_or_url: Union[str, Path],
|
|
|
|
model_name: str,
|
|
|
|
base_model: BaseModelType,
|
|
|
|
model_type: ModelType,
|
|
|
|
submodel_type: Optional[SubModelType] = None,
|
2024-02-17 16:45:32 +00:00
|
|
|
) -> LoadedModel:
|
|
|
|
"""Install a model if it is not already installed, then get the LoadedModel for that model.
|
2023-09-22 22:44:10 +00:00
|
|
|
|
|
|
|
This is intended as a utility function for tests.
|
|
|
|
|
|
|
|
Args:
|
2024-02-17 16:45:32 +00:00
|
|
|
mm2_model_manager (ModelManagerServiceBase): The model manager
|
2023-09-22 22:44:10 +00:00
|
|
|
model_path_id_or_url (Union[str, Path]): The path, HF ID, URL, etc. where the model can be installed from if it
|
|
|
|
is not already installed.
|
|
|
|
model_name (str): The model name, forwarded to ModelManager.get_model(...).
|
|
|
|
base_model (BaseModelType): The base model, forwarded to ModelManager.get_model(...).
|
|
|
|
model_type (ModelType): The model type, forwarded to ModelManager.get_model(...).
|
|
|
|
submodel_type (Optional[SubModelType]): The submodel type, forwarded to ModelManager.get_model(...).
|
|
|
|
|
|
|
|
Returns:
|
2024-02-10 22:27:57 +00:00
|
|
|
LoadedModelInfo
|
2023-09-22 22:44:10 +00:00
|
|
|
"""
|
2024-02-17 16:45:32 +00:00
|
|
|
# If the requested model is already installed, return its LoadedModel
|
|
|
|
with contextlib.suppress(UnknownModelException):
|
|
|
|
# TODO: Replace with wrapper call
|
2024-03-06 08:04:33 +00:00
|
|
|
configs = model_manager.store.search_by_attr(
|
2024-02-17 16:45:32 +00:00
|
|
|
model_name=model_name, base_model=base_model, model_type=model_type
|
|
|
|
)
|
2024-03-06 08:04:33 +00:00
|
|
|
loaded_model: LoadedModel = model_manager.load.load_model(configs[0])
|
2024-02-17 16:45:32 +00:00
|
|
|
return loaded_model
|
2023-09-22 22:44:10 +00:00
|
|
|
|
|
|
|
# Install the requested model.
|
2024-02-17 16:45:32 +00:00
|
|
|
job = model_manager.install.heuristic_import(model_path_id_or_url)
|
|
|
|
model_manager.install.wait_for_job(job, timeout=10)
|
|
|
|
assert job.complete
|
2023-09-22 22:44:10 +00:00
|
|
|
|
|
|
|
try:
|
2024-03-06 08:04:33 +00:00
|
|
|
loaded_model = model_manager.load.load_model(job.config_out)
|
2024-02-17 16:45:32 +00:00
|
|
|
return loaded_model
|
|
|
|
except UnknownModelException as e:
|
2023-09-22 22:44:10 +00:00
|
|
|
raise Exception(
|
|
|
|
"Failed to get model info after installing it. There could be a mismatch between the requested model and"
|
|
|
|
f" the installation id ('{model_path_id_or_url}'). Error: {e}"
|
|
|
|
)
|