2022-06-15 16:46:55 +02:00
|
|
|
# SPDX-FileCopyrightText: 2015-2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
2017-10-10 10:44:55 +08:00
|
|
|
|
|
|
|
"""
|
|
|
|
class for handling Test Apps. Currently it provides the following features:
|
|
|
|
|
|
|
|
1. get SDK path
|
|
|
|
2. get SDK tools
|
|
|
|
3. parse application info from its path. for example:
|
|
|
|
* provide download info
|
|
|
|
* provide partition table info
|
|
|
|
|
|
|
|
Test Apps should inherent from BaseApp class and overwrite the methods.
|
|
|
|
"""
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import time
|
|
|
|
|
|
|
|
# timestamp used for calculate log folder name
|
|
|
|
LOG_FOLDER_TIMESTAMP = time.time()
|
|
|
|
|
|
|
|
|
|
|
|
class BaseApp(object):
|
|
|
|
"""
|
|
|
|
Base Class for App.
|
|
|
|
Defines the mandatory methods that App need to implement.
|
|
|
|
Also implements some common methods.
|
|
|
|
|
|
|
|
:param app_path: the path for app.
|
2019-10-15 14:15:06 +02:00
|
|
|
:param config_name: app configuration to be tested
|
|
|
|
:param target: build target
|
2017-10-10 10:44:55 +08:00
|
|
|
"""
|
|
|
|
|
2019-10-15 14:15:06 +02:00
|
|
|
def __init__(self, app_path, config_name=None, target=None):
|
2017-10-10 10:44:55 +08:00
|
|
|
pass
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def get_sdk_path(cls):
|
|
|
|
"""
|
|
|
|
get sdk path.
|
|
|
|
|
|
|
|
subclass must overwrite this method.
|
|
|
|
|
|
|
|
:return: abs sdk path
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def get_tools(cls):
|
|
|
|
"""
|
|
|
|
get SDK related tools for applications
|
|
|
|
|
|
|
|
subclass must overwrite this method.
|
|
|
|
|
|
|
|
:return: tuple, abs path of each tool
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def get_log_folder(cls, test_suite_name):
|
|
|
|
"""
|
|
|
|
By default log folder is ``${SDK_PATH}/TEST_LOGS/${test_suite_name}_${timestamp}``.
|
|
|
|
|
|
|
|
The log folder name is consist once start running, ensure all logs of will be put into the same folder.
|
|
|
|
|
|
|
|
:param test_suite_name: the test suite name, by default it's the base file name for main module
|
|
|
|
:return: the log folder path
|
|
|
|
"""
|
|
|
|
if not test_suite_name:
|
|
|
|
test_suite_name = os.path.splitext(os.path.basename(sys.modules['__main__'].__file__))[0]
|
|
|
|
sdk_path = cls.get_sdk_path()
|
2021-01-26 10:49:01 +08:00
|
|
|
log_folder = os.path.join(sdk_path, 'TEST_LOGS',
|
2018-01-16 22:16:03 +08:00
|
|
|
test_suite_name +
|
2021-01-26 10:49:01 +08:00
|
|
|
time.strftime('_%m%d_%H_%M_%S', time.localtime(LOG_FOLDER_TIMESTAMP)))
|
2018-01-16 22:16:03 +08:00
|
|
|
if not os.path.exists(log_folder):
|
|
|
|
os.makedirs(log_folder)
|
|
|
|
return log_folder
|
2017-10-10 10:44:55 +08:00
|
|
|
|
|
|
|
def process_app_info(self):
|
|
|
|
"""
|
|
|
|
parse built app info for DUTTool
|
|
|
|
|
|
|
|
subclass must overwrite this method.
|
|
|
|
|
|
|
|
:return: required info for specific DUTTool
|
|
|
|
"""
|
|
|
|
pass
|