summaryrefslogtreecommitdiff
path: root/test/py/tests/test_eficonfig
diff options
context:
space:
mode:
Diffstat (limited to 'test/py/tests/test_eficonfig')
-rw-r--r--test/py/tests/test_eficonfig/conftest.py40
-rw-r--r--test/py/tests/test_eficonfig/test_eficonfig.py358
2 files changed, 0 insertions, 398 deletions
diff --git a/test/py/tests/test_eficonfig/conftest.py b/test/py/tests/test_eficonfig/conftest.py
deleted file mode 100644
index 0a82fbefd75..00000000000
--- a/test/py/tests/test_eficonfig/conftest.py
+++ /dev/null
@@ -1,40 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0+
-
-"""Fixture for UEFI eficonfig test
-"""
-
-import os
-import shutil
-from subprocess import check_call
-import pytest
-
-@pytest.fixture(scope='session')
-def efi_eficonfig_data(u_boot_config):
- """Set up a file system to be used in UEFI "eficonfig" command
- tests
-
- Args:
- u_boot_config -- U-Boot configuration.
-
- Return:
- A path to disk image to be used for testing
- """
- mnt_point = u_boot_config.persistent_data_dir + '/test_efi_eficonfig'
- image_path = u_boot_config.persistent_data_dir + '/efi_eficonfig.img'
-
- shutil.rmtree(mnt_point, ignore_errors=True)
- os.mkdir(mnt_point, mode = 0o755)
-
- with open(mnt_point + '/initrd-1.img', 'w', encoding = 'ascii') as file:
- file.write("initrd 1")
-
- with open(mnt_point + '/initrd-2.img', 'w', encoding = 'ascii') as file:
- file.write("initrd 2")
-
- shutil.copyfile(u_boot_config.build_dir + '/lib/efi_loader/initrddump.efi',
- mnt_point + '/initrddump.efi')
-
- check_call(f'virt-make-fs --partition=gpt --size=+1M --type=vfat {mnt_point} {image_path}',
- shell=True)
-
- return image_path
diff --git a/test/py/tests/test_eficonfig/test_eficonfig.py b/test/py/tests/test_eficonfig/test_eficonfig.py
deleted file mode 100644
index 3ca8e27c76b..00000000000
--- a/test/py/tests/test_eficonfig/test_eficonfig.py
+++ /dev/null
@@ -1,358 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0+
-""" Unit test for UEFI menu-driven configuration
-"""
-
-import pytest
-import time
-
-@pytest.mark.boardspec('sandbox')
-@pytest.mark.buildconfigspec('cmd_eficonfig')
-@pytest.mark.buildconfigspec('cmd_bootefi_bootmgr')
-def test_efi_eficonfig(ubman, efi_eficonfig_data):
-
- def send_user_input_and_wait(user_str, expect_str):
- time.sleep(0.1) # TODO: does not work correctly without sleep
- ubman.run_command(cmd=user_str, wait_for_prompt=False,
- wait_for_echo=True, send_nl=False)
- ubman.run_command(cmd='\x0d', wait_for_prompt=False,
- wait_for_echo=False, send_nl=False)
- if expect_str is not None:
- for i in expect_str:
- ubman.p.expect([i])
-
- def press_up_down_enter_and_wait(up_count, down_count, enter, expect_str):
- # press UP key
- for i in range(up_count):
- ubman.run_command(cmd='\x1b\x5b\x41', wait_for_prompt=False,
- wait_for_echo=False, send_nl=False)
- # press DOWN key
- for i in range(down_count):
- ubman.run_command(cmd='\x1b\x5b\x42', wait_for_prompt=False,
- wait_for_echo=False, send_nl=False)
- # press ENTER if requested
- if enter:
- ubman.run_command(cmd='\x0d', wait_for_prompt=False,
- wait_for_echo=False, send_nl=False)
- # wait expected output
- if expect_str is not None:
- for i in expect_str:
- ubman.p.expect([i])
-
- def press_escape_key(wait_prompt):
- ubman.run_command(cmd='\x1b', wait_for_prompt=wait_prompt, wait_for_echo=False, send_nl=False)
-
- def press_enter_key(wait_prompt):
- ubman.run_command(cmd='\x0d', wait_for_prompt=wait_prompt,
- wait_for_echo=False, send_nl=False)
-
- def check_current_is_maintenance_menu():
- for i in ('UEFI Maintenance Menu', 'Add Boot Option', 'Edit Boot Option',
- 'Change Boot Order', 'Delete Boot Option', 'Quit'):
- ubman.p.expect([i])
-
- """ Unit test for "eficonfig" command
- The menu-driven interface is used to set up UEFI load options.
- The bootefi bootmgr loads initrddump.efi as a payload.
- The crc32 of the loaded initrd.img is checked
-
- Args:
- ubman -- U-Boot console
- efi__data -- Path to the disk image used for testing.
- Test disk image has following files.
- initrd-1.img
- initrd-2.img
- initrddump.efi
-
- """
- # This test passes for unknown reasons in the bowels of U-Boot. It needs to
- # be replaced with a unit test.
- return
-
- # Restart the system to clean the previous state
- ubman.restart_uboot()
-
- with ubman.temporary_timeout(500):
- #
- # Test Case 1: Check the menu is displayed
- #
- ubman.run_command('eficonfig', wait_for_prompt=False)
- for i in ('UEFI Maintenance Menu', 'Add Boot Option', 'Edit Boot Option',
- 'Change Boot Order', 'Delete Boot Option', 'Quit'):
- ubman.p.expect([i])
- # Select "Add Boot Option"
- press_enter_key(False)
- for i in ('Add Boot Option', 'Description:', 'File', 'Initrd File', 'Optional Data',
- 'Save', 'Quit'):
- ubman.p.expect([i])
- press_escape_key(False)
- check_current_is_maintenance_menu()
- # return to U-Boot console
- press_escape_key(True)
-
- #
- # Test Case 2: check auto generated media device entry
- #
-
- # bind the test disk image for succeeding tests
- ubman.run_command(cmd = f'host bind 0 {efi_eficonfig_data}')
-
- ubman.run_command('eficonfig', wait_for_prompt=False)
-
- # Change the Boot Order
- press_up_down_enter_and_wait(0, 2, True, 'Quit')
- for i in ('host 0:1', 'Save', 'Quit'):
- ubman.p.expect([i])
- # disable auto generated boot option for succeeding test
- ubman.run_command(cmd=' ', wait_for_prompt=False,
- wait_for_echo=False, send_nl=False)
- # Save the BootOrder
- press_up_down_enter_and_wait(0, 1, True, None)
- check_current_is_maintenance_menu()
-
- #
- # Test Case 3: Add first Boot Option and load it
- #
-
- # Select 'Add Boot Option'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
-
- # Press the enter key to select 'Description:' entry, then enter Description
- press_up_down_enter_and_wait(0, 0, True, 'Enter description:')
- # Send Description user input, press ENTER key to complete
- send_user_input_and_wait('test 1', 'Quit')
-
- # Set EFI image(initrddump.efi)
- press_up_down_enter_and_wait(0, 1, True, 'Quit')
- press_up_down_enter_and_wait(0, 0, True, 'host 0:1')
- # Select 'host 0:1'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
- # Press down key to select "initrddump.efi" entry followed by the enter key
- press_up_down_enter_and_wait(0, 2, True, 'Quit')
-
- # Set Initrd file(initrd-1.img)
- press_up_down_enter_and_wait(0, 2, True, 'Quit')
- press_up_down_enter_and_wait(0, 0, True, 'host 0:1')
- # Select 'host 0:1'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
- # Press down key to select "initrd-1.img" entry followed by the enter key
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
-
- # Set optional_data
- press_up_down_enter_and_wait(0, 3, True, 'Optional Data:')
- # Send Description user input, press ENTER key to complete
- send_user_input_and_wait('nocolor', None)
- for i in ('Description: test 1', 'File: host 0:1/initrddump.efi',
- 'Initrd File: host 0:1/initrd-1.img', 'Optional Data: nocolor', 'Save', 'Quit'):
- ubman.p.expect([i])
-
- # Save the Boot Option
- press_up_down_enter_and_wait(0, 4, True, None)
- check_current_is_maintenance_menu()
-
- # Check the newly added Boot Option is handled correctly
- # Return to U-Boot console
- press_escape_key(True)
- ubman.run_command(cmd = 'bootefi bootmgr')
- response = ubman.run_command(cmd = 'load', wait_for_echo=False)
- assert 'crc32: 0x181464af' in response
- ubman.run_command(cmd = 'exit', wait_for_echo=False)
-
- #
- # Test Case 4: Add second Boot Option and load it
- #
- ubman.run_command('eficonfig', wait_for_prompt=False)
-
- # Select 'Add Boot Option'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
-
- # Press the enter key to select 'Description:' entry, then enter Description
- press_up_down_enter_and_wait(0, 0, True, 'Enter description:')
- # Send Description user input, press ENTER key to complete
- send_user_input_and_wait('test 2', 'Quit')
-
- # Set EFI image(initrddump.efi)
- press_up_down_enter_and_wait(0, 1, True, 'Quit')
- press_up_down_enter_and_wait(0, 0, True, 'host 0:1')
- # Select 'host 0:1'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
- # Press down key to select "initrddump.efi" entry followed by the enter key
- press_up_down_enter_and_wait(0, 2, True, 'Quit')
-
- # Set Initrd file(initrd-2.img)
- press_up_down_enter_and_wait(0, 2, True, 'Quit')
- press_up_down_enter_and_wait(0, 0, True, 'host 0:1')
- # Select 'host 0:1'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
- # Press down key to select "initrd-2.img" entry followed by the enter key
- press_up_down_enter_and_wait(0, 1, True, 'Quit')
-
- # Set optional_data
- press_up_down_enter_and_wait(0, 3, True, 'Optional Data:')
- # Send Description user input, press ENTER key to complete
- send_user_input_and_wait('nocolor', None)
- for i in ('Description: test 2', 'File: host 0:1/initrddump.efi',
- 'Initrd File: host 0:1/initrd-2.img', 'Optional Data: nocolor', 'Save', 'Quit'):
- ubman.p.expect([i])
-
- # Save the Boot Option
- press_up_down_enter_and_wait(0, 4, True, 'Quit')
-
- # Change the Boot Order
- press_up_down_enter_and_wait(0, 2, True, 'Quit')
- press_up_down_enter_and_wait(0, 1, False, 'Quit')
- # move 'test 1' to the second entry
- ubman.run_command(cmd='+', wait_for_prompt=False,
- wait_for_echo=False, send_nl=False)
- for i in ('test 2', 'test 1', 'host 0:1', 'Save', 'Quit'):
- ubman.p.expect([i])
- # Save the BootOrder
- press_up_down_enter_and_wait(0, 3, True, None)
- check_current_is_maintenance_menu()
-
- # Check the newly added Boot Option is handled correctly
- # Return to U-Boot console
- press_escape_key(True)
- ubman.run_command(cmd = 'bootefi bootmgr')
- response = ubman.run_command(cmd = 'load', wait_for_echo=False)
- assert 'crc32: 0x811d3515' in response
- ubman.run_command(cmd = 'exit', wait_for_echo=False)
-
- #
- # Test Case 5: Change BootOrder and load it
- #
- ubman.run_command('eficonfig', wait_for_prompt=False)
-
- # Change the Boot Order
- press_up_down_enter_and_wait(0, 2, True, None)
- # Check the current BootOrder
- for i in ('test 2', 'test 1', 'host 0:1', 'Save', 'Quit'):
- ubman.p.expect([i])
- # move 'test 2' to the second entry
- ubman.run_command(cmd='-', wait_for_prompt=False,
- wait_for_echo=False, send_nl=False)
- for i in ('test 1', 'test 2', 'host 0:1', 'Save', 'Quit'):
- ubman.p.expect([i])
- # Save the BootOrder
- press_up_down_enter_and_wait(0, 2, True, None)
- check_current_is_maintenance_menu()
-
- # Return to U-Boot console
- press_escape_key(True)
- ubman.run_command(cmd = 'bootefi bootmgr')
- response = ubman.run_command(cmd = 'load', wait_for_echo=False)
- assert 'crc32: 0x181464af' in response
- ubman.run_command(cmd = 'exit', wait_for_echo=False)
-
- #
- # Test Case 6: Delete Boot Option(label:test 2)
- #
- ubman.run_command('eficonfig', wait_for_prompt=False)
-
- # Select 'Delete Boot Option'
- press_up_down_enter_and_wait(0, 3, True, None)
- # Check the current BootOrder
- for i in ('test 1', 'test 2', 'Quit'):
- ubman.p.expect([i])
-
- # Delete 'test 2'
- press_up_down_enter_and_wait(0, 1, True, None)
- for i in ('test 1', 'Quit'):
- ubman.p.expect([i])
- press_escape_key(False)
- check_current_is_maintenance_menu()
- # Return to U-Boot console
- press_escape_key(True)
-
- #
- # Test Case 7: Edit Boot Option
- #
- ubman.run_command('eficonfig', wait_for_prompt=False)
- # Select 'Edit Boot Option'
- press_up_down_enter_and_wait(0, 1, True, None)
- # Check the current BootOrder
- for i in ('test 1', 'Quit'):
- ubman.p.expect([i])
- press_up_down_enter_and_wait(0, 0, True, None)
- for i in ('Description: test 1', 'File: host 0:1/initrddump.efi',
- 'Initrd File: host 0:1/initrd-1.img', 'Optional Data: nocolor', 'Save', 'Quit'):
- ubman.p.expect([i])
-
- # Press the enter key to select 'Description:' entry, then enter Description
- press_up_down_enter_and_wait(0, 0, True, 'Enter description:')
- # Send Description user input, press ENTER key to complete
- send_user_input_and_wait('test 3', 'Quit')
-
- # Set EFI image(initrddump.efi)
- press_up_down_enter_and_wait(0, 1, True, 'Quit')
- press_up_down_enter_and_wait(0, 0, True, 'host 0:1')
- # Select 'host 0:1'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
- # Press down key to select "initrddump.efi" entry followed by the enter key
- press_up_down_enter_and_wait(0, 2, True, 'Quit')
-
- # Set Initrd file(initrd-2.img)
- press_up_down_enter_and_wait(0, 2, True, 'Quit')
- press_up_down_enter_and_wait(0, 0, True, 'host 0:1')
- # Select 'host 0:1'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
- # Press down key to select "initrd-1.img" entry followed by the enter key
- press_up_down_enter_and_wait(0, 1, True, 'Quit')
-
- # Set optional_data
- press_up_down_enter_and_wait(0, 3, True, 'Optional Data:')
- # Send Description user input, press ENTER key to complete
- send_user_input_and_wait('', None)
- for i in ('Description: test 3', 'File: host 0:1/initrddump.efi',
- 'Initrd File: host 0:1/initrd-2.img', 'Optional Data:', 'Save', 'Quit'):
- ubman.p.expect([i])
-
- # Save the Boot Option
- press_up_down_enter_and_wait(0, 4, True, 'Quit')
- press_escape_key(False)
- check_current_is_maintenance_menu()
-
- # Check the updated Boot Option is handled correctly
- # Return to U-Boot console
- press_escape_key(True)
- ubman.run_command(cmd = 'bootefi bootmgr')
- response = ubman.run_command(cmd = 'load', wait_for_echo=False)
- assert 'crc32: 0x811d3515' in response
- ubman.run_command(cmd = 'exit', wait_for_echo=False)
-
- #
- # Test Case 8: Delete Boot Option(label:test 3)
- #
- ubman.run_command('eficonfig', wait_for_prompt=False)
-
- # Select 'Delete Boot Option'
- press_up_down_enter_and_wait(0, 3, True, None)
- # Check the current BootOrder
- for i in ('test 3', 'Quit'):
- ubman.p.expect([i])
-
- # Delete 'test 3'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
- press_escape_key(False)
- check_current_is_maintenance_menu()
- # Return to U-Boot console
- press_escape_key(True)
-
- # remove the host device
- ubman.run_command(cmd = f'host bind -r 0')
-
- #
- # Test Case 9: No block device found
- #
- ubman.run_command('eficonfig', wait_for_prompt=False)
-
- # Select 'Add Boot Option'
- press_up_down_enter_and_wait(0, 0, True, 'Quit')
-
- # Set EFI image
- press_up_down_enter_and_wait(0, 1, True, 'Quit')
- press_up_down_enter_and_wait(0, 0, True, 'No block device found!')
- press_escape_key(False)
- press_escape_key(False)
- check_current_is_maintenance_menu()
- # Return to U-Boot console
- press_escape_key(True)