Merge branch 'ci/enable_ip101_jobs_v5.2' into 'release/v5.2'

ci(esp_eth): enabled Ethernet ip101 jobs (v5.2)

See merge request espressif/esp-idf!28613
This commit is contained in:
Jiang Jiang Jian 2024-02-19 11:02:42 +08:00
commit 6bfe219bb1
4 changed files with 24 additions and 3 deletions

View File

@ -463,6 +463,15 @@ pytest_examples_esp32_ethernet_vlan:
artifacts: false artifacts: false
tags: [ esp32, ethernet_vlan ] tags: [ esp32, ethernet_vlan ]
pytest_examples_esp32_ethernet_ip101:
extends:
- .pytest_examples_dir_template
- .rules:test:example_test-esp32
needs:
- job: build_pytest_examples_esp32
artifacts: false
tags: [ esp32, eth_ip101 ]
pytest_examples_esp32_ethernet_bridge: pytest_examples_esp32_ethernet_bridge:
extends: extends:
- .pytest_examples_dir_template - .pytest_examples_dir_template
@ -715,6 +724,15 @@ pytest_components_esp32_sdio:
artifacts: false artifacts: false
tags: [ esp32, sdio_master_slave ] tags: [ esp32, sdio_master_slave ]
pytest_components_esp32_ip101:
extends:
- .pytest_components_dir_template
- .rules:test:component_ut-esp32
needs:
- job: build_pytest_components_esp32
artifacts: false
tags: [ esp32, eth_ip101 ]
pytest_components_esp32_lan8720: pytest_components_esp32_lan8720:
extends: extends:
- .pytest_components_dir_template - .pytest_components_dir_template

View File

@ -24,6 +24,7 @@ class EthTestIntf(object):
def find_target_if(self, my_if: str = '') -> None: def find_target_if(self, my_if: str = '') -> None:
# try to determine which interface to use # try to determine which interface to use
netifs = os.listdir('/sys/class/net/') netifs = os.listdir('/sys/class/net/')
# order matters - ETH NIC with the highest number is connected to DUT on CI runner
netifs.sort(reverse=True) netifs.sort(reverse=True)
logging.info('detected interfaces: %s', str(netifs)) logging.info('detected interfaces: %s', str(netifs))
@ -203,7 +204,7 @@ def test_esp_emac_hal(dut: IdfDut) -> None:
@pytest.mark.esp32 @pytest.mark.esp32
@pytest.mark.ip101 @pytest.mark.eth_ip101
@pytest.mark.parametrize('config', [ @pytest.mark.parametrize('config', [
'default_ip101', 'default_ip101',
], indirect=True) ], indirect=True)

View File

@ -22,6 +22,8 @@ def configure_eth_if(eth_type: int, target_if: str='') -> Iterator[socket.socket
if target_if == '': if target_if == '':
# try to determine which interface to use # try to determine which interface to use
netifs = os.listdir('/sys/class/net/') netifs = os.listdir('/sys/class/net/')
# order matters - ETH NIC with the highest number is connected to DUT on CI runner
netifs.sort(reverse=True)
logging.info('detected interfaces: %s', str(netifs)) logging.info('detected interfaces: %s', str(netifs))
for netif in netifs: for netif in netifs:
if netif.find('eth') == 0 or netif.find('enx') == 0 or netif.find('enp') == 0 or netif.find('eno') == 0: if netif.find('eth') == 0 or netif.find('enx') == 0 or netif.find('enp') == 0 or netif.find('eno') == 0:
@ -100,7 +102,7 @@ def actual_test(dut: Dut) -> None:
@pytest.mark.esp32 # internally tested using ESP32 with IP101 but may support all targets with SPI Ethernet @pytest.mark.esp32 # internally tested using ESP32 with IP101 but may support all targets with SPI Ethernet
@pytest.mark.ip101 @pytest.mark.eth_ip101
@pytest.mark.flaky(reruns=3, reruns_delay=5) @pytest.mark.flaky(reruns=3, reruns_delay=5)
def test_esp_netif_l2tap_example(dut: Dut) -> None: def test_esp_netif_l2tap_example(dut: Dut) -> None:
actual_test(dut) actual_test(dut)

View File

@ -42,7 +42,7 @@ ENV_MARKERS = {
# single-dut markers # single-dut markers
'generic': 'tests should be run on generic runners', 'generic': 'tests should be run on generic runners',
'flash_suspend': 'support flash suspend feature', 'flash_suspend': 'support flash suspend feature',
'ip101': 'connected via wired 10/100M ethernet', 'eth_ip101': 'connected via wired 10/100M ethernet',
'eth_lan8720': 'connected via LAN8720 ethernet transceiver', 'eth_lan8720': 'connected via LAN8720 ethernet transceiver',
'eth_rtl8201': 'connected via RTL8201 ethernet transceiver', 'eth_rtl8201': 'connected via RTL8201 ethernet transceiver',
'eth_ksz8041': 'connected via KSZ8041 ethernet transceiver', 'eth_ksz8041': 'connected via KSZ8041 ethernet transceiver',