2020-11-02 09:41:01 +01:00
|
|
|
import platform
|
|
|
|
|
2020-10-07 02:10:19 +02:00
|
|
|
from subprocess import STDOUT, PIPE
|
|
|
|
|
2020-03-29 14:29:44 +02:00
|
|
|
from qmk.commands import run
|
2019-09-22 22:25:33 +02:00
|
|
|
|
2020-11-02 09:41:01 +01:00
|
|
|
is_windows = 'windows' in platform.platform().lower()
|
|
|
|
|
2019-09-22 22:25:33 +02:00
|
|
|
|
|
|
|
def check_subcommand(command, *args):
|
|
|
|
cmd = ['bin/qmk', command] + list(args)
|
2020-10-07 02:10:19 +02:00
|
|
|
result = run(cmd, stdout=PIPE, stderr=STDOUT, universal_newlines=True)
|
2020-05-26 22:05:41 +02:00
|
|
|
return result
|
|
|
|
|
|
|
|
|
2020-11-16 22:09:32 +01:00
|
|
|
def check_returncode(result, expected=[0]):
|
2020-05-26 22:05:41 +02:00
|
|
|
"""Print stdout if `result.returncode` does not match `expected`.
|
|
|
|
"""
|
2020-11-16 22:09:32 +01:00
|
|
|
if result.returncode not in expected:
|
2020-05-26 22:05:41 +02:00
|
|
|
print('`%s` stdout:' % ' '.join(result.args))
|
|
|
|
print(result.stdout)
|
|
|
|
print('returncode:', result.returncode)
|
2020-11-16 22:09:32 +01:00
|
|
|
assert result.returncode in expected
|
2019-09-22 22:25:33 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_cformat():
|
2020-02-23 05:57:19 +01:00
|
|
|
result = check_subcommand('cformat', 'quantum/matrix.c')
|
2020-05-26 22:05:41 +02:00
|
|
|
check_returncode(result)
|
2019-09-22 22:25:33 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_compile():
|
2020-05-26 22:05:41 +02:00
|
|
|
result = check_subcommand('compile', '-kb', 'handwired/onekey/pytest', '-km', 'default', '-n')
|
|
|
|
check_returncode(result)
|
2019-09-22 22:25:33 +02:00
|
|
|
|
2019-11-16 08:10:19 +01:00
|
|
|
|
2020-10-07 02:10:19 +02:00
|
|
|
def test_compile_json():
|
2020-11-30 20:19:44 +01:00
|
|
|
result = check_subcommand('compile', '-kb', 'handwired/onekey/pytest', '-km', 'default_json', '-n')
|
2020-10-07 02:10:19 +02:00
|
|
|
check_returncode(result)
|
|
|
|
|
|
|
|
|
2019-10-05 08:38:34 +02:00
|
|
|
def test_flash():
|
2020-05-26 22:05:41 +02:00
|
|
|
result = check_subcommand('flash', '-kb', 'handwired/onekey/pytest', '-km', 'default', '-n')
|
|
|
|
check_returncode(result)
|
|
|
|
|
|
|
|
|
|
|
|
def test_flash_bootloaders():
|
|
|
|
result = check_subcommand('flash', '-b')
|
2020-11-16 22:09:32 +01:00
|
|
|
check_returncode(result, [1])
|
2019-09-22 22:25:33 +02:00
|
|
|
|
2019-11-16 08:10:19 +01:00
|
|
|
|
2019-09-22 22:25:33 +02:00
|
|
|
def test_config():
|
|
|
|
result = check_subcommand('config')
|
2020-05-26 22:05:41 +02:00
|
|
|
check_returncode(result)
|
2019-09-22 22:25:33 +02:00
|
|
|
assert 'general.color' in result.stdout
|
|
|
|
|
2019-11-13 06:24:56 +01:00
|
|
|
|
2019-11-13 05:55:41 +01:00
|
|
|
def test_kle2json():
|
2020-10-07 01:46:10 +02:00
|
|
|
result = check_subcommand('kle2json', 'lib/python/qmk/tests/kle.txt', '-f')
|
2020-05-26 22:05:41 +02:00
|
|
|
check_returncode(result)
|
2020-10-07 01:46:10 +02:00
|
|
|
assert 'Wrote out' in result.stdout
|
2019-09-22 22:25:33 +02:00
|
|
|
|
2019-11-13 06:24:56 +01:00
|
|
|
|
2019-09-22 22:25:33 +02:00
|
|
|
def test_doctor():
|
2020-02-08 13:43:55 +01:00
|
|
|
result = check_subcommand('doctor', '-n')
|
2020-11-16 22:09:32 +01:00
|
|
|
check_returncode(result, [0, 1])
|
2020-05-26 22:05:41 +02:00
|
|
|
assert 'QMK Doctor is checking your environment.' in result.stdout
|
|
|
|
assert 'QMK is ready to go' in result.stdout
|
2019-09-22 22:25:33 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_hello():
|
|
|
|
result = check_subcommand('hello')
|
2020-05-26 22:05:41 +02:00
|
|
|
check_returncode(result)
|
|
|
|
assert 'Hello,' in result.stdout
|
2019-09-22 22:25:33 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_pyformat():
|
|
|
|
result = check_subcommand('pyformat')
|
2020-05-26 22:05:41 +02:00
|
|
|
check_returncode(result)
|
|
|
|
assert 'Successfully formatted the python code' in result.stdout
|
|
|
|
|
|
|
|
|
|
|
|
def test_list_keyboards():
|
|
|
|
result = check_subcommand('list-keyboards')
|
|
|
|
check_returncode(result)
|
|
|
|
# check to see if a known keyboard is returned
|
|
|
|
# this will fail if handwired/onekey/pytest is removed
|
|
|
|
assert 'handwired/onekey/pytest' in result.stdout
|
2019-10-07 20:32:30 +02:00
|
|
|
|
|
|
|
|
2020-05-16 22:47:07 +02:00
|
|
|
def test_list_keymaps():
|
|
|
|
result = check_subcommand('list-keymaps', '-kb', 'handwired/onekey/pytest')
|
2020-11-16 22:09:32 +01:00
|
|
|
check_returncode(result)
|
2020-05-16 22:47:07 +02:00
|
|
|
assert 'default' and 'test' in result.stdout
|
2019-10-13 19:16:19 +02:00
|
|
|
|
2020-01-07 21:54:21 +01:00
|
|
|
|
2020-05-16 22:47:07 +02:00
|
|
|
def test_list_keymaps_long():
|
|
|
|
result = check_subcommand('list-keymaps', '--keyboard', 'handwired/onekey/pytest')
|
2020-11-16 22:09:32 +01:00
|
|
|
check_returncode(result)
|
2020-05-16 22:47:07 +02:00
|
|
|
assert 'default' and 'test' in result.stdout
|
|
|
|
|
|
|
|
|
|
|
|
def test_list_keymaps_kb_only():
|
|
|
|
result = check_subcommand('list-keymaps', '-kb', 'niu_mini')
|
2020-11-16 22:09:32 +01:00
|
|
|
check_returncode(result)
|
2020-05-16 22:47:07 +02:00
|
|
|
assert 'default' and 'via' in result.stdout
|
|
|
|
|
|
|
|
|
|
|
|
def test_list_keymaps_vendor_kb():
|
|
|
|
result = check_subcommand('list-keymaps', '-kb', 'ai03/lunar')
|
2020-11-16 22:09:32 +01:00
|
|
|
check_returncode(result)
|
2020-05-16 22:47:07 +02:00
|
|
|
assert 'default' and 'via' in result.stdout
|
|
|
|
|
|
|
|
|
|
|
|
def test_list_keymaps_vendor_kb_rev():
|
|
|
|
result = check_subcommand('list-keymaps', '-kb', 'kbdfans/kbd67/mkiirgb/v2')
|
2020-11-16 22:09:32 +01:00
|
|
|
check_returncode(result)
|
2020-05-16 22:47:07 +02:00
|
|
|
assert 'default' and 'via' in result.stdout
|
2020-01-07 21:54:21 +01:00
|
|
|
|
|
|
|
|
|
|
|
def test_list_keymaps_no_keyboard_found():
|
2020-05-16 22:47:07 +02:00
|
|
|
result = check_subcommand('list-keymaps', '-kb', 'asdfghjkl')
|
2020-11-16 22:09:32 +01:00
|
|
|
check_returncode(result, [1])
|
2020-05-16 22:47:07 +02:00
|
|
|
assert 'does not exist' in result.stdout
|
2020-05-26 17:43:33 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_json2c():
|
|
|
|
result = check_subcommand('json2c', 'keyboards/handwired/onekey/keymaps/default_json/keymap.json')
|
2020-11-16 22:09:32 +01:00
|
|
|
check_returncode(result)
|
2020-06-18 20:37:47 +02:00
|
|
|
assert result.stdout == '#include QMK_KEYBOARD_H\nconst uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {\t[0] = LAYOUT_ortho_1x1(KC_A)};\n\n'
|
2020-05-26 22:05:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_info():
|
|
|
|
result = check_subcommand('info', '-kb', 'handwired/onekey/pytest')
|
|
|
|
check_returncode(result)
|
|
|
|
assert 'Keyboard Name: handwired/onekey/pytest' in result.stdout
|
|
|
|
assert 'Processor: STM32F303' in result.stdout
|
|
|
|
assert 'Layout:' not in result.stdout
|
|
|
|
assert 'k0' not in result.stdout
|
|
|
|
|
|
|
|
|
|
|
|
def test_info_keyboard_render():
|
|
|
|
result = check_subcommand('info', '-kb', 'handwired/onekey/pytest', '-l')
|
|
|
|
check_returncode(result)
|
|
|
|
assert 'Keyboard Name: handwired/onekey/pytest' in result.stdout
|
|
|
|
assert 'Processor: STM32F303' in result.stdout
|
2020-06-18 20:37:47 +02:00
|
|
|
assert 'Layouts:' in result.stdout
|
2020-05-26 22:05:41 +02:00
|
|
|
assert 'k0' in result.stdout
|
|
|
|
|
|
|
|
|
|
|
|
def test_info_keymap_render():
|
|
|
|
result = check_subcommand('info', '-kb', 'handwired/onekey/pytest', '-km', 'default_json')
|
|
|
|
check_returncode(result)
|
|
|
|
assert 'Keyboard Name: handwired/onekey/pytest' in result.stdout
|
|
|
|
assert 'Processor: STM32F303' in result.stdout
|
2020-11-02 09:41:01 +01:00
|
|
|
|
|
|
|
if is_windows:
|
|
|
|
assert '|A |' in result.stdout
|
|
|
|
else:
|
|
|
|
assert '│A │' in result.stdout
|
2020-05-26 22:05:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_info_matrix_render():
|
|
|
|
result = check_subcommand('info', '-kb', 'handwired/onekey/pytest', '-m')
|
|
|
|
check_returncode(result)
|
|
|
|
assert 'Keyboard Name: handwired/onekey/pytest' in result.stdout
|
|
|
|
assert 'Processor: STM32F303' in result.stdout
|
2020-06-18 20:37:47 +02:00
|
|
|
assert 'LAYOUT_ortho_1x1' in result.stdout
|
2020-11-02 09:41:01 +01:00
|
|
|
|
|
|
|
if is_windows:
|
|
|
|
assert '|0A|' in result.stdout
|
|
|
|
else:
|
|
|
|
assert '│0A│' in result.stdout
|
|
|
|
|
2020-06-18 20:37:47 +02:00
|
|
|
assert 'Matrix for "LAYOUT_ortho_1x1"' in result.stdout
|
2020-10-07 02:10:19 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_c2json():
|
|
|
|
result = check_subcommand("c2json", "-kb", "handwired/onekey/pytest", "-km", "default", "keyboards/handwired/onekey/keymaps/default/keymap.c")
|
|
|
|
check_returncode(result)
|
|
|
|
assert result.stdout.strip() == '{"keyboard": "handwired/onekey/pytest", "documentation": "This file is a keymap.json file for handwired/onekey/pytest", "keymap": "default", "layout": "LAYOUT_ortho_1x1", "layers": [["KC_A"]]}'
|
|
|
|
|
|
|
|
|
|
|
|
def test_c2json_nocpp():
|
|
|
|
result = check_subcommand("c2json", "--no-cpp", "-kb", "handwired/onekey/pytest", "-km", "default", "keyboards/handwired/onekey/keymaps/pytest_nocpp/keymap.c")
|
|
|
|
check_returncode(result)
|
|
|
|
assert result.stdout.strip() == '{"keyboard": "handwired/onekey/pytest", "documentation": "This file is a keymap.json file for handwired/onekey/pytest", "keymap": "default", "layout": "LAYOUT", "layers": [["KC_ENTER"]]}'
|
2020-11-04 20:18:47 +01:00
|
|
|
|
|
|
|
|
|
|
|
def test_clean():
|
|
|
|
result = check_subcommand('clean', '-a')
|
|
|
|
check_returncode(result)
|
|
|
|
assert result.stdout.count('done') == 2
|
2020-12-16 04:24:42 +01:00
|
|
|
|
|
|
|
|
|
|
|
def test_generate_rgb_breathe_table():
|
|
|
|
result = check_subcommand("generate-rgb-breathe-table", "-c", "1.2", "-m", "127")
|
|
|
|
check_returncode(result)
|
|
|
|
assert 'Breathing center: 1.2' in result.stdout
|
|
|
|
assert 'Breathing max: 127' in result.stdout
|