9 echo "Starting the Apex deployment."
10 echo "--------------------------------------------------------"
13 if [ -z "$DEPLOY_SCENARIO" ]; then
14 echo "Deploy scenario not set!"
16 elif [[ "$DEPLOY_SCENARIO" == *gate* ]]; then
17 echo "Detecting Gating scenario..."
18 if [ -z "$GERRIT_EVENT_COMMENT_TEXT" ]; then
19 echo "ERROR: Gate job triggered without comment!"
22 DEPLOY_SCENARIO=$(echo ${GERRIT_EVENT_COMMENT_TEXT} | grep start-gate-scenario | grep -Eo 'os-.*$')
23 if [ -z "$DEPLOY_SCENARIO" ]; then
24 echo "ERROR: Unable to detect scenario in Gerrit Comment!"
25 echo "Format of comment to trigger gate should be 'start-gate-scenario: <scenario>'"
28 echo "Gate scenario detected: ${DEPLOY_SCENARIO}"
33 # Dev or RPM/ISO build
34 if [[ "$ARTIFACT_VERSION" =~ dev ]]; then
35 # Settings for deploying from git workspace
36 DEPLOY_SETTINGS_DIR="${WORKSPACE}/config/deploy"
37 NETWORK_SETTINGS_DIR="${WORKSPACE}/config/network"
38 DEPLOY_CMD="opnfv-deploy --image-dir ${WORKSPACE}/.build"
39 CLEAN_CMD="opnfv-clean"
40 RESOURCES="${WORKSPACE}/.build/"
41 CONFIG="${WORKSPACE}/build"
44 LIB="${WORKSPACE}/lib"
46 # Ensure artifacts were downloaded and extracted correctly
47 # TODO(trozet) add verification here
50 sudo rm -rf /tmp/.build
52 sudo pip3 install --upgrade --force-reinstall .
53 mv -f /tmp/.build ${WORKSPACE}/
55 DEPLOY_SETTINGS_DIR="/etc/opnfv-apex/"
56 NETWORK_SETTINGS_DIR="/etc/opnfv-apex/"
57 DEPLOY_CMD="opnfv-deploy"
58 CLEAN_CMD="opnfv-clean"
59 RESOURCES="/var/opt/opnfv/images"
60 CONFIG="/var/opt/opnfv"
63 LIB="/var/opt/opnfv/lib"
64 sudo mkdir -p /var/log/apex
65 sudo chmod 777 /var/log/apex
69 # Install Dependencies
70 # Make sure python34 dependencies are installed
71 dependencies="epel-release python34 python34-devel libvirt-devel python34-pip \
72 ansible python34-PyYAML python34-jinja2 python34-setuptools python-tox ansible"
74 for dep_pkg in $dependencies; do
75 if ! rpm -q ${dep_pkg} > /dev/null; then
76 if ! sudo yum install -y ${dep_pkg}; then
77 echo "Failed to install ${dep_pkg}"
83 if [[ "$JOB_NAME" =~ "virtual" ]]; then
84 # Make sure ipxe-roms-qemu package is updated to latest.
85 # This package is needed for multi virtio nic PXE boot in virtual environment.
86 sudo yum update -y ipxe-roms-qemu
89 if [ "$OPNFV_CLEAN" == 'yes' ]; then
90 if sudo test -e '/root/inventory/pod_settings.yaml'; then
91 clean_opts='-i /root/inventory/pod_settings.yaml'
96 sudo ${CLEAN_CMD} ${clean_opts}
99 if echo ${DEPLOY_SCENARIO} | grep ipv6; then
101 DEPLOY_SCENARIO=$(echo ${DEPLOY_SCENARIO} | sed 's/-ipv6//')
102 echo "INFO: IPV6 Enabled"
105 echo "Deploy Scenario set to ${DEPLOY_SCENARIO}"
106 DEPLOY_FILE="${DEPLOY_SETTINGS_DIR}/${DEPLOY_SCENARIO}.yaml"
108 if [ ! -e "$DEPLOY_FILE" ]; then
109 echo "ERROR: Required settings file missing: Deploy settings file ${DEPLOY_FILE}"
112 if [[ "$JOB_NAME" =~ "virtual" ]]; then
113 # settings for virtual deployment
114 DEPLOY_CMD="${DEPLOY_CMD} -v"
115 if [[ "${DEPLOY_SCENARIO}" =~ fdio|ovs ]]; then
116 DEPLOY_CMD="${DEPLOY_CMD} --virtual-default-ram 12 --virtual-compute-ram 7"
118 if [[ "$JOB_NAME" == *csit* ]]; then
119 DEPLOY_CMD="${DEPLOY_CMD} -e csit-environment.yaml"
121 if [[ "$PROMOTE" == "True" ]]; then
122 DEPLOY_CMD="${DEPLOY_CMD} --virtual-computes 2"
125 # settings for bare metal deployment
126 NETWORK_SETTINGS_DIR="/root/network"
127 INVENTORY_FILE="/root/inventory/pod_settings.yaml"
129 if ! sudo test -e "$INVENTORY_FILE"; then
130 echo "ERROR: Required settings file missing: Inventory settings file ${INVENTORY_FILE}"
133 # include inventory file for bare metal deployment
134 DEPLOY_CMD="${DEPLOY_CMD} -i ${INVENTORY_FILE}"
137 if [ "$IPV6_FLAG" == "True" ]; then
138 NETWORK_FILE="${NETWORK_SETTINGS_DIR}/network_settings_v6.yaml"
139 elif echo ${DEPLOY_SCENARIO} | grep fdio; then
140 NETWORK_FILE="${NETWORK_SETTINGS_DIR}/network_settings_vpp.yaml"
142 NETWORK_FILE="${NETWORK_SETTINGS_DIR}/network_settings.yaml"
145 # Check that network settings file exists
146 if ! sudo test -e "$NETWORK_FILE"; then
147 echo "ERROR: Required settings file missing: Network Settings file ${NETWORK_FILE}"
152 sudo ${DEPLOY_CMD} -d ${DEPLOY_FILE} -n ${NETWORK_FILE} --debug
154 if [[ "$JOB_NAME" == *csit* ]]; then
155 echo "CSIT job: setting host route for floating ip routing"
156 # csit route to allow docker container to reach floating ips
157 UNDERCLOUD=$(sudo virsh domifaddr undercloud | grep -Eo "[0-9\.]+{3}[0-9]+")
158 if sudo route | grep 192.168.37.128 > /dev/null; then
159 sudo route del -net 192.168.37.128 netmask 255.255.255.128
161 sudo route add -net 192.168.37.128 netmask 255.255.255.128 gw ${UNDERCLOUD}
165 echo "--------------------------------------------------------"