Merge "Backport of Congress parallel execution"
[apex.git] / build / overcloud-full.sh
1 #!/bin/sh
2 ##############################################################################
3 # Copyright (c) 2015 Tim Rozet (Red Hat), Dan Radez (Red Hat) and others.
4 #
5 # All rights reserved. This program and the accompanying materials
6 # are made available under the terms of the Apache License, Version 2.0
7 # which accompanies this distribution, and is available at
8 # http://www.apache.org/licenses/LICENSE-2.0
9 ##############################################################################
10 set -xe
11 source ./cache.sh
12 source ./variables.sh
13 source ./barometer-install.sh
14
15 populate_cache "$rdo_images_uri/overcloud-full.tar"
16
17 if [ ! -d ${BUILD_DIR} ]; then mkdir ${BUILD_DIR}; fi
18 tar -xf ${CACHE_DIR}/overcloud-full.tar -C ${BUILD_DIR}/
19 mv -f ${BUILD_DIR}/overcloud-full.qcow2 ${BUILD_DIR}/overcloud-full_build.qcow2
20
21 ##########################################################
22 #####  Prep initial overcloud image with common deps #####
23 ##########################################################
24
25 pushd ${BUILD_DIR} > /dev/null
26
27 # prep opnfv-puppet-tripleo for undercloud
28 python3 -B $BUILD_UTILS clone-fork -r apex-puppet-tripleo
29 pushd apex-puppet-tripleo > /dev/null
30 git archive --format=tar.gz --prefix=tripleo/ HEAD > ${BUILD_DIR}/apex-puppet-tripleo.tar.gz
31 popd > /dev/null
32
33 # download customized os-net-config
34 python3 -B $BUILD_UTILS clone-fork -r apex-os-net-config
35 pushd apex-os-net-config/os_net_config > /dev/null
36 git archive --format=tar.gz --prefix=os_net_config/ HEAD > ${BUILD_DIR}/apex-os-net-config.tar.gz
37 popd > /dev/null
38
39 # tar up vsperf
40 rm -rf vsperf vsperf.tar.gz
41 git clone https://gerrit.opnfv.org/gerrit/vswitchperf vsperf
42 tar czf vsperf.tar.gz vsperf
43
44 # Increase disk size by 1200MB to accommodate more packages
45 qemu-img resize overcloud-full_build.qcow2 +1200MB
46
47 # expand file system to max disk size
48 # installing forked apex-puppet-tripleo
49 # upload neutron port data plane status
50 LIBGUESTFS_BACKEND=direct virt-customize \
51     --run-command "xfs_growfs /dev/sda" \
52     --upload ${BUILD_DIR}/apex-puppet-tripleo.tar.gz:/etc/puppet/modules \
53     --run-command "cd /etc/puppet/modules && rm -rf tripleo && tar xzf apex-puppet-tripleo.tar.gz" \
54     --upload ${BUILD_DIR}/apex-os-net-config.tar.gz:/usr/lib/python2.7/site-packages \
55     --run-command "cd /usr/lib/python2.7/site-packages/ && rm -rf os_net_config && tar xzf apex-os-net-config.tar.gz" \
56     --run-command "if ! rpm -qa | grep python-redis; then yum install -y python-redis; fi" \
57     --install epel-release \
58     --run-command "sed -i 's/^#UseDNS.*$/UseDNS no/' /etc/ssh/sshd_config" \
59     --run-command "sed -i 's/^GSSAPIAuthentication.*$/GSSAPIAuthentication no/' /etc/ssh/sshd_config" \
60     --run-command "rm -f /etc/sysctl.d/80-vpp.conf" \
61     --install unzip \
62     --upload ${BUILD_DIR}/vsperf.tar.gz:/var/opt \
63     --run-command "cd /var/opt && tar xzf vsperf.tar.gz" \
64     --run-command "sed -i -E 's/timeout=[0-9]+/timeout=60/g' /usr/share/openstack-puppet/modules/rabbitmq/lib/puppet/provider/rabbitmqctl.rb" \
65     --install patch \
66     --upload ${BUILD_ROOT}/patches/neutron_lib_dps.patch:/usr/lib/python2.7/site-packages/ \
67     --upload ${BUILD_ROOT}/patches/neutron_server_dps.patch:/usr/lib/python2.7/site-packages/ \
68     --upload ${BUILD_ROOT}/patches/neutron_openstacksdk_dps.patch:/usr/lib/python2.7/site-packages/ \
69     --upload ${BUILD_ROOT}/patches/neutron_openstackclient_dps.patch:/usr/lib/python2.7/site-packages/ \
70     --upload ${BUILD_ROOT}/patches/puppet-neutron-add-sfc.patch:/usr/share/openstack-puppet/modules/neutron/ \
71     --upload ${BUILD_ROOT}/patches/congress-parallel-execution.patch:/usr/lib/python2.7/site-packages/ \
72     -a overcloud-full_build.qcow2
73
74 # apply neutron port data plane status patches
75 # https://specs.openstack.org/openstack/neutron-specs/specs/backlog/ocata/port-data-plane-status.html
76 # apply congress parallel execution patch
77 # Requirements from Doctor project
78 # TODO(cgoncalves): code merged in Pike dev cycle. drop from >= OpenStack Pike / > OPNFV Euphrates
79 LIBGUESTFS_BACKEND=direct virt-customize \
80     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < neutron_lib_dps.patch " \
81     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < neutron_server_dps.patch" \
82     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < neutron_openstacksdk_dps.patch" \
83     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < neutron_openstackclient_dps.patch" \
84     --run-command "cd /usr/share/openstack-puppet/modules/neutron && patch -p1 < puppet-neutron-add-sfc.patch" \
85     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < congress-parallel-execution.patch" \
86     -a overcloud-full_build.qcow2
87
88 # Arch dependent on x86
89 if [ "$(uname -i)" == 'x86_64' ]; then
90 dpdk_pkg_str=''
91 for package in ${dpdk_rpms[@]}; do
92   wget "$dpdk_uri_base/$package"
93   dpdk_pkg_str+=" --upload ${BUILD_DIR}/${package}:/root/dpdk_rpms"
94 done
95
96 # tar up the fd.io module
97 rm -rf puppet-fdio
98 git clone https://git.fd.io/puppet-fdio
99 pushd puppet-fdio > /dev/null
100 #TODO: Remove this when we update to 17.07
101 git revert a6e575c8f0af17e62990653bcf4a12c688c21aad --no-edit
102 git archive --format=tar.gz --prefix=fdio/ HEAD > ${BUILD_DIR}/puppet-fdio.tar.gz
103 popd > /dev/null
104
105 # Master FD.IO Repo
106 cat > ${BUILD_DIR}/fdio.repo << EOF
107 [fdio-master]
108 name=fd.io master branch latest merge
109 baseurl=https://nexus.fd.io/content/repositories/fd.io.master.centos7/
110 enabled=1
111 gpgcheck=0
112 EOF
113
114 # Get Real Time Kernel from kvm4nfv
115 populate_cache $kvmfornfv_uri_base/$kvmfornfv_kernel_rpm
116
117 # packages frozen for fdio scenarios
118 fdio_pkg_str=''
119 for package in ${fdio_pkgs[@]}; do
120   wget "$package"
121   fdio_pkg_str+=" --upload ${BUILD_DIR}/${package##*/}:/root/fdio/"
122 done
123
124 # upload dpdk rpms but do not install
125 # install fd.io yum repo and packages
126 # upload puppet fdio
127 # git clone vsperf into the overcloud image
128 # upload the rt_kvm kernel
129 LIBGUESTFS_BACKEND=direct virt-customize \
130     --run-command "mkdir /root/dpdk_rpms" \
131     $dpdk_pkg_str \
132     --upload ${BUILD_DIR}/puppet-fdio.tar.gz:/etc/puppet/modules \
133     --run-command "cd /etc/puppet/modules && tar xzf puppet-fdio.tar.gz" \
134     --upload ${BUILD_DIR}/fdio.repo:/etc/yum.repos.d/ \
135     --run-command "mkdir /root/fdio" \
136     --upload ${BUILD_DIR}/noarch/$netvpp_pkg:/root/fdio \
137     $fdio_pkg_str \
138     --run-command "yum install -y /root/fdio/*.rpm" \
139     --run-command "curl -f https://copr.fedorainfracloud.org/coprs/leifmadsen/ovs-master/repo/epel-7/leifmadsen-ovs-master-epel-7.repo > /etc/yum.repos.d/leifmadsen-ovs-master-epel-7.repo" \
140     --run-command "mkdir /root/ovs27" \
141     --run-command "yumdownloader --destdir=/root/ovs27 openvswitch*2.7* python-openvswitch-2.7*" \
142     --upload ${CACHE_DIR}/$kvmfornfv_kernel_rpm:/root/ \
143     --install python2-networking-sfc \
144     --install python-etcd,puppet-etcd \
145     --install patch \
146     --upload ${BUILD_ROOT}/patches/puppet-neutron-ml2-ip-version-fix.patch:/usr/share/openstack-puppet/modules/neutron/ \
147     --run-command "cd /usr/share/openstack-puppet/modules/neutron && patch -p1 < puppet-neutron-ml2-ip-version-fix.patch" \
148     --upload ${BUILD_ROOT}/patches/puppet-neutron-vpp-ml2-type_drivers-setting.patch:/usr/share/openstack-puppet/modules/neutron/ \
149     --run-command "cd /usr/share/openstack-puppet/modules/neutron && patch -p1 < puppet-neutron-vpp-ml2-type_drivers-setting.patch" \
150     -a overcloud-full_build.qcow2
151
152     # upload and install barometer packages
153     barometer_pkgs overcloud-full_build.qcow2
154
155     # Build OVS with NSH
156     rm -rf ovs_nsh_patches
157     rm -rf ovs
158     git clone https://github.com/yyang13/ovs_nsh_patches.git
159     git clone https://github.com/openvswitch/ovs.git
160     pushd ovs > /dev/null
161     git checkout v2.6.1
162     cp ../ovs_nsh_patches/v2.6.1/*.patch ./
163     cp ${BUILD_ROOT}/patches/ovs-fix-build-on-RHEL-7.3.patch ./
164     # Hack for build servers that have no git config
165     git config user.email "apex@opnfv.com"
166     git config user.name "apex"
167     git am *.patch
168     popd > /dev/null
169     tar czf ovs.tar.gz ovs
170
171
172 LIBGUESTFS_BACKEND=direct virt-customize \
173     --upload ${BUILD_ROOT}/build_ovs_nsh.sh:/root/ \
174     --upload ovs.tar.gz:/root/ \
175     --run-command "cd /root/ && tar xzf ovs.tar.gz" \
176     --run-command "cd /root/ovs && /root/build_ovs_nsh.sh" \
177     -a overcloud-full_build.qcow2
178
179 fi # end x86_64 specific items
180
181 mv -f overcloud-full_build.qcow2 overcloud-full.qcow2
182 popd > /dev/null