app_test.py 1.1 KB

123456789101112131415161718192021222324252627282930313233
  1. #!/usr/bin/env python
  2. import glob
  3. import os
  4. import re
  5. import ttfw_idf
  6. from tiny_test_fw import Utility
  7. from ttfw_idf.IDFDUT import ESP32DUT
  8. @ttfw_idf.idf_custom_test(env_tag='Example_GENERIC', group='test-apps')
  9. def test_startup(env, extra_data):
  10. config_files = glob.glob(os.path.join(os.path.dirname(__file__), 'sdkconfig.ci.*'))
  11. config_names = [os.path.basename(s).replace('sdkconfig.ci.', '') for s in config_files]
  12. for name in config_names:
  13. Utility.console_log("Checking config \"{}\"... ".format(name), end='')
  14. dut = env.get_dut('startup', 'tools/test_apps/system/startup', app_config_name=name)
  15. dut.start_app()
  16. if (name == 'single_core_variant' and isinstance(dut, ESP32DUT)):
  17. dut.allow_dut_exception = True
  18. dut.expect('Running on single core variant of a chip, but app is built with multi-core support.')
  19. dut.expect(re.compile(r'abort\(\) was called at PC [0-9xa-f]+ on core 0'))
  20. else:
  21. dut.expect('app_main running')
  22. env.close_dut(dut.name)
  23. Utility.console_log('done')
  24. if __name__ == '__main__':
  25. test_startup()