example_test.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. from __future__ import print_function
  2. import ttfw_idf
  3. # Timer events
  4. TIMER_EVENT_LIMIT = 3
  5. TIMER_EXPIRY_HANDLING = 'TIMER_EVENTS:TIMER_EVENT_EXPIRY: timer_expiry_handler, executed {} out of ' + str(TIMER_EVENT_LIMIT) + ' times'
  6. # Task events
  7. TASK_ITERATION_LIMIT = 5
  8. TASK_UNREGISTRATION_LIMIT = 3
  9. TASK_ITERATION_POST = 'TASK_EVENTS:TASK_ITERATION_EVENT: posting to default loop, {} out of ' + str(TASK_ITERATION_LIMIT)
  10. TASK_ITERATION_HANDLING = 'TASK_EVENTS:TASK_ITERATION_EVENT: task_iteration_handler, executed {} times'
  11. def _test_timer_events(dut):
  12. dut.start_app()
  13. print('Checking timer events posting and handling')
  14. dut.expect('setting up')
  15. dut.expect('starting event sources')
  16. print('Finished setup')
  17. dut.expect('TIMER_EVENTS:TIMER_EVENT_STARTED: posting to default loop')
  18. print('Posted timer started event')
  19. dut.expect('TIMER_EVENTS:TIMER_EVENT_STARTED: timer_started_handler, instance 0')
  20. dut.expect('TIMER_EVENTS:TIMER_EVENT_STARTED: timer_started_handler, instance 1')
  21. dut.expect('TIMER_EVENTS:TIMER_EVENT_STARTED: timer_started_handler_2')
  22. dut.expect('TIMER_EVENTS:TIMER_EVENT_STARTED: timer_any_handler')
  23. dut.expect('TIMER_EVENTS:TIMER_EVENT_STARTED: all_event_handler')
  24. print('Handled timer started event')
  25. for expiries in range(1, TIMER_EVENT_LIMIT + 1):
  26. dut.expect('TIMER_EVENTS:TIMER_EVENT_EXPIRY: posting to default loop')
  27. print('Posted timer expiry event {} out of {}'.format(expiries, TIMER_EVENT_LIMIT))
  28. if expiries >= TIMER_EVENT_LIMIT:
  29. dut.expect('TIMER_EVENTS:TIMER_EVENT_STOPPED: posting to default loop')
  30. print('Posted timer stopped event')
  31. dut.expect(TIMER_EXPIRY_HANDLING.format(expiries))
  32. dut.expect('TIMER_EVENTS:TIMER_EVENT_EXPIRY: timer_any_handler')
  33. dut.expect('TIMER_EVENTS:TIMER_EVENT_EXPIRY: all_event_handler')
  34. print('Handled timer expiry event {} out of {}'.format(expiries, TIMER_EVENT_LIMIT))
  35. dut.expect('TIMER_EVENTS:TIMER_EVENT_STOPPED: timer_stopped_handler')
  36. dut.expect('TIMER_EVENTS:TIMER_EVENT_STOPPED: deleted timer event source')
  37. print('Handled timer stopped event')
  38. def _test_iteration_events(dut):
  39. dut.start_app()
  40. print('Checking iteration events posting and handling')
  41. dut.expect('setting up')
  42. dut.expect('starting event sources')
  43. print('Finished setup')
  44. for iteration in range(1, TASK_ITERATION_LIMIT + 1):
  45. dut.expect(TASK_ITERATION_POST.format(iteration))
  46. print('Posted iteration {} out of {}'.format(iteration, TASK_ITERATION_LIMIT))
  47. if iteration < TASK_UNREGISTRATION_LIMIT:
  48. dut.expect(TASK_ITERATION_HANDLING.format(iteration))
  49. dut.expect('TASK_EVENTS:TASK_ITERATION_EVENT: all_event_handler')
  50. elif iteration == TASK_UNREGISTRATION_LIMIT:
  51. dut.expect_all('TASK_EVENTS:TASK_ITERATION_EVENT: unregistering task_iteration_handler',
  52. 'TASK_EVENTS:TASK_ITERATION_EVENT: all_event_handler')
  53. print('Unregistered handler at iteration {} out of {}'.format(iteration, TASK_ITERATION_LIMIT))
  54. else:
  55. dut.expect('TASK_EVENTS:TASK_ITERATION_EVENT: all_event_handler')
  56. print('Handled iteration {} out of {}'.format(iteration, TASK_ITERATION_LIMIT))
  57. dut.expect('TASK_EVENTS:TASK_ITERATION_EVENT: deleting task event source')
  58. print('Deleted task event source')
  59. @ttfw_idf.idf_example_test(env_tag='Example_GENERIC', target=['esp32', 'esp32c3'])
  60. def test_default_event_loop_example(env, extra_data):
  61. dut = env.get_dut('default_event_loop', 'examples/system/esp_event/default_event_loop')
  62. _test_iteration_events(dut)
  63. _test_timer_events(dut)
  64. if __name__ == '__main__':
  65. test_default_event_loop_example()