example_test.py 1.1 KB

123456789101112131415161718192021222324252627282930313233
  1. import re
  2. import os
  3. import ttfw_idf
  4. @ttfw_idf.idf_example_test(env_tag="Example_WIFI", ignore=True)
  5. def test_examples_protocol_websocket(env, extra_data):
  6. """
  7. steps: |
  8. 1. join AP
  9. 2. connect to ws://echo.websocket.org
  10. 3. send and receive data
  11. """
  12. dut1 = env.get_dut("websocket", "examples/protocols/websocket", dut_class=ttfw_idf.ESP32DUT)
  13. # check and log bin size
  14. binary_file = os.path.join(dut1.app.binary_path, "websocket-example.bin")
  15. bin_size = os.path.getsize(binary_file)
  16. ttfw_idf.log_performance("websocket_bin_size", "{}KB".format(bin_size // 1024))
  17. ttfw_idf.check_performance("websocket_bin_size", bin_size // 1024)
  18. # start test
  19. dut1.start_app()
  20. dut1.expect("Waiting for wifi ...")
  21. dut1.expect("Connection established...", timeout=30)
  22. dut1.expect("WEBSOCKET_EVENT_CONNECTED")
  23. for i in range(0, 10):
  24. dut1.expect(re.compile(r"Sending hello (\d)"))
  25. dut1.expect(re.compile(r"Received=hello (\d)"))
  26. dut1.expect("Websocket Stopped")
  27. if __name__ == '__main__':
  28. test_examples_protocol_websocket()