aboutsummaryrefslogtreecommitdiffstats
path: root/conf
diff options
context:
space:
mode:
authorMatthew Somerville <matthew-github@dracos.co.uk>2013-09-11 18:16:43 +0100
committerMatthew Somerville <matthew-github@dracos.co.uk>2013-09-13 15:09:02 +0100
commit54492adeede411f4391dd6cd7cf5f62061d55fdb (patch)
treee27d760786debf7fb1fc5b4d32e93be1049405a4 /conf
parent0053c2a413843df34d5353c4757f556fb4f78dab (diff)
Example Vagrantfile and notes.
Based on previous work on vagrant branches, adjusted to use the new --dev argument of the install script.
Diffstat (limited to 'conf')
-rwxr-xr-xconf/Vagrantfile.example90
1 files changed, 90 insertions, 0 deletions
diff --git a/conf/Vagrantfile.example b/conf/Vagrantfile.example
new file mode 100755
index 000000000..fbc647746
--- /dev/null
+++ b/conf/Vagrantfile.example
@@ -0,0 +1,90 @@
+# -*- mode: ruby -*-
+# vi: set ft=ruby :
+
+BOX_NAME = ENV['BOX_NAME'] || "precise64"
+BOX_URI = ENV['BOX_URI'] || "http://files.vagrantup.com/precise64.box"
+
+# Vagrantfile API/syntax version. Don't touch unless you know what you're doing!
+VAGRANTFILE_API_VERSION = "2"
+
+Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
+ # All Vagrant configuration is done here. The most common configuration
+ # options are documented and commented below. For a complete reference,
+ # please see the online documentation at vagrantup.com.
+
+ # Every Vagrant virtual environment requires a box to build off of.
+ config.vm.box = BOX_NAME
+
+ # The url from where the 'config.vm.box' box will be fetched if it
+ # doesn't already exist on the user's system.
+ config.vm.box_url = BOX_URI
+
+ # Create a forwarded port mapping which allows access to a specific port
+ # within the machine from a port on the host machine. In the example below,
+ # accessing "localhost:8080" will access port 80 on the guest machine.
+ config.vm.network :forwarded_port, guest: 3000, host: 3000
+
+ config.vm.provider "virtualbox" do |v|
+ v.customize ["setextradata", :id, "VBoxInternal2/SharedFoldersEnableSymlinksCreate/vagrant", "1"]
+ end
+
+ config.vm.provision :shell, :inline => <<-EOS
+ # To prevent "dpkg-preconfigure: unable to re-open stdin: No such file or directory" warnings
+ export DEBIAN_FRONTEND=noninteractive
+ # To be in the shared directory where the repository might already be
+ cd /vagrant/
+ # We need curl to fetch the install script
+ apt-get update -qq
+ apt-get install -qq -y curl >/dev/null
+ curl -s https://raw.github.com/mysociety/commonlib/master/bin/install-site.sh | \
+ sh -s -- --dev fixmystreet vagrant 127.0.0.1.xip.io
+ # Assume a developer will want to run the tests.
+ # TODO The tests should be further altered to work regardless of
+ # configuration file settings
+ sed -i -r \
+ -e "s,(MAPIT_URL:) '',\\1 'http://mapit.mysociety.org/'," \
+ -e "s, - cobrand_one, - barnet\\n - bromley\\n - emptyhomes\\n - fiksgatami\\n - fixmybarangay\\n - lichfielddc\\n - reading\\n - seesomething\\n - southampton\\n - zurich," \
+ -e "s, - cobrand_two: 'hostname_substring2', - fixmystreet: '.'," \
+ fixmystreet/conf/general.yml
+ # All done
+ echo "****************"
+ echo "You can now ssh into your vagrant box: vagrant ssh"
+ echo "The website code is found in: ~/fixmystreet"
+ echo "You can run the dev server with: bin/cron-wrapper script/fixmystreet_app_server.pl [-d] [-r] [--fork]"
+ EOS
+
+ # Create a private network, which allows host-only access to the machine
+ # using a specific IP.
+ # config.vm.network :private_network, ip: "192.168.33.10"
+
+ # Create a public network, which generally matched to bridged network.
+ # Bridged networks make the machine appear as another physical device on
+ # your network.
+ # config.vm.network :public_network
+
+ # If true, then any SSH connections made will enable agent forwarding.
+ # Default value: false
+ # config.ssh.forward_agent = true
+
+ # Share an additional folder to the guest VM. The first argument is
+ # the path on the host to the actual folder. The second argument is
+ # the path on the guest to mount the folder. And the optional third
+ # argument is a set of non-required options.
+ # config.vm.synced_folder "../data", "/vagrant_data"
+
+ # Provider-specific configuration so you can fine-tune various
+ # backing providers for Vagrant. These expose provider-specific options.
+ # Example for VirtualBox:
+ #
+ # config.vm.provider :virtualbox do |vb|
+ # # Don't boot with headless mode
+ # vb.gui = true
+ #
+ # # Use VBoxManage to customize the VM. For example to change memory:
+ # vb.customize ["modifyvm", :id, "--memory", "1024"]
+ # end
+ #
+ # View the documentation for the provider you're using for more
+ # information on available options.
+
+end