1
0
Fork 0
mirror of https://github.com/borgbackup/borg.git synced 2024-12-23 16:26:29 +00:00
borg/Vagrantfile

297 lines
10 KiB
Text
Raw Normal View History

# -*- mode: ruby -*-
# vi: set ft=ruby :
2015-09-15 21:45:12 +00:00
# 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
2015-09-15 21:45:12 +00:00
#
# 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.
2015-09-15 21:45:12 +00:00
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
2015-09-13 21:39:34 +00:00
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
2015-09-14 15:35:04 +00:00
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"
2015-09-15 21:45:12 +00:00
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
2015-09-15 21:45:12 +00:00
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
2015-09-15 21:45:12 +00:00
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
2015-09-15 21:45:12 +00:00
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
2015-09-13 21:39:34 +00:00
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
2015-09-14 15:35:04 +00:00
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