diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2005-01-24 13:12:40 +0000 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2005-01-24 13:12:40 +0000 |
commit | 2257980c504d4c20577afc1d35d123dfb9ce411c (patch) | |
tree | 028c6cc8f2b5d1ece9395f5b0efbc35846bdff37 /railties/fresh_rakefile | |
parent | 566a36966b43d4f76e6a4e6dfa0d12112cbe46b4 (diff) | |
download | rails-2257980c504d4c20577afc1d35d123dfb9ce411c.tar.gz rails-2257980c504d4c20577afc1d35d123dfb9ce411c.tar.bz2 rails-2257980c504d4c20577afc1d35d123dfb9ce411c.zip |
Fixed skeleton Rakefile to work with sqlite3 out of the box #521 [rasputnik]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@490 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'railties/fresh_rakefile')
-rwxr-xr-x | railties/fresh_rakefile | 64 |
1 files changed, 38 insertions, 26 deletions
diff --git a/railties/fresh_rakefile b/railties/fresh_rakefile index 95daddb261..445eb65694 100755 --- a/railties/fresh_rakefile +++ b/railties/fresh_rakefile @@ -73,40 +73,52 @@ end desc "Recreate the test databases from the development structure" task :clone_structure_to_test => [ :db_structure_dump, :purge_test_database ] do - if ActiveRecord::Base.configurations["test"]["adapter"] == "mysql" - ActiveRecord::Base.establish_connection(:test) - ActiveRecord::Base.connection.execute('SET foreign_key_checks = 0') - IO.readlines("db/#{RAILS_ENV}_structure.sql").join.split("\n\n").each do |table| - ActiveRecord::Base.connection.execute(table) - end - elsif ActiveRecord::Base.configurations["test"]["adapter"] == "postgresql" - `psql -U #{ActiveRecord::Base.configurations["test"]["username"]} -f db/#{RAILS_ENV}_structure.sql #{ActiveRecord::Base.configurations["test"]["database"]}` - elsif ActiveRecord::Base.configurations["test"]["adapter"] == "sqlite" - `sqlite #{ActiveRecord::Base.configurations["test"]["dbfile"]} < db/#{RAILS_ENV}_structure.sql` + abcs = ActiveRecord::Base.configurations + case abcs["test"]["adapter"] + when "mysql" + ActiveRecord::Base.establish_connection(:test) + ActiveRecord::Base.connection.execute('SET foreign_key_checks = 0') + IO.readlines("db/#{RAILS_ENV}_structure.sql").join.split("\n\n").each do |table| + ActiveRecord::Base.connection.execute(table) + end + when "postgresql" + `psql -U #{abcs["test"]["username"]} -f db/#{RAILS_ENV}_structure.sql #{abcs["test"]["database"]}` + when "sqlite", "sqlite3" + `#{abcs[RAILS_ENV]["adapter"]} #{abcs["test"]["dbfile"]} < db/#{RAILS_ENV}_structure.sql` + else + raise "Unknown database adapter '#{abcs["test"]["adapter"]}'" end end desc "Dump the database structure to a SQL file" task :db_structure_dump do - if ActiveRecord::Base.configurations[RAILS_ENV]["adapter"] == "mysql" - ActiveRecord::Base.establish_connection(ActiveRecord::Base.configurations[RAILS_ENV]) - File.open("db/#{RAILS_ENV}_structure.sql", "w+") { |f| f << ActiveRecord::Base.connection.structure_dump } - elsif ActiveRecord::Base.configurations[RAILS_ENV]["adapter"] == "postgresql" - `pg_dump -U #{ActiveRecord::Base.configurations[RAILS_ENV]["username"]} -s -f db/#{RAILS_ENV}_structure.sql #{ActiveRecord::Base.configurations[RAILS_ENV]["database"]}` - elsif ActiveRecord::Base.configurations[RAILS_ENV]["adapter"] == "sqlite" - `sqlite #{ActiveRecord::Base.configurations[RAILS_ENV]["dbfile"]} .schema > db/#{RAILS_ENV}_structure.sql` + abcs = ActiveRecord::Base.configurations + case abcs[RAILS_ENV]["adapter"] + when "mysql" + ActiveRecord::Base.establish_connection(abcs[RAILS_ENV]) + File.open("db/#{RAILS_ENV}_structure.sql", "w+") { |f| f << ActiveRecord::Base.connection.structure_dump } + when "postgresql" + `pg_dump -U #{abcs[RAILS_ENV]["username"]} -s -f db/#{RAILS_ENV}_structure.sql #{abcs[RAILS_ENV]["database"]}` + when "sqlite", "sqlite3" + `#{abcs[RAILS_ENV]["adapter"]} #{abcs[RAILS_ENV]["dbfile"]} .schema > db/#{RAILS_ENV}_structure.sql` + else + raise "Unknown database adapter '#{abcs["test"]["adapter"]}'" end end -desc "Drop the test database and bring it back again" +desc "Empty the test database" task :purge_test_database do - if ActiveRecord::Base.configurations["test"]["adapter"] == "mysql" - ActiveRecord::Base.establish_connection(ActiveRecord::Base.configurations[RAILS_ENV]) - ActiveRecord::Base.connection.recreate_database(ActiveRecord::Base.configurations["test"]["database"]) - elsif ActiveRecord::Base.configurations["test"]["adapter"] == "postgresql" - `dropdb -U #{ActiveRecord::Base.configurations["test"]["username"]} #{ActiveRecord::Base.configurations["test"]["database"]}` - `createdb -U #{ActiveRecord::Base.configurations["test"]["username"]} #{ActiveRecord::Base.configurations["test"]["database"]}` - elsif ActiveRecord::Base.configurations["test"]["adapter"] == "sqlite" - File.delete(ActiveRecord::Base.configurations["test"]["dbfile"]) if File.exist?(ActiveRecord::Base.configurations["test"]["dbfile"]) + abcs = ActiveRecord::Base.configurations + case abcs["test"]["adapter"] + when "mysql" + ActiveRecord::Base.establish_connection(abcs[RAILS_ENV]) + ActiveRecord::Base.connection.recreate_database(abcs["test"]["database"]) + when "postgresql" + `dropdb -U #{abcs["test"]["username"]} #{abcs["test"]["database"]}` + `createdb -U #{abcs["test"]["username"]} #{abcs["test"]["database"]}` + when "sqlite","sqlite3" + File.delete(abcs["test"]["dbfile"]) if File.exist?(abcs["test"]["dbfile"]) + else + raise "Unknown database adapter '#{abcs["test"]["adapter"]}'" end end |