mirror of
https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
synced 2025-10-31 18:58:01 +00:00
gui-automation: Add serial-console and other logging.
The openwrt_ctl.py program can do some basic commands and console logging on OpenWrt and LANforge Linux systems. Add some more log gathering logic to the basic_regression.bash script.
This commit is contained in:
@@ -11,6 +11,14 @@
|
|||||||
#
|
#
|
||||||
#
|
#
|
||||||
|
|
||||||
|
# Disable stdout buffering in python so that we get serial console log
|
||||||
|
# output promptly.
|
||||||
|
PYTHONUNBUFFERED=1
|
||||||
|
export PYTHONUNBUFFERED
|
||||||
|
|
||||||
|
AP_SERIAL=${AP_SERIAL:-NONE}
|
||||||
|
LF_SERIAL=${LF_SERIAL:-NONE}
|
||||||
|
LFPASSWD=${LFPASSWD:-lanforge} # Root password on LANforge machine
|
||||||
AP_AUTO_CFG_FILE=${AP_AUTO_CFG_FILE:-test_configs/AP-Auto-ap-auto-32-64-dual.txt}
|
AP_AUTO_CFG_FILE=${AP_AUTO_CFG_FILE:-test_configs/AP-Auto-ap-auto-32-64-dual.txt}
|
||||||
WCT_CFG_FILE=${WCT_CFG_FILE:-test_configs/WCT-64sta.txt}
|
WCT_CFG_FILE=${WCT_CFG_FILE:-test_configs/WCT-64sta.txt}
|
||||||
DPT_CFG_FILE=${DPT_CFG_FILE:-test_configs/dpt-pkt-sz.txt}
|
DPT_CFG_FILE=${DPT_CFG_FILE:-test_configs/dpt-pkt-sz.txt}
|
||||||
@@ -66,7 +74,7 @@ RSLTS_DIR=${RSLTS_DIR:-basic_regression_results_$DATESTR}
|
|||||||
AP_AUTO_CFG=ben
|
AP_AUTO_CFG=ben
|
||||||
WCT_CFG=ben
|
WCT_CFG=ben
|
||||||
DPT_CFG=ben
|
DPT_CFG=ben
|
||||||
SCENARIO=64sta
|
SCENARIO=tip-auto
|
||||||
RPT_TMPDIR=${MY_TMPDIR}/lf_reports
|
RPT_TMPDIR=${MY_TMPDIR}/lf_reports
|
||||||
|
|
||||||
# Query DUT from the scenario
|
# Query DUT from the scenario
|
||||||
@@ -74,9 +82,61 @@ DUT=`grep DUT: $SCENARIO_CFG_FILE |head -1|grep -o "DUT: .*"|cut -f2 -d ' '`
|
|||||||
|
|
||||||
echo "Found DUT: $DUT from scenario $SCENARIO_CFG_FILE"
|
echo "Found DUT: $DUT from scenario $SCENARIO_CFG_FILE"
|
||||||
|
|
||||||
mkdir -p $RSLTS_DIR
|
function pre_test {
|
||||||
|
# Clean logs, this bounces radios and such too as side effect
|
||||||
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --cmd "cli admin clean_logs"
|
||||||
|
|
||||||
|
if [ "_${LF_SERIAL}" != "_NONE" ]
|
||||||
|
then
|
||||||
|
# Kill any existing processes on this serial port
|
||||||
|
pkill -f ".*openwrt_ctl.*$LF_SERIAL.*"
|
||||||
|
../openwrt_ctl.py --action lurk --tty $LF_SERIAL --scheme serial --user root --passwd $LFPASSWD --prompt "\[root@" > $MY_TMPDIR/lanforge_console_log.txt 2>&1 &
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "_${AP_SERIAL}" != "_NONE" ]
|
||||||
|
then
|
||||||
|
# Kill any existing processes on this serial port
|
||||||
|
pkill -f ".*openwrt_ctl.*$AP_SERIAL.*"
|
||||||
|
../openwrt_ctl.py --action logread --tty $AP_SERIAL --scheme serial > $MY_TMPDIR/dut_console_log.txt 2>&1 &
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function post_test {
|
||||||
|
DEST=$1
|
||||||
|
mkdir -p $DEST/logs
|
||||||
|
|
||||||
|
if [ "_${LF_SERIAL}" != "_NONE" ]
|
||||||
|
then
|
||||||
|
# Kill any existing processes on this serial port
|
||||||
|
pkill -f ".*openwrt_ctl.*$LF_SERIAL.*"
|
||||||
|
mv $MY_TMPDIR/lanforge_console_log.txt $DEST/logs/
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "_${AP_SERIAL}" != "_NONE" ]
|
||||||
|
then
|
||||||
|
# Kill any existing processes on this serial port
|
||||||
|
pkill -f ".*openwrt_ctl.*$AP_SERIAL.*"
|
||||||
|
mv $MY_TMPDIR/dut_console_log.txt $DEST/logs/
|
||||||
|
fi
|
||||||
|
|
||||||
|
mv $MY_TMPDIR/basic_regression_log.txt $DEST/logs/test_automation_log.txt
|
||||||
|
if [ -f /home/lanforge/lanforge_log_0.txt ]
|
||||||
|
then
|
||||||
|
# Must be running on LF itself
|
||||||
|
cp /home/lanforge/lanforge_log_*.txt* $DEST/logs/
|
||||||
|
cp /home/lanforge/wifi/*log* $DEST/logs/
|
||||||
|
else
|
||||||
|
# Try via scp. Root perms needed to read wifi logs, thus root@
|
||||||
|
scp root@$LFMANAGER:/home/lanforge/lanforge_log_*.txt* $DEST/logs/
|
||||||
|
scp root@$LFMANAGER:/home/lanforge/wifi/*log* $DEST/logs/
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
set -x
|
set -x
|
||||||
|
|
||||||
|
mkdir -p $RSLTS_DIR
|
||||||
|
|
||||||
# Load scenario file
|
# Load scenario file
|
||||||
../lf_testmod.pl --mgr $LFMANAGER --action set --test_type Network-Connectivity --test_name $SCENARIO --file $SCENARIO_CFG_FILE
|
../lf_testmod.pl --mgr $LFMANAGER --action set --test_type Network-Connectivity --test_name $SCENARIO --file $SCENARIO_CFG_FILE
|
||||||
|
|
||||||
@@ -101,7 +161,7 @@ fi
|
|||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --cmd "cli show_dut"
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --cmd "cli show_dut"
|
||||||
|
|
||||||
# Pause to let GUI finish getting data from the server
|
# Pause to let GUI finish getting data from the server
|
||||||
sleep 10
|
sleep 20
|
||||||
|
|
||||||
# Tell GUI to load and build the scenario
|
# Tell GUI to load and build the scenario
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --scenario $SCENARIO
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --scenario $SCENARIO
|
||||||
@@ -117,19 +177,21 @@ fi
|
|||||||
echo "Checking if we should run Dataplane packet size test."
|
echo "Checking if we should run Dataplane packet size test."
|
||||||
if [ "_$DO_DPT_PKT_SZ" == "_1" ]
|
if [ "_$DO_DPT_PKT_SZ" == "_1" ]
|
||||||
then
|
then
|
||||||
|
pre_test
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "Dataplane" --tname dpt-ben --tconfig $DPT_CFG \
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "Dataplane" --tname dpt-ben --tconfig $DPT_CFG \
|
||||||
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
||||||
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
||||||
--modifier_key "Show Low-Level Graphs" --modifier_val true \
|
--modifier_key "Show Low-Level Graphs" --modifier_val true \
|
||||||
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
||||||
mv $RPT_TMPDIR/* $RSLTS_DIR/dataplane_pkt_sz
|
mv $RPT_TMPDIR/* $RSLTS_DIR/dataplane_pkt_sz
|
||||||
mv $MY_TMPDIR/basic_regression_log.txt $RSLTS_DIR/dataplane_pkt_sz/test_automation.txt
|
post_test $RSLTS_DIR/dataplane_pkt_sz
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Do capacity test
|
# Do capacity test
|
||||||
echo "Checking if we should run WCT Download test."
|
echo "Checking if we should run WCT Download test."
|
||||||
if [ "_$DO_WCT_DL" == "_1" ]
|
if [ "_$DO_WCT_DL" == "_1" ]
|
||||||
then
|
then
|
||||||
|
pre_test
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "WiFi Capacity" --tname wct-ben --tconfig $WCT_CFG \
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "WiFi Capacity" --tname wct-ben --tconfig $WCT_CFG \
|
||||||
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
||||||
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
||||||
@@ -137,12 +199,13 @@ then
|
|||||||
--modifier_key "RATE_UL" --modifier_val "0" \
|
--modifier_key "RATE_UL" --modifier_val "0" \
|
||||||
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
||||||
mv $RPT_TMPDIR/* $RSLTS_DIR/wifi_capacity_dl
|
mv $RPT_TMPDIR/* $RSLTS_DIR/wifi_capacity_dl
|
||||||
mv $MY_TMPDIR/basic_regression_log.txt $RSLTS_DIR/wifi_capacity_dl/test_automation.txt
|
post_test $RSLTS_DIR/wifi_capacity_dl
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Checking if we should run WCT Upload test."
|
echo "Checking if we should run WCT Upload test."
|
||||||
if [ "_$DO_WCT_UL" == "_1" ]
|
if [ "_$DO_WCT_UL" == "_1" ]
|
||||||
then
|
then
|
||||||
|
pre_test
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "WiFi Capacity" --tname wct-ben --tconfig $WCT_CFG \
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "WiFi Capacity" --tname wct-ben --tconfig $WCT_CFG \
|
||||||
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
||||||
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
||||||
@@ -150,12 +213,13 @@ then
|
|||||||
--modifier_key "RATE_DL" --modifier_val "0" \
|
--modifier_key "RATE_DL" --modifier_val "0" \
|
||||||
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
||||||
mv $RPT_TMPDIR/* $RSLTS_DIR/wifi_capacity_ul
|
mv $RPT_TMPDIR/* $RSLTS_DIR/wifi_capacity_ul
|
||||||
mv $MY_TMPDIR/basic_regression_log.txt $RSLTS_DIR/wifi_capacity_ul/test_automation.txt
|
post_test $RSLTS_DIR/wifi_capacity_ul
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Checking if we should run WCT Bi-Direction test."
|
echo "Checking if we should run WCT Bi-Direction test."
|
||||||
if [ "_$DO_WCT_BI" == "_1" ]
|
if [ "_$DO_WCT_BI" == "_1" ]
|
||||||
then
|
then
|
||||||
|
pre_test
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "WiFi Capacity" --tname wct-ben --tconfig $WCT_CFG \
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "WiFi Capacity" --tname wct-ben --tconfig $WCT_CFG \
|
||||||
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
||||||
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
||||||
@@ -164,7 +228,7 @@ then
|
|||||||
--modifier_key "Protocol:" --modifier_val "TCP-IPv4" \
|
--modifier_key "Protocol:" --modifier_val "TCP-IPv4" \
|
||||||
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
||||||
mv $RPT_TMPDIR/* $RSLTS_DIR/wifi_capacity_bi
|
mv $RPT_TMPDIR/* $RSLTS_DIR/wifi_capacity_bi
|
||||||
mv $MY_TMPDIR/basic_regression_log.txt $RSLTS_DIR/wifi_capacity_bi/test_automation.txt
|
post_test $RSLTS_DIR/wifi_capacity_bi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
@@ -172,12 +236,13 @@ fi
|
|||||||
echo "Checking if we should run Short-AP Basic CX test."
|
echo "Checking if we should run Short-AP Basic CX test."
|
||||||
if [ "_$DO_SHORT_AP_BASIC_CX" == "_1" ]
|
if [ "_$DO_SHORT_AP_BASIC_CX" == "_1" ]
|
||||||
then
|
then
|
||||||
|
pre_test
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
||||||
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
||||||
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
||||||
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
||||||
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_basic_cx
|
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_basic_cx
|
||||||
mv $MY_TMPDIR/basic_regression_log.txt $RSLTS_DIR/ap_auto_basic_cx/test_automation.txt
|
post_test $RSLTS_DIR/ap_auto_basic_cx
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Run Throughput, Dual-Band, Capacity test in a row, the Capacity will use results from earlier
|
# Run Throughput, Dual-Band, Capacity test in a row, the Capacity will use results from earlier
|
||||||
@@ -185,6 +250,7 @@ fi
|
|||||||
echo "Checking if we should run Short-AP Throughput test."
|
echo "Checking if we should run Short-AP Throughput test."
|
||||||
if [ "_$DO_SHORT_AP_TPUT" == "_1" ]
|
if [ "_$DO_SHORT_AP_TPUT" == "_1" ]
|
||||||
then
|
then
|
||||||
|
pre_test
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
||||||
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
||||||
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
||||||
@@ -194,13 +260,14 @@ then
|
|||||||
--modifier_key "Capacity" --modifier_val true \
|
--modifier_key "Capacity" --modifier_val true \
|
||||||
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
||||||
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_capacity
|
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_capacity
|
||||||
mv $MY_TMPDIR/basic_regression_log.txt $RSLTS_DIR/ap_auto_capacity/test_automation.txt
|
post_test $RSLTS_DIR/ap_auto_capacity
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Run Stability test (single port resets, voip, tcp, udp)
|
# Run Stability test (single port resets, voip, tcp, udp)
|
||||||
echo "Checking if we should run Short-AP Stability Reset test."
|
echo "Checking if we should run Short-AP Stability Reset test."
|
||||||
if [ "_$DO_SHORT_AP_STABILITY_RESET" == "_1" ]
|
if [ "_$DO_SHORT_AP_STABILITY_RESET" == "_1" ]
|
||||||
then
|
then
|
||||||
|
pre_test
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
||||||
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
||||||
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
||||||
@@ -209,13 +276,14 @@ then
|
|||||||
--modifier_key "Stability Duration:" --modifier_val $STABILITY_DURATION \
|
--modifier_key "Stability Duration:" --modifier_val $STABILITY_DURATION \
|
||||||
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
||||||
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_stability_reset_ports
|
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_stability_reset_ports
|
||||||
mv $MY_TMPDIR/basic_regression_log.txt $RSLTS_DIR/ap_auto_stability_reset_ports/test_automation.txt
|
post_test $RSLTS_DIR/ap_auto_stability_reset_ports
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Run Stability test (radio resets, voip, tcp, udp)
|
# Run Stability test (radio resets, voip, tcp, udp)
|
||||||
echo "Checking if we should run Short-AP Stability Radio Reset test."
|
echo "Checking if we should run Short-AP Stability Radio Reset test."
|
||||||
if [ "_$DO_SHORT_AP_STABILITY_RADIO_RESET" == "_1" ]
|
if [ "_$DO_SHORT_AP_STABILITY_RADIO_RESET" == "_1" ]
|
||||||
then
|
then
|
||||||
|
pre_test
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
||||||
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
||||||
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
||||||
@@ -225,13 +293,14 @@ then
|
|||||||
--modifier_key "Reset Radios" --modifier_val true \
|
--modifier_key "Reset Radios" --modifier_val true \
|
||||||
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
||||||
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_stability_reset_radios
|
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_stability_reset_radios
|
||||||
mv $MY_TMPDIR/basic_regression_log.txt $RSLTS_DIR/ap_auto_stability_reset_radios/test_automation.txt
|
post_test $RSLTS_DIR/ap_auto_stability_reset_radios
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Run Stability test (no resets, no voip, tcp, udp)
|
# Run Stability test (no resets, no voip, tcp, udp)
|
||||||
echo "Checking if we should run Short-AP Stability No-Reset test."
|
echo "Checking if we should run Short-AP Stability No-Reset test."
|
||||||
if [ "_$DO_SHORT_AP_STABILITY_NO_RESET" == "_1" ]
|
if [ "_$DO_SHORT_AP_STABILITY_NO_RESET" == "_1" ]
|
||||||
then
|
then
|
||||||
|
pre_test
|
||||||
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
../lf_gui_cmd.pl --manager $GMANAGER --port $GMPORT --ttype "AP-Auto" --tname ap-auto-ben --tconfig $AP_AUTO_CFG \
|
||||||
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
--modifier_key "Test Rig ID:" --modifier_val "$TEST_RIG_ID" \
|
||||||
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
--modifier_key "DUT_NAME" --modifier_val "$DUT" \
|
||||||
@@ -242,7 +311,18 @@ then
|
|||||||
--modifier_key "Concurrent Ports To Reset:" --modifier_val 0 \
|
--modifier_key "Concurrent Ports To Reset:" --modifier_val 0 \
|
||||||
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
--rpt_dest $RPT_TMPDIR > $MY_TMPDIR/basic_regression_log.txt 2>&1
|
||||||
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_stability_no_reset
|
mv $RPT_TMPDIR/* $RSLTS_DIR/ap_auto_stability_no_reset
|
||||||
mv $MY_TMPDIR/basic_regression_log.txt $RSLTS_DIR/ap_auto_stability_no_reset/test_automation.txt
|
post_test $RSLTS_DIR/ap_auto_stability_no_reset
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "_${LFLOG_PID}" != "_" ]
|
||||||
|
then
|
||||||
|
kill $LFLOG_PID
|
||||||
|
mv $MY_TMPDIR/lanforge_console_log.txt $RSLTS_DIR/
|
||||||
|
fi
|
||||||
|
if [ "_${DUTLOG_PID}" != "_" ]
|
||||||
|
then
|
||||||
|
kill $DUTLOG_PID
|
||||||
|
mv $MY_TMPDIR/dut_console_log.txt $RSLTS_DIR/
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Done with regression test."
|
echo "Done with regression test."
|
||||||
|
|||||||
256
openwrt_ctl.py
Executable file
256
openwrt_ctl.py
Executable file
@@ -0,0 +1,256 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
'''
|
||||||
|
|
||||||
|
make sure pexpect is installed:
|
||||||
|
$ sudo yum install python3-pexpect
|
||||||
|
|
||||||
|
You might need to install pexpect-serial using pip:
|
||||||
|
$ pip3 install pexpect-serial
|
||||||
|
|
||||||
|
./openwrt_ctl.py -l stdout -u root -p TIP -s serial --tty ttyUSB0
|
||||||
|
'''
|
||||||
|
|
||||||
|
|
||||||
|
import sys
|
||||||
|
if sys.version_info[0] != 3:
|
||||||
|
print("This script requires Python 3")
|
||||||
|
exit()
|
||||||
|
|
||||||
|
import re
|
||||||
|
import logging
|
||||||
|
import time
|
||||||
|
from time import sleep
|
||||||
|
import pprint
|
||||||
|
import telnetlib
|
||||||
|
import argparse
|
||||||
|
import pexpect
|
||||||
|
|
||||||
|
default_host = "localhost"
|
||||||
|
default_ports = {
|
||||||
|
"serial": None,
|
||||||
|
"ssh": 22,
|
||||||
|
"telnet": 23
|
||||||
|
}
|
||||||
|
NL = "\n"
|
||||||
|
CR = "\r\n"
|
||||||
|
Q = '"'
|
||||||
|
A = "'"
|
||||||
|
FORMAT = '%(asctime)s %(name)s %(levelname)s: %(message)s'
|
||||||
|
prompt = "root@OpenWrt:"
|
||||||
|
|
||||||
|
def usage():
|
||||||
|
print("$0 used connect to OpenWrt AP or similar Linux machine:")
|
||||||
|
print("-d|--dest IP address of the OpenWrt AP, for ssh/telnet scheme")
|
||||||
|
print("-o|--port IP port of the OpenWrt AP, for ssh/telnet scheme")
|
||||||
|
print("-t|--tty Serial port, if using serial scheme")
|
||||||
|
print("-u|--user login name")
|
||||||
|
print("-p|--pass password")
|
||||||
|
print("--prompt Prompt to look for when commands are done (default: root@OpenWrt)")
|
||||||
|
print("-s|--scheme (serial|telnet|ssh): connect via serial, ssh or telnet")
|
||||||
|
print("-l|--log file log messages here")
|
||||||
|
print("--action (logread | journalctl | lurk | reboot | cmd")
|
||||||
|
print("--value (option to help complete the action")
|
||||||
|
print("-h|--help")
|
||||||
|
|
||||||
|
# see https://stackoverflow.com/a/13306095/11014343
|
||||||
|
class FileAdapter(object):
|
||||||
|
def __init__(self, logger):
|
||||||
|
self.logger = logger
|
||||||
|
def write(self, data):
|
||||||
|
# NOTE: data can be a partial line, multiple lines
|
||||||
|
data = data.strip() # ignore leading/trailing whitespace
|
||||||
|
if data: # non-blank
|
||||||
|
self.logger.info(data)
|
||||||
|
def flush(self):
|
||||||
|
pass # leave it to logging to flush properly
|
||||||
|
|
||||||
|
def main():
|
||||||
|
global prompt
|
||||||
|
|
||||||
|
parser = argparse.ArgumentParser(description="OpenWrt AP Control Script")
|
||||||
|
parser.add_argument("-d", "--dest", type=str, help="address of the cisco controller")
|
||||||
|
parser.add_argument("-o", "--port", type=int, help="control port on the controller")
|
||||||
|
parser.add_argument("-u", "--user", type=str, help="credential login/username")
|
||||||
|
parser.add_argument("-p", "--passwd", type=str, help="credential password")
|
||||||
|
parser.add_argument("-P", "--prompt", type=str, help="Prompt to look for")
|
||||||
|
parser.add_argument("-s", "--scheme", type=str, choices=["serial", "ssh", "telnet"], help="Connect via serial, ssh or telnet")
|
||||||
|
parser.add_argument("-t", "--tty", type=str, help="tty serial device")
|
||||||
|
parser.add_argument("-l", "--log", type=str, help="logfile for messages, stdout means output to console")
|
||||||
|
parser.add_argument("--action", type=str, help="perform action",
|
||||||
|
choices=["logread", "journalctl", "lurk", "reboot", "cmd" ])
|
||||||
|
parser.add_argument("--value", type=str, help="set value")
|
||||||
|
tty = None
|
||||||
|
|
||||||
|
args = None
|
||||||
|
try:
|
||||||
|
args = parser.parse_args()
|
||||||
|
host = args.dest
|
||||||
|
scheme = args.scheme
|
||||||
|
port = args.port
|
||||||
|
#port = (default_ports[scheme], args.port)[args.port != None]
|
||||||
|
user = args.user
|
||||||
|
passwd = args.passwd
|
||||||
|
logfile = args.log
|
||||||
|
tty = args.tty;
|
||||||
|
if (args.prompt != None):
|
||||||
|
prompt = args.prompt
|
||||||
|
filehandler = None
|
||||||
|
except Exception as e:
|
||||||
|
logging.exception(e);
|
||||||
|
usage()
|
||||||
|
exit(2);
|
||||||
|
|
||||||
|
console_handler = logging.StreamHandler()
|
||||||
|
formatter = logging.Formatter(FORMAT)
|
||||||
|
logg = logging.getLogger(__name__)
|
||||||
|
logg.setLevel(logging.DEBUG)
|
||||||
|
file_handler = None
|
||||||
|
if (logfile is not None):
|
||||||
|
if (logfile != "stdout"):
|
||||||
|
file_handler = logging.FileHandler(logfile, "w")
|
||||||
|
file_handler.setLevel(logging.DEBUG)
|
||||||
|
file_handler.setFormatter(formatter)
|
||||||
|
logg.addHandler(file_handler)
|
||||||
|
logging.basicConfig(format=FORMAT, handlers=[file_handler])
|
||||||
|
else:
|
||||||
|
# stdout logging
|
||||||
|
logging.basicConfig(format=FORMAT, handlers=[console_handler])
|
||||||
|
|
||||||
|
CCPROMPT=prompt
|
||||||
|
|
||||||
|
ser = None
|
||||||
|
egg = None # think "eggpect"
|
||||||
|
try:
|
||||||
|
if (scheme == "serial"):
|
||||||
|
#eggspect = pexpect.fdpexpect.fdspan(telcon, logfile=sys.stdout.buffer)
|
||||||
|
import serial
|
||||||
|
from pexpect_serial import SerialSpawn
|
||||||
|
ser = serial.Serial(tty, 115200, timeout=5)
|
||||||
|
|
||||||
|
egg = SerialSpawn(ser);
|
||||||
|
egg.logfile = FileAdapter(logg)
|
||||||
|
egg.sendline(NL)
|
||||||
|
try:
|
||||||
|
i = egg.expect([prompt, "Please pres Enter to activate", "login:"], timeout=3)
|
||||||
|
if (i == 2):
|
||||||
|
egg.sendline(user)
|
||||||
|
egg.expect("Password:")
|
||||||
|
egg.sendline(passwd)
|
||||||
|
egg.expect(prompt)
|
||||||
|
|
||||||
|
egg.sendline(NL)
|
||||||
|
except Exception as e:
|
||||||
|
# maybe something like 'logread -f' is running?
|
||||||
|
# send ctrl-c
|
||||||
|
egg.send(chr(3))
|
||||||
|
|
||||||
|
elif (scheme == "ssh"):
|
||||||
|
# Not implemented/tested currently. --Ben
|
||||||
|
if (port is None):
|
||||||
|
port = 22
|
||||||
|
cmd = "ssh -p%d %s@%s"%(port, user, host)
|
||||||
|
logg.info("Spawn: "+cmd+NL)
|
||||||
|
egg = pexpect.spawn(cmd)
|
||||||
|
#egg.logfile_read = sys.stdout.buffer
|
||||||
|
egg.logfile = FileAdapter(logg)
|
||||||
|
i = egg.expect(["password:", "continue connecting (yes/no)?"], timeout=3)
|
||||||
|
time.sleep(0.1)
|
||||||
|
if i == 1:
|
||||||
|
egg.sendline('yes')
|
||||||
|
egg.expect('password:')
|
||||||
|
sleep(0.1)
|
||||||
|
egg.sendline(passwd)
|
||||||
|
|
||||||
|
elif (scheme == "telnet"):
|
||||||
|
# Not implemented/tested currently. --Ben
|
||||||
|
if (port is None):
|
||||||
|
port = 23
|
||||||
|
cmd = "telnet %s %d"%(host, port)
|
||||||
|
logg.info("Spawn: "+cmd+NL)
|
||||||
|
egg = pexpect.spawn(cmd)
|
||||||
|
egg.logfile = FileAdapter(logg)
|
||||||
|
time.sleep(0.1)
|
||||||
|
egg.sendline(' ')
|
||||||
|
egg.expect('User\:')
|
||||||
|
egg.sendline(user)
|
||||||
|
egg.expect('Password\:')
|
||||||
|
egg.sendline(passwd)
|
||||||
|
egg.sendline('config paging disable')
|
||||||
|
else:
|
||||||
|
usage()
|
||||||
|
exit(1)
|
||||||
|
except Exception as e:
|
||||||
|
logging.exception(e);
|
||||||
|
|
||||||
|
command = None
|
||||||
|
|
||||||
|
CLOSEDBYREMOTE = "closed by remote host."
|
||||||
|
CLOSEDCX = "Connection to .* closed."
|
||||||
|
|
||||||
|
egg.expect(CCPROMPT)
|
||||||
|
TO=10
|
||||||
|
wait_forever = False
|
||||||
|
|
||||||
|
# Clean pending output
|
||||||
|
egg.sendline("echo __hello__")
|
||||||
|
egg.expect("__hello__")
|
||||||
|
egg.expect(CCPROMPT)
|
||||||
|
|
||||||
|
logg.info("Action[%s] Value[%s] "%(args.action, args.value))
|
||||||
|
|
||||||
|
if (args.action == "reboot"):
|
||||||
|
command = "reboot"
|
||||||
|
TO=60
|
||||||
|
|
||||||
|
if (args.action == "cmd"):
|
||||||
|
if (args.value is None):
|
||||||
|
raise Exception("cmd requires value to be set.")
|
||||||
|
command = "%s"%(args.value)
|
||||||
|
|
||||||
|
if (args.action == "logread"):
|
||||||
|
command = "logread -f"
|
||||||
|
TO=1
|
||||||
|
wait_forever = True
|
||||||
|
|
||||||
|
if (args.action == "journalctl"):
|
||||||
|
command = "journalctl -f"
|
||||||
|
TO=1
|
||||||
|
wait_forever = True
|
||||||
|
|
||||||
|
if (args.action == "lurk"):
|
||||||
|
command = "date"
|
||||||
|
TO=1
|
||||||
|
wait_forever = True
|
||||||
|
|
||||||
|
if (command is None):
|
||||||
|
logg.info("No command specified, going to log out.")
|
||||||
|
else:
|
||||||
|
logg.info("Command[%s]"%command)
|
||||||
|
egg.sendline(command);
|
||||||
|
while True:
|
||||||
|
try:
|
||||||
|
i = egg.expect([CCPROMPT, "kmodloader: done loading kernel", "\n"], timeout=TO)
|
||||||
|
print (egg.before.decode('utf-8', 'ignore'))
|
||||||
|
if i == 1:
|
||||||
|
egg.sendline(' ')
|
||||||
|
egg.expect(CCPROMPT, timeout=20)
|
||||||
|
print (egg.before.decode('utf-8', 'ignore'))
|
||||||
|
if i == 2: # new line of text, just print and continue
|
||||||
|
continue
|
||||||
|
|
||||||
|
if not wait_forever:
|
||||||
|
break
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
# Some commands take a long time (logread -f)
|
||||||
|
if not wait_forever:
|
||||||
|
logging.exception(e)
|
||||||
|
break
|
||||||
|
|
||||||
|
# ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- -----
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
||||||
|
|
||||||
|
####
|
||||||
|
####
|
||||||
|
####
|
||||||
Reference in New Issue
Block a user