forked from mozilla/dxr
-
Notifications
You must be signed in to change notification settings - Fork 0
/
vagrant_provision.sh
82 lines (71 loc) · 2.93 KB
/
vagrant_provision.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#!/bin/sh
# Shell script to provision the vagrant box
set -e
set -x
apt-get update
# node and npm:
apt-get install -y npm
# Homogenize binary name with production RHEL:
ln -sf /usr/bin/nodejs /usr/local/bin/node
# Docs build system:
apt-get install -y sphinx-common
# Python:
apt-get install -y libapache2-mod-wsgi python-pip
pip install virtualenv virtualenvwrapper python-hglib nose
cd ~vagrant/dxr
# If it hangs here, you might have a mismatched version of the VirtualBox Guest
# Additions. Shut down the box. Start it back up using the VB GUI. Choose
# "Insert Guest Additions CD" from the Devices menu. On the guest, mount
# /dev/cdrom /mnt && cd /mnt && ./VBoxLinuxAdditions.run. Shut the guest back
# down.
#
# Alternately, per
# https://github.com/TryGhost/Ghost-Vagrant#updating-virtual-box-guest-additions,
# from the host, run...
# 1) vagrant plugin install vagrant-vbguest
# 2) vagrant up --no-provision
# 3) vagrant ssh -c 'sudo apt-get -y -q purge virtualbox-guest-dkms
# virtualbox-guest-utils virtualbox-guest-x11'
# 4) vagrant halt
# 5) vagrant up --provision
./peep.py install -r requirements.txt
python setup.py develop
# Apache:
apt-get install -y apache2-dev apache2
mkdir -p /etc/apache2/sites-enabled
if [ ! -e /etc/apache2/sites-enabled/dxr.conf ]; then
cat >/etc/apache2/sites-enabled/dxr.conf <<THEEND
# This is an example of serving a DXR target directory with Apache. To try it
# out, go into tests/test_basic and run "make". Everything but a few static
# files is delegated to a WSGI process.
#
# This should be adaptable to serve at non-root positions in the URL hierarchy.
<VirtualHost *:80>
# Serve static resources, like CSS and images, with plain Apache:
Alias /static/ /home/vagrant/dxr/dxr/static/
# We used to make special efforts to also serve the static pages of
# HTML-formatted source code from the tree via plain Apache, but that
# tangle of RewriteRules saved us only about 20ms per request. You can do
# it if you're on a woefully underpowered machine, but I'm not maintaining
# it.
# Tell this instance of DXR where its target folder is:
SetEnv DXR_FOLDER /home/vagrant/dxr/tests/test_basic/target/
# On a production machine, you'd typically do "python setup.py install"
# rather than "python setup.py develop", so this would point inside your
# site-packages directory.
WSGIScriptAlias / /home/vagrant/dxr/dxr/dxr.wsgi
</VirtualHost>
THEEND
chmod 0644 /etc/apache2/sites-enabled/dxr.conf
fi
a2enmod rewrite
a2enmod proxy
a2dissite 000-default
# DXR itself:
# sqlite3 is so trilite's make test works.
# pkg-config is so make clean works.
apt-get install -y libsqlite3-dev sqlite3 git mercurial llvm-3.3 libclang-3.3-dev clang-3.3 pkg-config
update-alternatives --install /usr/local/bin/llvm-config llvm-config /usr/bin/llvm-config-3.3 0
# Install libtrilite so Apache WSGI processes can see it:
ln -sf ~vagrant/dxr/trilite/libtrilite.so /usr/local/lib/libtrilite.so
/sbin/ldconfig