Skip to content

Commit

Permalink
🚧 Test caching in ClassLoader
Browse files Browse the repository at this point in the history
Signed-off-by: ff137 <ff137@proton.me>
  • Loading branch information
ff137 committed Nov 28, 2024
1 parent 13e5a38 commit e7ba26f
Showing 1 changed file with 25 additions and 7 deletions.
32 changes: 25 additions & 7 deletions acapy_agent/utils/classloader.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@
import inspect
import logging
import sys
from functools import lru_cache
from importlib import import_module, resources
from importlib.util import find_spec, resolve_name
from types import ModuleType
Expand All @@ -25,8 +24,10 @@ class ClassNotFoundError(BaseError):
class ClassLoader:
"""Class used to load classes from modules dynamically."""

_module_cache = {} # Cache for loaded modules
_class_cache = {} # Cache for loaded classes

@classmethod
@lru_cache(maxsize=1024)
def load_module(
cls, mod_path: str, package: Optional[str] = None
) -> Optional[ModuleType]:
Expand All @@ -43,8 +44,15 @@ def load_module(
ModuleLoadError: If there was an error loading the module
"""

# Check the cache
cache_key = (mod_path, package)
if cache_key in cls._module_cache:
LOGGER.debug("Module found in cache: %s", cache_key)
return cls._module_cache[cache_key]

LOGGER.debug(
"Attempting to load module: %s%s",
"Loading module: %s%s",
mod_path,
f" with package: {package}" if package else "",
)
Expand All @@ -60,7 +68,9 @@ def load_module(
full_path = resolve_name(mod_path, package)

if full_path in sys.modules:
return sys.modules[full_path]
module = sys.modules[full_path]
cls._module_cache[cache_key] = module # Cache the module for future lookups
return module

if "." in mod_path:
parent_mod_path, mod_name = mod_path.rsplit(".", 1)
Expand All @@ -78,13 +88,14 @@ def load_module(

try:
LOGGER.debug("Importing package: %s, module: %s", package, mod_path)
return import_module(mod_path, package)
module = import_module(mod_path, package)
cls._module_cache[cache_key] = module # Cache the loaded module
return module
except ModuleNotFoundError as e:
LOGGER.warning("Module %s not found during import", full_path)
raise ModuleLoadError(f"Unable to import module {full_path}: {str(e)}") from e

@classmethod
@lru_cache(maxsize=1024)
def load_class(
cls,
class_name: str,
Expand All @@ -107,8 +118,14 @@ def load_class(
"""

# Check the cache
cache_key = (class_name, default_module, package)
if cache_key in cls._class_cache:
LOGGER.debug("Class found in cache: %s", class_name)
return cls._class_cache[cache_key]

LOGGER.debug(
"Attempting to load class: %s%s%s",
"Loading class: %s%s%s",
class_name,
f", with default_module: {default_module}" if default_module else "",
f", with package: {package}" if package else "",
Expand Down Expand Up @@ -149,6 +166,7 @@ def load_class(
f"Resolved value is not a class: {mod_path}.{class_name}"
)
LOGGER.debug("Successfully loaded class %s from module %s", class_name, mod_path)
cls._class_cache[cache_key] = resolved # Cache the resolved class
return resolved

@classmethod
Expand Down

0 comments on commit e7ba26f

Please sign in to comment.