897888db41
A new CLI subcommand was added, flash, which behaves very similar to the already present compile CLI comamnd, but with the added ability to target a bootloader. The command is used like so: qmk flash [-h] [-b] [-kb KEYBOARD] [-km KEYMAP] [-bl BOOTLOADER] [filename]. A -kb <keyboard> and -km <keymap> is expected, or a configurator export JSON filename. A bootloader can be specified using -bl <target>, and if left unspecified, the target is assumed to be :flash. -bl can be used to list the available bootloaders. If -km <keymap> is provided, but no -kb <keyboard>, then a message is printed suggesting the user to run qmk list_keyboards.
54 lines
1.6 KiB
Python
54 lines
1.6 KiB
Python
import subprocess
|
|
|
|
|
|
def check_subcommand(command, *args):
|
|
cmd = ['bin/qmk', command] + list(args)
|
|
return subprocess.run(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
|
|
|
|
|
|
def test_cformat():
|
|
assert check_subcommand('cformat', 'tmk_core/common/keyboard.c').returncode == 0
|
|
|
|
|
|
def test_compile():
|
|
assert check_subcommand('compile', '-kb', 'handwired/onekey/pytest', '-km', 'default').returncode == 0
|
|
|
|
def test_flash():
|
|
assert check_subcommand('flash', '-b').returncode == 1
|
|
assert check_subcommand('flash').returncode == 1
|
|
|
|
def test_config():
|
|
result = check_subcommand('config')
|
|
assert result.returncode == 0
|
|
assert 'general.color' in result.stdout
|
|
|
|
|
|
def test_kle2json():
|
|
assert check_subcommand('kle2json', 'kle.txt', '-f').returncode == 0
|
|
|
|
|
|
def test_doctor():
|
|
result = check_subcommand('doctor')
|
|
assert result.returncode == 0
|
|
assert 'QMK Doctor is checking your environment.' in result.stderr
|
|
assert 'QMK is ready to go' in result.stderr
|
|
|
|
|
|
def test_hello():
|
|
result = check_subcommand('hello')
|
|
assert result.returncode == 0
|
|
assert 'Hello,' in result.stderr
|
|
|
|
|
|
def test_pyformat():
|
|
result = check_subcommand('pyformat')
|
|
assert result.returncode == 0
|
|
assert 'Successfully formatted the python code' in result.stderr
|
|
|
|
|
|
def test_list_keyboards():
|
|
result = check_subcommand('list-keyboards')
|
|
assert result.returncode == 0
|
|
# 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
|