stress_isolcpus=${first}-${last}
echo "Stress tool runs on $stress_isolcpus"
+#Host for executing test cases based on test_type/job from releng
+function setHostIP {
+ test_type=$1
+ if [ ${test_type} == "verify" ];then
+ HOST_IP="10.10.100.21"
+ elif [ ${test_type} == "daily" ];then
+ HOST_IP="10.10.100.22"
+ else
+ echo "Incorrect test type"
+ fi
+ echo ${HOST_IP}
+}
+
+#Time duration for executing test cases based on test_type/job from releng
+function setTestTime {
+ test_type=$1
+ if [ ${test_type} == "verify" ];then
+ test_time=1000 # 1s
+ elif [ ${test_type} == "daily" ];then
+ test_time=3600000 # 1hr
+ else
+ echo "Incorrect test type"
+ fi
+ echo ${test_time}
+}
+
#Tar the log files generated during testcase execution and exit.
function test_exit {
exitCode=$1
# figure out log file name
LOG_SUBDIR="OvsDpdkVhost"
LOG_FILE="${LOG_FILE_PREFIX}_${LOG_SUBDIR}_${DATE_SUFFIX}.log"
- echo " $VSPERF_BIN $OPNFVPOD --vswitch OvsDpdkVhost --vnf QemuDpdkVhostUser $CONF_FILE $TESTPARAM $TESTCASES > $LOG_FILE"
- echo "daily test cases started"
cd $HOME/vswitchperf
$VSPERF_BIN --list
+ echo "daily test cases started"
+ echo " $VSPERF_BIN --vswitch OvsDpdkVhost --vnf QemuDpdkVhostUser $CONF_FILE $TESTPARAM $TESTCASES > $LOG_FILE"
$VSPERF_BIN --vswitch OvsDpdkVhost --vnf QemuDpdkVhostUser $CONF_FILE $TESTPARAM $TESTCASES &>> $LOG_FILE
;;
esac
# copy logs into dedicated directory
mkdir -p ${TEST_REPORT_LOG_DIR}/${LOG_SUBDIR}
- [ -f "$LOG_FILE" ] && cp -a "${LOG_FILE}" "${TEST_REPORT_LOG_DIR}/${LOG_SUBDIR}" &> /dev/null
- [ -d "$RES_DIR" ] && cp -ar "$RES_DIR" "${TEST_REPORT_LOG_DIR}/${LOG_SUBDIR}" &> /dev/null
+ [ -f "$LOG_FILE" ] && mv "${LOG_FILE}" "${TEST_REPORT_LOG_DIR}/${LOG_SUBDIR}" &> /dev/null
+ [ -d "$RES_DIR" ] && mv "$RES_DIR" "${TEST_REPORT_LOG_DIR}/${LOG_SUBDIR}" &> /dev/null
}
#Install vsperf and set up the environment
# execute job based on passed parameter
case $1 in
"daily")
- echo "================"
- echo "VSPERF daily job"
- echo "================"
+ echo "========================================================"
+ echo "KVM4NFV daily job executing packet forwarding test cases"
+ echo "========================================================"
execute_vsperf OVS_with_DPDK_and_vHost_User $1
execute_vsperf SRIOV $1
exit $EXIT
fi
}
+function getTestParams {
+ HOST_IP=$( setHostIP $test_type )
+ test_time=$( setTestTime $test_type )
+}
+
function cyclictest {
test_case=$1
source $WORKSPACE/ci/cyclicTestTrigger.sh $HOST_IP $test_time $test_type $test_case
echo "Terminating PCM Process"
sudo ssh root@${HOST_IP} "pid=\$(ps aux | grep 'pcm' | awk '{print \$2}' | head -1); echo \$pid |xargs kill -SIGTERM"
}
+#Collecting the Memory Bandwidth Information using pcm-memory utility
function collect_MBWInfo {
- #Collecting the Memory Bandwidth Information using pcm-memory utility
- source $WORKSPACE/ci/envs/host-config
testType=$1
timeStamp=$(date +%Y%m%d%H%M%S)
echo "Running PCM memory to collect memory bandwidth"
sudo ssh root@${HOST_IP} "${pcm_memory} 60 &>/root/MBWInfo/MBWInfo_${testType}_${timeStamp} &disown"
}
function install_pcm {
- source $WORKSPACE/ci/envs/host-config
sudo ssh root@${HOST_IP} '
modelName=`cat /proc/cpuinfo | grep -i "model name" | uniq`
if echo "$modelName" | grep -i "xeon" ;then
#Execution of testcases based on test type and test name from releng.
if [ ${test_type} == "verify" ];then
- HOST_IP="10.10.100.21"
- test_time=1000 # 1s
+ getTestParams
install_pcm
if [ ${ftrace_enable} -eq '1' ]; then
for env in ${cyclictest_env_verify[@]}
test_exit 0
fi
elif [ ${test_type} == "daily" ];then
- HOST_IP="10.10.100.22"
- test_time=3600000 #1h
+ getTestParams
install_pcm
if [ ${test_name} == "packet_forward" ];then
packetForward
sed -i '/host-setup1.sh/a\ \- \"enable-trace.sh\"' kvmfornfv_cyclictest_hostenv_guestenv.yaml
#Executing cyclictest through yardstick.
cyclictest ${env}
- #disabling ftrace and collecting the logs to upload to artifact repository.
+ #disabling ftrace and collecting the logs to upload to artifact repository.
ftrace_disable
sleep 5
done