mirror of
https://0xacab.org/liberate/backupninja.git
synced 2024-11-08 11:52:32 +01:00
tests: Add a remote machine to test push backups
The default system 'local' hosts the backupninja code and local backups are done in that system. The vagrant user account on the 'remote' system is made accessible by the root user in the 'local' system so that it may accept ssh connections needed by the different handlers.
This commit is contained in:
parent
340853d96a
commit
b25e7f471b
91
Vagrantfile
vendored
91
Vagrantfile
vendored
@ -8,39 +8,72 @@ lukspart_disk = '.vagrant/tmp/lukspart.vdi'
|
||||
luksdev_disk = '.vagrant/tmp/luksdev.vdi'
|
||||
|
||||
Vagrant.configure("2") do |config|
|
||||
config.vm.box = "debian/buster64"
|
||||
config.vm.provision "shell", inline: <<-SHELL
|
||||
locale-gen
|
||||
apt-get update
|
||||
apt-get install -y automake make dialog
|
||||
cd /vagrant
|
||||
./autogen.sh
|
||||
./configure --prefix=/usr --mandir=/usr/share/man --sysconfdir=/etc --localstatedir=/var --libdir=/usr/lib --libexecdir=/usr/lib
|
||||
make
|
||||
make install
|
||||
SHELL
|
||||
config.vm.synced_folder ".", "/vagrant", type: "rsync",
|
||||
|
||||
config.vm.define "remote" do |remote|
|
||||
remote.vm.box = "debian/buster64"
|
||||
remote.vm.hostname = "bntest1"
|
||||
remote.vm.network "private_network", ip: "192.168.181.5"
|
||||
remote.vm.provision "shell", inline: <<-SHELL
|
||||
locale-gen
|
||||
apt-get update
|
||||
apt-get install -y rdiff-backup borgbackup restic
|
||||
sed -i 's/^PasswordAuthentication no/PasswordAuthentication yes/' /etc/ssh/sshd_config
|
||||
systemctl reload sshd
|
||||
mkdir /tmp/backups
|
||||
mount -t tmpfs tmpfs /tmp/backups
|
||||
chown vagrant: /tmp/backups
|
||||
SHELL
|
||||
end
|
||||
|
||||
config.vm.define "local", primary: true do |local|
|
||||
local.vm.box = "debian/buster64"
|
||||
local.vm.hostname = "bntest0"
|
||||
local.vm.network "private_network", ip: "192.168.181.4"
|
||||
local.vm.provision "shell", inline: <<-SHELL
|
||||
locale-gen
|
||||
apt-get update
|
||||
apt-get install -y automake make dialog sshpass
|
||||
cd /vagrant
|
||||
./autogen.sh
|
||||
./configure --prefix=/usr --mandir=/usr/share/man --sysconfdir=/etc --localstatedir=/var --libdir=/usr/lib --libexecdir=/usr/lib
|
||||
make
|
||||
make install
|
||||
mkdir /tmp/backups
|
||||
mount -t tmpfs tmpfs /tmp/backups
|
||||
chown vagrant: /tmp/backups
|
||||
mkdir -p /root/.ssh
|
||||
yes y | ssh-keygen -t ed25519 -f /root/.ssh/id_ed25519 -N ''
|
||||
echo "StrictHostKeyChecking accept-new" >> /root/.ssh/config
|
||||
echo "192.168.181.5 bntest1" >> /etc/hosts
|
||||
sshpass -p vagrant scp /root/.ssh/id_ed25519.pub vagrant@bntest1:/tmp/bntest.pub
|
||||
sshpass -p vagrant ssh vagrant@bntest1 "cat /tmp/bntest.pub >> /home/vagrant/.ssh/authorized_keys"
|
||||
sshpass -p vagrant ssh vagrant@bntest1 "chmod 400 /home/vagrant/.ssh/authorized_keys"
|
||||
ssh vagrant@bntest1 "sudo sed -i 's/^PasswordAuthentication yes/PasswordAuthentication no/' /etc/ssh/sshd_config"
|
||||
ssh vagrant@bntest1 "sudo systemctl reload sshd"
|
||||
SHELL
|
||||
|
||||
local.vm.synced_folder ".", "/vagrant", type: "rsync",
|
||||
rsync__exclude: ".git/",
|
||||
rsync__args: ["--recursive", "--delete"]
|
||||
config.vm.hostname = "bntest0"
|
||||
|
||||
config.vm.provider :virtualbox do |vb|
|
||||
unless File.exist?(empty_disk)
|
||||
vb.customize ['createhd', '--filename', empty_disk, '--size', 100 ]
|
||||
local.vm.provider :virtualbox do |vb|
|
||||
unless File.exist?(empty_disk)
|
||||
vb.customize ['createhd', '--filename', empty_disk, '--size', 100 ]
|
||||
end
|
||||
unless File.exist?(empty_disk)
|
||||
vb.customize ['createhd', '--filename', lvm_disk, '--size', 100 ]
|
||||
end
|
||||
unless File.exist?(lukspart_disk)
|
||||
vb.customize ['createhd', '--filename', lukspart_disk, '--size', 100 ]
|
||||
end
|
||||
unless File.exist?(luksdev_disk)
|
||||
vb.customize ['createhd', '--filename', luksdev_disk, '--size', 100 ]
|
||||
end
|
||||
vb.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 1, '--device', 0, '--type', 'hdd', '--medium', empty_disk]
|
||||
vb.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 2, '--device', 0, '--type', 'hdd', '--medium', lvm_disk]
|
||||
vb.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 3, '--device', 0, '--type', 'hdd', '--medium', lukspart_disk]
|
||||
vb.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 4, '--device', 0, '--type', 'hdd', '--medium', luksdev_disk]
|
||||
end
|
||||
unless File.exist?(empty_disk)
|
||||
vb.customize ['createhd', '--filename', lvm_disk, '--size', 100 ]
|
||||
end
|
||||
unless File.exist?(lukspart_disk)
|
||||
vb.customize ['createhd', '--filename', lukspart_disk, '--size', 100 ]
|
||||
end
|
||||
unless File.exist?(luksdev_disk)
|
||||
vb.customize ['createhd', '--filename', luksdev_disk, '--size', 100 ]
|
||||
end
|
||||
vb.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 1, '--device', 0, '--type', 'hdd', '--medium', empty_disk]
|
||||
vb.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 2, '--device', 0, '--type', 'hdd', '--medium', lvm_disk]
|
||||
vb.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 3, '--device', 0, '--type', 'hdd', '--medium', lukspart_disk]
|
||||
vb.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 4, '--device', 0, '--type', 'hdd', '--medium', luksdev_disk]
|
||||
end
|
||||
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user