5 # Generic parameters used across all ONAP components
6 'key_name' => 'ecomp_key',
8 'nexus_repo' => 'https://nexus.onap.org/content/sites/raw',
9 'nexus_repo_root' => 'https://nexus.onap.org',
10 'nexus_url_snapshot' => 'https://nexus.onap.org/content/repositories/snapshots',
11 'nexus_docker_repo' => 'nexus3.onap.org:10001',
12 'nexus_username' => 'docker',
13 'nexus_password' => 'docker',
14 'dmaap_topic' => 'AUTO',
15 'artifacts_version' => '1.0.0',
16 'docker_version' => 'latest',
17 # Parameters for DCAE instantiation
18 'dcae_zone' => 'iad4',
20 'openstack_tenant_id' => '',
21 'openstack_username' => '',
22 'openstack_api_key' => '',
23 'openstack_password' => '',
24 'odl_version' => '0.5.3-Boron-SR3',
25 # Parameters for enabling features
27 'build_image' => 'True',
28 'clone_repo' => 'True',
29 'compile_repo' => 'False',
30 'enable_oparent' => 'True',
31 'skip_get_images' => 'False',
32 'skip_install' => 'True'
36 :virtualbox => 'ubuntu/trusty64',
37 :libvirt => 'elastic/ubuntu-14.04-x86_64',
44 :ips => ['10.252.0.6', "192.168.50.6"],
49 :groups => ["individual"],
53 :name => "all-in-one",
54 :ips => ['10.252.1.3', "192.168.51.3"],
59 :groups => ["all-in-one"],
60 :flavor => 'm1.xlarge',
61 :args => ['mr', 'sdc', 'aai', 'mso', 'robot', 'vid', 'sdnc', 'portal', 'dcae', 'policy', 'appc', 'vfc', 'ccsdk', 'multicloud', 'vnfsdk', 'vpp', 'msb'],
65 :ips => ['10.252.0.14', "192.168.50.14"],
70 :groups => ["individual"],
75 :ips => ['10.252.0.19', "192.168.50.19"],
80 :groups => ["individual"],
85 :ips => ['10.252.0.12', "192.168.50.12"],
90 :groups => ["individual"],
95 :ips => ['10.252.0.3', "192.168.50.3"],
100 :groups => ["individual"],
101 :flavor => 'm1.small',
105 :name => "message-router",
106 :ips => ['10.252.0.4', "192.168.50.4"],
111 :groups => ["individual"],
116 :ips => ['10.252.0.20', "192.168.50.20"],
121 :groups => ["individual"],
126 :ips => ['10.252.0.7', "192.168.50.7"],
131 :groups => ["individual"],
135 :name => "multicloud",
136 :ips => ['10.252.0.16', "192.168.50.16"],
141 :groups => ["individual"],
142 :args => ["multicloud"],
146 :ips => ['10.252.0.21', "192.168.50.21"],
151 :groups => ["individual"],
155 { :guest => 8880, :host => 8880, :guest_ip => '192.168.50.21' },
156 { :guest => 8989, :host => 8989, :guest_ip => '192.168.50.21' },
161 :ips => ['10.252.0.13', "192.168.50.13"],
166 :groups => ["individual"],
171 :ips => ['10.252.0.11', "192.168.50.11"],
176 :groups => ["individual"],
181 :ips => ['10.252.0.8', "192.168.50.8"],
186 :groups => ["individual"],
191 :ips => ['10.252.0.5', "192.168.50.5"],
196 :groups => ["individual"],
202 :ips => ['10.252.0.10', "192.168.50.10"],
207 :groups => ["individual"],
212 :ips => ['10.252.2.3', "192.168.52.3"],
217 :groups => ["testing"],
218 :flavor => 'm1.small',
223 :ips => ['10.252.0.15', "192.168.50.15"],
228 :groups => ["individual"],
233 :ips => ['10.252.0.9', "192.168.50.9"],
238 :groups => ["individual"],
243 :ips => ['10.252.0.18', "192.168.50.18"],
248 :groups => ["individual"],
253 :ips => ['10.252.0.17', "192.168.50.17"],
258 :groups => ["individual"],
262 :name => "openstack",
263 :ips => ['10.252.3.3', "192.168.53.3"],
268 :groups => ["individual"],
269 :args => ['openstack'],
271 { :guest => 80, :host => 8888, :guest_ip => '192.168.53.4' },
272 { :guest => 6080, :host => 6080, :guest_ip => '192.168.53.4' },
277 run_path = 'vagrant_utils/postinstall.sh'
278 sdc_volume = 'vol1-sdc-data.vdi'
280 Vagrant.require_version ">= 1.8.6"
282 # Determine the provider used
283 provider = (ENV['VAGRANT_DEFAULT_PROVIDER'] || :virtualbox).to_sym
284 puts "[INFO] Provider: #{provider} "
286 vd_conf = ENV.fetch('VD_CONF', 'etc/settings.yaml')
287 if File.exist?(vd_conf)
289 user_conf = YAML.load_file(vd_conf)
290 configuration.update(user_conf)
293 # Set network interface
294 net_interface = 'vboxnet0'
295 is_windows = Gem.win_platform?
297 net_interface = 'VirtualBox Host-Only Ethernet Adapter #2'
299 puts "[INFO] Net interface: #{net_interface}"
302 # If argument is given use it. Otherwise use Env: DEPLOY_MODE else use default
303 requested_machine = ARGV[1]
305 deploy_mode = ENV.fetch('DEPLOY_MODE', 'individual')
306 if requested_machine != nil
307 if requested_machine.include?("all-in-one") || requested_machine.include?("testing")
308 deploy_mode = requested_machine
312 # Catch the status of all machines
313 if ARGV[0] == 'status' || ARGV[0] == 'destroy'
317 puts "[INFO] Deploy Mode: #{deploy_mode}"
319 # In case of all-in-one or testing clean the nodes list
322 nodes.select! do |node|
323 if node[:name].include?("all-in-one")
329 nodes.select! do |node|
330 if node[:groups][0].include?("individual")
336 nodes.select! do |node|
337 if node[:name].include?("testing")
343 Vagrant.configure("2") do |config|
346 if ENV['http_proxy'] != nil and ENV['https_proxy'] != nil
347 if not Vagrant.has_plugin?('vagrant-proxyconf')
348 system 'vagrant plugin install vagrant-proxyconf'
349 raise 'vagrant-proxyconf was installed but it requires to execute again'
351 config.proxy.http = ENV['http_proxy']
352 config.proxy.https = ENV['https_proxy']
353 configuration['socks_proxy'] = ENV['socks_proxy']
356 if Vagrant.has_plugin?('vagrant-vbguest')
357 puts 'vagrant-vbguest auto_update feature will be disable to avoid sharing conflicts'
358 config.vbguest.auto_update = false
361 if provider == :libvirt
362 if not Vagrant.has_plugin?('vagrant-libvirt')
363 system 'vagrant plugin install vagrant-libvirt'
364 raise 'vagrant-libvirt was installed but it requires to execute again'
368 if provider == :openstack
369 config.ssh.username = 'ubuntu'
370 if not Vagrant.has_plugin?('vagrant-openstack-provider')
371 system 'vagrant plugin install vagrant-openstack-provider'
372 raise 'vagrant-openstack-provider was installed but it requires to execute again'
377 config.vm.define node[:name] do |nodeconfig|
379 # NO_PROXY definitions
380 if ENV['no_proxy'] != nil
381 if not Vagrant.has_plugin?('vagrant-proxyconf')
382 system 'vagrant plugin install vagrant-proxyconf'
383 raise 'vagrant-proxyconf was installed but it requires to execute again'
385 config.proxy.no_proxy = node[:ips].join(",") + "," + ENV['no_proxy']
390 nodeconfig.vm.provider "virtualbox" do |vbox|
391 vbox.customize ['modifyvm', :id, '--nictype1', 'virtio']
392 vbox.customize ['modifyvm', :id, '--audio', 'none']
393 vbox.customize ['modifyvm', :id, '--vram', '1']
394 vbox.customize ['modifyvm', :id, "--cpuhotplug", "off"]
395 vbox.customize ['modifyvm', :id, "--cpuexecutioncap", node[:cpu]]
396 vbox.customize ['modifyvm', :id, "--cpus", node[:cpus]]
397 vbox.customize ["modifyvm", :id, "--memory", node[:ram]]
400 nodeconfig.vm.network :private_network,
402 :name => net_interface,
405 nodeconfig.vm.network :private_network,
407 :ip => node[:ips][1],
412 volume_file = node[:name] + '-vol1-data.vdi'
413 unless File.exist?(volume_file)
414 vbox.customize ['createhd', '--filename', volume_file, '--size', node[:hd]]
416 vbox.customize ['storageattach', :id, '--storagectl', 'SATAController', '--port', 1, '--device', 0, '--type', 'hdd', '--medium', volume_file]
420 nodeconfig.vm.provider "libvirt" do |lbox|
421 lbox.memory = node[:ram]
423 lbox.cpu_mode = 'host-passthrough'
424 lbox.cpus = node[:cpus]
427 nodeconfig.vm.network :private_network,
430 nodeconfig.vm.network :private_network,
431 :ip => node[:ips][1],
436 lbox.storage :file, bus: 'sata', device: 'sda', size: node[:hd]
439 if node.has_key? :fwds
440 node[:fwds].each do |fwd|
441 nodeconfig.vm.network :forwarded_port,
442 :guest => fwd[:guest],
443 :guest_ip => fwd[:guest_ip],
445 :host_ip => "0.0.0.0"
449 nodeconfig.vm.provider :openstack do |obox|
450 obox.openstack_auth_url = ENV.fetch('OS_AUTH_URL', '')
451 obox.tenant_name = ENV.fetch('OS_TENANT_NAME', '')
452 obox.username = ENV.fetch('OS_USERNAME', '')
453 obox.password = ENV.fetch('OS_PASSWORD', '')
454 obox.region = ENV.fetch('OS_REGION_NAME', '')
455 obox.identity_api_version = ENV.fetch('OS_IDENTITY_API_VERSION', '')
456 obox.domain_name = ENV.fetch('OS_PROJECT_DOMAIN_ID', '')
457 obox.project_name = ENV.fetch('OS_PROJECT_NAME', '')
458 obox.floating_ip_pool = ENV.fetch('OS_FLOATING_IP_POOL', '')
459 obox.floating_ip_pool_always_allocate = (ENV['OS_FLOATING_IP_ALWAYS_ALLOCATE'] == 'true')
460 obox.image = ENV.fetch('OS_IMAGE', '')
461 obox.security_groups = [ENV.fetch('OS_SEC_GROUP', '')]
462 obox.networks = ENV.fetch('OS_NETWORK', '')
463 obox.flavor = node[:flavor]
464 obox.server_name = node[:name]
468 if "openstack" == node[:name]
470 :virtualbox => 'ubuntu/xenial64',
471 :libvirt => 'elastic/ubuntu-16.04-x86_64'
474 nodeconfig.vm.box = box[provider]
477 nodeconfig.vm.hostname = node[:name]
480 nodeconfig.vm.synced_folder ".", "/vagrant", disabled: true
481 nodeconfig.vm.synced_folder './opt', '/opt/', create: true, type: "nfs"
482 nodeconfig.vm.synced_folder './lib', '/var/onap/', create: true, type: "nfs"
484 nodeconfig.vm.synced_folder '~/.m2', '/root/.m2/', create: true
489 if node[:name].include? "testing"
490 nodeconfig.vm.synced_folder './tests', '/var/onap_tests/', create: true
491 test_suite = ENV.fetch('TEST_SUITE', '*')
492 test_case = ENV.fetch('TEST_CASE', '*')
494 run_path = 'vagrant_utils/unit_testing.sh'
495 node[:args] = [test_suite, test_case]
497 configuration['skip_get_images'] = ENV.fetch('SKIP_GET_IMAGES', configuration['skip_get_images'])
498 configuration['skip_install'] = ENV.fetch('SKIP_INSTALL', configuration['skip_install'])
501 if node[:name].include? "vfc"
502 nodeconfig.vm.provision 'docker'
505 nodeconfig.vm.provision 'shell' do |s|
508 s.env = configuration