blob: be9da5e490a24bd8e9e1024f1c4dc19d5157a478 [file] [log] [blame]
# -*- mode: ruby -*-
# vi: set ft=ruby :
# Vagrantfile API/syntax version. Don't touch unless you know what you're doing!
VAGRANTFILE_API_VERSION = "2"
$setup = <<SCRIPT
sudo apt-get update -qq
SCRIPT
$setup_integ = <<SCRIPT
cp -R /vagrant integration-tests
cd integration-tests && ./install_apps.py install_all 2>&1 | tee install.log
SCRIPT
$setup_ssh = <<SCRIPT
mkdir -p ~/.ssh
cp /vagrant/temp/sshkey ~/.ssh/id_rsa
cp /vagrant/temp/sshkey.pub ~/.ssh/id_rsa.pub
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
chown -R vagrant:vagrant ~/.ssh
chmod -R 700 ~/.ssh
SCRIPT
$setup_a = <<SCRIPT
cat > ~/.ssh/config <<EOF
Host 192.168.*.*
StrictHostKeyChecking no
EOF
sudo ip route add 192.168.3.0/24 via 192.168.2.3
sudo ip -6 addr add fd01::3/64 dev eth1
sudo ip -6 addr add fd02::2/64 dev eth2
sudo ip -6 route add fd03::/64 via fd02::3
SCRIPT
$setup_d = <<SCRIPT
ip route add 192.168.2.0/24 via 192.168.3.2
ip -6 addr add fd03::3/64 dev eth1
ip -6 route add fd02::/64 via fd03::2
SCRIPT
$setup_router = <<SCRIPT
echo 1 > /proc/sys/net/ipv4/ip_forward
echo 1 > /proc/sys/net/ipv6/conf/all/forwarding
ip -6 addr add fd02::3/64 dev eth1
ip -6 addr add fd03::2/64 dev eth2
SCRIPT
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
config.vm.box = "ubuntu/trusty64"
config.vm.provider "virtualbox" do |vb|
vb.memory = "512"
vb.cpus = "1"
vb.customize ["storagectl", :id, "--name", "SATAController", "--hostiocache", "off"]
end
config.vm.define "template" do |t|
t.vm.provision "shell", inline: $setup, privileged: false
t.vm.provision "shell", inline: $setup_ssh, privileged: false
t.vm.provision "shell", inline: $setup_integ, privileged: false
config.vm.provider "virtualbox" do |vb|
vb.memory = "6144"
vb.cpus = "4"
end
end
config.vm.define "A" do |a|
a.vm.box = "nfd-integ"
a.vm.network "private_network", ip: "192.168.1.3", virtualbox__intnet: "ABC-switch"
a.vm.network "private_network", ip: "192.168.2.2", virtualbox__intnet: "AtoRouter"
a.vm.provision "shell", inline: $setup, privileged: false
a.vm.provision "shell", inline: $setup_a, privileged: false
end
config.vm.define "B" do |b|
b.vm.box = "nfd-integ"
b.vm.network "private_network", ip: "192.168.1.2", virtualbox__intnet: "ABC-switch"
b.vm.provision "shell", inline: $setup, privileged: false
b.vm.provision "shell", inline: "ip -6 addr add fd01::2/64 dev eth1"
end
config.vm.define "C" do |c|
c.vm.box = "nfd-integ"
c.vm.network "private_network", ip: "192.168.1.4", virtualbox__intnet: "ABC-switch"
c.vm.provision "shell", inline: $setup, privileged: false
c.vm.provision "shell", inline: "ip -6 addr add fd01::4/64 dev eth1"
end
config.vm.define "D" do |d|
d.vm.box = "nfd-integ"
d.vm.network "private_network", ip: "192.168.3.3", virtualbox__intnet: "DtoRouter"
d.vm.provision "shell", inline: $setup, privileged: false
d.vm.provision "shell", inline: $setup_d
end
config.vm.define "router" do |router|
router.vm.network "private_network", ip: "192.168.2.3", virtualbox__intnet: "AtoRouter"
router.vm.network "private_network", ip: "192.168.3.2", virtualbox__intnet: "DtoRouter"
router.vm.provision "shell", inline: $setup_router
router.vm.provider "virtualbox" do |vb|
vb.memory = "128"
vb.cpus = "1"
end
end
end