286 lines
7.4 KiB
Python
286 lines
7.4 KiB
Python
import unittest
|
|
|
|
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()
|