a675b34dda
Change-Id: I044affa85290caf9d71e8ba5bc7cf0f5be8941e7
(cherry picked from commit ce4ff5a0b8
)
131 lines
3.7 KiB
Bash
Executable File
131 lines
3.7 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -o xtrace
|
|
set -o errexit
|
|
set -o pipefail
|
|
|
|
# Enable unbuffered output for Ansible in Jenkins.
|
|
export PYTHONUNBUFFERED=1
|
|
|
|
function prepare_images {
|
|
if [[ "${BUILD_IMAGE}" == "False" ]]; then
|
|
return
|
|
fi
|
|
|
|
if [[ $SCENARIO != "bifrost" ]]; then
|
|
GATE_IMAGES="^cron,^fluentd,^glance,^haproxy,^proxysql,^keepalived,^keystone,^kolla-toolbox,^mariadb,^memcached,^neutron,^nova-,^openvswitch,^rabbitmq,^horizon,^heat,^placement"
|
|
else
|
|
GATE_IMAGES="bifrost"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "cephadm" ]]; then
|
|
GATE_IMAGES+=",^cinder,^redis"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "cells" ]]; then
|
|
GATE_IMAGES+=",^proxysql"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "zun" ]]; then
|
|
GATE_IMAGES+=",^zun,^kuryr,^etcd,^cinder,^iscsid"
|
|
if [[ $BASE_DISTRO != "centos" && $BASE_DISTRO != "rocky" ]]; then
|
|
GATE_IMAGES+=",^tgtd"
|
|
fi
|
|
fi
|
|
|
|
if [[ $SCENARIO == "scenario_nfv" ]]; then
|
|
GATE_IMAGES+=",^aodh,^tacker,^mistral,^redis,^barbican"
|
|
fi
|
|
if [[ $SCENARIO == "ironic" ]]; then
|
|
GATE_IMAGES+=",^dnsmasq,^ironic,^iscsid"
|
|
fi
|
|
if [[ $SCENARIO == "magnum" ]]; then
|
|
GATE_IMAGES+=",^designate,^magnum,^trove"
|
|
fi
|
|
if [[ $SCENARIO == "octavia" ]]; then
|
|
GATE_IMAGES+=",^redis,^octavia"
|
|
fi
|
|
if [[ $SCENARIO == "masakari" ]]; then
|
|
GATE_IMAGES+=",^masakari-,^hacluster-"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "swift" ]]; then
|
|
GATE_IMAGES+=",^swift"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "ovn" ]]; then
|
|
GATE_IMAGES+=",^redis,^octavia,^ovn"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "mariadb" ]]; then
|
|
GATE_IMAGES="^cron,^fluentd,^haproxy,^proxysql,^keepalived,^kolla-toolbox,^mariadb"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "lets-encrypt" ]]; then
|
|
GATE_IMAGES+=",^letsencrypt,^haproxy"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "prometheus-opensearch" ]]; then
|
|
GATE_IMAGES="^cron,^fluentd,^grafana,^haproxy,^proxysql,^keepalived,^kolla-toolbox,^mariadb,^memcached,^opensearch,^prometheus,^rabbitmq"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "venus" ]]; then
|
|
GATE_IMAGES="^cron,^opensearch,^fluentd,^haproxy,^proxysql,^keepalived,^keystone,^kolla-toolbox,^mariadb,^memcached,^rabbitmq,^venus"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "skyline" || $SCENARIO == "skyline-sso" ]]; then
|
|
GATE_IMAGES+=",^skyline"
|
|
fi
|
|
|
|
sudo tee -a /etc/kolla/kolla-build.conf <<EOF
|
|
[DEFAULT]
|
|
engine = ${CONTAINER_ENGINE}
|
|
EOF
|
|
|
|
if [[ $BASE_DISTRO == "debian" || $BASE_DISTRO == "ubuntu" ]]; then
|
|
sudo tee -a /etc/kolla/kolla-build.conf <<EOF
|
|
base_image = quay.io/openstack.kolla/${BASE_DISTRO}
|
|
EOF
|
|
fi
|
|
|
|
sudo tee -a /etc/kolla/kolla-build.conf <<EOF
|
|
[profiles]
|
|
gate = ${GATE_IMAGES}
|
|
EOF
|
|
|
|
sudo mkdir -p /tmp/logs/build
|
|
sudo mkdir -p /opt/kolla_registry
|
|
|
|
sudo $CONTAINER_ENGINE run -d --net=host -e REGISTRY_HTTP_ADDR=0.0.0.0:4000 --restart=always -v /opt/kolla_registry/:/var/lib/registry --name registry quay.io/libpod/registry:2.8.2
|
|
|
|
|
|
python3 -m venv ~/kolla-venv
|
|
source ~/kolla-venv/bin/activate
|
|
if [[ "$CONTAINER_ENGINE" == "docker" ]]; then
|
|
pip install "${KOLLA_SRC_DIR}" "docker"
|
|
else
|
|
pip install "${KOLLA_SRC_DIR}" "podman"
|
|
fi
|
|
|
|
sudo ~/kolla-venv/bin/kolla-build
|
|
|
|
# NOTE(yoctozepto): due to debian buster we push after images are built
|
|
# see https://github.com/docker/for-linux/issues/711
|
|
if [[ "debian" == $BASE_DISTRO ]]; then
|
|
for img in $(sudo ${CONTAINER_ENGINE} image ls --format '{{ .Repository }}:{{ .Tag }}' | grep lokolla/); do
|
|
sudo $CONTAINER_ENGINE push $img;
|
|
done
|
|
fi
|
|
|
|
deactivate
|
|
}
|
|
|
|
|
|
RAW_INVENTORY=/etc/kolla/inventory
|
|
|
|
source $KOLLA_ANSIBLE_VENV_PATH/bin/activate
|
|
kolla-ansible bootstrap-servers -i ${RAW_INVENTORY} -vvv &> /tmp/logs/ansible/bootstrap-servers
|
|
deactivate
|
|
|
|
prepare_images
|