X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=resources%2Ftools%2Fvagrant%2FVagrantfile;h=f0b842c55061e153961c4a8d999bd341690b2ed1;hb=ed648e7c1f6493fd3bd01213ed0692a5b2e1a020;hp=86e78602aa394410b057a0e62e7fe0a303dcf3d0;hpb=d73918448ce23f52479008c6a61601abb24415ea;p=csit.git diff --git a/resources/tools/vagrant/Vagrantfile b/resources/tools/vagrant/Vagrantfile index 86e78602aa..f0b842c550 100644 --- a/resources/tools/vagrant/Vagrantfile +++ b/resources/tools/vagrant/Vagrantfile @@ -1,115 +1,107 @@ -# 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 - 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, port1, port2, port3, port4) - config.vm.box_check_update = false - 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: port1 - node.vm.network "private_network", type: "dhcp", auto_config: false, virtualbox__intnet: port2 - node.vm.network "private_network", type: "dhcp", auto_config: false, virtualbox__intnet: port3 - node.vm.network "private_network", type: "dhcp", auto_config: false, virtualbox__intnet: port4 - node.vm.provider "virtualbox" do |vb| - vb.memory = "3232" - 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"] + # 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 -net_prefix = '' -if ENV.key?('VPP_VAGRANT_NET_PREFIX') - net_prefix = ENV['VPP_VAGRANT_NET_PREFIX'] + '_' -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" -def add_tg(config, name, mgmt_ip, port1, port2, port3, port4, port5, port6) - config.vm.box_check_update = false - config.vm.define name do |node| - 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 + # 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 - 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.network "private_network", ip: mgmt_ip - node.vm.network "private_network", type: "dhcp", auto_config: false, virtualbox__intnet: port1 - node.vm.network "private_network", type: "dhcp", auto_config: false, virtualbox__intnet: port2 - node.vm.network "private_network", type: "dhcp", auto_config: false, virtualbox__intnet: port3 - node.vm.network "private_network", type: "dhcp", auto_config: false, virtualbox__intnet: port4 - node.vm.network "private_network", type: "dhcp", auto_config: false, virtualbox__intnet: port5 - node.vm.network "private_network", type: "dhcp", auto_config: false, virtualbox__intnet: port6 - node.vm.provider "virtualbox" do |vb| - vb.memory = "2048" - 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"] - vb.customize ["modifyvm", :id, "--nicpromisc8", "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 -end -Vagrant.configure(2) do |config| - add_tg(config, "tg", "192.168.255.100/24", net_prefix + "tg_tg", net_prefix + "tg_tg", net_prefix + "tg_dut1_1", net_prefix + "tg_dut1_2", net_prefix + "tg_dut2_1", net_prefix + "tg_dut2_2") - add_dut(config, "dut1", "192.168.255.101/24", net_prefix + "tg_dut1_1", net_prefix + "tg_dut1_2", net_prefix + "dut1_dut2_1", net_prefix + "dut1_dut2_2") - add_dut(config, "dut2", "192.168.255.102/24", net_prefix + "tg_dut2_1", net_prefix + "tg_dut2_2", net_prefix + "dut1_dut2_1", net_prefix + "dut1_dut2_2") + 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 + + # 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