Added support for kolla-cli development

Updated the vagrant dev environment to include support
for development and testing of the kolla-cli

Change-Id: I1d8f66cced7f0a9cc37e3b296c5ae10ab989f736
This commit is contained in:
Borne Mace 2018-04-19 12:36:31 -07:00
parent d6861961fb
commit e751a7cc07
3 changed files with 10 additions and 4 deletions

View File

@ -15,10 +15,11 @@ end
vagrant_dir = File.expand_path(File.dirname(__FILE__)) vagrant_dir = File.expand_path(File.dirname(__FILE__))
# get kolla and kolla-ansibe repos path relative to current directory # get kolla, kolla-ansibe and kolla-cli repos path relative to current directory
# they will be used by the bootstrap script to configure the nodes # they will be used by the bootstrap script to configure the nodes
kolla_ansible_repo_path = File.expand_path(File.join(vagrant_dir, '..', '..', '..')) kolla_ansible_repo_path = File.expand_path(File.join(vagrant_dir, '..', '..', '..'))
kolla_repo_path = File.expand_path(File.join(vagrant_dir, '..', '..', '..', '..', 'kolla')) kolla_repo_path = File.expand_path(File.join(vagrant_dir, '..', '..', '..', '..', 'kolla'))
kolla_cli_repo_path = File.expand_path(File.join(vagrant_dir, '..', '..', '..', '..', 'kolla-cli'))
# Vagrantfile.custom contains user customization for the Vagrantfile # Vagrantfile.custom contains user customization for the Vagrantfile
# You shouldn't have to edit the Vagrantfile, ever. # You shouldn't have to edit the Vagrantfile, ever.
@ -181,6 +182,7 @@ Vagrant.configure(2) do |config|
vagrant_shared_folder = "#{user_home}/sync" vagrant_shared_folder = "#{user_home}/sync"
kolla_path = "#{user_home}/kolla" kolla_path = "#{user_home}/kolla"
kolla_ansible_path = "#{user_home}/kolla-ansible" kolla_ansible_path = "#{user_home}/kolla-ansible"
kolla_cli_path = "#{user_home}/kolla-cli"
# Next to the hostonly NAT-network there is a host-only network with all # Next to the hostonly NAT-network there is a host-only network with all
# nodes attached. Plus, each node receives a 3rd adapter connected to the # nodes attached. Plus, each node receives a 3rd adapter connected to the
@ -230,9 +232,10 @@ Vagrant.configure(2) do |config|
# The operator controls the deployment # The operator controls the deployment
config.vm.define "operator", primary: true do |admin| config.vm.define "operator", primary: true do |admin|
admin.vm.hostname = "operator.local" admin.vm.hostname = "operator.local"
admin.vm.provision :shell, path: PROVISION_SCRIPT, args: "operator #{MULTINODE ? 'multinode' : 'aio'} #{kolla_path} #{kolla_ansible_path}" admin.vm.provision :shell, path: PROVISION_SCRIPT, args: "operator #{MULTINODE ? 'multinode' : 'aio'} #{kolla_path} #{kolla_ansible_path} #{kolla_cli_path}"
admin.vm.synced_folder kolla_ansible_repo_path, kolla_ansible_path, create:"True", type: get_default(:sync_method) admin.vm.synced_folder kolla_ansible_repo_path, kolla_ansible_path, create:"True", type: get_default(:sync_method)
admin.vm.synced_folder kolla_repo_path, kolla_path, create:"True", type: get_default(:sync_method) admin.vm.synced_folder kolla_repo_path, kolla_path, create:"True", type: get_default(:sync_method)
admin.vm.synced_folder kolla_cli_repo_path, kolla_cli_path, create:"True", type: get_default(:sync_method)
admin.vm.synced_folder File.join(vagrant_dir, 'storage', 'operator'), "/data/host", create:"True", type: get_default(:sync_method) admin.vm.synced_folder File.join(vagrant_dir, 'storage', 'operator'), "/data/host", create:"True", type: get_default(:sync_method)
admin.vm.synced_folder File.join(vagrant_dir, 'storage', 'shared'), "/data/shared", create:"True", type: get_default(:sync_method) admin.vm.synced_folder File.join(vagrant_dir, 'storage', 'shared'), "/data/shared", create:"True", type: get_default(:sync_method)
admin.vm.synced_folder ".", vagrant_shared_folder, disabled: true admin.vm.synced_folder ".", vagrant_shared_folder, disabled: true
@ -253,7 +256,7 @@ Vagrant.configure(2) do |config|
hostname = "#{node_type}0#{i}" hostname = "#{node_type}0#{i}"
config.vm.define hostname do |node| config.vm.define hostname do |node|
node.vm.hostname = "#{hostname}.local" node.vm.hostname = "#{hostname}.local"
node.vm.provision :shell, path: PROVISION_SCRIPT, args: "#{hostname} multinode #{kolla_path} #{kolla_ansible_path}" node.vm.provision :shell, path: PROVISION_SCRIPT, args: "#{hostname} multinode #{kolla_path} #{kolla_ansible_path} #{kolla_cli_path}"
node.vm.synced_folder File.join(vagrant_dir, 'storage', node_type), "/data/host", create:"True", type: get_default(:sync_method) node.vm.synced_folder File.join(vagrant_dir, 'storage', node_type), "/data/host", create:"True", type: get_default(:sync_method)
node.vm.synced_folder File.join(vagrant_dir, 'storage', 'shared'), "/data/shared", create:"True", type: get_default(:sync_method) node.vm.synced_folder File.join(vagrant_dir, 'storage', 'shared'), "/data/shared", create:"True", type: get_default(:sync_method)
node.vm.synced_folder ".", vagrant_shared_folder, disabled: true node.vm.synced_folder ".", vagrant_shared_folder, disabled: true

View File

@ -10,6 +10,7 @@ VM=$1
MODE=$2 MODE=$2
KOLLA_PATH=$3 KOLLA_PATH=$3
KOLLA_ANSIBLE_PATH=$4 KOLLA_ANSIBLE_PATH=$4
KOLLA_CLI_PATH=$5
export http_proxy= export http_proxy=
export https_proxy= export https_proxy=
@ -175,6 +176,7 @@ function configure_operator {
pip install ${KOLLA_ANSIBLE_PATH} pip install ${KOLLA_ANSIBLE_PATH}
pip install ${KOLLA_PATH} pip install ${KOLLA_PATH}
pip install ${KOLLA_CLI_PATH}
# Set selinux to permissive # Set selinux to permissive
if [[ "$(getenforce)" == "Enforcing" ]]; then if [[ "$(getenforce)" == "Enforcing" ]]; then

View File

@ -167,12 +167,13 @@ Find a location in the system's home directory and checkout Kolla repos:
.. code-block:: console .. code-block:: console
git clone https://git.openstack.org/openstack/kolla-cli
git clone https://git.openstack.org/openstack/kolla-ansible git clone https://git.openstack.org/openstack/kolla-ansible
git clone https://git.openstack.org/openstack/kolla git clone https://git.openstack.org/openstack/kolla
.. end .. end
Both repos must share the same parent directory so the bootstrap code can All repos must share the same parent directory so the bootstrap code can
locate them. locate them.
Developers can now tweak the Vagrantfile or bring up the default **all-in-one** Developers can now tweak the Vagrantfile or bring up the default **all-in-one**