Skip to content

A vagrant manifest to create continuous integration environments with puppet on a local box or in the cloud.

Notifications You must be signed in to change notification settings

vccabral/django-vagrant-ci

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

54 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

django-vagrant-ci

A vagrant manifest to create continuous integration environments with puppet on a local box or in the cloud.

Getting started

This project uses git submodules. After cloning it, the submodules must be cloned too:

git clone git@github.com:vccabral/django-vagrant-ci.git
git submodule update --init

or

git clone --recursive git@github.com:vccabral/django-vagrant-ci.git

To create a django ci environment you should run

vagrant up

in the root of the project. Building the VM for the first time will take a few minutes.

Configuration variables

All the configuration variables are located at the top of the base.pp file. After changing one variable the machine might work after running:

vagrant reload

but it is advised to recreate it from the beginning:

vagrant destroy
vagrant up

Connecting

Access jenkins via

http://localhost:8081

SSH into the box via

vagrant ssh

Activate the virtual env via:

source ~/virtualenv/icecream/bin/activate

Connect to the database via:

psql -h localhost -U icecream -d icecream

Connect to the 'live' database via:

psql -h localhost -U icecream -d live_icecream

The user icecream has full access to the database icecream. Another way to connect to the database is with this sequence of commands:

source ~/virtualenv/icecream/bin/activate
cd ~/icecream
python icecream/manage.py dbshell

Django is installed inside the virtual env, so the virtualenv must be activated before running django-admin.py:

source ~/virtualenv/icecream/bin/activate
django-admin.py --version

Run the django project via

. ~/virtualenv/icecream/bin/activate
cd ~/ci/icecream/icecream
python manage.py runserver 0.0.0.0:8000

You can check the database content after the initial python manage.py syncdb in the psql shell with the '\d' command:

. ~/virtualenv/icecream/bin/activate
cd ~/ci/icecream/icecream

python manage.py dbshell
\d

Access the web application via

http://localhost:8082

You can check the live database content after the initial python manage.py syncdb in the psql shell with the '\d' command:

. ~/virtualenv/icecream/bin/activate
cd ~/live/icecream
export DJANGO_SETTINGS_MODULE=icecream.settings.live
python manage.py dbshell
\d

Run the "live" web application:

. ~/virtualenv/icecream/bin/activate
cd ~/live/icecream/icecream
python manage.py runserver 0.0.0.0:8001

Access the "live" web application via

http://localhost:8083

TODO

- on success, makes the project publically available on 8083.
Other items should be collecting static content, deploying latest code.

Credits

This project uses the following puppet modules:

About

A vagrant manifest to create continuous integration environments with puppet on a local box or in the cloud.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published