1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/dist/pythonlibs/riotctrl_shell/tests/test_gnrc.py
Martine S. Lenders 667ba11732
riotctrl_shell.gnrc: fix some more ping6 parsing errors
Found during integration of release tests:

- if the payload is too small, RTTs are not shown
- duplicates are now shown properly, if duplicates exist, the stats are
  now parsed instead of ignored
2020-07-09 13:03:08 +02:00

119 lines
3.6 KiB
Python

# Copyright (C) 2020 Freie Universität Berlin
#
# This file is subject to the terms and conditions of the GNU Lesser
# General Public License v2.1. See the file LICENSE in the top level
# directory for more details.
import riotctrl_shell.gnrc
from .common import init_ctrl
def test_ping6():
rc = init_ctrl()
si = riotctrl_shell.gnrc.GNRCICMPv6Echo(rc)
res = si.ping6("::1", interval=100)
# mock just returns last input
assert "ping6" in res
assert " ::1 " in res
assert " -i 100 " in res
def test_ping6_parser_success1():
parser = riotctrl_shell.gnrc.GNRCICMPv6EchoParser()
ping_res = parser.parse("""
12 bytes from ::1: icmp_seq=0 ttl=64 time=0.435 ms
12 bytes from ::1: icmp_seq=1 ttl=64 time=0.433 ms
12 bytes from ::1: icmp_seq=2 ttl=64 time=0.432 ms
--- ::1 PING statistics ---
3 packets transmitted, 3 packets received, 0% packet loss
round-trip min/avg/max = 0.432/0.433/0.435 ms""")
assert ping_res
assert "rtts" in ping_res
assert "avg" in ping_res["rtts"]
def test_ping6_parser_success2():
parser = riotctrl_shell.gnrc.GNRCICMPv6EchoParser()
ping_res = parser.parse("""
12 bytes from ::1: icmp_seq=0 ttl=64
12 bytes from ::1: icmp_seq=1 ttl=64
12 bytes from ::1: icmp_seq=1 ttl=64 (DUP)
--- ::1 PING statistics ---
2 packets transmitted, 3 packets received, 1 duplicates, 0% packet loss
round-trip min/avg/max = 0.432/0.433/0.435 ms""")
assert ping_res
assert "rtts" in ping_res
assert "avg" in ping_res["rtts"]
assert len(ping_res["replies"]) == 3
assert ping_res["replies"][2]["dup"]
def test_ping6_parser_empty():
parser = riotctrl_shell.gnrc.GNRCICMPv6EchoParser()
ping_res = parser.parse("")
assert not ping_res
def test_ping6_parser_missing_rtts():
parser = riotctrl_shell.gnrc.GNRCICMPv6EchoParser()
ping_res = parser.parse("""
12 bytes from ::1: icmp_seq=0 ttl=64
12 bytes from ::1: icmp_seq=1 ttl=64
12 bytes from ::1: icmp_seq=2 ttl=64
--- ::1 PING statistics ---
3 packets transmitted, 3 packets received, 0% packet loss""")
assert ping_res
assert "rtts" not in ping_res
assert len(ping_res["replies"]) == 3
def test_pktbuf():
rc = init_ctrl()
si = riotctrl_shell.gnrc.GNRCPktbufStats(rc)
res = si.pktbuf_stats()
# mock just returns last input
assert res == "pktbuf"
def test_pktbuf_parser_success_empty():
parser = riotctrl_shell.gnrc.GNRCPktbufStatsParser()
pktbuf_res = parser.parse("""
packet buffer: first byte: 0x5660dce0, last byte: 0x5660fce0 (size: 8192)
position of last byte used: 1792
~ unused: 0x5660dce0 (next: (nil), size: 8192) ~""")
assert pktbuf_res is not None
assert pktbuf_res["first_byte"] > 0
assert "start" in pktbuf_res["first_unused"]
assert pktbuf_res.is_empty()
def test_pktbuf_parser_success_not_empty():
parser = riotctrl_shell.gnrc.GNRCPktbufStatsParser()
pktbuf_res = parser.parse("""
packet buffer: first byte: 0x5660dce0, last byte: 0x5660fce0 (size: 8192)
position of last byte used: 1792
~ unused: 0x5660de00 (next: (nil), size: 7904) ~""")
assert pktbuf_res is not None
assert pktbuf_res["first_byte"] > 0
assert "start" in pktbuf_res["first_unused"]
assert not pktbuf_res.is_empty()
def test_pktbuf_parser_empty():
parser = riotctrl_shell.gnrc.GNRCPktbufStatsParser()
pktbuf_res = parser.parse("")
assert pktbuf_res is None
def test_pktbuf_parser_2nd_header_not_found():
parser = riotctrl_shell.gnrc.GNRCPktbufStatsParser()
pktbuf_res = parser.parse(
"packet buffer: first byte: 0x5668ace0, last byte: 0x5668cce0 "
"(size: 8192)"
)
assert pktbuf_res is None