kmk_firmware/tests/test_kmk_keys.py

286 lines
7.4 KiB
Python
Raw Normal View History

import unittest
2022-04-23 09:01:20 +02:00
from kmk.keys import KC, Key, ModifierKey, make_key
from tests.keyboard_test import KeyboardTest
class TestKmkKeys(unittest.TestCase):
def test_basic_kmk_keyboard(self):
keyboard = KeyboardTest(
[],
[
[
KC.HASH,
KC.RALT(KC.HASH),
KC.RALT(KC.LSFT(KC.N3)),
KC.RALT(KC.LSFT),
# Note: this is correct, if unusual, syntax. It's a useful test because it failed silently on previous builds.
KC.RALT(KC.LSFT)(KC.N3),
KC.RALT,
]
],
)
keyboard.test(
'Shifted key',
[(0, True), (0, False)],
[
{
KC.N3,
KC.LSFT,
},
{},
],
)
keyboard.test(
'AltGr+Shifted key',
[(1, True), (1, False)],
[
{
KC.N3,
KC.LSFT,
KC.RALT,
},
{},
],
)
keyboard.test(
'AltGr+Shift+key',
[(2, True), (2, False)],
[
{
KC.N3,
KC.LSFT,
KC.RALT,
},
{},
],
)
keyboard.test(
'Shift+AltGr',
[(3, True), (3, False)],
[
{
KC.LSFT,
KC.RALT,
},
{},
],
)
keyboard.test(
'AltGr+Shift+key, alternate chaining',
[(4, True), (4, False)],
[
{
KC.N3,
KC.LSFT,
KC.RALT,
},
{},
],
)
keyboard.test(
'AltGr',
[(5, True), (5, False)],
[
{
KC.RALT,
},
{},
],
)
assert isinstance(KC.RGUI(no_press=True), ModifierKey)
assert isinstance(KC.RALT(KC.RGUI), ModifierKey)
assert isinstance(KC.Q(no_press=True), Key)
assert not isinstance(KC.Q(no_press=True), ModifierKey)
assert isinstance(KC.RALT(KC.Q), Key)
assert not isinstance(KC.RALT(KC.Q), ModifierKey)
class TestKeys_dot(unittest.TestCase):
def setUp(self):
KC.clear()
def test_expected_code_uppercase(self):
assert 4 == KC.A.code
def test_expected_code_lowercase(self):
assert 4 == KC.a.code
def test_case_ignored_alpha(self):
upper_key = KC.A
lower_key = KC.a
assert upper_key is lower_key
def test_case_requested_order_irrelevant(self):
lower_key = KC.a
upper_key = KC.A
assert upper_key is lower_key
def test_secondary_name(self):
primary_key = KC.NO
secondary_key = KC.XXXXXXX
assert primary_key is secondary_key
def test_invalid_key_upper(self):
with self.assertRaises(ValueError):
KC.INVALID_KEY
def test_invalid_key_lower(self):
with self.assertRaises(ValueError):
KC.invalid_key
def test_custom_key(self):
created = make_key(
KC.N2.code,
names=(
'EURO',
'',
),
has_modifiers={KC.LSFT.code, KC.ROPT.code},
)
assert created is KC.get('EURO')
assert created is KC.get('')
def test_match_exactly_case(self):
created = make_key(names=('ThIs_Is_A_StRaNgE_kEy',))
assert created is KC.get('ThIs_Is_A_StRaNgE_kEy')
class TestKeys_index(unittest.TestCase):
def setUp(self):
KC.clear()
def test_expected_code_uppercase(self):
assert 4 == KC['A'].code
def test_expected_code_lowercase(self):
assert 4 == KC['a'].code
def test_case_ignored_alpha(self):
upper_key = KC['A']
lower_key = KC['a']
assert upper_key is lower_key
def test_case_requested_order_irrelevant(self):
lower_key = KC['a']
upper_key = KC['A']
assert upper_key is lower_key
def test_invalid_key_upper(self):
with self.assertRaises(ValueError):
KC['NOT_A_VALID_KEY']
def test_invalid_key_lower(self):
with self.assertRaises(ValueError):
KC['not_a_valid_key']
def test_custom_key(self):
created = make_key(
KC['N2'].code,
names=(
'EURO',
'',
),
has_modifiers={KC['LSFT'].code, KC['ROPT'].code},
)
assert created is KC['EURO']
assert created is KC['']
def test_match_exactly_case(self):
created = make_key(names=('ThIs_Is_A_StRaNgE_kEy',))
assert created is KC['ThIs_Is_A_StRaNgE_kEy']
class TestKeys_get(unittest.TestCase):
def setUp(self):
KC.clear()
def test_expected_code_uppercase(self):
assert 4 == KC.get('A').code
def test_expected_code_lowercase(self):
assert 4 == KC.get('a').code
def test_case_ignored_alpha(self):
upper_key = KC.get('A')
lower_key = KC.get('a')
assert upper_key is lower_key
def test_case_requested_order_irrelevant(self):
lower_key = KC.get('a')
upper_key = KC.get('A')
assert upper_key is lower_key
def test_secondary_name(self):
primary_key = KC.NO
secondary_key = KC.XXXXXXX
assert primary_key is secondary_key
def test_invalid_key_upper(self):
assert KC.get('INVALID_KEY') is None
def test_invalid_key_lower(self):
assert KC.get('not_a_valid_key') is None
def test_custom_key(self):
created = make_key(
KC.get('N2').code,
names=(
'EURO',
'',
),
has_modifiers={KC.get('LSFT').code, KC.get('ROPT').code},
)
assert created is KC.get('EURO')
assert created is KC.get('')
def test_match_exactly_case(self):
created = make_key(names=('ThIs_Is_A_StRaNgE_kEy',))
assert created is KC.get('ThIs_Is_A_StRaNgE_kEy')
# Some of these test appear silly, but they're testing we get the
# same, single, instance back when requested through KC and that
# order of request doesn't matter
class TestKeys_instances(unittest.TestCase):
def setUp(self):
KC.clear()
def test_make_key_new_instance(self):
key1 = make_key(code=1)
key2 = make_key(code=1)
assert key1 is not key2
assert key1.code == key2.code
def test_index_is_index(self):
assert KC['A'] is KC['A']
def test_index_is_dot(self):
assert KC['A'] is KC.A
def test_index_is_get(self):
assert KC['A'] is KC.get('A')
def test_dot_is_dot(self):
assert KC.A is KC.A
def test_dot_is_index(self):
assert KC.A is KC['A']
def test_dot_is_get(self):
assert KC.A is KC.get('A')
def test_get_is_get(self):
assert KC.get('A') is KC.get('A')
def test_get_is_index(self):
assert KC.get('A') is KC['A']
def test_get_is_dot(self):
assert KC.get('A') is KC.A
if __name__ == '__main__':
unittest.main()