From 7b0c299afe07cf2043e5c98815a5b8a3c845321e Mon Sep 17 00:00:00 2001 From: Maska989 Date: Mon, 18 Sep 2023 12:17:04 +0200 Subject: [PATCH] linuxrc: psh: ping test JIRA: CI-326 --- psh/test-ping.py | 159 +++++++++++++++++++++++++++++++++++++++++++++++ psh/test.yaml | 116 ++++++++++++++++++---------------- 2 files changed, 221 insertions(+), 54 deletions(-) create mode 100644 psh/test-ping.py diff --git a/psh/test-ping.py b/psh/test-ping.py new file mode 100644 index 000000000..d30725377 --- /dev/null +++ b/psh/test-ping.py @@ -0,0 +1,159 @@ +# Phoenix-RTOS +# +# phoenix-rtos-tests +# +# ping command test +# +# Copyright 2023 Phoenix Systems +# Author: Damian Modzelewski +# +# This file is part of Phoenix-RTOS. +# +# %LICENSE% +# + +import psh.tools.psh as psh +import pexpect +import time + +GOOGLE_DNS = "8.8.8.8" +IP_LOOPBACK = "127.0.0.1" + + +def ping_output_regex(target, iteration): + iter_str = r"{" + str(iteration) + r"}" + + psh_output_regex = r"(([0-9]+[a-z\s]+ " + psh_output_regex += str(target) + psh_output_regex += r": ttl=[0-9]+ icmp_seq=[0-9]+ time=([0-9.]+) ms)" + psh_output_regex += f"{psh.EOL}){iter_str}" + + return psh_output_regex + + +def network_startup(p): + p.sendline("./etc/rc.d/network.sh") + psh_cmd = p.expect_exact(["(psh)% ", pexpect.TIMEOUT], timeout=10) + + if psh_cmd == 1: + raise AssertionError("network.sh Timeout!") + # wait for full load of network.sh + time.sleep(5) + + +def psh_ping_network_off(p): + # wait for last lwip log + time.sleep(5) + + psh.assert_cmd(p, f"ping {GOOGLE_DNS}", expected="ping: Fail to send a packet!", result="fail", is_regex=False) + + # self ping + psh.assert_cmd( + p, f"ping {IP_LOOPBACK}", expected=ping_output_regex(IP_LOOPBACK, 5), result="success", is_regex=True + ) + + +def psh_ping_help(p): + help = ( + "Usage: ping [options] address", + "Options", + " -h: prints help", + " -c: count, number of requests to be sent, default 5", + " -i: interval in milliseconds, minimum 200 ms, default 1000", + " -t: IP Time To Live, default 64", + " -s: payload size, default 56, maximum 2040", + " -W: socket timetout, default 2000", + "", + ) + psh.assert_cmd(p, "ping -h", expected=help, result="success", is_regex=False) + + +def psh_ping(p): + counter = 0 + + # google dns ping after linuxrc run (success) + psh.assert_cmd(p, f"ping {GOOGLE_DNS}", expected=ping_output_regex(GOOGLE_DNS, 5), result="success", is_regex=True) + + # find TTL route + for i in range(1, 10): + psh.assert_cmd( + p, + f"ping -t {i} {GOOGLE_DNS}", + expected=ping_output_regex(GOOGLE_DNS, 5) + "|Host timeout" + psh.EOL, + result="dont-check", + is_regex=True, + ) + + if psh.get_exit_code(p) == 0: + counter += 1 + + assert counter > 0 + + # long ping (ping tics are every second that's why timeout 50) + psh.assert_cmd( + p, + f"ping -c 50 {GOOGLE_DNS}", + expected=ping_output_regex(GOOGLE_DNS, 50), + result="success", + is_regex=True, + timeout=50, + ) + + # ping with long time to respond (IBM cloud name server). + ping_target = "67.228.254.4" + psh.assert_cmd( + p, f"ping {ping_target}", expected=ping_output_regex(ping_target, 5), result="success", is_regex=True + ) + + # ping max payload (truncated to 1480) + psh.assert_cmd( + p, f"ping -s 2000 {ping_target}", expected=ping_output_regex(ping_target, 5), result="success", is_regex=True + ) + + # ping min payload + psh.assert_cmd( + p, f"ping -i 200 {ping_target}", expected=ping_output_regex(ping_target, 5), result="success", is_regex=True + ) + + # ping max payload (Cloudflare DNS capable to hold payload) + ping_target = "1.0.0.1" + psh.assert_cmd( + p, f"ping -s 2000 {ping_target}", expected=ping_output_regex(ping_target, 5), result="success", is_regex=True + ) + + +def psh_ping_errors(p): + ping_target = "192.168.0.1" + psh.assert_cmd(p, f"ping {ping_target}", expected="Host timeout", result="fail", is_regex=False) + + # invalid ping target + ping_target = "" + psh.assert_cmd(p, f"ping -c 4 {ping_target}", expected="ping: Expected address!", result="fail", is_regex=False) + + # invalid ip + ping_target = "localhost" + psh.assert_cmd(p, f"ping {ping_target}", expected="ping: Invalid IP address!", result="fail", is_regex=False) + + # invalid ping count + psh.assert_cmd(p, f"ping -c -1 {GOOGLE_DNS}", expected="ping: Wrong count value!", result="fail", is_regex=False) + + # invalid ttl value + psh.assert_cmd(p, f"ping -t -1 {GOOGLE_DNS}", expected="ping: Wrong ttl value!", result="fail", is_regex=False) + + # invalid interval value + psh.assert_cmd(p, f"ping -i -1 {GOOGLE_DNS}", expected="ping: Wrong interval value!", result="fail", is_regex=False) + + # invalid timeout + psh.assert_cmd(p, f"ping -W -1 {GOOGLE_DNS}", expected="ping: Wrong timeout value!", result="fail", is_regex=False) + + # invlid_payload_len + psh.assert_cmd(p, f"ping -s 2041 {GOOGLE_DNS}", expected="ping: Wrong payload len", result="fail", is_regex=False) + + +@psh.run +def harness(p): + psh_ping_network_off(p) + psh_ping_help(p) + network_startup(p) + psh_ping(p) + psh_ping_errors(p) diff --git a/psh/test.yaml b/psh/test.yaml index 77dd628e7..d9072ed25 100644 --- a/psh/test.yaml +++ b/psh/test.yaml @@ -4,75 +4,83 @@ test: include: [riscv64-generic-qemu] tests: - - name: gibber - harness: test-gibber.py - # additional resources may be necessary for psh tests, especially on smaller syspage targets - # ensure no other binaries are loaded from the previous tests during the psh tests - reboot: True + # - name: gibber + # harness: test-gibber.py + # # additional resources may be necessary for psh tests, especially on smaller syspage targets + # # ensure no other binaries are loaded from the previous tests during the psh tests + # reboot: True - - name: auth - harness: test-auth.py + # - name: auth + # harness: test-auth.py - #FIXME - test-pshlogin.py is only for targets with root - - name: pshlogin - harness: test-pshlogin.py - targets: - exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] + # #FIXME - test-pshlogin.py is only for targets with root + # - name: pshlogin + # harness: test-pshlogin.py + # targets: + # exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] - - name: echo - harness: test-echo.py + # - name: echo + # harness: test-echo.py - - name: date - harness: test-date.py + # - name: date + # harness: test-date.py - - name: prompt - harness: test-prompt.py + # - name: prompt + # harness: test-prompt.py - - name: autocompletion - harness: test-autocompletion.py + # - name: autocompletion + # harness: test-autocompletion.py - - name: ps - harness: test-ps.py + # - name: ps + # harness: test-ps.py - - name: cat - harness: test-cat.py + # - name: cat + # harness: test-cat.py - - name: cat-shells - harness: test-cat-shells.py - targets: - exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] + # - name: cat-shells + # harness: test-cat-shells.py + # targets: + # exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] - - name: kill - harness: test-kill.py + # - name: kill + # harness: test-kill.py - - name: mkdir - harness: test-mkdir.py + # - name: mkdir + # harness: test-mkdir.py - - name: touch - # TODO touch of netsocket and pf fails... - harness: test-touch.py - ignore: True + # - name: touch + # # TODO touch of netsocket and pf fails... + # harness: test-touch.py + # ignore: True - - name: touch-rootfs - harness: test-touch-rootfs.py - # temporary disabled because of the following issue: https://github.com/phoenix-rtos/phoenix-rtos-project/issues/621 - ignore: true - targets: - exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] + # - name: touch-rootfs + # harness: test-touch-rootfs.py + # # temporary disabled because of the following issue: https://github.com/phoenix-rtos/phoenix-rtos-project/issues/621 + # ignore: true + # targets: + # exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] - - name: ls - harness: test-ls.py + # - name: ls + # harness: test-ls.py - - name: ls-rootfs - harness: test-ls-rootfs.py - targets: - exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] + # - name: ls-rootfs + # harness: test-ls-rootfs.py + # targets: + # exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] + + # - name: runfile + # harness: test-runfile.py + # targets: + # # runfile applet is not intended for non-rootfs targets + # exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] - - name: runfile - harness: test-runfile.py + # - name: history + # harness: test-history.py + + - name: ping + harness: test-ping.py + reboot: True + nightly: True targets: - # runfile applet is not intended for non-rootfs targets - exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo] + exclude: [armv7m7-imxrt106x-evk, armv7m7-imxrt117x-evk, armv7m4-stm32l4x6-nucleo, armv7a9-zynq7000-zedboard, armv7a9-zynq7000-qemu, ia32-generic-qemu] - - name: history - harness: test-history.py