Applies Tacker upstream patches and fixes fernet dir perms
[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 +1200M
46
47 # expand file system to max disk size
48 # installing forked apex-puppet-tripleo
49 # upload neutron port data plane status
50 # REMOVE Tacker VNFFG patch when moving to Pike
51 LIBGUESTFS_BACKEND=direct virt-customize \
52     --run-command "xfs_growfs /dev/sda" \
53     --upload ${BUILD_DIR}/apex-puppet-tripleo.tar.gz:/etc/puppet/modules \
54     --run-command "cd /etc/puppet/modules && rm -rf tripleo && tar xzf apex-puppet-tripleo.tar.gz" \
55     --upload ${BUILD_DIR}/apex-os-net-config.tar.gz:/usr/lib/python2.7/site-packages \
56     --run-command "cd /usr/lib/python2.7/site-packages/ && rm -rf os_net_config && tar xzf apex-os-net-config.tar.gz" \
57     --run-command "if ! rpm -qa | grep python-redis; then yum install -y python-redis; fi" \
58     --install epel-release \
59     --run-command "sed -i 's/^#UseDNS.*$/UseDNS no/' /etc/ssh/sshd_config" \
60     --run-command "sed -i 's/^GSSAPIAuthentication.*$/GSSAPIAuthentication no/' /etc/ssh/sshd_config" \
61     --run-command "rm -f /etc/sysctl.d/80-vpp.conf" \
62     --install unzip \
63     --upload ${BUILD_DIR}/vsperf.tar.gz:/var/opt \
64     --run-command "cd /var/opt && tar xzf vsperf.tar.gz" \
65     --run-command "sed -i -E 's/timeout=[0-9]+/timeout=60/g' /usr/share/openstack-puppet/modules/rabbitmq/lib/puppet/provider/rabbitmqctl.rb" \
66     --install patch \
67     --upload ${BUILD_ROOT}/patches/neutron_lib_dps.patch:/usr/lib/python2.7/site-packages/ \
68     --upload ${BUILD_ROOT}/patches/neutron_server_dps.patch:/usr/lib/python2.7/site-packages/ \
69     --upload ${BUILD_ROOT}/patches/neutron_openstacksdk_dps.patch:/usr/lib/python2.7/site-packages/ \
70     --upload ${BUILD_ROOT}/patches/neutron_openstackclient_dps.patch:/usr/lib/python2.7/site-packages/ \
71     --upload ${BUILD_ROOT}/patches/puppet-neutron-add-sfc.patch:/usr/share/openstack-puppet/modules/neutron/ \
72     --upload ${BUILD_ROOT}/patches/congress-parallel-execution.patch:/usr/lib/python2.7/site-packages/ \
73     --upload ${BUILD_ROOT}/patches/puppet-neutron-ml2-ip-version-fix.patch:/usr/share/openstack-puppet/modules/neutron/ \
74     --run-command "cd /usr/share/openstack-puppet/modules/neutron && patch -p1 < puppet-neutron-ml2-ip-version-fix.patch" \
75     --upload ${BUILD_ROOT}/patches/puppet-neutron-vpp-ml2-type_drivers-setting.patch:/usr/share/openstack-puppet/modules/neutron/ \
76     --run-command "cd /usr/share/openstack-puppet/modules/neutron && patch -p1 < puppet-neutron-vpp-ml2-type_drivers-setting.patch" \
77     --upload ${BUILD_ROOT}/patches/tacker-vnffg-input-params.patch:/usr/lib/python2.7/site-packages/ \
78     --run-command "cd usr/lib/python2.7/site-packages/ && patch -p1 < tacker-vnffg-input-params.patch" \
79     -a overcloud-full_build.qcow2
80
81 # apply neutron port data plane status patches
82 # https://specs.openstack.org/openstack/neutron-specs/specs/backlog/ocata/port-data-plane-status.html
83 # apply congress parallel execution patch
84 # Requirements from Doctor project
85 # TODO(cgoncalves): code merged in Pike dev cycle. drop from >= OpenStack Pike / > OPNFV Euphrates
86 LIBGUESTFS_BACKEND=direct virt-customize \
87     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < neutron_lib_dps.patch " \
88     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < neutron_server_dps.patch" \
89     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < neutron_openstacksdk_dps.patch" \
90     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < neutron_openstackclient_dps.patch" \
91     --run-command "cd /usr/share/openstack-puppet/modules/neutron && patch -p1 < puppet-neutron-add-sfc.patch" \
92     --run-command "cd /usr/lib/python2.7/site-packages/ && patch -p1 < congress-parallel-execution.patch" \
93     -a overcloud-full_build.qcow2
94
95 # Arch dependent on x86
96 if [ "$(uname -i)" == 'x86_64' ]; then
97 dpdk_pkg_str=''
98 for package in ${dpdk_rpms[@]}; do
99   wget "$dpdk_uri_base/$package"
100   dpdk_pkg_str+=" --upload ${BUILD_DIR}/${package}:/root/dpdk_rpms"
101 done
102
103 # tar up the fd.io module
104 rm -rf puppet-fdio
105 git clone https://git.fd.io/puppet-fdio
106 pushd puppet-fdio > /dev/null
107 #TODO: Remove this when we update to 17.07
108 git revert a6e575c8f0af17e62990653bcf4a12c688c21aad --no-edit
109 git archive --format=tar.gz --prefix=fdio/ HEAD > ${BUILD_DIR}/puppet-fdio.tar.gz
110 popd > /dev/null
111
112 # Master FD.IO Repo
113 cat > ${BUILD_DIR}/fdio.repo << EOF
114 [fdio-master]
115 name=fd.io master branch latest merge
116 baseurl=https://nexus.fd.io/content/repositories/fd.io.master.centos7/
117 enabled=1
118 gpgcheck=0
119 EOF
120
121 # Kubernetes Repo
122 cat > ${BUILD_DIR}/kubernetes.repo << EOF
123 [kubernetes]
124 name=Kubernetes
125 baseurl=https://packages.cloud.google.com/yum/repos/kubernetes-el7-x86_64
126 enabled=1
127 gpgcheck=1
128 repo_gpgcheck=1
129 gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg
130         https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg
131 EOF
132
133 # Get Real Time Kernel from kvm4nfv
134 populate_cache $kvmfornfv_uri_base/$kvmfornfv_kernel_rpm
135
136 # packages frozen for fdio scenarios
137 fdio_pkg_str=''
138 for package in ${fdio_pkgs[@]}; do
139   wget "$package"
140   fdio_pkg_str+=" --upload ${BUILD_DIR}/${package##*/}:/root/fdio/"
141 done
142
143 # upload dpdk rpms but do not install
144 # install fd.io yum repo and packages
145 # upload puppet fdio
146 # git clone vsperf into the overcloud image
147 # upload the rt_kvm kernel
148 LIBGUESTFS_BACKEND=direct virt-customize \
149     --run-command "mkdir /root/dpdk_rpms" \
150     $dpdk_pkg_str \
151     --upload ${BUILD_DIR}/puppet-fdio.tar.gz:/etc/puppet/modules \
152     --run-command "cd /etc/puppet/modules && tar xzf puppet-fdio.tar.gz" \
153     --upload ${BUILD_DIR}/fdio.repo:/etc/yum.repos.d/ \
154     --upload ${BUILD_DIR}/kubernetes.repo:/etc/yum.repos.d/ \
155     --run-command "mkdir /root/fdio" \
156     --upload ${BUILD_DIR}/noarch/$netvpp_pkg:/root/fdio \
157     $fdio_pkg_str \
158     --run-command "yum install -y /root/fdio/*.rpm" \
159     --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" \
160     --run-command "mkdir /root/ovs28" \
161     --run-command "yumdownloader --destdir=/root/ovs28 openvswitch*2.8* python-openvswitch-2.8*" \
162     --upload ${CACHE_DIR}/$kvmfornfv_kernel_rpm:/root/ \
163     --install python2-networking-sfc \
164     --install python-etcd,puppet-etcd \
165     --install patch \
166     --install docker,kubelet,kubeadm,kubectl,kubernetes-cni \
167     -a overcloud-full_build.qcow2
168
169     # upload and install barometer packages
170     barometer_pkgs overcloud-full_build.qcow2
171
172 fi # end x86_64 specific items
173
174 mv -f overcloud-full_build.qcow2 overcloud-full.qcow2
175 popd > /dev/null