summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xforeman/ci/clean.sh16
-rwxr-xr-xforeman/ci/deploy.sh58
2 files changed, 57 insertions, 17 deletions
diff --git a/foreman/ci/clean.sh b/foreman/ci/clean.sh
index f61ac93..05c35fc 100755
--- a/foreman/ci/clean.sh
+++ b/foreman/ci/clean.sh
@@ -5,7 +5,7 @@
#
#Uses Vagrant and VirtualBox
#
-#Destroys Vagrant VM running in /tmp/bgs_vagrant
+#Destroys Vagrant VM running in $vm_dir/foreman_vm
#Shuts down all nodes found in Khaleesi settings
#Removes hypervisor kernel modules (VirtualBox)
@@ -14,6 +14,8 @@ reset=`tput sgr0`
blue=`tput setaf 4`
red=`tput setaf 1`
green=`tput setaf 2`
+
+vm_dir=/var/opt/opnfv
##END VARS
##FUNCTIONS
@@ -106,9 +108,17 @@ else
skip_vagrant=1
fi
+###legacy VM location check
+###remove me later
+if [ -d /tmp/bgs_vagrant ]; then
+ cd /tmp/bgs_vagrant
+ vagrant destroy -f
+ rm -rf /tmp/bgs_vagrant
+fi
+
###destroy vagrant
if [ $skip_vagrant -eq 0 ]; then
- cd /tmp/bgs_vagrant
+ cd $vm_dir/foreman_vm
if vagrant destroy -f; then
echo "${blue}Successfully destroyed Foreman VM ${reset}"
else
@@ -135,6 +145,8 @@ else
echo "${blue}Skipping Vagrant destroy + Vbox Removal as VirtualBox package is already removed ${reset}"
fi
+###remove working vm directory
+rm -rf $vm_dir
###remove kernel modules
echo "${blue}Removing kernel modules ${reset}"
diff --git a/foreman/ci/deploy.sh b/foreman/ci/deploy.sh
index edad2a4..46a09f5 100755
--- a/foreman/ci/deploy.sh
+++ b/foreman/ci/deploy.sh
@@ -28,6 +28,8 @@ declare -A interface_arr
declare -A controllers_ip_arr
declare -A admin_ip_arr
declare -A public_ip_arr
+
+vm_dir=/var/opt/opnfv
##END VARS
##FUNCTIONS
@@ -44,6 +46,24 @@ display_usage() {
echo -e "\n -floating_ip_count : number of IP address from the public range to be used for floating IP. Default is 20.\n"
}
+##verify vm dir exists
+##params: none
+function verify_vm_dir {
+ if [ -d "$vm_dir" ]; then
+ echo -e "\n\n${red}ERROR: VM Directory: $vm_dir already exists. Environment not clean. Please use clean.sh. Exiting${reset}\n\n"
+ exit 1
+ else
+ mkdir -p $vm_dir
+ fi
+
+ chmod 700 $vm_dir
+
+ if [ ! -d $vm_dir ]; then
+ echo -e "\n\n${red}ERROR: Unable to create VM Directory: $vm_dir Exiting${reset}\n\n"
+ exit -1
+ fi
+}
+
##find ip of interface
##params: interface name
function find_ip {
@@ -353,27 +373,31 @@ install_vagrant() {
##params: none
##usage: clean_tmp()
clean_tmp() {
- rm -rf /tmp/bgs_vagrant
+ rm -rf $vm_dir/foreman_vm
}
-##clone bgs vagrant version 1.0 using git
+##clone genesis and move to node vm dir
##params: none
##usage: clone_bgs
clone_bgs() {
cd /tmp/
+ rm -rf /tmp/genesis/
- ##will change this to be opnfv repo when commit is done
- if ! git clone -b v1.0 https://github.com/trozet/bgs_vagrant.git; then
- printf '%s\n' 'deploy.sh: Unable to clone vagrant repo' >&2
+ ##clone artifacts and move into foreman_vm dir
+ if ! git clone https://gerrit.opnfv.org/gerrit/genesis; then
+ printf '%s\n' 'deploy.sh: Unable to clone genesis repo' >&2
exit 1
fi
+
+ mv -f /tmp/genesis/foreman/ci $vm_dir/foreman_vm
+ rm -rf /tmp/genesis/
}
##validates the network settings and update VagrantFile with network settings
##params: none
##usage: configure_network()
configure_network() {
- cd /tmp/bgs_vagrant
+ cd $vm_dir/foreman_vm
echo "${blue}Detecting network configuration...${reset}"
##detect host 1 or 3 interface configuration
@@ -792,7 +816,7 @@ start_foreman() {
##stand up vagrant
if ! vagrant up; then
- printf '%s\n' 'deploy.sh: Unable to start vagrant' >&2
+ printf '%s\n' 'deploy.sh: Unable to complete Foreman VM install' >&2
exit 1
else
echo "${blue}Foreman VM is up! ${reset}"
@@ -819,19 +843,22 @@ start_virtual_nodes() {
compute_wait_completed=false
for node in ${nodes}; do
- cd /tmp
+ cd /tmp/
##remove VM nodes incase it wasn't cleaned up
- rm -rf /tmp/$node
+ rm -rf $vm_dir/$node
+ rm -rf /tmp/genesis/
- ##clone bgs vagrant
- ##will change this to be opnfv repo when commit is done
- if ! git clone https://github.com/trozet/bgs_vagrant.git $node; then
+ ##clone genesis and move into node folder
+ if ! git clone https://gerrit.opnfv.org/gerrit/genesis; then
printf '%s\n' 'deploy.sh: Unable to clone vagrant repo' >&2
exit 1
fi
- cd $node
+ mv -f /tmp/genesis/foreman/ci $vm_dir/$node
+ rm -rf /tmp/genesis/
+
+ cd $vm_dir/$node
if [ $base_config ]; then
if ! cp -f $base_config opnfv_ksgen_settings.yml; then
@@ -994,7 +1021,7 @@ start_virtual_nodes() {
echo "${blue} Waiting for puppet to complete on the nodes... ${reset}"
##check puppet is complete
##ssh into foreman server, run check to verify puppet is complete
- pushd /tmp/bgs_vagrant
+ pushd $vm_dir/foreman_vm
if ! vagrant ssh -c "/opt/khaleesi/run.sh --no-logs --use /vagrant/opnfv_ksgen_settings.yml /opt/khaleesi/playbooks/validate_opnfv-vm.yml"; then
echo "${red} Failed to validate puppet completion on nodes ${reset}"
exit 1
@@ -1004,7 +1031,7 @@ start_virtual_nodes() {
popd
##add routes back to nodes
for node in ${nodes}; do
- pushd /tmp/$node
+ pushd $vm_dir/$node
if ! vagrant ssh -c "route | grep default | grep $this_default_gw"; then
echo "${blue} Adding public route back to $node! ${reset}"
vagrant ssh -c "route add default gw $this_default_gw"
@@ -1029,6 +1056,7 @@ main() {
install_ansible
install_vagrant
clean_tmp
+ verify_vm_dir
clone_bgs
configure_network
configure_virtual