chmod +x ${SUBF}
cat > ${SUBF} <<- EOF
#!/bin/bash -e
+ set -x
while true; do
if strings screenlog.0 | grep -m 1 "\${1}"; then
exit 0
sleep 0.5s
done
EOF
+ cat ${SUBF}
timeout -k 3s ${T} ${SUBF} "${1}"
local RES=$?
rm -f ${SUBF}
sudo apt-get install -y screen
screen --version | grep 'Screen version'
fi
+if ! timeout --version; then
+ # Install coreutils for the timeout command
+ sudo apt-get update -qq -y
+ sudo apt-get install -y coreutils
+ timeout --version
+fi
# Initial cleanup
-pkill 'screen' || true
+pkill -f 'SCREEN -L -S sonemu' || true
screen -wipe || true
rm -f screenlog.0
# Start containernet with a topology
-screen -L -S sonemu -d -m python src/emuvim/examples/simple_topology.py
+screen -L -S sonemu -d -m sudo python src/emuvim/examples/simple_topology.py
# Setup screen for immediate flusing
screen -S sonemu -X logfile flush 0
# Wait for the cli to start
-W '^*** Starting CLI:'
+W '^*** Starting CLI:' 60s
# Print nodes
Cmd 'nodes'
# Start vnf1
son-emu-cli compute list && sleep 1s
# Gather some infos
Cmd 'sh echo "... starting various checks"'
-sync # avoid test overlapping
+sync # avoid text overlapping
Cmd 'vnf1 ifconfig && echo "... checked vnf1"'
W "^... checked vnf1"
Cmd 'vnf2 ifconfig && echo "... checked vnf2"'