add known_output override #3 #4

This commit is contained in:
JerryXiao 2021-02-09 11:01:33 +08:00
parent 6bdbd52707
commit c5d110c9b8
Signed by: Jerry
GPG key ID: 9D9CE43650FF2BAA
3 changed files with 28 additions and 1 deletions

View file

@ -1,8 +1,12 @@
import json import json
from pathlib import Path from pathlib import Path
import sys
import importlib.util
from typing import Any
CONFIG_DIR = Path('/etc/pacroller') CONFIG_DIR = Path('/etc/pacroller')
CONFIG_FILE = 'config.json' CONFIG_FILE = 'config.json'
F_KNOWN_OUTPUT_OVERRIDE = 'known_output_override.py'
LIB_DIR = Path('/var/lib/pacroller') LIB_DIR = Path('/var/lib/pacroller')
DB_FILE = 'db' DB_FILE = 'db'
PACMAN_CONFIG = '/etc/pacman.conf' PACMAN_CONFIG = '/etc/pacman.conf'
@ -16,6 +20,17 @@ if (cfg := (CONFIG_DIR / CONFIG_FILE)).exists():
else: else:
_config = dict() _config = dict()
def _import_module(fpath: str) -> Any:
spec = importlib.util.spec_from_file_location(fpath.removesuffix('.py').replace('/', '.'), fpath)
mod = importlib.util.module_from_spec(spec)
spec.loader.exec_module(mod)
return mod
if (_komf := (CONFIG_DIR / F_KNOWN_OUTPUT_OVERRIDE)).exists():
_kom = _import_module(str(_komf.resolve()))
KNOWN_OUTPUT_OVERRIDE = (_kom.KNOWN_HOOK_OUTPUT, _kom.KNOWN_PACKAGE_OUTPUT)
else:
KNOWN_OUTPUT_OVERRIDE = (dict(), dict())
TIMEOUT = int(_config.get('timeout', 300)) TIMEOUT = int(_config.get('timeout', 300))
UPGRADE_TIMEOUT = int(_config.get('upgrade_timeout', 3600)) UPGRADE_TIMEOUT = int(_config.get('upgrade_timeout', 3600))
NETWORK_RETRY = int(_config.get('network_retry', 5)) NETWORK_RETRY = int(_config.get('network_retry', 5))

View file

@ -1,3 +1,6 @@
from pacroller.config import KNOWN_OUTPUT_OVERRIDE
KNOWN_HOOK_OUTPUT_OVERRIDE, KNOWN_PACKAGE_OUTPUT_OVERRIDE = KNOWN_OUTPUT_OVERRIDE
KNOWN_HOOK_OUTPUT = { KNOWN_HOOK_OUTPUT = {
'': [], '': [],
'20-systemd-sysusers.hook': [ '20-systemd-sysusers.hook': [
@ -15,7 +18,8 @@ KNOWN_HOOK_OUTPUT = {
r'==> Creating (?:.+)-compressed initcpio image: .+', r'==> Creating (?:.+)-compressed initcpio image: .+',
r'==> Image generation successful.*', r'==> Image generation successful.*',
r'[ ]+-> .+', r'[ ]+-> .+',
] ],
**KNOWN_HOOK_OUTPUT_OVERRIDE
} }
_keyring_output = [ _keyring_output = [
@ -46,4 +50,5 @@ KNOWN_PACKAGE_OUTPUT = {
r'Generation complete\.', r'Generation complete\.',
r' .*_.*\.\.\. done', r' .*_.*\.\.\. done',
], ],
**KNOWN_PACKAGE_OUTPUT_OVERRIDE
} }

View file

@ -0,0 +1,7 @@
KNOWN_HOOK_OUTPUT = {
'example.hook': [],
}
KNOWN_PACKAGE_OUTPUT = {
'example-package': [],
}