From db045dbbf60b53dbe013ef25554fd013baf88134 Mon Sep 17 00:00:00 2001 From: David Heinemeier Hansson Date: Wed, 24 Nov 2004 01:04:44 +0000 Subject: Initial git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4 5ecf4fe2-1ee6-0310-87b1-e25e094e27de --- railties/fresh_rakefile | 104 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 104 insertions(+) create mode 100755 railties/fresh_rakefile (limited to 'railties/fresh_rakefile') diff --git a/railties/fresh_rakefile b/railties/fresh_rakefile new file mode 100755 index 0000000000..3b746a49a5 --- /dev/null +++ b/railties/fresh_rakefile @@ -0,0 +1,104 @@ +require 'rake' +require 'rake/testtask' +require 'rake/rdoctask' + +$VERBOSE = nil + +require File.dirname(__FILE__) + '/config/environment' +require 'code_statistics' + +desc "Run all the tests on a fresh test database" +task :default => [ :clone_development_structure_to_test, :test_units, :test_functional ] + +desc "Generate API documentatio, show coding stats" +task :doc => [ :appdoc, :stats ] + + +desc "Run the unit tests in test/unit" +Rake::TestTask.new("test_units") { |t| + t.libs << "test" + t.pattern = 'test/unit/*_test.rb' + t.verbose = true +} + +desc "Run the functional tests in test/functional" +Rake::TestTask.new("test_functional") { |t| + t.libs << "test" + t.pattern = 'test/functional/*_test.rb' + t.verbose = true +} + +desc "Generate documentation for the application" +Rake::RDocTask.new("appdoc") { |rdoc| + rdoc.rdoc_dir = 'doc/app' + rdoc.title = "Rails Application Documentation" + rdoc.options << '--line-numbers --inline-source' + rdoc.rdoc_files.include('doc/README_FOR_APP') + rdoc.rdoc_files.include('app/**/*.rb') +} + +desc "Generate documentation for the Rails framework" +Rake::RDocTask.new("apidoc") { |rdoc| + rdoc.rdoc_dir = 'doc/api' + rdoc.title = "Rails Framework Documentation" + rdoc.options << '--line-numbers --inline-source' + rdoc.rdoc_files.include('README') + rdoc.rdoc_files.include('vendor/railties/CHANGELOG') + rdoc.rdoc_files.include('vendor/railties/MIT-LICENSE') + rdoc.rdoc_files.include('vendor/activerecord/README') + rdoc.rdoc_files.include('vendor/activerecord/CHANGELOG') + rdoc.rdoc_files.include('vendor/activerecord/lib/active_record/**/*.rb') + rdoc.rdoc_files.exclude('vendor/activerecord/lib/active_record/vendor/*') + rdoc.rdoc_files.include('vendor/actionpack/README') + rdoc.rdoc_files.include('vendor/actionpack/CHANGELOG') + rdoc.rdoc_files.include('vendor/actionpack/lib/action_controller/**/*.rb') + rdoc.rdoc_files.include('vendor/actionpack/lib/action_view/**/*.rb') + rdoc.rdoc_files.include('vendor/actionmailer/README') + rdoc.rdoc_files.include('vendor/actionmailer/CHANGELOG') + rdoc.rdoc_files.include('vendor/actionmailer/lib/action_mailer/base.rb') +} + +desc "Report code statistics (KLOCs, etc) from the application" +task :stats do + CodeStatistics.new( + ["Controllers", "app/controllers"], + ["Helpers", "app/helpers"], + ["Models", "app/models"], + ["Units", "test/unit"], + ["Functionals", "test/functional"] + ).to_s +end + +desc "Recreate the test databases from the development structure" +task :clone_development_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/development_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/development_structure.sql #{ActiveRecord::Base.configurations["test"]["database"]}` + end +end + +desc "Dump the database structure to a SQL file" +task :db_structure_dump do + if ActiveRecord::Base.configurations["test"]["adapter"] == "mysql" + ActiveRecord::Base.establish_connection(ActiveRecord::Base.configurations["test"]) + File.open("db/development_structure.sql", "w+") { |f| f << ActiveRecord::Base.connection.structure_dump } + elsif ActiveRecord::Base.configurations["test"]["adapter"] == "postgresql" + `pg_dump -U #{ActiveRecord::Base.configurations["test"]["username"]} -s -f db/development_structure.sql #{ActiveRecord::Base.configurations["test"]["database"]}` + end +end + +desc "Drop the test database and bring it back again" +task :purge_test_database do + if ActiveRecord::Base.configurations["test"]["adapter"] == "mysql" + ActiveRecord::Base.establish_connection(ActiveRecord::Base.configurations["development"]) + 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"]}` + end +end -- cgit v1.2.3