mirror of
https://github.com/arcan1s/ahriman.git
synced 2025-04-24 15:27:17 +00:00
allow setting context with existing
In case of running command from web interface, it will raise exception because context has been copied with subprocesses
This commit is contained in:
parent
84d4523e85
commit
5c4d3eeffd
@ -58,23 +58,26 @@ class _Context:
|
||||
raise ValueError(f"Value {value} is not an instance of {key.return_type}")
|
||||
return value
|
||||
|
||||
def set(self, key: ContextKey[T], value: T) -> None:
|
||||
def set(self, key: ContextKey[T], value: T, strict: bool = True) -> None:
|
||||
"""
|
||||
set value for the specified key
|
||||
|
||||
Args:
|
||||
key(ContextKey[T]): context key name
|
||||
value(T): context value associated with the specified key
|
||||
strict(bool, optional): check if key already exists (Default value = True)
|
||||
|
||||
Raises:
|
||||
KeyError: in case if the specified context variable already exists
|
||||
ValueError: in case if type of value is not an instance of specified return type
|
||||
"""
|
||||
if key.key in self._content:
|
||||
has_key = key.key in self._content
|
||||
if strict and has_key:
|
||||
raise KeyError(key.key)
|
||||
if not isinstance(value, key.return_type):
|
||||
raise ValueError(f"Value {value} is not an instance of {key.return_type}")
|
||||
self._content[key.key] = value
|
||||
if not has_key:
|
||||
self._content[key.key] = value
|
||||
|
||||
def __iter__(self) -> Iterator[str]:
|
||||
"""
|
||||
|
@ -83,12 +83,12 @@ class Repository(Executor, UpdateHandler):
|
||||
"""
|
||||
ctx = context.get()
|
||||
|
||||
ctx.set(ContextKey("database", SQLite), self.database)
|
||||
ctx.set(ContextKey("configuration", Configuration), self.configuration)
|
||||
ctx.set(ContextKey("pacman", Pacman), self.pacman)
|
||||
ctx.set(ContextKey("sign", GPG), self.sign)
|
||||
ctx.set(ContextKey("database", SQLite), self.database, strict=False)
|
||||
ctx.set(ContextKey("configuration", Configuration), self.configuration, strict=False)
|
||||
ctx.set(ContextKey("pacman", Pacman), self.pacman, strict=False)
|
||||
ctx.set(ContextKey("sign", GPG), self.sign, strict=False)
|
||||
|
||||
ctx.set(ContextKey("repository", type(self)), self)
|
||||
ctx.set(ContextKey("repository", type(self)), self, strict=False)
|
||||
|
||||
context.set(ctx)
|
||||
|
||||
|
@ -32,11 +32,11 @@ def test_set_context(configuration: Configuration, database: SQLite, mocker: Moc
|
||||
|
||||
instance = Repository.load("x86_64", configuration, database, report=False, unsafe=False)
|
||||
set_mock.assert_has_calls([
|
||||
MockCall(ContextKey("database", SQLite), instance.database),
|
||||
MockCall(ContextKey("configuration", Configuration), instance.configuration),
|
||||
MockCall(ContextKey("pacman", Pacman), instance.pacman),
|
||||
MockCall(ContextKey("sign", GPG), instance.sign),
|
||||
MockCall(ContextKey("repository", Repository), instance),
|
||||
MockCall(ContextKey("database", SQLite), instance.database, strict=False),
|
||||
MockCall(ContextKey("configuration", Configuration), instance.configuration, strict=False),
|
||||
MockCall(ContextKey("pacman", Pacman), instance.pacman, strict=False),
|
||||
MockCall(ContextKey("sign", GPG), instance.sign, strict=False),
|
||||
MockCall(ContextKey("repository", Repository), instance, strict=False),
|
||||
])
|
||||
|
||||
|
||||
|
@ -57,6 +57,17 @@ def test_set_value_exception() -> None:
|
||||
ctx.set(ContextKey("key", str), 42)
|
||||
|
||||
|
||||
def test_set_value_exists() -> None:
|
||||
"""
|
||||
must skip key set in case if key already exists and strict check is disabled
|
||||
"""
|
||||
key, value = ContextKey("key", int), 42
|
||||
ctx = _Context()
|
||||
ctx.set(key, value)
|
||||
|
||||
ctx.set(key, value, strict=False)
|
||||
|
||||
|
||||
def test_contains() -> None:
|
||||
"""
|
||||
must correctly check if element is in list
|
||||
|
Loading…
Reference in New Issue
Block a user