diff options
-rw-r--r-- | configs/kvmd/main/v0-hdmi.yaml | 2 | ||||
-rw-r--r-- | configs/kvmd/main/v1-hdmi.yaml | 2 | ||||
-rw-r--r-- | configs/kvmd/main/v2-hdmi.yaml | 2 | ||||
-rw-r--r-- | kvmd/apps/__init__.py | 7 | ||||
-rw-r--r-- | kvmd/validators/basic.py | 4 | ||||
-rw-r--r-- | testenv/main.yaml | 2 | ||||
-rw-r--r-- | testenv/tests/validators/test_basic.py | 15 |
7 files changed, 31 insertions, 3 deletions
diff --git a/configs/kvmd/main/v0-hdmi.yaml b/configs/kvmd/main/v0-hdmi.yaml index 7ad0fa4b..c1e0b001 100644 --- a/configs/kvmd/main/v0-hdmi.yaml +++ b/configs/kvmd/main/v0-hdmi.yaml @@ -28,6 +28,8 @@ kvmd: type: disabled streamer: + sync_delay: 0 + init_delay: 1 desired_fps: 30 max_fps: 60 unix: /run/kvmd/ustreamer.sock diff --git a/configs/kvmd/main/v1-hdmi.yaml b/configs/kvmd/main/v1-hdmi.yaml index 830ff378..5bb7cb3e 100644 --- a/configs/kvmd/main/v1-hdmi.yaml +++ b/configs/kvmd/main/v1-hdmi.yaml @@ -30,6 +30,8 @@ kvmd: device: /dev/kvmd-msd streamer: + sync_delay: 0 + init_delay: 1 desired_fps: 30 max_fps: 60 unix: /run/kvmd/ustreamer.sock diff --git a/configs/kvmd/main/v2-hdmi.yaml b/configs/kvmd/main/v2-hdmi.yaml index 060bede5..0b4233a3 100644 --- a/configs/kvmd/main/v2-hdmi.yaml +++ b/configs/kvmd/main/v2-hdmi.yaml @@ -26,6 +26,8 @@ kvmd: type: otg streamer: + sync_delay: 0 + init_delay: 1 desired_fps: 30 max_fps: 60 unix: /run/kvmd/ustreamer.sock diff --git a/kvmd/apps/__init__.py b/kvmd/apps/__init__.py index 8014d8f6..b04f13a6 100644 --- a/kvmd/apps/__init__.py +++ b/kvmd/apps/__init__.py @@ -51,6 +51,7 @@ from ..yamlconf.loader import load_yaml_file from ..validators.basic import valid_bool from ..validators.basic import valid_number +from ..validators.basic import valid_float_f0 from ..validators.basic import valid_float_f01 from ..validators.auth import valid_users_list @@ -224,9 +225,9 @@ def _get_config_scheme() -> Dict: "cap_pin": Option(-1, type=valid_gpio_pin_optional), "conv_pin": Option(-1, type=valid_gpio_pin_optional), - "sync_delay": Option(1.0, type=valid_float_f01), - "init_delay": Option(3.0, type=valid_float_f01), - "init_restart_after": Option(0.0, type=(lambda arg: valid_number(arg, min=0.0, type=float))), + "sync_delay": Option(1.0, type=valid_float_f0), + "init_delay": Option(3.0, type=valid_float_f0), + "init_restart_after": Option(0.0, type=valid_float_f0), "shutdown_delay": Option(10.0, type=valid_float_f01), "state_poll": Option(1.0, type=valid_float_f01), diff --git a/kvmd/validators/basic.py b/kvmd/validators/basic.py index 87056428..0328490d 100644 --- a/kvmd/validators/basic.py +++ b/kvmd/validators/basic.py @@ -74,6 +74,10 @@ def valid_int_f1(arg: Any) -> int: return int(valid_number(arg, min=1)) +def valid_float_f0(arg: Any) -> float: + return float(valid_number(arg, min=0, type=float)) + + def valid_float_f01(arg: Any) -> float: return float(valid_number(arg, min=0.1, type=float)) diff --git a/testenv/main.yaml b/testenv/main.yaml index f0f48d4d..e1589a34 100644 --- a/testenv/main.yaml +++ b/testenv/main.yaml @@ -25,6 +25,8 @@ kvmd: streamer: cap_pin: 17 conv_pin: 18 + sync_delay: 0 + init_delay: 1 init_restart_after: 1 desired_fps: 30 max_fps: 40 diff --git a/testenv/tests/validators/test_basic.py b/testenv/tests/validators/test_basic.py index 96feb666..15964a54 100644 --- a/testenv/tests/validators/test_basic.py +++ b/testenv/tests/validators/test_basic.py @@ -29,6 +29,7 @@ from kvmd.validators import ValidatorError from kvmd.validators.basic import valid_bool from kvmd.validators.basic import valid_number from kvmd.validators.basic import valid_int_f1 +from kvmd.validators.basic import valid_float_f0 from kvmd.validators.basic import valid_float_f01 from kvmd.validators.basic import valid_string_list @@ -96,6 +97,20 @@ def test_fail__valid_int_f1(arg: Any) -> None: # ===== [email protected]("arg", [0, 1, 5, "5 ", "5.0 "]) +def test_ok__valid_float_f0(arg: Any) -> None: + value = valid_float_f0(arg) + assert type(value) == float # pylint: disable=unidiomatic-typecheck + assert value == float(str(arg).strip()) + + [email protected]("arg", ["test", "", None, -6, "-6"]) +def test_fail__valid_float_f0(arg: Any) -> None: + with pytest.raises(ValidatorError): + print(valid_float_f0(arg)) + + +# ===== @pytest.mark.parametrize("arg", [0.1, 1, 5, "5 ", "5.0 "]) def test_ok__valid_float_f01(arg: Any) -> None: value = valid_float_f01(arg) |