example_test.py 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. import re
  2. import os
  3. import sys
  4. import IDF
  5. from IDF.IDFDUT import ESP32DUT
  6. # this is a test case write with tiny-test-fw.
  7. # to run test cases outside tiny-test-fw,
  8. # we need to set environment variable `TEST_FW_PATH`,
  9. # then get and insert `TEST_FW_PATH` to sys path before import FW module
  10. test_fw_path = os.getenv("TEST_FW_PATH")
  11. if test_fw_path and test_fw_path not in sys.path:
  12. sys.path.insert(0, test_fw_path)
  13. @IDF.idf_example_test(env_tag="Example_WIFI", ignore=True)
  14. def test_examples_protocol_websocket(env, extra_data):
  15. """
  16. steps: |
  17. 1. join AP
  18. 2. connect to ws://echo.websocket.org
  19. 3. send and receive data
  20. """
  21. dut1 = env.get_dut("websocket", "examples/protocols/websocket", dut_class=ESP32DUT)
  22. # check and log bin size
  23. binary_file = os.path.join(dut1.app.binary_path, "websocket-example.bin")
  24. bin_size = os.path.getsize(binary_file)
  25. IDF.log_performance("websocket_bin_size", "{}KB".format(bin_size // 1024))
  26. IDF.check_performance("websocket_bin_size", bin_size // 1024)
  27. # start test
  28. dut1.start_app()
  29. dut1.expect("Waiting for wifi ...")
  30. dut1.expect("Connection established...", timeout=30)
  31. dut1.expect("WEBSOCKET_EVENT_CONNECTED")
  32. for i in range(0, 10):
  33. dut1.expect(re.compile(r"Sending hello (\d)"))
  34. dut1.expect(re.compile(r"Received=hello (\d)"))
  35. dut1.expect("Websocket Stopped")
  36. if __name__ == '__main__':
  37. test_examples_protocol_websocket()