X-Git-Url: https://gerrit.opnfv.org/gerrit/gitweb?a=blobdiff_plain;f=ci%2Ftest_kvmfornfv.sh;h=6a6d70c42299ef2135d0130c33ed80e7adcdc17c;hb=ac6ed7c1037d6734a622bfe7f4bcb1bbac099ff0;hp=70961d74893e67a92348b5dde9b05e6ac4c4cf67;hpb=dc1629ad84bbc3df0f1d3aa7007c8f2d7237b601;p=kvmfornfv.git diff --git a/ci/test_kvmfornfv.sh b/ci/test_kvmfornfv.sh index 70961d748..6a6d70c42 100755 --- a/ci/test_kvmfornfv.sh +++ b/ci/test_kvmfornfv.sh @@ -1,12 +1,142 @@ #!/bin/bash -############################################################# -## !!! The original test_kvmfornfv.sh is removed because it -## break the verification process!!! -############################################################# -## This script will launch ubuntu docker container -## runs cyclictest through yardstick -## and verifies the test results. ############################################################ +## This script is an interface to trigger the +## cyclicTestTrigger.sh for test type like patch verification, +## daily testing. +## Releng will trigger this script by passing test type as +## verify/daily and test name as idle_idle/stress_idle/ +## packet_forward as arguments. +## Verify Job runs idle_idle,packet_forward test +## daily job runs base on the test name parameter +############################################################ + +test_type=$1 +test_name=$2 +ftrace_enable=0 +cyclictest_env_verify=("idle_idle" "cpustress_idle" "memorystress_idle" "iostress_idle") #cyclictest environment +cyclictest_env_daily=("idle_idle" "cpustress_idle" "memorystress_idle" "iostress_idle") +cyclictest_result=0 #exit code of cyclictest +packetforward_result=0 #exit code of packet forward +source $WORKSPACE/ci/envs/host-config + +function packetForward { +# source $WORKSPACE/ci/packet_forward_test.sh $HOST_IP + echo "Packetforwarding need to be implemented" + packetforward_result=$? + if [ ${packetforward_result} -ne 0 ];then + echo "Packet Forwarding test case execution FAILED" + else + echo "Packet Forwarding test case executed SUCCESSFULLY" + fi + host_clean +} + +function cyclictest { + test_case=$1 + source $WORKSPACE/ci/cyclicTestTrigger.sh $HOST_IP $test_time $test_type $test_case + #Verifying whether the test node is up and running + connect_host + #Waiting for ssh to be available for the host machine. + sleep 10 + #calculating and verifying sha512sum of the guestimage. + if ! verifyGuestImage;then + exit 1 + fi + #Update kvmfornfv_cyclictest_${testName}.yaml with test_time and pod.yaml with IP + updateYaml + #Cleaning up the test environment before running cyclictest through yardstick. + env_clean + #Creating a docker image with yardstick installed and launching ubuntu docker to run yardstick cyclic testcase + if runCyclicTest;then + cyclictest_result=`expr ${cyclictest_result} + 0` + else + echo "Test case execution FAILED for ${test_case} environment" + cyclictest_result=`expr ${cyclictest_result} + 1` + fi +} + +function ftrace_disable { + sudo ssh root@${HOST_IP} "sh /root/workspace/scripts/disbale-trace.sh" + sudo ssh root@${HOST_IP} "cd /tmp ; a=\$(ls -rt | tail -1) ; echo \$a ; mv \$a cyclictest_${env}.txt" + sudo mkdir -p $WORKSPACE/build_output/log/kernel_trace + sudo scp root@${HOST_IP}:/tmp/cyclictest_${env}.txt $WORKSPACE/build_output/log/kernel_trace/ +} -echo "Hello world" +#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=120000 # 2m + if [ ${ftrace_enable} -eq '1' ]; then + for env in ${cyclictest_env_verify[@]} + do + #Enabling ftrace for kernel debugging. + 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. + ftrace_disable + sleep 10 + done + #Execution of packet forwarding test cases. + packetForward + else + for env in ${cyclictest_env_verify[@]} + do + #Executing cyclictest through yardstick. + cyclictest ${env} + sleep 10 + done + #Execution of packet forwarding test cases. + packetForward + fi + if [ ${cyclictest_result} -ne 0 ] || [ ${packetforward_result} -ne 0 ];then + echo "Test case FAILED" + err_exit 1 + else + err_exit 0 + fi +elif [ ${test_type} == "daily" ];then + HOST_IP="10.10.100.22" + test_time=3600000 #1h + if [ ${test_name} == "packet_forward" ];then + packetForward + if [ ${packetforward_result} -ne 0 ] ; then + err_exit 1 + else + err_exit 0 + fi + elif [ ${test_name} == "cyclictest" ];then + if [ ${ftrace_enable} -eq '1' ]; then + for env in ${cyclictest_env_daily[@]} + do + #Enabling ftrace for kernel debugging. + 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. + ftrace_disable + sleep 5 + done + else + for env in ${cyclictest_env_daily[@]} + do + #Executing cyclictest through yardstick. + cyclictest ${env} + sleep 5 + done + fi + if [ ${cyclictest_result} -ne 0 ] ; then + echo "Cyclictest case execution FAILED" + err_exit 1 + else + echo "Cyclictest case executed SUCCESSFULLY" + err_exit 0 + fi + fi +elif [ ${test_type} == "merge" ];then + echo "Test is not enabled for ${test_type}" + exit 0 +else + echo "Incorrect test type ${test_type}" +fi