1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/tests/gnrc_tcp
Martine Lenders 26a1348a9a
Merge pull request #12867 from fjmolinas/pr_tests_no_reset_dep
tests: adapt tests so they can use `tests_utils_interactive_sync`
2019-12-12 15:47:21 +01:00
..
tests tests: expect match \r\n or \s 2019-11-27 14:12:12 +01:00
main.c gnrc_tcp_recv: immediatly return on closed connection 2019-10-22 20:12:38 +02:00
Makefile Merge pull request #12867 from fjmolinas/pr_tests_no_reset_dep 2019-12-12 15:47:21 +01:00
Makefile.board.dep tests/gnrc_tcp: move board specific deps in Makefile.board.dep 2019-12-06 21:19:35 +01:00
Makefile.ci boards/derfmega*: initial support 2019-11-27 20:53:14 +01:00
README.md gnrc_tcp_recv: immediatly return on closed connection 2019-10-22 20:12:38 +02:00

Test description

The entire GNRC TCP test consists of several test cases. Each test is ran via its own python script in the tests directory.

  1. 01-conn_lifecycle_as_client.py This test covers TCP connection establishment and teardown with GNRC_TCP acting as tcp client.

  2. 02-conn_lifecycle_as_server.py This test covers TCP connection establishment and teardown with GNRC_TCP acting as tcp server.

  3. 03-send_data.py This test covers sending of a byte stream from GNRC_TCP to the host system. The amount of data to send is large enough to force GNRC_TCP to split the given stream into multiple packets.

  4. 04-receive_data.py This test covers receiving of a byte stream from the host system. The received data is causing window opening and closing as well as data transmission over multiple packets.

  5. 05-garbage-pkts.py This test mostly is a regression test for issues that were found through fuzzing. It uses scapy to interact with the node.

  6. 06-receive_data_closed_conn.py This test covers accessing received data after receiving a FIN packet. If the connection was closed by the peer, a call to gnrc_tcp_recv must return directly with all currently received data or zero if there is no data. The function must return immediatly dispite any given timeout.

Setup

The test requires a tap-device setup. This can be achieved by running 'dist/tools/tapsetup/tapsetup' or by executing the following commands:

sudo ip tuntap add tap0 mode tap user ${USER}
sudo ip link set tap0 up

Usage

make BOARD=<BOARD_NAME> all flash
sudo make BOARD=<BOARD_NAME> test

'sudo' is required due to ethos and raw socket usage.