2017-09-15 08:06:12 +00:00
|
|
|
# SPDX-License-Identifier: GPL-2.0
|
2018-05-06 21:58:06 +00:00
|
|
|
# Copyright (c) 2017, Heinrich Schuchardt <xypron.glpk@gmx.de>
|
2017-09-15 08:06:12 +00:00
|
|
|
|
|
|
|
# Test efi API implementation
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
import u_boot_utils
|
|
|
|
|
|
|
|
@pytest.mark.buildconfigspec('cmd_bootefi_selftest')
|
|
|
|
def test_efi_selftest(u_boot_console):
|
2018-11-18 16:58:54 +00:00
|
|
|
"""Test the UEFI implementation
|
2017-09-15 08:06:12 +00:00
|
|
|
|
2018-11-18 16:58:54 +00:00
|
|
|
:param u_boot_console: U-Boot console
|
|
|
|
|
|
|
|
This function executes all selftests that are not marked as on request.
|
|
|
|
"""
|
2017-10-18 16:13:17 +00:00
|
|
|
u_boot_console.run_command(cmd='setenv efi_selftest')
|
2019-04-20 11:33:55 +00:00
|
|
|
u_boot_console.run_command(cmd='bootefi selftest', wait_for_prompt=False)
|
2017-09-15 08:06:12 +00:00
|
|
|
m = u_boot_console.p.expect(['Summary: 0 failures', 'Press any key'])
|
|
|
|
if m != 0:
|
2018-09-06 18:29:50 +00:00
|
|
|
raise Exception('Failures occurred during the EFI selftest')
|
2017-09-15 08:06:12 +00:00
|
|
|
u_boot_console.restart_uboot();
|
2017-10-18 16:13:17 +00:00
|
|
|
|
2018-03-03 14:29:04 +00:00
|
|
|
@pytest.mark.buildconfigspec('cmd_bootefi_selftest')
|
|
|
|
@pytest.mark.buildconfigspec('of_control')
|
2019-04-20 11:33:55 +00:00
|
|
|
@pytest.mark.notbuildconfigspec('generate_acpi_table')
|
2018-03-03 14:29:04 +00:00
|
|
|
def test_efi_selftest_device_tree(u_boot_console):
|
|
|
|
u_boot_console.run_command(cmd='setenv efi_selftest list')
|
|
|
|
output = u_boot_console.run_command('bootefi selftest')
|
|
|
|
assert '\'device tree\'' in output
|
|
|
|
u_boot_console.run_command(cmd='setenv efi_selftest device tree')
|
|
|
|
u_boot_console.run_command(cmd='setenv -f serial# Testing DT')
|
|
|
|
u_boot_console.run_command(cmd='bootefi selftest ${fdtcontroladdr}', wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(['serial-number: Testing DT', 'U-Boot'])
|
|
|
|
if m != 0:
|
2019-07-05 15:43:13 +00:00
|
|
|
raise Exception('serial-number missing in device tree')
|
2018-03-03 14:29:04 +00:00
|
|
|
u_boot_console.restart_uboot();
|
|
|
|
|
2017-10-18 16:13:17 +00:00
|
|
|
@pytest.mark.buildconfigspec('cmd_bootefi_selftest')
|
|
|
|
def test_efi_selftest_watchdog_reboot(u_boot_console):
|
|
|
|
u_boot_console.run_command(cmd='setenv efi_selftest list')
|
|
|
|
output = u_boot_console.run_command('bootefi selftest')
|
|
|
|
assert '\'watchdog reboot\'' in output
|
|
|
|
u_boot_console.run_command(cmd='setenv efi_selftest watchdog reboot')
|
|
|
|
u_boot_console.run_command(cmd='bootefi selftest', wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(['resetting', 'U-Boot'])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('Reset failed in \'watchdog reboot\' test')
|
|
|
|
u_boot_console.restart_uboot();
|
2018-09-06 18:19:31 +00:00
|
|
|
|
|
|
|
@pytest.mark.buildconfigspec('cmd_bootefi_selftest')
|
|
|
|
def test_efi_selftest_text_input(u_boot_console):
|
|
|
|
"""Test the EFI_SIMPLE_TEXT_INPUT_PROTOCOL
|
|
|
|
|
|
|
|
:param u_boot_console: U-Boot console
|
|
|
|
|
|
|
|
This function calls the text input EFI selftest.
|
|
|
|
"""
|
|
|
|
u_boot_console.run_command(cmd='setenv efi_selftest text input')
|
|
|
|
output = u_boot_console.run_command(cmd='bootefi selftest',
|
|
|
|
wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(['To terminate type \'x\''])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('No prompt for \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
u_boot_console.p.timeout = 500
|
|
|
|
# EOT
|
|
|
|
u_boot_console.run_command(cmd=chr(4), wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
2018-09-11 20:38:07 +00:00
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 4 \(unknown\), scan code 0 \(Null\)'])
|
2018-09-06 18:19:31 +00:00
|
|
|
if m != 0:
|
|
|
|
raise Exception('EOT failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# BS
|
|
|
|
u_boot_console.run_command(cmd=chr(8), wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
2018-09-11 20:38:07 +00:00
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 8 \(BS\), scan code 0 \(Null\)'])
|
2018-09-06 18:19:31 +00:00
|
|
|
if m != 0:
|
|
|
|
raise Exception('BS failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# TAB
|
|
|
|
u_boot_console.run_command(cmd=chr(9), wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
2018-09-11 20:38:07 +00:00
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 9 \(TAB\), scan code 0 \(Null\)'])
|
2018-09-06 18:19:31 +00:00
|
|
|
if m != 0:
|
|
|
|
raise Exception('BS failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# a
|
|
|
|
u_boot_console.run_command(cmd='a', wait_for_echo=False, send_nl=False,
|
|
|
|
wait_for_prompt=False)
|
2018-09-11 20:38:07 +00:00
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 97 \(\'a\'\), scan code 0 \(Null\)'])
|
2018-09-06 18:19:31 +00:00
|
|
|
if m != 0:
|
|
|
|
raise Exception('\'a\' failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# UP escape sequence
|
|
|
|
u_boot_console.run_command(cmd=chr(27) + '[A', wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
2018-09-11 20:38:07 +00:00
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 0 \(Null\), scan code 1 \(Up\)'])
|
2018-09-06 18:19:31 +00:00
|
|
|
if m != 0:
|
|
|
|
raise Exception('UP failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
2018-09-11 20:38:03 +00:00
|
|
|
# Euro sign
|
|
|
|
u_boot_console.run_command(cmd='\xe2\x82\xac', wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
2018-09-11 20:38:07 +00:00
|
|
|
m = u_boot_console.p.expect(['Unicode char 8364 \(\''])
|
2018-09-11 20:38:03 +00:00
|
|
|
if m != 0:
|
|
|
|
raise Exception('Euro sign failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
2018-09-06 18:19:31 +00:00
|
|
|
u_boot_console.run_command(cmd='x', wait_for_echo=False, send_nl=False,
|
|
|
|
wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(['Summary: 0 failures', 'Press any key'])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('Failures occurred during the EFI selftest')
|
|
|
|
u_boot_console.restart_uboot();
|
2018-09-11 20:38:11 +00:00
|
|
|
|
|
|
|
@pytest.mark.buildconfigspec('cmd_bootefi_selftest')
|
|
|
|
def test_efi_selftest_text_input_ex(u_boot_console):
|
|
|
|
"""Test the EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL
|
|
|
|
|
|
|
|
:param u_boot_console: U-Boot console
|
|
|
|
|
|
|
|
This function calls the extended text input EFI selftest.
|
|
|
|
"""
|
|
|
|
u_boot_console.run_command(cmd='setenv efi_selftest extended text input')
|
|
|
|
output = u_boot_console.run_command(cmd='bootefi selftest',
|
|
|
|
wait_for_prompt=False)
|
2018-09-11 20:38:13 +00:00
|
|
|
m = u_boot_console.p.expect(['To terminate type \'CTRL\+x\''])
|
2018-09-11 20:38:11 +00:00
|
|
|
if m != 0:
|
|
|
|
raise Exception('No prompt for \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
u_boot_console.p.timeout = 500
|
|
|
|
# EOT
|
|
|
|
u_boot_console.run_command(cmd=chr(4), wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(
|
2019-04-06 18:59:24 +00:00
|
|
|
['Unicode char 100 \\(\'d\'\\), scan code 0 \\(CTRL\\+Null\\)'])
|
2018-09-11 20:38:11 +00:00
|
|
|
if m != 0:
|
|
|
|
raise Exception('EOT failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# BS
|
|
|
|
u_boot_console.run_command(cmd=chr(8), wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 8 \(BS\), scan code 0 \(\+Null\)'])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('BS failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# TAB
|
|
|
|
u_boot_console.run_command(cmd=chr(9), wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 9 \(TAB\), scan code 0 \(\+Null\)'])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('TAB failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# a
|
|
|
|
u_boot_console.run_command(cmd='a', wait_for_echo=False, send_nl=False,
|
|
|
|
wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 97 \(\'a\'\), scan code 0 \(Null\)'])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('\'a\' failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# UP escape sequence
|
|
|
|
u_boot_console.run_command(cmd=chr(27) + '[A', wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 0 \(Null\), scan code 1 \(\+Up\)'])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('UP failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# Euro sign
|
|
|
|
u_boot_console.run_command(cmd='\xe2\x82\xac', wait_for_echo=False,
|
|
|
|
send_nl=False, wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(['Unicode char 8364 \(\''])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('Euro sign failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
|
|
|
# SHIFT+ALT+FN 5
|
|
|
|
u_boot_console.run_command(cmd='\x1b\x5b\x31\x35\x3b\x34\x7e',
|
|
|
|
wait_for_echo=False, send_nl=False,
|
|
|
|
wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(
|
|
|
|
['Unicode char 0 \(Null\), scan code 15 \(SHIFT\+ALT\+FN 5\)'])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('SHIFT+ALT+FN 5 failed in \'text input\' test')
|
|
|
|
u_boot_console.drain_console()
|
2018-09-11 20:38:13 +00:00
|
|
|
u_boot_console.run_command(cmd=chr(24), wait_for_echo=False, send_nl=False,
|
2018-09-11 20:38:11 +00:00
|
|
|
wait_for_prompt=False)
|
|
|
|
m = u_boot_console.p.expect(['Summary: 0 failures', 'Press any key'])
|
|
|
|
if m != 0:
|
|
|
|
raise Exception('Failures occurred during the EFI selftest')
|
|
|
|
u_boot_console.restart_uboot();
|