2020-03-30 16:26:21 +02:00
|
|
|
import os
|
|
|
|
import shutil
|
|
|
|
import tempfile
|
2021-01-26 10:49:01 +08:00
|
|
|
from io import open
|
|
|
|
|
2020-03-30 16:26:21 +02:00
|
|
|
import ttfw_idf
|
|
|
|
|
|
|
|
try:
|
|
|
|
from itertools import izip_longest as zip_longest
|
|
|
|
except ImportError:
|
|
|
|
# Python 3
|
|
|
|
from itertools import zip_longest
|
|
|
|
|
|
|
|
|
2021-01-26 10:49:01 +08:00
|
|
|
@ttfw_idf.idf_example_test(env_tag='test_jtag_arm')
|
2020-03-30 16:26:21 +02:00
|
|
|
def test_examples_semihost_vfs(env, extra_data):
|
|
|
|
|
|
|
|
rel_project_path = os.path.join('examples', 'storage', 'semihost_vfs')
|
|
|
|
dut = env.get_dut('semihost_vfs', rel_project_path)
|
|
|
|
idf_path = dut.app.get_sdk_path()
|
|
|
|
proj_path = os.path.join(idf_path, rel_project_path)
|
|
|
|
host_file_name = 'host_file.txt'
|
|
|
|
|
|
|
|
try:
|
|
|
|
temp_dir = tempfile.mkdtemp()
|
|
|
|
host_file_path = os.path.join(proj_path, 'data', host_file_name)
|
|
|
|
shutil.copyfile(host_file_path, os.path.join(temp_dir, host_file_name))
|
2020-05-19 14:27:31 +02:00
|
|
|
cfg_cmds = ['set ESP_SEMIHOST_BASEDIR "{}"'.format(temp_dir)]
|
2020-03-30 16:26:21 +02:00
|
|
|
|
2020-05-19 14:27:31 +02:00
|
|
|
with ttfw_idf.OCDBackend(os.path.join(proj_path, 'openocd.log'), dut.app.target, cfg_cmds=cfg_cmds):
|
2020-03-30 16:26:21 +02:00
|
|
|
dut.start_app()
|
|
|
|
dut.expect_all('example: Switch to semihosted stdout',
|
|
|
|
'example: Switched back to UART stdout',
|
|
|
|
'example: Wrote 2798 bytes',
|
|
|
|
'====================== HOST DATA START =========================',
|
|
|
|
timeout=20)
|
|
|
|
with open(host_file_path) as f:
|
|
|
|
file_content = [line.strip() for line in f]
|
|
|
|
dut.expect_all(*file_content, timeout=20)
|
|
|
|
dut.expect_all('====================== HOST DATA END =========================',
|
|
|
|
'example: Read 6121 bytes',
|
|
|
|
timeout=5)
|
|
|
|
|
|
|
|
with open(os.path.join(temp_dir, 'esp32_stdout.txt')) as f:
|
|
|
|
def expected_content():
|
|
|
|
yield 'example: Switched to semihosted stdout'
|
|
|
|
for i in range(100):
|
|
|
|
yield 'Semihosted stdout write {}'.format(i)
|
|
|
|
yield 'example: Switch to UART stdout'
|
|
|
|
|
|
|
|
for actual, expected in zip_longest(f, expected_content(), fillvalue='-'):
|
|
|
|
if expected not in actual: # "in" used because of the printed ASCII color codes
|
|
|
|
raise RuntimeError('"{}" != "{}"'.format(expected, actual.strip()))
|
|
|
|
finally:
|
|
|
|
shutil.rmtree(temp_dir, ignore_errors=True)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
test_examples_semihost_vfs()
|