1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
# Copyright (c) 2016 Cisco and/or its affiliates.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at:
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# -*- mode: ruby -*-
# vi: set ts=2 sw=2 sts=2 et ft=ruby :
$user_addition = <<-SHELL
sudo deluser csit
sudo adduser --disabled-password --gecos "" csit
echo csit:csit | sudo chpasswd
sudo adduser csit vagrant
id csit
echo "csit ALL=(root) NOPASSWD:ALL" | sudo tee /etc/sudoers.d/csit
sudo chmod 0440 /etc/sudoers.d/csit
SHELL
$install_prereqs = <<-SHELL
sudo apt-get -y update
sudo apt-get -y -f install
sudo apt-get -y install python-virtualenv python-dev iproute2 debhelper dkms
sudo update-alternatives --install /bin/sh sh /bin/bash 100
SHELL
$install_vpp = <<-SHELL
sudo apt-get -y purge vpp\*
cd /vagrant
vpp_pkgs="$(echo vpp*.deb)"
if [ "$vpp_pkgs" != "vpp*.deb" ]; then
sudo dpkg -i vpp*.deb
fi
SHELL
def add_dut(config, name, mgmt_ip, net1, net2)
config.vm.define name do |node|
node.vm.box = "fdio-csit/ubuntu-14.04.4_2016-05-25_1.0"
node.vm.hostname = name
node.vm.provision "shell", inline: $user_addition
node.vm.provision "shell", inline: $install_prereqs
node.vm.provision "shell", inline: $install_vpp
node.vm.network "private_network", ip: mgmt_ip
node.vm.network "private_network", type: "dhcp", auto_config: false,
virtualbox__intnet: net1
node.vm.network "private_network", type: "dhcp", auto_config: false,
virtualbox__intnet: net2
node.vm.provider "virtualbox" do |vb|
vb.memory = "3232"
vb.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
vb.customize ["modifyvm", :id, "--nicpromisc4", "allow-all"]
end
end
end
net_prefix = ''
if ENV.key?('VPP_VAGRANT_NET_PREFIX')
net_prefix = ENV['VPP_VAGRANT_NET_PREFIX'] + '_'
end
Vagrant.configure(2) do |config|
config.vm.box_check_update = false
config.vm.define "tg" do |tg|
if Vagrant.has_plugin?("vagrant-proxyconf")
if ENV["http_proxy"]
config.proxy.http = ENV["http_proxy"]
end
if ENV["https_proxy"]
config.proxy.https = ENV["https_proxy"]
end
if ENV["no_proxy"]
config.proxy.no_proxy = ENV["no_proxy"]
end
end
tg.vm.box = "fdio-csit/ubuntu-14.04.4_2016-05-25_1.0"
tg.vm.hostname = "tg"
tg.vm.provision "shell", inline: $user_addition
tg.vm.provision "shell", inline: $install_prereqs
tg.vm.network "private_network", ip: '192.168.255.100/24'
tg.vm.network "private_network", type: "dhcp", auto_config: false,
virtualbox__intnet: net_prefix + "tg_dut1"
tg.vm.network "private_network", type: "dhcp", auto_config: false,
virtualbox__intnet: net_prefix + "tg_dut2"
tg.vm.provider "virtualbox" do |vb|
vb.memory = "2048"
vb.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
vb.customize ["modifyvm", :id, "--nicpromisc4", "allow-all"]
end
end
add_dut(config, "dut1", "192.168.255.101/24", net_prefix + "tg_dut1", net_prefix + "dut1_dut2")
add_dut(config, "dut2", "192.168.255.102/24", net_prefix + "tg_dut2", net_prefix + "dut1_dut2")
end
|