test: add pytest_wifi_getting_started script

This commit is contained in:
Fu Hanxi 2022-05-07 12:18:56 +08:00
parent 511ccdcb70
commit 52b5a8348e
4 changed files with 60 additions and 4 deletions

View File

@ -111,6 +111,16 @@ example_test_pytest_esp32_flash_encryption:
TARGET: ESP32
ENV_MARKER: flash_encryption
example_test_pytest_esp32_multi_dut_generic:
extends:
- .pytest_examples_dir_template
- .rules:test:example_test-esp32
needs:
- build_pytest_examples_esp32
variables:
TARGET: ESP32
ENV_MARKER: multi_dut_generic
example_test_pytest_esp32c3_flash_encryption:
extends:
- .pytest_examples_dir_template

View File

@ -0,0 +1,42 @@
# SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
# SPDX-License-Identifier: CC0-1.0
import os.path
from typing import Tuple
import pytest
from pytest_embedded_idf.dut import IdfDut
# @pytest.mark.supported_targets
# This test should support all targets, even between different target types
# For now our CI only support multi dut with esp32
# If you want to enable different target type, please use the following param
# @pytest.mark.parametrize(
# 'count, app_path, target', [
# (2,
# f'{os.path.join(os.path.dirname(__file__), "softAP")}|{os.path.join(os.path.dirname(__file__), "station")}',
# 'esp32|esp32s2'),
# ],
# indirect=True,
# )
@pytest.mark.esp32
@pytest.mark.multi_dut_generic
@pytest.mark.parametrize(
'count, app_path', [
(2,
f'{os.path.join(os.path.dirname(__file__), "softAP")}|{os.path.join(os.path.dirname(__file__), "station")}'),
], indirect=True
)
def test_wifi_getting_started(dut: Tuple[IdfDut, IdfDut]) -> None:
softap = dut[0]
station = dut[1]
ssid = 'myssid'
password = 'mypassword'
tag = 'wifi station'
station.expect(f'{tag}: got ip:', timeout=60)
station.expect(f'{tag}: connected to ap SSID:{ssid} password:{password}', timeout=60)
softap.expect('station .+ join, AID=', timeout=60)

View File

@ -35,6 +35,9 @@ markers =
flash_encryption: Flash Encryption runners
ir_transceiver: runners with a pair of IR transmitter and receiver
## multi-dut markers
multi_dut_generic: tests should be run on generic runners, at least have two duts connected.
# log related
log_cli = True
log_cli_level = INFO

View File

@ -117,12 +117,13 @@ def is_in_directory(file_path: str, folder: str) -> bool:
def to_list(s: Any) -> List[Any]:
if isinstance(s, set) or isinstance(s, tuple):
if isinstance(s, (set, tuple)):
return list(s)
elif isinstance(s, list):
if isinstance(s, list):
return s
else:
return [s]
return [s]
@dataclass