esp-idf/examples/protocols/asio/chat_client
David Cermak 8d90156c07 asio: fix asio test code to start the test after ip address received from common example code
Previously set to wait until IP address got from tcpip_adapter, but since common example connect code blocks until both IP4 and IPv6 address received it could happen that test code might have started connection to the ASIO counter-part while ESP32 still waiting for IPv6 address
2019-11-14 12:12:15 +08:00
..
main examples: use new component registration api 2019-06-21 19:53:29 +08:00
asio_chat_client_test.py asio: fix asio test code to start the test after ip address received from common example code 2019-11-14 12:12:15 +08:00
CMakeLists.txt examples/protocols/asio: use common network component 2019-04-15 03:32:05 +00:00
Makefile examples/protocols/asio: use common network component 2019-04-15 03:32:05 +00:00
README.md examples: change default build instructions in docs to CMake 2019-08-06 17:25:25 +05:30
sdkconfig.defaults Rename Kconfig options (components/esp32) 2019-05-21 09:09:01 +02:00

Asio chat client example

Simple Asio chat client using WiFi STA or Ethernet.

Example workflow

  • Wi-Fi or Ethernet connection is established, and IP address is obtained.
  • Asio chat client connects to the corresponding server whose port number and IP are defined through the project configuration menu.
  • Chat client receives all messages from other chat clients, also it sends message received from stdin using idf.py -p PORT monitor.

Running the example

  • Open the project configuration menu (idf.py menuconfig) to configure Wi-Fi or Ethernet. See "Establishing Wi-Fi or Ethernet Connection" section in examples/protocols/README.md for more details.
  • Set server IP address and port number in menuconfig, "Example configuration".
  • Start chat server either on host machine or as another ESP device running chat_server example.
  • Run idf.py -p PORT flash monitor to build and upload the example to your board and connect to it's serial terminal.
  • Wait for the board to connect to WiFi or Ethernet.
  • Receive and send messages to/from other clients on stdin/stdout via serial terminal.

See the README.md file in the upper level 'examples' directory for more information about examples.