Boot the vm with vagrant up
. Get a safe, stable version of puppet:
wget http://apt.puppetlabs.com/puppetlabs-release-precise.deb
sudo dpkg -i puppetlabs-release-precise.deb
sudo apt-get update
sudo apt-get install puppet-common=2.7.23-1puppetlabs1 puppet=2.7.23-1puppetlabs1
Option 1: Configure against the live Puppet Master.
# /etc/hosts
46.43.41.25 puppet
sudo ln -fs /vagrant/puppet/puppet.conf /etc/puppet/puppet.conf
export FACTER_CKAN=true
export FACTER_CKAN=false
sudo -E puppet agent --test
Option 2: Run a local Puppet Master.
See puppet/README.md.
IMPORTANT You must activate the CKAN virtual environment when working on the VM. Eg.:
source ~/ckan/bin/activate
And setup a useful environment variable...
export CKAN_INI=/var/ckan/ckan.ini
createdb -O dgu ckan --template template_postgis
paster --plugin=ckanext-ga-report initdb --config=$CKAN_INI
paster --plugin=ckanext-dgu create-test-data --config=$CKAN_INI
paster --plugin=ckan search-index rebuild --config=$CKAN_INI
export CKAN_DUMP_FILE=dgu_as_root_user.2013-07-09.pg_dump.gz
export [email protected]:/var/backups/ckan/$CKAN_DUMP_FILE
cd $THIS_REPO
mkdir -p db_backup && cd db_backup
rsync --progress $URL $CKAN_DUMP_FILE
On the VM:
export CKAN_DUMP_FILE=`ls /vagrant/db_backup/ -t |head -n 1` && echo $CKAN_DUMP_FILE
sudo apachectl stop
dropdb ckan
createdb -O dgu ckan --template template_postgis
pv /vagrant/db_backup/$CKAN_DUMP_FILE | funzip \
| PGPASSWORD=pass psql -h localhost -U dgu -d ckan
sudo apachectl start
paster --plugin=ckan db upgrade --config=$CKAN_INI
# is it just me that gets a benign failure on upgrade in init_const_data?
# If the database is pre-CKAN 2 then run the manual migrations in the pad:
# http://etherpad.co-dev1.dh.bytemark.co.uk/p/ckan2
paster --plugin=ckan search-index rebuild --config=$CKAN_INI
paster --plugin=ckan user remove admin --config=$CKAN_INI
paster --plugin=ckan user add admin email=admin@ckan password=pass --config=$CKAN_INI
paster --plugin=ckan sysadmin add admin --config=$CKAN_INI
The VM opens in the ckan directory with the virtualenv activated and there is a symlink to the ckan.ini there, making it easy to run paster commands.
Warning: Since apache runs as www-data user, reading and writing log and session files, you may get problems if you run paster as vagrant user. To avoid issue, run paster commands sudo -u www-data paster
. However, most of the time you can get away with it.
Examples::
paster create-test-data --config=ckan.ini
paster search-index rebuild --config=ckan.ini
paster --plugin=ckanext-dgu celeryd run concurrency=1 --queue=priority --config=ckan.ini
Examples::
nosetests --ckan --with-pylons=test-core.ini ckan/tests/
nosetests --ckan --with-pylons=../ckanext-spatial/test-core.ini ../ckanext-spatial/ckanext/spatial/tests
multiple values encountered for non multiValued field groups: [david, roger]
SOLR complains of this when running core ckan tests with the DGU schema. Ideally we'd have SOLR multicore to have the default CKAN schema running. But we don't have this in vagrant yet, so use the dgu-vagrant-puppet branch for non-DGU ckan to test this code.
sqlalchemy.exc.OperationalError: (OperationalError) no such table: user
This is caused by running the ckan tests with SQLite, rather than Postgres. Ensure you use --with-pylons=test-core.ini
rather than the default test.ini
. It would be good to fix up SQLite soon - it is an issue with it dropping all tables before tests spuriously.