2 # Copyright (c) 2018 Cisco and/or its affiliates.
3 # Licensed under the Apache License, Version 2.0 (the "License");
4 # you may not use this file except in compliance with the License.
5 # You may obtain a copy of the License at:
7 # http://www.apache.org/licenses/LICENSE-2.0
9 # Unless required by applicable law or agreed to in writing, software
10 # distributed under the License is distributed on an "AS IS" BASIS,
11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 # See the License for the specific language governing permissions and
13 # limitations under the License.
17 # Space separated list of available testbeds, described by topology files
18 TOPOLOGIES="topologies/available/lf_testbed1.yaml \
19 topologies/available/lf_testbed2.yaml \
20 topologies/available/lf_testbed3.yaml"
22 SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
25 RESERVATION_DIR="/tmp/reservation_dir"
26 INSTALLATION_DIR="/tmp/install_dir"
28 JOB_ARCHIVE_ARTIFACTS=(log.html output.xml report.html)
29 LOG_ARCHIVE_ARTIFACTS=(log.html output.xml report.html)
30 JOB_ARCHIVE_DIR="archive"
31 LOG_ARCHIVE_DIR="$WORKSPACE/archives"
32 mkdir -p ${JOB_ARCHIVE_DIR}
33 mkdir -p ${LOG_ARCHIVE_DIR}
35 # If we run this script from CSIT jobs we want to use stable vpp version
36 if [[ ${JOB_NAME} == csit-* ]] ;
38 mkdir -p vpp/build-root
41 if [[ ${TEST_TAG} == *DAILY ]] || \
42 [[ ${TEST_TAG} == *WEEKLY ]];
44 # Download the latest VPP build .deb install packages
45 echo Downloading VPP packages...
46 bash ${SCRIPT_DIR}/resources/tools/scripts/download_install_vpp_pkgs.sh --skip-install
48 VPP_DEBS="$( readlink -f *.deb | tr '\n' ' ' )"
49 # Take vpp package and get the vpp version
50 VPP_STABLE_VER="$( expr match $(ls *.deb | head -n 1) 'vpp-\(.*\)-deb.deb' )"
52 DPDK_STABLE_VER=$(cat ${SCRIPT_DIR}/DPDK_STABLE_VER)_amd64
53 VPP_REPO_URL=$(cat ${SCRIPT_DIR}/VPP_REPO_URL_UBUNTU)
54 VPP_STABLE_VER=$(cat ${SCRIPT_DIR}/VPP_STABLE_VER_UBUNTU)
56 # Download vpp build from nexus and set VPP_DEBS variable
57 wget -q "${VPP_REPO_URL}/vpp/${VPP_STABLE_VER}/vpp-${VPP_STABLE_VER}${VPP_CLASSIFIER}.deb" || exit
58 wget -q "${VPP_REPO_URL}/vpp-dbg/${VPP_STABLE_VER}/vpp-dbg-${VPP_STABLE_VER}${VPP_CLASSIFIER}.deb" || exit
59 wget -q "${VPP_REPO_URL}/vpp-dev/${VPP_STABLE_VER}/vpp-dev-${VPP_STABLE_VER}${VPP_CLASSIFIER}.deb" || exit
60 # Temporary disable using dpdk
61 # wget -q "${VPP_REPO_URL}/vpp-dpdk-dkms/${DPDK_STABLE_VER}/vpp-dpdk-dkms-${DPDK_STABLE_VER}${VPP_CLASSIFIER}.deb" || exit
62 wget -q "${VPP_REPO_URL}/vpp-lib/${VPP_STABLE_VER}/vpp-lib-${VPP_STABLE_VER}${VPP_CLASSIFIER}.deb" || exit
63 wget -q "${VPP_REPO_URL}/vpp-plugins/${VPP_STABLE_VER}/vpp-plugins-${VPP_STABLE_VER}${VPP_CLASSIFIER}.deb" || exit
64 VPP_DEBS="$( readlink -f *.deb | tr '\n' ' ' )"
67 # Temporary workaround as ligato docker file requires specific file name
68 rename -v 's/^(.*)-(\d.*)-deb.deb/$1_$2.deb/' *.deb
71 # If we run this script from vpp project we want to use local build
72 elif [[ ${JOB_NAME} == vpp-* ]] ;
74 mkdir -p vpp/build-root
75 # Use local packages provided as argument list
76 # Jenkins VPP deb paths (convert to full path)
77 VPP_DEBS="$( readlink -f $@ | tr '\n' ' ' )"
78 # Take vpp package and get the vpp version
79 VPP_STABLE_VER="$( expr match $1 'vpp-\(.*\)-deb.deb' )"
80 # Move files to build-root for packing
81 for deb in ${VPP_DEBS}; do mv ${deb} vpp/build-root/; done
83 echo "Unable to identify job type based on JOB_NAME variable: ${JOB_NAME}"
87 # Extract VPP API to specific folder
88 dpkg -x vpp/build-root/vpp_${VPP_STABLE_VER}.deb /tmp/vpp
89 # Compress all VPP debs and remove temporary directory
90 tar -zcvf ${SCRIPT_DIR}/vpp.tar.gz vpp/* && rm -R vpp
92 LIGATO_REPO_URL=$(cat ${SCRIPT_DIR}/LIGATO_REPO_URL)
93 VPP_AGENT_STABLE_VER=$(cat ${SCRIPT_DIR}/VPP_AGENT_STABLE_VER)
94 DOCKER_DEB="docker-ce_18.03.0~ce-0~ubuntu_amd64.deb"
96 # Clone & checkout stable vnf-agent
97 cd .. && git clone ${LIGATO_REPO_URL}/vpp-agent
98 # If the git clone fails, complain clearly and exit
100 echo "Failed to run: git clone --depth 1 ${LIGATO_REPO_URL}/vpp-agent"
103 cd vpp-agent && git checkout ${VPP_AGENT_STABLE_VER}
104 # If the git checkout fails, complain clearly and exit
106 echo "Failed to run: git checkout ${VPP_AGENT_STABLE_VER}"
111 wget -q https://download.docker.com/linux/ubuntu/dists/xenial/pool/stable/amd64/${DOCKER_DEB}
112 sudo dpkg -i ${DOCKER_DEB}
113 # If installation fails, complain clearly and exit
115 echo "Failed to install Docker"
119 # Pull ligato/dev_vpp_agent docker image and re-tag as local
120 sudo docker pull ligato/dev-vpp-agent:${VPP_AGENT_STABLE_VER}
121 sudo docker tag ligato/dev-vpp-agent:${VPP_AGENT_STABLE_VER}\
124 # Start dev_vpp_agent container as daemon
125 sudo docker run --rm -itd --name agentcnt dev_vpp_agent bash
126 # Copy latest vpp api into running container
127 sudo docker cp /tmp/vpp/usr/share/vpp/api agentcnt:/usr/share/vpp
128 # Recompile vpp-agent
129 sudo docker exec -i agentcnt \
130 script -qec '. ~/.bashrc; cd /root/go/src/github.com/ligato/vpp-agent && make generate && make install'
132 echo "Failed to build vpp-agent in Docker image."
138 sudo docker cp agentcnt:/root/go/bin/vpp-agent agent/
139 sudo docker cp agentcnt:/root/go/bin/vpp-agent-ctl agent/
140 sudo docker cp agentcnt:/root/go/bin/agentctl agent/
141 tar -zcvf ${SCRIPT_DIR}/../vpp-agent/docker/prod_vpp_agent/agent.tar.gz agent
142 # Kill running container
143 sudo docker rm -f agentcnt
145 # Build prod_vpp_agent docker image
146 cd ${SCRIPT_DIR}/../vpp-agent/docker/prod_vpp_agent/ &&\
147 mv ${SCRIPT_DIR}/vpp.tar.gz . &&\
148 sudo docker build -t prod_vpp_agent --no-cache .
149 # Export Docker image
150 sudo docker save prod_vpp_agent | gzip > prod_vpp_agent.tar.gz
151 # If image build fails, complain clearly and exit
153 echo "Failed to build vpp-agent Docker image."
156 DOCKER_IMAGE="$( readlink -f prod_vpp_agent.tar.gz | tr '\n' ' ' )"
161 export PYTHONPATH=${SCRIPT_DIR}
163 sudo apt-get -y update
164 sudo apt-get -y install libpython2.7-dev python-virtualenv
166 virtualenv --system-site-packages env
170 pip install -r requirements.txt
172 # We iterate over available topologies and wait until we reserve topology
174 for TOPOLOGY in ${TOPOLOGIES};
176 python ${SCRIPT_DIR}/resources/tools/scripts/topo_reservation.py -t ${TOPOLOGY}
177 if [ $? -eq 0 ]; then
178 WORKING_TOPOLOGY=${TOPOLOGY}
179 echo "Reserved: ${WORKING_TOPOLOGY}"
184 if [ ! -z "${WORKING_TOPOLOGY}" ]; then
185 # Exit the infinite while loop if we made a reservation
189 # Wait ~3minutes before next try
190 SLEEP_TIME=$[ ( $RANDOM % 20 ) + 180 ]s
191 echo "Sleeping ${SLEEP_TIME}"
195 function cancel_all {
196 python ${SCRIPT_DIR}/resources/tools/scripts/topo_container_copy.py -c -d ${INSTALLATION_DIR} -t $1
197 python ${SCRIPT_DIR}/resources/tools/scripts/topo_reservation.py -c -t $1
200 # On script exit we cancel the reservation and installation and delete all vpp
202 trap "cancel_all ${WORKING_TOPOLOGY}" EXIT
204 python ${SCRIPT_DIR}/resources/tools/scripts/topo_container_copy.py \
205 -t ${WORKING_TOPOLOGY} -d ${INSTALLATION_DIR} -i ${DOCKER_IMAGE}
206 if [ $? -eq 0 ]; then
207 echo "Docker image copied and loaded on hosts from: ${WORKING_TOPOLOGY}"
209 echo "Failed to copy and load Docker image to DUTs"
213 # Based on job we will identify DUT
214 if [[ ${JOB_NAME} == *hc2vpp* ]] ;
217 elif [[ ${JOB_NAME} == *vpp* ]] ;
220 elif [[ ${JOB_NAME} == *ligato* ]] ;
223 elif [[ ${JOB_NAME} == *dpdk* ]] ;
227 echo "Unable to identify dut type based on JOB_NAME variable: ${JOB_NAME}"
231 PYBOT_ARGS="--consolewidth 120 --loglevel TRACE --variable TOPOLOGY_PATH:${WORKING_TOPOLOGY} --suite tests.${DUT}.perf"
234 # select specific performance tests based on jenkins job type variable
236 TAGS=('ndrdiscANDnic_intel-x520-da2AND1t1c'
237 'ndrdiscANDnic_intel-x520-da2AND2t2c'
238 'ndrdiscAND1t1cANDipsec'
239 'ndrdiscAND2t2cANDipsec')
241 PERFTEST_SEMI_WEEKLY )
242 TAGS=('ndrdiscANDnic_intel-x710AND1t1c'
243 'ndrdiscANDnic_intel-x710AND2t2c'
244 'ndrdiscANDnic_intel-xl710AND1t1c'
245 'ndrdiscANDnic_intel-xl710AND2t2c')
248 TAGS=('mrrAND64bAND1t1c'
254 'mrrANDimixAND1t1cANDvhost'
255 'mrrANDimixAND2t2cANDvhost'
256 'mrrANDimixAND4t4cANDvhost'
257 'mrrANDimixAND1t1cANDmemif'
258 'mrrANDimixAND2t2cANDmemif'
259 'mrrANDimixAND4t4cANDmemif')
261 VERIFY-PERF-NDRDISC )
262 TAGS=('ndrdiscAND1t1c'
265 VERIFY-PERF-PDRDISC )
266 TAGS=('pdrdiscAND1t1c'
274 TAGS=('mrrANDnic_intel-x520-da2AND1t1cANDip4base'
275 'mrrANDnic_intel-x520-da2AND1t1cANDip4fwdANDfib_2m')
278 TAGS=('mrrANDnic_intel-x520-da2AND1t1cANDip6base'
279 'mrrANDnic_intel-x520-da2AND1t1cANDip6fwdANDfib_2m')
282 TAGS=('mrrANDnic_intel-x520-da2AND1t1cANDl2xcbase'
283 'mrrANDnic_intel-x520-da2AND1t1cANDl2bdbase')
286 TAGS=('pdrchkANDnic_intel-x520-da2AND1t1cANDlisp')
289 TAGS=('pdrchkANDnic_intel-x520-da2AND1t1cANDvxlan')
292 TAGS=('pdrdiscANDnic_intel-x520-da2AND1t1cANDvhost')
295 TAGS=('pdrdiscANDnic_intel-x520-da2AND1t1cANDmemif'
296 'pdrdiscANDnic_intel-x520-da2AND2t2cANDmemif'
297 'mrrANDnic_intel-x520-da2AND1t1cANDmemif'
298 'mrrANDnic_intel-x520-da2AND2t2cANDmemif')
300 VERIFY-PERF-IPSECHW )
301 TAGS=('pdrdiscANDnic_intel-xl710AND1t1cANDipsechw'
302 'pdrdiscANDnic_intel-xl710AND2t2cANDipsechw'
303 'mrrANDnic_intel-xl710AND1t1cANDipsechw'
304 'mrrANDnic_intel-xl710AND2t2cANDipsechw')
306 VPP-VERIFY-PERF-IP4 )
307 TAGS=('mrrANDnic_intel-x520-da2AND1t1cANDip4base'
308 'mrrANDnic_intel-x520-da2AND1t1cANDip4fwdANDfib_2m')
310 VPP-VERIFY-PERF-IP6 )
311 TAGS=('mrrANDnic_intel-x520-da2AND1t1cANDip6base'
312 'mrrANDnic_intel-x520-da2AND1t1cANDip6fwdANDfib_2m')
315 TAGS=('mrrANDnic_intel-x520-da2AND1t1cANDl2xcbase'
316 'mrrANDnic_intel-x520-da2AND1t1cANDl2bdbase')
318 VPP-VERIFY-PERF-LISP )
319 TAGS=('pdrchkANDnic_intel-x520-da2AND1t1cANDlisp')
321 VPP-VERIFY-PERF-VXLAN )
322 TAGS=('pdrchkANDnic_intel-x520-da2AND1t1cANDvxlan')
324 VPP-VERIFY-PERF-VHOST )
325 TAGS=('pdrdiscANDnic_intel-x520-da2AND1t1cANDvhost')
327 VPP-VERIFY-PERF-MEMIF )
328 TAGS=('pdrdiscANDnic_intel-x520-da2AND1t1cANDmemif'
329 'pdrdiscANDnic_intel-x520-da2AND2t2cANDmemif'
330 'mrrANDnic_intel-x520-da2AND1t1cANDmemif'
331 'mrrANDnic_intel-x520-da2AND2t2cANDmemif')
333 VPP-VERIFY-PERF-ACL )
334 TAGS=('pdrdiscANDnic_intel-x520-da2AND1t1cANDacl'
335 'pdrdiscANDnic_intel-x520-da2AND2t2cANDacl')
337 VPP-VERIFY-PERF-IPSECHW )
338 TAGS=('pdrdiscANDnic_intel-xl710AND1t1cANDipsechw'
339 'pdrdiscANDnic_intel-xl710AND2t2cANDipsechw'
340 'mrrANDnic_intel-xl710AND1t1cANDipsechw'
341 'mrrANDnic_intel-xl710AND2t2cANDipsechw')
347 # Catenate TAG selections by 'OR'
348 printf -v INCLUDES " --include %s " "${TAGS[@]}"
351 pybot ${PYBOT_ARGS}${INCLUDES} tests/
352 RETURN_STATUS=$(echo $?)
354 # Archive JOB artifacts in jenkins
355 for i in ${JOB_ARCHIVE_ARTIFACTS[@]}; do
356 cp $( readlink -f ${i} | tr '\n' ' ' ) ${JOB_ARCHIVE_DIR}/
358 # Archive JOB artifacts to logs.fd.io
359 for i in ${LOG_ARCHIVE_ARTIFACTS[@]}; do
360 cp $( readlink -f ${i} | tr '\n' ' ' ) ${LOG_ARCHIVE_DIR}/
363 exit ${RETURN_STATUS}