# -*- mode: ruby -*- # vi: set ft=ruby : # Automated creation of testing environments on misc. platforms # Usage: # vagrant up OS # vagrant ssh OS command # vagrant halt OS # # packages_OS goals: # - have all dependencies installed # - have a working "virtualenv" command # - have a working "python3" command # # packages_prepare_OS goals: (for some older OS) # - adds additional package sources, so packages_OS can find all it needs. # # prepare_user goals: # - have a working "borg-env" virtual env installed, with code from "borg". # both directories are in /vagrant/borg/. def packages_prepare_wheezy return <<-EOF # debian 7 wheezy does not have lz4, but it is available from wheezy-backports: echo "deb http://http.debian.net/debian wheezy-backports main" > /etc/apt/sources.list.d/wheezy-backports.list EOF end def packages_prepare_precise return <<-EOF # ubuntu 12.04 precise does not have lz4, but it is available from a ppa: add-apt-repository -y ppa:gezakovacs/lz4 EOF end def packages_centos return <<-EOF yum install -y epel-release yum update -y yum install -y python34 python34-devel ln -s /usr/bin/python3.4 /usr/bin/python3 yum install -y openssl-devel openssl yum install -y libacl-devel libacl yum install -y lz4-devel yum install -y fuse-devel fuse pkgconfig yum install -y fakeroot gcc git yum install -y python-pip pip install virtualenv EOF end def packages_debianoid return <<-EOF apt-get update apt-get install -y python3-dev python3-setuptools apt-get install -y libssl-dev libacl1-dev liblz4-dev apt-get install -y libfuse-dev fuse pkg-config apt-get install -y fakeroot build-essential git # this way it works on older dists (like ubuntu 12.04) also: easy_install3 pip pip3 install virtualenv EOF end def packages_freebsd return <<-EOF pkg install -y python34 py34-setuptools34 ln -s /usr/local/bin/python3.4 /usr/local/bin/python3 pkg install -y openssl liblz4 pkg install -y fusefs-libs pkgconf pkg install -y fakeroot git easy_install-3.4 pip pip3 install virtualenv # make FUSE work echo 'fuse_load="YES"' >> /boot/loader.conf echo 'vfs.usermount=1' >> /etc/sysctl.conf kldload fuse sysctl vfs.usermount=1 pw groupmod operator -M vagrant EOF end def packages_openbsd return <<-EOF . ~/.profile mkdir -p /home/vagrant/borg rsync -aH /vagrant/borg/ /home/vagrant/borg/ rm -rf /vagrant/borg ln -sf /home/vagrant/borg /vagrant/ pkg_add bash chsh -s /usr/local/bin/bash vagrant pkg_add python-3.4.2 pkg_add py3-setuptools ln -sf /usr/local/bin/python3.4 /usr/local/bin/python3 ln -sf /usr/local/bin/python3.4 /usr/local/bin/python pkg_add openssl pkg_add lz4 # pkg_add fuse # does not install, sdl dependency missing pkg_add git # no fakeroot easy_install-3.4 pip pip3 install virtualenv EOF end def packages_netbsd # ftp://ftp.netbsd.org/pub/pkgsrc/packages/NetBSD/amd64/6.1.5/All/ return <<-EOF #ftp ftp://ftp.NetBSD.org/pub/pkgsrc/current/pkgsrc.tar.gz #tar xzf pkgsrc.tar.gz #cd pkgsrc/bootstrap #./bootstrap #PATH="/usr/pkg/sbin:$PATH" hostname netbsd # the box we use has an invalid hostname PKG_PATH="ftp://ftp.NetBSD.org/pub/pkgsrc/packages/NetBSD/amd64/6.1.5/All/" export PKG_PATH pkg_add python34 py34-setuptools ln -s /usr/pkg/bin/python3.4 /usr/pkg/bin/python ln -s /usr/pkg/bin/python3.4 /usr/pkg/bin/python3 pkg_add mozilla-rootcerts lz4 git mkdir -p /usr/local/opt/lz4/include mkdir -p /usr/local/opt/lz4/lib ln -s /usr/pkg/include/lz4*.h /usr/local/opt/lz4/include/ ln -s /usr/pkg/lib/liblz4* /usr/local/opt/lz4/lib/ touch /etc/openssl/openssl.cnf # avoids a flood of "can't open ..." mozilla-rootcerts install #pkg_add pkg-config fuse-2.9.3 # llfuse does not support netbsd easy_install-3.4 pip pip install virtualenv EOF end def packages_darwin return <<-EOF ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" brew update # this installs osxfuse 2.8.0 (which is based on libfuse 2.7.3). # llfuse later complains about needing (libfuse) 2.8.0 at least. #brew install caskroom/cask/brew-cask #brew cask install osxfuse # needs cask install because of apple's unsigned kext ban # get osxfuse 3.0.x pre-release code from github: curl https://github.com/osxfuse/osxfuse/releases/download/osxfuse-3.0.5/osxfuse-3.0.5.dmg -L >osxfuse.dmg MOUNTDIR=$(echo `hdiutil mount osxfuse.dmg | tail -1 | awk '{$1="" ; print $0}'` | xargs -0 echo) \ && sudo installer -pkg "${MOUNTDIR}/Extras/FUSE for OS X 3.0.5.pkg" -target / brew install openssl brew install lz4 # looks dirty, is there a better way without root?: mkdir -p /usr/local/opt/lz4 ln -s /usr/local/Cellar/lz4/r*/include /usr/local/opt/lz4/ ln -s /usr/local/Cellar/lz4/r*/lib /usr/local/opt/lz4/ brew install fakeroot brew install pyenv if which pyenv > /dev/null; then eval "$(pyenv init -)" fi pyenv install 3.4.3 pyenv global 3.4.3 pyenv rehash python -m pip install virtualenv EOF end def prepare_user(boxname) return <<-EOF echo export 'PATH=/usr/local/bin:$PATH' >> ~/.profile . ~/.profile # initialize python on darwin if which pyenv > /dev/null; then eval "$(pyenv init -)" fi cd /vagrant/borg #python -m virtualenv --python=python3 borg-env virtualenv --python=python3 borg-env . borg-env/bin/activate cd borg # pip install -U pip setuptools # we fetch a current virtualenv, so these are fresh also pip install 'llfuse<0.41' # 0.41 does not install due to UnicodeDecodeError pip install -r requirements.d/development.txt pip install -e . echo echo "Run:" echo " vagrant rsync #{boxname}" echo " vagrant ssh #{boxname} -c 'cd project/path; ...'" EOF end def fix_perms return <<-EOF chown -R vagrant /vagrant/borg EOF end Vagrant.configure(2) do |config| # use rsync to copy content to the folder config.vm.synced_folder ".", "/vagrant/borg/borg", :type => "rsync" # do not let the VM access . on the host machine via the default shared folder! config.vm.synced_folder ".", "/vagrant", disabled: true # fix permissions on synced folder config.vm.provision "fix perms", :type => :shell, :inline => fix_perms config.vm.provider :virtualbox do |v| #v.gui = true v.cpus = 2 end config.vm.define "centos7" do |b| b.vm.box = "centos/7" b.vm.provision "packages centos7 64", :type => :shell, :inline => packages_centos b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("centos7_64") end config.vm.define "trusty64" do |b| b.vm.box = "ubuntu/trusty64" b.vm.provision "packages debianoid", :type => :shell, :inline => packages_debianoid b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("trusty64") end config.vm.define "precise32" do |b| b.vm.box = "ubuntu/precise32" b.vm.provision "packages prepare precise", :type => :shell, :inline => packages_prepare_precise b.vm.provision "packages debianoid", :type => :shell, :inline => packages_debianoid b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("precise32") end config.vm.define "jessie64" do |b| b.vm.box = "debian/jessie64" b.vm.provision "packages debianoid", :type => :shell, :inline => packages_debianoid b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("jessie64") end config.vm.define "wheezy32" do |b| b.vm.box = "puppetlabs/debian-7.8-32-nocm" b.vm.provision "packages prepare wheezy", :type => :shell, :inline => packages_prepare_wheezy b.vm.provision "packages debianoid", :type => :shell, :inline => packages_debianoid b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("wheezy32") end # BSD config.vm.define "freebsd" do |b| b.vm.box = "geoffgarside/freebsd-10.2" b.vm.provision "packages freebsd", :type => :shell, :inline => packages_freebsd b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("freebsd") end config.vm.define "openbsd" do |b| b.vm.box = "bodgit/openbsd-5.7-amd64" b.vm.provision "packages openbsd", :type => :shell, :inline => packages_openbsd b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("openbsd") end config.vm.define "netbsd" do |b| #b.vm.box = "Kralian/netbsd_6.1.5_amd64" b.vm.box = "alex-skimlinks/netbsd-6.1.5-amd64" b.ssh.shell = "ksh -l" #b.ssh.shell = "sh" b.vm.provision "packages netbsd", :type => :shell, :inline => packages_netbsd b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("netbsd") end # OS X config.vm.define "darwin" do |b| b.vm.box = "jhcook/yosemite-clitools" b.vm.provision "packages darwin", :type => :shell, :privileged => false, :inline => packages_darwin b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("darwin") end end