xref: /rk3399_rockchip-uboot/test/py/tests/test_net.py (revision e8debf394fbba594fcfc267c61f8c6bbca395b06)
1e5bb279fSStephen Warren# Copyright (c) 2016, NVIDIA CORPORATION. All rights reserved.
2e5bb279fSStephen Warren#
3e5bb279fSStephen Warren# SPDX-License-Identifier: GPL-2.0
4e5bb279fSStephen Warren
5e5bb279fSStephen Warren# Test various network-related functionality, such as the dhcp, ping, and
6e5bb279fSStephen Warren# tftpboot commands.
7e5bb279fSStephen Warren
8e5bb279fSStephen Warrenimport pytest
9e5bb279fSStephen Warrenimport u_boot_utils
10e5bb279fSStephen Warren
11*e8debf39SStephen Warren"""
12e5bb279fSStephen WarrenNote: This test relies on boardenv_* containing configuration values to define
13e5bb279fSStephen Warrenwhich the network environment available for testing. Without this, this test
14e5bb279fSStephen Warrenwill be automatically skipped.
15e5bb279fSStephen Warren
16e5bb279fSStephen WarrenFor example:
17e5bb279fSStephen Warren
1856382a81SStephen Warren# Boolean indicating whether the Ethernet device is attached to USB, and hence
1956382a81SStephen Warren# USB enumeration needs to be performed prior to network tests.
2056382a81SStephen Warren# This variable may be omitted if its value is False.
2156382a81SStephen Warrenenv__net_uses_usb = False
2256382a81SStephen Warren
2356382a81SStephen Warren# Boolean indicating whether the Ethernet device is attached to PCI, and hence
2456382a81SStephen Warren# PCI enumeration needs to be performed prior to network tests.
2556382a81SStephen Warren# This variable may be omitted if its value is False.
2656382a81SStephen Warrenenv__net_uses_pci = True
27e5bb279fSStephen Warren
28e5bb279fSStephen Warren# True if a DHCP server is attached to the network, and should be tested.
29e5bb279fSStephen Warren# If DHCP testing is not possible or desired, this variable may be omitted or
30e5bb279fSStephen Warren# set to False.
31e5bb279fSStephen Warrenenv__net_dhcp_server = True
32e5bb279fSStephen Warren
33e5bb279fSStephen Warren# A list of environment variables that should be set in order to configure a
34e5bb279fSStephen Warren# static IP. If solely relying on DHCP, this variable may be omitted or set to
35e5bb279fSStephen Warren# an empty list.
36e5bb279fSStephen Warrenenv__net_static_env_vars = [
37e5bb279fSStephen Warren    ("ipaddr", "10.0.0.100"),
38e5bb279fSStephen Warren    ("netmask", "255.255.255.0"),
39e5bb279fSStephen Warren    ("serverip", "10.0.0.1"),
40e5bb279fSStephen Warren]
41e5bb279fSStephen Warren
42e5bb279fSStephen Warren# Details regarding a file that may be read from a TFTP server. This variable
43e5bb279fSStephen Warren# may be omitted or set to None if TFTP testing is not possible or desired.
44e5bb279fSStephen Warrenenv__net_tftp_readable_file = {
45e5bb279fSStephen Warren    "fn": "ubtest-readable.bin",
46e5bb279fSStephen Warren    "size": 5058624,
47e5bb279fSStephen Warren    "crc32": "c2244b26",
48e5bb279fSStephen Warren}
49*e8debf39SStephen Warren"""
50e5bb279fSStephen Warren
51e5bb279fSStephen Warrennet_set_up = False
52e5bb279fSStephen Warren
53e5bb279fSStephen Warrendef test_net_pre_commands(u_boot_console):
54*e8debf39SStephen Warren    """Execute any commands required to enable network hardware.
55e5bb279fSStephen Warren
56e5bb279fSStephen Warren    These commands are provided by the boardenv_* file; see the comment at the
57e5bb279fSStephen Warren    beginning of this file.
58*e8debf39SStephen Warren    """
59e5bb279fSStephen Warren
6056382a81SStephen Warren    init_usb = u_boot_console.config.env.get('env__net_uses_usb', False)
6156382a81SStephen Warren    if init_usb:
6256382a81SStephen Warren        u_boot_console.run_command('usb start')
63e5bb279fSStephen Warren
6456382a81SStephen Warren    init_pci = u_boot_console.config.env.get('env__net_uses_pci', False)
6556382a81SStephen Warren    if init_pci:
6656382a81SStephen Warren        u_boot_console.run_command('pci enum')
67e5bb279fSStephen Warren
68e5bb279fSStephen Warren@pytest.mark.buildconfigspec('cmd_dhcp')
69e5bb279fSStephen Warrendef test_net_dhcp(u_boot_console):
70*e8debf39SStephen Warren    """Test the dhcp command.
71e5bb279fSStephen Warren
72e5bb279fSStephen Warren    The boardenv_* file may be used to enable/disable this test; see the
73e5bb279fSStephen Warren    comment at the beginning of this file.
74*e8debf39SStephen Warren    """
75e5bb279fSStephen Warren
76e5bb279fSStephen Warren    test_dhcp = u_boot_console.config.env.get('env__net_dhcp_server', False)
77e5bb279fSStephen Warren    if not test_dhcp:
78e5bb279fSStephen Warren        pytest.skip('No DHCP server available')
79e5bb279fSStephen Warren
80e5bb279fSStephen Warren    u_boot_console.run_command('setenv autoload no')
81e5bb279fSStephen Warren    output = u_boot_console.run_command('dhcp')
82e5bb279fSStephen Warren    assert 'DHCP client bound to address ' in output
83e5bb279fSStephen Warren
84e5bb279fSStephen Warren    global net_set_up
85e5bb279fSStephen Warren    net_set_up = True
86e5bb279fSStephen Warren
87e5bb279fSStephen Warren@pytest.mark.buildconfigspec('net')
88e5bb279fSStephen Warrendef test_net_setup_static(u_boot_console):
89*e8debf39SStephen Warren    """Set up a static IP configuration.
90e5bb279fSStephen Warren
91e5bb279fSStephen Warren    The configuration is provided by the boardenv_* file; see the comment at
92e5bb279fSStephen Warren    the beginning of this file.
93*e8debf39SStephen Warren    """
94e5bb279fSStephen Warren
95e5bb279fSStephen Warren    env_vars = u_boot_console.config.env.get('env__net_static_env_vars', None)
96e5bb279fSStephen Warren    if not env_vars:
97e5bb279fSStephen Warren        pytest.skip('No static network configuration is defined')
98e5bb279fSStephen Warren
99e5bb279fSStephen Warren    for (var, val) in env_vars:
100e5bb279fSStephen Warren        u_boot_console.run_command('setenv %s %s' % (var, val))
101e5bb279fSStephen Warren
102e5bb279fSStephen Warren    global net_set_up
103e5bb279fSStephen Warren    net_set_up = True
104e5bb279fSStephen Warren
105e5bb279fSStephen Warren@pytest.mark.buildconfigspec('cmd_ping')
106e5bb279fSStephen Warrendef test_net_ping(u_boot_console):
107*e8debf39SStephen Warren    """Test the ping command.
108e5bb279fSStephen Warren
109e5bb279fSStephen Warren    The $serverip (as set up by either test_net_dhcp or test_net_setup_static)
110e5bb279fSStephen Warren    is pinged. The test validates that the host is alive, as reported by the
111e5bb279fSStephen Warren    ping command's output.
112*e8debf39SStephen Warren    """
113e5bb279fSStephen Warren
114e5bb279fSStephen Warren    if not net_set_up:
115e5bb279fSStephen Warren        pytest.skip("Network not initialized")
116e5bb279fSStephen Warren
117e5bb279fSStephen Warren    output = u_boot_console.run_command('ping $serverip')
118e5bb279fSStephen Warren    assert 'is alive' in output
119e5bb279fSStephen Warren
120e5bb279fSStephen Warren@pytest.mark.buildconfigspec('cmd_net')
121e5bb279fSStephen Warrendef test_net_tftpboot(u_boot_console):
122*e8debf39SStephen Warren    """Test the tftpboot command.
123e5bb279fSStephen Warren
124e5bb279fSStephen Warren    A file is downloaded from the TFTP server, its size and optionally its
125e5bb279fSStephen Warren    CRC32 are validated.
126e5bb279fSStephen Warren
127e5bb279fSStephen Warren    The details of the file to download are provided by the boardenv_* file;
128e5bb279fSStephen Warren    see the comment at the beginning of this file.
129*e8debf39SStephen Warren    """
130e5bb279fSStephen Warren
131e5bb279fSStephen Warren    if not net_set_up:
132e5bb279fSStephen Warren        pytest.skip("Network not initialized")
133e5bb279fSStephen Warren
134e5bb279fSStephen Warren    f = u_boot_console.config.env.get('env__net_tftp_readable_file', None)
135e5bb279fSStephen Warren    if not f:
136e5bb279fSStephen Warren        pytest.skip('No TFTP readable file to read')
137e5bb279fSStephen Warren
138e5bb279fSStephen Warren    addr = u_boot_utils.find_ram_base(u_boot_console)
139e5bb279fSStephen Warren    fn = f['fn']
140e5bb279fSStephen Warren    output = u_boot_console.run_command('tftpboot %x %s' % (addr, fn))
141e5bb279fSStephen Warren    expected_text = 'Bytes transferred = '
142e5bb279fSStephen Warren    sz = f.get('size', None)
143e5bb279fSStephen Warren    if sz:
144e5bb279fSStephen Warren        expected_text += '%d' % sz
145e5bb279fSStephen Warren    assert expected_text in output
146e5bb279fSStephen Warren
147e5bb279fSStephen Warren    expected_crc = f.get('crc32', None)
148e5bb279fSStephen Warren    if not expected_crc:
149e5bb279fSStephen Warren        return
150e5bb279fSStephen Warren
151e5bb279fSStephen Warren    if u_boot_console.config.buildconfig.get('config_cmd_crc32', 'n') != 'y':
152e5bb279fSStephen Warren        return
153e5bb279fSStephen Warren
154e5bb279fSStephen Warren    output = u_boot_console.run_command('crc32 %x $filesize' % addr)
155e5bb279fSStephen Warren    assert expected_crc in output
156