123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296 |
- # -*- 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
- # - have a working "python3.4" command on platforms where we build a binary
- #
- # 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/.
- # - have a working "borg-env34" virtual env installed, with code from "borg"
- # and pyinstaller.
- 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
- # we build the 32bit binary here also, using pyinstaller and py3.4.
- add-apt-repository -y ppa:fkrull/deadsnakes
- EOF
- end
- def packages_prepare_trusty
- return <<-EOF
- # we build the 64bit binary here also, using pyinstaller and py3.4.
- add-apt-repository -y ppa:fkrull/deadsnakes
- 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 python-dev # pyinstaller needs py2
- apt-get install -y python3-dev python3-setuptools
- apt-get install -y python3.4-dev # for pyinstaller / binary building
- 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
- env PYTHON_CONFIGURE_OPTS="--enable-framework" 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
- # this is the env with the STANDARD python3.x on this platform
- virtualenv --python=python3 borg-env
- . borg-env/bin/activate
- cd borg
- pip install 'llfuse<0.41' # 0.41 does not install due to UnicodeDecodeError
- pip install -r requirements.d/development.txt
- pip install -e .
- # on some platforms, we build a borg binary (and use py3.4 for it)
- if which python3.4 > /dev/null; then
- cd /vagrant/borg
- virtualenv --python=python3.4 borg-env34
- . borg-env34/bin/activate
- cd borg
- pip install 'PyInstaller==3.0.dev2'
- pip install 'llfuse<0.41' # 0.41 does not install due to UnicodeDecodeError
- pip install -r requirements.d/development.txt
- pip install -e .
- fi
- echo
- echo "Run:"
- echo " vagrant rsync #{boxname}"
- echo " vagrant ssh #{boxname} -c 'cd project/path; ...'"
- EOF
- end
- def fix_perms
- return <<-EOF
- . ~/.profile
- 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 prepare trusty", :type => :shell, :inline => packages_prepare_trusty
- 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
|