mirror of
https://github.com/mofeng-git/One-KVM.git
synced 2025-12-13 01:30:31 +08:00
refactoring
This commit is contained in:
parent
5a5e3a3cc9
commit
6a8ee1a114
@ -84,11 +84,12 @@ from ..validators.net import valid_ports_list
|
||||
from ..validators.net import valid_mac
|
||||
from ..validators.net import valid_ssl_ciphers
|
||||
|
||||
from ..validators.hid import valid_hid_key
|
||||
from ..validators.hid import valid_hid_mouse_move
|
||||
|
||||
from ..validators.kvm import valid_stream_quality
|
||||
from ..validators.kvm import valid_stream_fps
|
||||
from ..validators.kvm import valid_stream_resolution
|
||||
from ..validators.kvm import valid_hid_key
|
||||
from ..validators.kvm import valid_hid_mouse_move
|
||||
from ..validators.kvm import valid_ugpio_driver
|
||||
from ..validators.kvm import valid_ugpio_channel
|
||||
from ..validators.kvm import valid_ugpio_mode
|
||||
|
||||
@ -38,12 +38,12 @@ from ....validators import raise_error
|
||||
from ....validators.basic import valid_bool
|
||||
from ....validators.basic import valid_int_f0
|
||||
from ....validators.os import valid_printable_filename
|
||||
from ....validators.kvm import valid_hid_keyboard_output
|
||||
from ....validators.kvm import valid_hid_mouse_output
|
||||
from ....validators.kvm import valid_hid_key
|
||||
from ....validators.kvm import valid_hid_mouse_move
|
||||
from ....validators.kvm import valid_hid_mouse_button
|
||||
from ....validators.kvm import valid_hid_mouse_delta
|
||||
from ....validators.hid import valid_hid_keyboard_output
|
||||
from ....validators.hid import valid_hid_mouse_output
|
||||
from ....validators.hid import valid_hid_key
|
||||
from ....validators.hid import valid_hid_mouse_move
|
||||
from ....validators.hid import valid_hid_mouse_button
|
||||
from ....validators.hid import valid_hid_mouse_delta
|
||||
|
||||
from ....keyboard.keysym import build_symmap
|
||||
from ....keyboard.printer import text_to_web_keys
|
||||
|
||||
56
kvmd/validators/hid.py
Normal file
56
kvmd/validators/hid.py
Normal file
@ -0,0 +1,56 @@
|
||||
# ========================================================================== #
|
||||
# #
|
||||
# KVMD - The main Pi-KVM daemon. #
|
||||
# #
|
||||
# Copyright (C) 2018 Maxim Devaev <mdevaev@gmail.com> #
|
||||
# #
|
||||
# This program is free software: you can redistribute it and/or modify #
|
||||
# it under the terms of the GNU General Public License as published by #
|
||||
# the Free Software Foundation, either version 3 of the License, or #
|
||||
# (at your option) any later version. #
|
||||
# #
|
||||
# This program is distributed in the hope that it will be useful, #
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
|
||||
# GNU General Public License for more details. #
|
||||
# #
|
||||
# You should have received a copy of the GNU General Public License #
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>. #
|
||||
# #
|
||||
# ========================================================================== #
|
||||
|
||||
|
||||
from typing import Any
|
||||
|
||||
from ..keyboard.mappings import KEYMAP
|
||||
|
||||
from . import check_string_in_list
|
||||
|
||||
from .basic import valid_number
|
||||
|
||||
|
||||
# =====
|
||||
def valid_hid_keyboard_output(arg: Any) -> str:
|
||||
return check_string_in_list(arg, "Keyboard output", ["usb", "ps2", ""])
|
||||
|
||||
|
||||
def valid_hid_mouse_output(arg: Any) -> str:
|
||||
return check_string_in_list(arg, "Mouse output", ["usb", "usb_rel", "ps2", ""])
|
||||
|
||||
|
||||
def valid_hid_key(arg: Any) -> str:
|
||||
return check_string_in_list(arg, "Keyboard key", KEYMAP, lower=False)
|
||||
|
||||
|
||||
def valid_hid_mouse_move(arg: Any) -> int:
|
||||
arg = valid_number(arg, name="Mouse move")
|
||||
return min(max(-32768, arg), 32767)
|
||||
|
||||
|
||||
def valid_hid_mouse_button(arg: Any) -> str:
|
||||
return check_string_in_list(arg, "Mouse button", ["left", "right", "middle", "up", "down"])
|
||||
|
||||
|
||||
def valid_hid_mouse_delta(arg: Any) -> int:
|
||||
arg = valid_number(arg, name="Mouse delta")
|
||||
return min(max(-127, arg), 127)
|
||||
@ -25,8 +25,6 @@ from typing import Set
|
||||
from typing import Optional
|
||||
from typing import Any
|
||||
|
||||
from ..keyboard.mappings import KEYMAP
|
||||
|
||||
from . import raise_error
|
||||
from . import check_string_in_list
|
||||
from . import check_re_match
|
||||
@ -82,33 +80,6 @@ def valid_stream_resolution(arg: Any) -> str:
|
||||
return f"{width}x{height}"
|
||||
|
||||
|
||||
# =====
|
||||
def valid_hid_keyboard_output(arg: Any) -> str:
|
||||
return check_string_in_list(arg, "Keyboard output", ["usb", "ps2", ""])
|
||||
|
||||
|
||||
def valid_hid_mouse_output(arg: Any) -> str:
|
||||
return check_string_in_list(arg, "Mouse output", ["usb", "usb_rel", "ps2", ""])
|
||||
|
||||
|
||||
def valid_hid_key(arg: Any) -> str:
|
||||
return check_string_in_list(arg, "HID key", KEYMAP, lower=False)
|
||||
|
||||
|
||||
def valid_hid_mouse_move(arg: Any) -> int:
|
||||
arg = valid_number(arg, name="HID mouse move")
|
||||
return min(max(-32768, arg), 32767)
|
||||
|
||||
|
||||
def valid_hid_mouse_button(arg: Any) -> str:
|
||||
return check_string_in_list(arg, "HID mouse button", ["left", "right", "middle", "up", "down"])
|
||||
|
||||
|
||||
def valid_hid_mouse_delta(arg: Any) -> int:
|
||||
arg = valid_number(arg, name="HID mouse delta")
|
||||
return min(max(-127, arg), 127)
|
||||
|
||||
|
||||
# =====
|
||||
def valid_ugpio_driver(arg: Any, variants: Optional[Set[str]]=None) -> str:
|
||||
name = "GPIO driver"
|
||||
|
||||
98
testenv/tests/validators/test_hid.py
Normal file
98
testenv/tests/validators/test_hid.py
Normal file
@ -0,0 +1,98 @@
|
||||
# ========================================================================== #
|
||||
# #
|
||||
# KVMD - The main Pi-KVM daemon. #
|
||||
# #
|
||||
# Copyright (C) 2018 Maxim Devaev <mdevaev@gmail.com> #
|
||||
# #
|
||||
# This program is free software: you can redistribute it and/or modify #
|
||||
# it under the terms of the GNU General Public License as published by #
|
||||
# the Free Software Foundation, either version 3 of the License, or #
|
||||
# (at your option) any later version. #
|
||||
# #
|
||||
# This program is distributed in the hope that it will be useful, #
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
|
||||
# GNU General Public License for more details. #
|
||||
# #
|
||||
# You should have received a copy of the GNU General Public License #
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>. #
|
||||
# #
|
||||
# ========================================================================== #
|
||||
|
||||
|
||||
from typing import Any
|
||||
|
||||
import pytest
|
||||
|
||||
from kvmd.keyboard.mappings import KEYMAP
|
||||
|
||||
from kvmd.validators import ValidatorError
|
||||
from kvmd.validators.hid import valid_hid_key
|
||||
from kvmd.validators.hid import valid_hid_mouse_move
|
||||
from kvmd.validators.hid import valid_hid_mouse_button
|
||||
from kvmd.validators.hid import valid_hid_mouse_delta
|
||||
|
||||
|
||||
# =====
|
||||
def test_ok__valid_hid_key() -> None:
|
||||
for key in KEYMAP:
|
||||
print(valid_hid_key(key))
|
||||
print(valid_hid_key(key + " "))
|
||||
|
||||
|
||||
@pytest.mark.parametrize("arg", ["test", "", None, "keya"])
|
||||
def test_fail__valid_hid_key(arg: Any) -> None:
|
||||
with pytest.raises(ValidatorError):
|
||||
print(valid_hid_key(arg))
|
||||
|
||||
|
||||
# =====
|
||||
@pytest.mark.parametrize("arg", [-20000, "1 ", "-1", 1, -1, 0, "20000 "])
|
||||
def test_ok__valid_hid_mouse_move(arg: Any) -> None:
|
||||
assert valid_hid_mouse_move(arg) == int(str(arg).strip())
|
||||
|
||||
|
||||
def test_ok__valid_hid_mouse_move__m50000() -> None:
|
||||
assert valid_hid_mouse_move(-50000) == -32768
|
||||
|
||||
|
||||
def test_ok__valid_hid_mouse_move__p50000() -> None:
|
||||
assert valid_hid_mouse_move(50000) == 32767
|
||||
|
||||
|
||||
@pytest.mark.parametrize("arg", ["test", "", None, 1.1])
|
||||
def test_fail__valid_hid_mouse_move(arg: Any) -> None:
|
||||
with pytest.raises(ValidatorError):
|
||||
print(valid_hid_mouse_move(arg))
|
||||
|
||||
|
||||
# =====
|
||||
@pytest.mark.parametrize("arg", ["LEFT ", "RIGHT ", "Up ", " Down", " MiDdLe "])
|
||||
def test_ok__valid_hid_mouse_button(arg: Any) -> None:
|
||||
assert valid_hid_mouse_button(arg) == arg.strip().lower()
|
||||
|
||||
|
||||
@pytest.mark.parametrize("arg", ["test", "", None])
|
||||
def test_fail__valid_hid_mouse_button(arg: Any) -> None:
|
||||
with pytest.raises(ValidatorError):
|
||||
print(valid_hid_mouse_button(arg))
|
||||
|
||||
|
||||
# =====
|
||||
@pytest.mark.parametrize("arg", [-100, "1 ", "-1", 1, -1, 0, "100 "])
|
||||
def test_ok__valid_hid_mouse_delta(arg: Any) -> None:
|
||||
assert valid_hid_mouse_delta(arg) == int(str(arg).strip())
|
||||
|
||||
|
||||
def test_ok__valid_hid_mouse_delta__m200() -> None:
|
||||
assert valid_hid_mouse_delta(-200) == -127
|
||||
|
||||
|
||||
def test_ok__valid_hid_mouse_delta__p200() -> None:
|
||||
assert valid_hid_mouse_delta(200) == 127
|
||||
|
||||
|
||||
@pytest.mark.parametrize("arg", ["test", "", None, 1.1])
|
||||
def test_fail__valid_hid_mouse_delta(arg: Any) -> None:
|
||||
with pytest.raises(ValidatorError):
|
||||
print(valid_hid_mouse_delta(arg))
|
||||
@ -25,8 +25,6 @@ from typing import Any
|
||||
|
||||
import pytest
|
||||
|
||||
from kvmd.keyboard.mappings import KEYMAP
|
||||
|
||||
from kvmd.validators import ValidatorError
|
||||
from kvmd.validators.kvm import valid_atx_power_action
|
||||
from kvmd.validators.kvm import valid_atx_button
|
||||
@ -35,10 +33,6 @@ from kvmd.validators.kvm import valid_log_seek
|
||||
from kvmd.validators.kvm import valid_stream_quality
|
||||
from kvmd.validators.kvm import valid_stream_fps
|
||||
from kvmd.validators.kvm import valid_stream_resolution
|
||||
from kvmd.validators.kvm import valid_hid_key
|
||||
from kvmd.validators.kvm import valid_hid_mouse_move
|
||||
from kvmd.validators.kvm import valid_hid_mouse_button
|
||||
from kvmd.validators.kvm import valid_hid_mouse_delta
|
||||
from kvmd.validators.kvm import valid_ugpio_driver
|
||||
from kvmd.validators.kvm import valid_ugpio_channel
|
||||
from kvmd.validators.kvm import valid_ugpio_mode
|
||||
@ -141,71 +135,6 @@ def test_fail__valid_stream_resolution(arg: Any) -> None:
|
||||
print(valid_stream_resolution(arg))
|
||||
|
||||
|
||||
# =====
|
||||
def test_ok__valid_hid_key() -> None:
|
||||
for key in KEYMAP:
|
||||
print(valid_hid_key(key))
|
||||
print(valid_hid_key(key + " "))
|
||||
|
||||
|
||||
@pytest.mark.parametrize("arg", ["test", "", None, "keya"])
|
||||
def test_fail__valid_hid_key(arg: Any) -> None:
|
||||
with pytest.raises(ValidatorError):
|
||||
print(valid_hid_key(arg))
|
||||
|
||||
|
||||
# =====
|
||||
@pytest.mark.parametrize("arg", [-20000, "1 ", "-1", 1, -1, 0, "20000 "])
|
||||
def test_ok__valid_hid_mouse_move(arg: Any) -> None:
|
||||
assert valid_hid_mouse_move(arg) == int(str(arg).strip())
|
||||
|
||||
|
||||
def test_ok__valid_hid_mouse_move__m50000() -> None:
|
||||
assert valid_hid_mouse_move(-50000) == -32768
|
||||
|
||||
|
||||
def test_ok__valid_hid_mouse_move__p50000() -> None:
|
||||
assert valid_hid_mouse_move(50000) == 32767
|
||||
|
||||
|
||||
@pytest.mark.parametrize("arg", ["test", "", None, 1.1])
|
||||
def test_fail__valid_hid_mouse_move(arg: Any) -> None:
|
||||
with pytest.raises(ValidatorError):
|
||||
print(valid_hid_mouse_move(arg))
|
||||
|
||||
|
||||
# =====
|
||||
@pytest.mark.parametrize("arg", ["LEFT ", "RIGHT ", "Up ", " Down", " MiDdLe "])
|
||||
def test_ok__valid_hid_mouse_button(arg: Any) -> None:
|
||||
assert valid_hid_mouse_button(arg) == arg.strip().lower()
|
||||
|
||||
|
||||
@pytest.mark.parametrize("arg", ["test", "", None])
|
||||
def test_fail__valid_hid_mouse_button(arg: Any) -> None:
|
||||
with pytest.raises(ValidatorError):
|
||||
print(valid_hid_mouse_button(arg))
|
||||
|
||||
|
||||
# =====
|
||||
@pytest.mark.parametrize("arg", [-100, "1 ", "-1", 1, -1, 0, "100 "])
|
||||
def test_ok__valid_hid_mouse_delta(arg: Any) -> None:
|
||||
assert valid_hid_mouse_delta(arg) == int(str(arg).strip())
|
||||
|
||||
|
||||
def test_ok__valid_hid_mouse_delta__m200() -> None:
|
||||
assert valid_hid_mouse_delta(-200) == -127
|
||||
|
||||
|
||||
def test_ok__valid_hid_mouse_delta__p200() -> None:
|
||||
assert valid_hid_mouse_delta(200) == 127
|
||||
|
||||
|
||||
@pytest.mark.parametrize("arg", ["test", "", None, 1.1])
|
||||
def test_fail__valid_hid_mouse_delta(arg: Any) -> None:
|
||||
with pytest.raises(ValidatorError):
|
||||
print(valid_hid_mouse_delta(arg))
|
||||
|
||||
|
||||
# =====
|
||||
@pytest.mark.parametrize("validator", [valid_ugpio_driver, valid_ugpio_channel])
|
||||
@pytest.mark.parametrize("arg", [
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user