#!/bin/bash
+set +x
+
LIBDIR="$(dirname "$(dirname "$PWD")")"
source $LIBDIR/env/lib/common.sh
function set_bm_kud {
pushd $DOWNLOAD_PATH/multicloud-k8s/kud/hosting_providers/vagrant/inventory
HOST_IP=${HOST_IP:-$(hostname -I | cut -d ' ' -f 1)}
+ if [ "$1" == "minimal" ] ; then
cat <<EOL > hosts.ini
[all]
$HOSTNAME ansible_ssh_host=${HOST_IP} ansible_ssh_port=22
[etcd]
$HOSTNAME
+[k8s-cluster:children]
+kube-node
+kube-master
+EOL
+ else
+ cat <<EOL > hosts.ini
+[all]
+$HOSTNAME ansible_ssh_host=${HOST_IP} ansible_ssh_port=22
+
+[kube-master]
+$HOSTNAME
+
+[kube-node]
+$HOSTNAME
+
+[etcd]
+$HOSTNAME
+
+[ovn-central]
+$HOSTNAME
+
+[ovn-controller]
+$HOSTNAME
+
[virtlet]
$HOSTNAME
kube-node
kube-master
EOL
+ fi
popd
}
function kud_install {
pushd $DOWNLOAD_PATH/multicloud-k8s/kud/hosting_providers/vagrant/
- ./installer.sh | tee kud_minial_deploy.log
+ if [ "$1" == "all" ]; then
+ sed -i -e 's/testing_enabled=${KUD_ENABLE_TESTS:-false}/testing_enabled=${KUD_ENABLE_TESTS:-true}/g' installer.sh
+ fi
+ ./installer.sh | tee kud_deploy.log
popd
}
+function kud_reset {
+ pushd $DOWNLOAD_PATH/multicloud-k8s/kud/hosting_providers/vagrant/
+ ansible-playbook -i inventory/hosts.ini /opt/kubespray-2.10.4/reset.yml \
+ --become --become-user=root -e reset_confirmation=yes
+ popd
+}
+
+
function verifier {
APISERVER=$(kubectl config view --minify -o \
jsonpath='{.clusters[0].cluster.server}')
call_api $APISERVER/api --header "Authorization: Bearer $TOKEN" --insecure
}
+if [ "$1" == "reset" ] ; then
+ kud_reset
+ exit 0
+fi
get_kud_repo
set_ssh_key
-set_bm_kud
-kud_install
+set_bm_kud $1
+kud_install $1
verifier
exit 0