genome/dgi-db

View on GitHub
lib/capistrano/tasks/db.rake

Summary

Maintainability
Test Coverage
namespace :db do
  desc 'deploy local data files to remote database'
  task load_remote: [:copy_data_to_remote, :restore_remote_db]

  desc 'copy local data files to remote server'
  task :copy_data_to_remote do
    on roles(:all) do
      upload!('data/data.sql', "#{shared_path}/public/data/data.sql")
      upload!('data/dGene_04-16-2013_2257.tsv', "#{shared_path}/public/data/dGene_04-16-2013_2257.tsv")
    end
  end
  before 'copy_data_to_remote', 'deploy:update_data_submodule'

  desc 'restore database from remote data.sql file'
  task :restore_remote_db do
    ustring = '-U dgidb'
    hstring = '-h 127.0.0.1'
    dstring = '-d dgidb'
    on roles(:all) do
      execute sudo :service, :apache2, :stop
      begin
        execute :dropdb, '-U postgres', :dgidb
        execute :createdb, ustring, hstring, :dgidb
        execute :psql, ustring, hstring, dstring, "< #{current_path}/db/structure.sql"
        execute :psql, ustring, hstring, dstring, "< #{shared_path}/public/data/data.sql"
      ensure
        execute sudo :service, :apache2, :start
      end
    end
  end
  after 'db:restore_remote_db', 'deploy:flush_memcached'
end