mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
example: use pytest-embedded to replace examples/system/console test scripts
This commit is contained in:
parent
3222b5c720
commit
ef685456ab
131
conftest.py
Normal file
131
conftest.py
Normal file
@ -0,0 +1,131 @@
|
|||||||
|
# SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
# pylint: disable=W0621
|
||||||
|
|
||||||
|
# This file is a pytest root configuration file and provide the following functionalities:
|
||||||
|
# 1. Defines a few fixtures that could be used under the whole project.
|
||||||
|
# 2. Defines a few hook functions.
|
||||||
|
#
|
||||||
|
# IDF is using [pytest](https://github.com/pytest-dev/pytest) and
|
||||||
|
# [pytest-embedded plugin](https://github.com/espressif/pytest-embedded) as its example test framework.
|
||||||
|
#
|
||||||
|
# This is an experimental feature, and if you found any bug or have any question, please report to
|
||||||
|
# https://github.com/espressif/pytest-embedded/issues
|
||||||
|
|
||||||
|
import logging
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
from typing import List, Optional
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
from _pytest.config import Config
|
||||||
|
from _pytest.fixtures import FixtureRequest
|
||||||
|
from pytest_embedded.plugin import parse_configuration
|
||||||
|
|
||||||
|
|
||||||
|
def _is_target_marker(marker: str) -> bool:
|
||||||
|
if marker.startswith('esp32'):
|
||||||
|
return True
|
||||||
|
|
||||||
|
if marker.startswith('esp8'):
|
||||||
|
return True
|
||||||
|
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope='session')
|
||||||
|
def target_markers(pytestconfig: Config) -> List[str]:
|
||||||
|
res = []
|
||||||
|
for item in pytestconfig.getini('markers'):
|
||||||
|
marker = item.split(':')[0]
|
||||||
|
if _is_target_marker(marker):
|
||||||
|
res.append(marker)
|
||||||
|
return res
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope='session')
|
||||||
|
def env_markers(pytestconfig: Config) -> List[str]:
|
||||||
|
res = []
|
||||||
|
for item in pytestconfig.getini('markers'):
|
||||||
|
marker = item.split(':')[0]
|
||||||
|
if not marker.startswith('esp32'):
|
||||||
|
res.append(marker)
|
||||||
|
return res
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope='session')
|
||||||
|
def param_markers(pytestconfig: Config) -> List[str]:
|
||||||
|
res: List[str] = []
|
||||||
|
offset = -1
|
||||||
|
while True:
|
||||||
|
try:
|
||||||
|
offset = pytestconfig.invocation_params.args.index('-m', offset + 1)
|
||||||
|
except ValueError:
|
||||||
|
return res
|
||||||
|
res.append(pytestconfig.invocation_params.args[offset + 1]) # we want the marker after '-m'
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def target(request: FixtureRequest, target_markers: List[str], param_markers: List[str]) -> Optional[str]:
|
||||||
|
param_target_markers = [marker for marker in param_markers if marker in target_markers]
|
||||||
|
if len(param_target_markers) > 1:
|
||||||
|
raise ValueError('Please only specify one target marker at the same time')
|
||||||
|
elif len(param_target_markers) == 0:
|
||||||
|
target = None
|
||||||
|
else:
|
||||||
|
target = param_target_markers[0]
|
||||||
|
|
||||||
|
return getattr(request, 'param', None) or target
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def config(request: FixtureRequest) -> Optional[str]:
|
||||||
|
return getattr(request, 'param', None) or request.config.option.__dict__.get('config') or None
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
@parse_configuration
|
||||||
|
def build_dir(request: FixtureRequest, app_path: str, target: Optional[str], config: Optional[str]) -> str:
|
||||||
|
"""
|
||||||
|
Check local build dir with the following priority:
|
||||||
|
|
||||||
|
1. build_<target>_<config>
|
||||||
|
2. build_<target>
|
||||||
|
3. build_<config>
|
||||||
|
4. build
|
||||||
|
|
||||||
|
Args:
|
||||||
|
request: pytest fixture
|
||||||
|
app_path: app path
|
||||||
|
target: target
|
||||||
|
config: config
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
valid build directory
|
||||||
|
"""
|
||||||
|
param_or_cli: str = getattr(request, 'param', None) or request.config.option.__dict__.get('build_dir')
|
||||||
|
if param_or_cli is not None: # respect the parametrize and the cli
|
||||||
|
return param_or_cli
|
||||||
|
|
||||||
|
check_dirs = []
|
||||||
|
if target is not None and config is not None:
|
||||||
|
check_dirs.append(f'build_{target}_{config}')
|
||||||
|
if target is not None:
|
||||||
|
check_dirs.append(f'build_{target}')
|
||||||
|
if config is not None:
|
||||||
|
check_dirs.append(f'build_{config}')
|
||||||
|
check_dirs.append('build')
|
||||||
|
|
||||||
|
for check_dir in check_dirs:
|
||||||
|
binary_path = os.path.join(app_path, check_dir)
|
||||||
|
if os.path.isdir(binary_path):
|
||||||
|
logging.info(f'find valid binary path: {binary_path}')
|
||||||
|
return check_dir
|
||||||
|
|
||||||
|
logging.warning(f'checking binary path: {binary_path}... missing... try another place')
|
||||||
|
|
||||||
|
recommend_place = check_dirs[0]
|
||||||
|
logging.error(
|
||||||
|
f'no build dir valid. Please build the binary via "idf.py -B {recommend_place} build" and run pytest again')
|
||||||
|
sys.exit(1)
|
@ -1,22 +0,0 @@
|
|||||||
# type: ignore
|
|
||||||
from __future__ import print_function
|
|
||||||
|
|
||||||
import ttfw_idf
|
|
||||||
|
|
||||||
|
|
||||||
@ttfw_idf.idf_example_test(env_tag='Example_GENERIC', target=['esp32', 'esp32c3'])
|
|
||||||
def test_examples_system_console_advanced(env, _):
|
|
||||||
dut = env.get_dut('console_example', 'examples/system/console/advanced', app_config_name='history')
|
|
||||||
print('Using binary path: {}'.format(dut.app.binary_path))
|
|
||||||
dut.start_app()
|
|
||||||
dut.expect('Command history enabled')
|
|
||||||
env.close_dut(dut.name)
|
|
||||||
|
|
||||||
dut = env.get_dut('console_example', 'examples/system/console/advanced', app_config_name='nohistory')
|
|
||||||
print('Using binary path: {}'.format(dut.app.binary_path))
|
|
||||||
dut.start_app()
|
|
||||||
dut.expect('Command history disabled')
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
test_examples_system_console_advanced()
|
|
18
examples/system/console/advanced/pytest_console_advanced.py
Normal file
18
examples/system/console/advanced/pytest_console_advanced.py
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
|
||||||
|
# SPDX-License-Identifier: CC0-1.0
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.esp32
|
||||||
|
@pytest.mark.esp32c3
|
||||||
|
@pytest.mark.generic
|
||||||
|
@pytest.mark.parametrize('config', [
|
||||||
|
'history',
|
||||||
|
'nohistory',
|
||||||
|
], indirect=True)
|
||||||
|
def test_console_advanced(config, dut): # type: ignore
|
||||||
|
if config == 'history':
|
||||||
|
dut.expect('Command history enabled')
|
||||||
|
elif config == 'nohistory':
|
||||||
|
dut.expect('Command history disabled')
|
@ -1,22 +0,0 @@
|
|||||||
# type: ignore
|
|
||||||
from __future__ import print_function
|
|
||||||
|
|
||||||
import ttfw_idf
|
|
||||||
|
|
||||||
|
|
||||||
@ttfw_idf.idf_example_test(env_tag='Example_GENERIC', target=['esp32', 'esp32c3'])
|
|
||||||
def test_examples_system_console_basic(env, _):
|
|
||||||
dut = env.get_dut('console_example', 'examples/system/console/basic', app_config_name='history')
|
|
||||||
print('Using binary path: {}'.format(dut.app.binary_path))
|
|
||||||
dut.start_app()
|
|
||||||
dut.expect('Command history enabled')
|
|
||||||
env.close_dut(dut.name)
|
|
||||||
|
|
||||||
dut = env.get_dut('console_example', 'examples/system/console/basic', app_config_name='nohistory')
|
|
||||||
print('Using binary path: {}'.format(dut.app.binary_path))
|
|
||||||
dut.start_app()
|
|
||||||
dut.expect('Command history disabled')
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
test_examples_system_console_basic()
|
|
18
examples/system/console/basic/pytest_console_basic.py
Normal file
18
examples/system/console/basic/pytest_console_basic.py
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
|
||||||
|
# SPDX-License-Identifier: CC0-1.0
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.esp32
|
||||||
|
@pytest.mark.esp32c3
|
||||||
|
@pytest.mark.generic
|
||||||
|
@pytest.mark.parametrize('config', [
|
||||||
|
'history',
|
||||||
|
'nohistory',
|
||||||
|
], indirect=True)
|
||||||
|
def test_console_advanced(config, dut): # type: ignore
|
||||||
|
if config == 'history':
|
||||||
|
dut.expect('Command history enabled')
|
||||||
|
elif config == 'nohistory':
|
||||||
|
dut.expect('Command history disabled')
|
17
pytest.ini
Normal file
17
pytest.ini
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
[pytest]
|
||||||
|
# only the files with prefix `pytest_` would be recognized as pytest test scripts.
|
||||||
|
python_files = pytest_*.py
|
||||||
|
|
||||||
|
addopts = --embedded-services esp,idf
|
||||||
|
|
||||||
|
markers =
|
||||||
|
esp32: support esp32 target
|
||||||
|
esp32c3: support esp32c3 target
|
||||||
|
generic: tests should be run on generic runners
|
||||||
|
|
||||||
|
# log related
|
||||||
|
log_auto_indent = True
|
||||||
|
log_cli = True
|
||||||
|
log_cli_level = INFO
|
||||||
|
log_cli_format = %(asctime)s %(levelname)s %(message)s
|
||||||
|
log_cli_date_format = %Y-%m-%d %H:%M:%S
|
Loading…
x
Reference in New Issue
Block a user