[PATCH v8 22/23] test/py: add HTTP (wget) test for the EFI loader
Jerome Forissier
jerome.forissier at linaro.org
Thu Aug 8 15:06:05 CEST 2024
On 8/7/24 19:57, Tom Rini wrote:
> On Wed, Aug 07, 2024 at 07:12:06PM +0200, Jerome Forissier wrote:
>> Add a test to test_efi_loader.py similar to the TFTP test but for HTTP
>> with the wget command.
>>
>> Suggested-by: Tom Rini <trini at konsulko.com>
>> Signed-off-by: Jerome Forissier <jerome.forissier at linaro.org>
>> ---
>> test/py/tests/test_efi_loader.py | 52 +++++++++++++++++++++++---------
>> 1 file changed, 37 insertions(+), 15 deletions(-)
>>
>> diff --git a/test/py/tests/test_efi_loader.py b/test/py/tests/test_efi_loader.py
>> index 85473a9049b..64c994fdf95 100644
>> --- a/test/py/tests/test_efi_loader.py
>> +++ b/test/py/tests/test_efi_loader.py
>> @@ -50,6 +50,8 @@ env__efi_loader_helloworld_file = {
>> import pytest
>> import u_boot_utils
>>
>> +PROTO_TFTP, PROTO_HTTP = range(0, 2)
>> +
>> net_set_up = False
>>
>> def test_efi_pre_commands(u_boot_console):
>> @@ -110,10 +112,10 @@ def test_efi_setup_static(u_boot_console):
>> global net_set_up
>> net_set_up = True
>>
>> -def fetch_tftp_file(u_boot_console, env_conf):
>> - """Grab an env described file via TFTP and return its address
>> +def fetch_file(u_boot_console, env_conf, proto):
>> + """Grab an env described file via TFTP or HTTP and return its address
>>
>> - A file as described by an env config <env_conf> is downloaded from the TFTP
>> + A file as described by an env config <env_conf> is downloaded from the
>> server. The address to that file is returned.
>> """
>> if not net_set_up:
>> @@ -128,7 +130,13 @@ def fetch_tftp_file(u_boot_console, env_conf):
>> addr = u_boot_utils.find_ram_base(u_boot_console)
>>
>> fn = f['fn']
>> - output = u_boot_console.run_command('tftpboot %x %s' % (addr, fn))
>> + if proto == PROTO_TFTP:
>> + cmd = 'tftpboot'
>> + elif proto == PROTO_HTTP:
>> + cmd = 'wget'
>> + else:
>> + assert False
>> + output = u_boot_console.run_command('%s %x %s' % (cmd, addr, fn))
>> expected_text = 'Bytes transferred = '
>> sz = f.get('size', None)
>> if sz:
>> @@ -147,16 +155,8 @@ def fetch_tftp_file(u_boot_console, env_conf):
>>
>> return addr
>>
>> - at pytest.mark.buildconfigspec('of_control')
>> - at pytest.mark.buildconfigspec('cmd_bootefi_hello_compile')
>> -def test_efi_helloworld_net(u_boot_console):
>> - """Run the helloworld.efi binary via TFTP.
>> -
>> - The helloworld.efi file is downloaded from the TFTP server and is executed
>> - using the fallback device tree at $fdtcontroladdr.
>> - """
>> -
>> - addr = fetch_tftp_file(u_boot_console, 'env__efi_loader_helloworld_file')
>> +def do_test_efi_helloworld_net(u_boot_console, proto):
>> + addr = fetch_file(u_boot_console, 'env__efi_loader_helloworld_file', proto)
>>
>> output = u_boot_console.run_command('bootefi %x' % addr)
>> expected_text = 'Hello, world'
>> @@ -164,6 +164,28 @@ def test_efi_helloworld_net(u_boot_console):
>> expected_text = '## Application failed'
>> assert expected_text not in output
>>
>> + at pytest.mark.buildconfigspec('of_control')
>> + at pytest.mark.buildconfigspec('cmd_bootefi_hello_compile')
>> +def test_efi_helloworld_net_tftp(u_boot_console):
>> + """Run the helloworld.efi binary via TFTP.
>> +
>> + The helloworld.efi file is downloaded from the TFTP server and is executed
>> + using the fallback device tree at $fdtcontroladdr.
>> + """
>> +
>> + do_test_efi_helloworld_net(u_boot_console, PROTO_TFTP);
>> +
>> + at pytest.mark.buildconfigspec('of_control')
>> + at pytest.mark.buildconfigspec('cmd_bootefi_hello_compile')
>> +def test_efi_helloworld_net_http(u_boot_console):
>> + """Run the helloworld.efi binary via HTTP.
>> +
>> + The helloworld.efi file is downloaded from the HTTP server and is executed
>> + using the fallback device tree at $fdtcontroladdr.
>> + """
>> +
>> + do_test_efi_helloworld_net(u_boot_console, PROTO_HTTP);
>> +
>> @pytest.mark.buildconfigspec('cmd_bootefi_hello')
>> def test_efi_helloworld_builtin(u_boot_console):
>> """Run the builtin helloworld.efi binary.
>> @@ -185,7 +207,7 @@ def test_efi_grub_net(u_boot_console):
>> executed.
>> """
>>
>> - addr = fetch_tftp_file(u_boot_console, 'env__efi_loader_grub_file')
>> + addr = fetch_file(u_boot_console, 'env__efi_loader_grub_file', PROTO_TFTP)
>>
>> u_boot_console.run_command('bootefi %x' % addr, wait_for_prompt=False)
>
> Looking at this now that I've added wget to my Pi builds, erm:
> U-Boot> wget 200000 EFI/arm64/helloworld.efi
>
> That's not going to work. That's what works fine for a tftp server. I
> think the test is going to need to require some http specific
> configuration added (and I'll locally start firing off the python
> trivial http server or something, for tests).
It should work because 'wget <addr> <file>' is a valid syntax for the legacy
wget as well as for the new one, now that I have added support for it. It
takes the address of the http server from ${serverip}. Of course you need a
http server listening on the same host as the tfp server, yes.
I have tested this on the RPi3.
--
Jerome
More information about the U-Boot
mailing list