a88ebd77b0
We replaced redis with etcd in that scenario, but GATE_IMAGES are not updated. Change-Id: Ie9d6642f8ce51bc2a35b800c6c149153c14378db
123 lines
3.4 KiB
Bash
Executable File
123 lines
3.4 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,^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,^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,^keepalived,^kolla-toolbox,^mariadb,^memcached,^opensearch,^prometheus,^rabbitmq"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "venus" ]]; then
|
|
GATE_IMAGES="^cron,^opensearch,^fluentd,^haproxy,^keepalived,^keystone,^kolla-toolbox,^mariadb,^memcached,^rabbitmq,^venus"
|
|
fi
|
|
|
|
if [[ $SCENARIO == "skyline" ]]; then
|
|
GATE_IMAGES+=",^skyline"
|
|
fi
|
|
|
|
sudo tee -a /etc/kolla/kolla-build.conf <<EOF
|
|
[DEFAULT]
|
|
engine = ${CONTAINER_ENGINE}
|
|
|
|
[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 registry:2
|
|
|
|
|
|
python3 -m venv ~/kolla-venv
|
|
source ~/kolla-venv/bin/activate
|
|
if [[ "$CONTAINER_ENGINE" == "docker" ]]; then
|
|
pip install "${KOLLA_SRC_DIR}" "docker<7"
|
|
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 -i ${RAW_INVENTORY} -vvv bootstrap-servers &> /tmp/logs/ansible/bootstrap-servers
|
|
deactivate
|
|
|
|
prepare_images
|