Add Devstack machine and its provisioning

Issue-ID: ONAPARC-537
Change-Id: If725843c3e5ee47724a98d70611cbde464b9debc
Signed-off-by: Pawel Wieczorek <p.wieczorek2@samsung.com>
diff --git a/bootstrap/vagrant-minimal-onap/Vagrantfile b/bootstrap/vagrant-minimal-onap/Vagrantfile
index 3685df2..53d78b5 100644
--- a/bootstrap/vagrant-minimal-onap/Vagrantfile
+++ b/bootstrap/vagrant-minimal-onap/Vagrantfile
@@ -8,21 +8,25 @@
 synced_folder_main = "/vagrant"
 synced_folder_config = "#{synced_folder_main}/config"
 synced_folder_tools_config = "#{synced_folder_main}/tools/config"
+os_config = "#{synced_folder_config}/local.conf"
 cluster_yml = "cluster.yml"
 apt_prefs_dir = "/etc/apt/apt.conf.d"
 apt_prefs = "95silent-approval"
 
 vm_memory = 2 * 1024
+vm_memory_os = 8 * 1024
 vm_cpus = 1
+vm_cpus_os = 2
 vm_box = "generic/ubuntu1804"
 
 operation = { name: 'operator', hostname: 'operator', ip: '172.17.4.254' }
+devstack = { name: 'devstack', hostname: 'devstack', ip: '172.17.4.200' }
 cluster = [
   { name: 'control', hostname: 'control', ip: '172.17.4.100' },
   { name: 'worker', hostname: 'worker', ip: '172.17.4.101' }
 ]
 
-all = cluster.dup << operation
+all = cluster.dup << operation << devstack
 
 operation_post_msg = "Run: \"vagrant provision #{operation[:name]} --provision-with=rke_up,setup_kubectl\" to complete cluster creation"
 
@@ -32,6 +36,19 @@
   echo nameserver "$HOST_IP" | tee /etc/resolv.conf
 SCRIPT
 
+$enable_ipv6 = <<-SCRIPT
+  sed -i'' 's/net.ipv6.conf.all.disable_ipv6.*$/net.ipv6.conf.all.disable_ipv6 = 0/' /etc/sysctl.conf
+  sysctl -p
+SCRIPT
+
+$setup_devstack = <<-SCRIPT
+  CONFIG="$1"
+  git clone https://opendev.org/openstack/devstack
+  cd devstack
+  cp "$CONFIG" .
+  ./stack.sh
+SCRIPT
+
 $add_to_docker_group = <<-SCRIPT
   USER="$1"
   echo "Adding ${USER} to 'docker' group"
@@ -97,18 +114,25 @@
 
       config.vm.provider :virtualbox do |v|
         v.name = machine[:name]
-        v.memory = vm_memory
-        v.cpus = vm_cpus
+        v.memory = machine[:name] != 'devstack' ? vm_memory : vm_memory_os
+        v.cpus = machine[:name] != 'devstack' ? vm_cpus : vm_cpus_os
       end
 
       config.vm.provider :libvirt do |v|
-        v.memory = vm_memory
-        v.cpus = vm_cpus
+        v.memory = machine[:name] != 'devstack' ? vm_memory : vm_memory_os
+        v.cpus = machine[:name] != 'devstack' ? vm_cpus : vm_cpus_os
       end
 
       config.vm.network :private_network, ip: machine[:ip]
       config.vm.provision "replace_dns", type: :shell, run: "always", inline: $replace_dns, args: host_ip
 
+      if machine[:name] == 'devstack'
+        config.vm.synced_folder ".", synced_folder_main, type: "rsync", rsync__exclude: "Vagrantfile"
+
+        config.vm.provision "enable_ipv6", type: :shell, run: "always", inline: $enable_ipv6
+        config.vm.provision "setup_devstack", type: :shell, privileged: false, inline: $setup_devstack, args: os_config
+      end
+
       if machine[:name] == 'control'
         config.vm.provision "customize_control", type: :shell, path: "tools/imported/openstack-k8s-controlnode.sh"
         config.vm.provision "fix_groups_control", type: :shell, inline: $add_to_docker_group, args: vagrant_user
diff --git a/bootstrap/vagrant-minimal-onap/config/local.conf b/bootstrap/vagrant-minimal-onap/config/local.conf
new file mode 100644
index 0000000..f891286
--- /dev/null
+++ b/bootstrap/vagrant-minimal-onap/config/local.conf
@@ -0,0 +1,5 @@
+[[local|localrc]]
+ADMIN_PASSWORD=default123456!
+DATABASE_PASSWORD=$ADMIN_PASSWORD
+RABBIT_PASSWORD=$ADMIN_PASSWORD
+SERVICE_PASSWORD=$ADMIN_PASSWORD