-# 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:
+# -*- mode: ruby -*-
+# vi: set ft=ruby :
-# http://www.apache.org/licenses/LICENSE-2.0
+Vagrant.configure("2") do |config|
-# 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.
+ # Configure cached packages to be shared between instances of the
+ # same base box.
+ if Vagrant.has_plugin?("vagrant-cachier")
+ config.cache.scope = :box
+ end
-# -*- 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
-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
- cd /vagrant
- vpp_pkgs="$(echo vpp*.deb)"
- if [ "$vpp_pkgs" != "vpp*.deb" ]; then
- if [ "$(dpkg -l | grep vpp)" != "" ] ; then
- sudo apt-get -y purge vpp\*
- fi
- sudo dpkg -i vpp*.deb
- vppcfg="/etc/vpp/startup.conf"
- sudo rm -f $vppcfg.orig
- sudo cp $vppcfg $vppcfg.orig
- echo -e '\nheapsize 512M' | sudo tee -a $vppcfg
- fi
-SHELL
-
-
-def add_dut(config, name, mgmt_ip, net1, net2)
- config.vm.define name do |node|
- node.vm.box = "puppetlabs/ubuntu-14.04-64-nocm"
- 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 = "2048"
- vb.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
- vb.customize ["modifyvm", :id, "--nicpromisc4", "allow-all"]
+ # Configure proxy if needed.
+ if Vagrant.has_plugin?("vagrant-proxyconf")
+ config.proxy.http = "http://192.168.0.2:3128/"
+ config.proxy.https = "http://192.168.0.2:3128/"
+ config.proxy.ftp = "http://192.168.0.2:3128/"
+ config.proxy.no_proxy = "localhost,127.0.0.1"
end
- end
-end
+ # Configure testing network interfaces (tg).
+ config.vm.network :private_network, type: "dhcp", auto_config: false, virtualbox__intnet: "link1", nic_type: "82545em", mac: "0800270fe04d"
+ config.vm.network :private_network, type: "dhcp", auto_config: false, virtualbox__intnet: "link2", nic_type: "82545em", mac: "08002761f7ad"
+ config.vm.network :private_network, type: "dhcp", auto_config: false, virtualbox__intnet: "link3", nic_type: "82545em", mac: "080027dc5da4"
-Vagrant.configure(2) do |config|
- 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"]
+ # Configure testing network interfaces (sut).
+ config.vm.network :private_network, type: "dhcp", auto_config: false, virtualbox__intnet: "link1", nic_type: "82545em", mac: "080027385e58"
+ config.vm.network :private_network, type: "dhcp", auto_config: false, virtualbox__intnet: "link2", nic_type: "82545em", mac: "080027e3f542"
+ config.vm.network :private_network, type: "dhcp", auto_config: false, virtualbox__intnet: "link3", nic_type: "82545em", mac: "0800274f7c63"
+
+ # Provision the box using ansible local (no Ansible installation needed
+ # on host).
+ config.vm.provision "ansible_local" do |ansible|
+ ansible.version = "latest"
+ ansible.compatibility_mode = "2.0"
+ ansible.become = true
+ ansible.verbose = false
+ ansible.limit = "all"
+ ansible.inventory_path = "ansible/vppdevice"
+ ansible.playbook = "ansible/master.yml"
end
- end
- config.vm.define "tg" do |tg|
- tg.vm.box = "puppetlabs/ubuntu-14.04-64-nocm"
- 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: "tg_dut1"
- tg.vm.network "private_network", type: "dhcp", auto_config: false,
- virtualbox__intnet: "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"]
+
+ config.vm.post_up_message = <<-MESSAGE
+ Your virtual machine is configured!
+
+ Login to the box using command:
+ vagrant ssh
+
+ To run some tests use the VPP Device bootstrap script, eg:
+ cd /home/vagrant/csit/resources/libraries/bash/entry
+ ./bootstrap_vpp_device.sh csit-vpp-device-master-ubuntu1804-1n-vbox
+
+ To run only selected tests based on TAGS, export environment variables
+ before running the test suite:
+ export GERRIT_EVENT_TYPE="comment-added"
+ export GERRIT_EVENT_COMMENT_TEXT="devicetest memif"
+ ./bootstrap_vpp_device.sh csit-vpp-device-master-ubuntu1804-1n-vbox
+
+ For more information please visit:
+ https://docs.fd.io/csit/rls1908/report/index.html
+ https://docs.fd.io/csit/master/trending/
+
+ MESSAGE
+
+ config.vm.define "bionic", primary: true do |bionic|
+ # Base box definition, currently using
+ # Official Ubuntu 18.04 LTS (Bionic Beaver) Daily Build
+ bionic.vm.box = "ubuntu/bionic64"
+ bionic.vm.box_version = "20190724.1.0"
+ bionic.vm.box_check_update = false
+
+ # Virtualbox machine configuration
+ bionic.vm.provider "virtualbox" do |vb|
+ vb.name = "vppdevice-bionic"
+ vb.gui = false
+ vb.memory = "4096"
+ vb.cpus = "4"
+ vb.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc4", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc5", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc6", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc7", "allow-all"]
+ end
end
- end
+ config.vm.define "centos8", autostart: false do |centos8|
+ # Base box definition, currently using
+ # Unofficial Centos8 (as currently there is no offical build)
+ centos8.vm.box = "geerlingguy/centos8"
+ centos8.vm.box_version = "1.0.2"
+ centos8.vm.box_check_update = false
- add_dut(config, "dut1", "192.168.255.101/24", "tg_dut1", "dut1_dut2")
- add_dut(config, "dut2", "192.168.255.102/24", "tg_dut2", "dut1_dut2")
+ # Virtualbox machine configuration
+ centos8.vm.provider "virtualbox" do |vb|
+ vb.name = "vppdevice-centos8"
+ vb.gui = false
+ vb.memory = "4096"
+ vb.cpus = "4"
+ vb.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc4", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc5", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc6", "allow-all"]
+ vb.customize ["modifyvm", :id, "--nicpromisc7", "allow-all"]
+ end
+ end
end
-