1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/tests/gnrc_dhcpv6_client_stateless
2022-03-04 10:35:27 +01:00
..
tests-as-root tests: Add test for stateless DHCPv6 2021-10-04 21:41:49 +02:00
app.config tests: Add test for stateless DHCPv6 2021-10-04 21:41:49 +02:00
main.c tests: Add test for stateless DHCPv6 2021-10-04 21:41:49 +02:00
Makefile tests/gnrc_dhcpv6_client_stateless: use netdev_default 2022-03-04 10:35:27 +01:00
Makefile.board.dep tests: Add test for stateless DHCPv6 2021-10-04 21:41:49 +02:00
Makefile.ci boards/calliope-mini: add nrf51 common dependencies 2021-11-26 08:48:23 +01:00
README.md tests: Add test for stateless DHCPv6 2021-10-04 21:41:49 +02:00
test-graph.svg tests: Add test for stateless DHCPv6 2021-10-04 21:41:49 +02:00

gnrc_dhcpv6_client_stateless test

This test utilizes scapy to test the DHCPv6 client configuration for stateless DHCP.

The protocol procedure is modelled using a scapy Automaton by first waiting for an NDP Router Solicitation (RS) which is replied to with an NDP Router Advertisement (RA). The RA contains a set O-bit which indicates that additional information can be acquired by sending a DHCPv6 Information Request (IR). The Automaton now waits for an IR, expects it to contain a number of options, and sends a DHCPv6 Reply back to the client. After this procedure is completed, a check for a correctly assigned global IP address (from the RA using SLAAC) is performed. If this final assertion is correct, the test succeeds.

The procedure is visualized in the following graph:

Visualization of the test procedure as a graph.

To test, compile and flash the application to any board of your liking (since ethos is used to communicate with non-native boards it really doesn't matter as long as the application fits).

make flash

And run the tests using

sudo make test-as-root

Note that root privileges are required since scapy needs to construct Ethernet frames to properly communicate over the TAP interface.

The test succeeds if you see the string SUCCESS.

If any problems are encountered (i.e. if the test prints the string FAILED), set the echo parameter in the run() function at the bottom of the test script (tests-as-root/01-run.py) to True. The test script will then offer a more detailed output.