2004-11-23 20:04:44 -05:00
|
|
|
require 'rubygems'
|
|
|
|
require 'rake'
|
|
|
|
require 'rake/testtask'
|
|
|
|
require 'rake/rdoctask'
|
|
|
|
require 'rake/packagetask'
|
|
|
|
require 'rake/gempackagetask'
|
2008-01-21 12:20:51 -05:00
|
|
|
|
2005-10-10 10:28:41 -04:00
|
|
|
require File.join(File.dirname(__FILE__), 'lib', 'active_record', 'version')
|
2008-01-21 12:20:51 -05:00
|
|
|
require File.expand_path(File.dirname(__FILE__)) + "/test/config"
|
2004-11-23 20:04:44 -05:00
|
|
|
|
|
|
|
PKG_BUILD = ENV['PKG_BUILD'] ? '.' + ENV['PKG_BUILD'] : ''
|
|
|
|
PKG_NAME = 'activerecord'
|
2005-11-16 19:32:16 -05:00
|
|
|
PKG_VERSION = ActiveRecord::VERSION::STRING + PKG_BUILD
|
2004-11-23 20:04:44 -05:00
|
|
|
PKG_FILE_NAME = "#{PKG_NAME}-#{PKG_VERSION}"
|
|
|
|
|
2005-03-27 08:33:54 -05:00
|
|
|
RELEASE_NAME = "REL #{PKG_VERSION}"
|
|
|
|
|
|
|
|
RUBY_FORGE_PROJECT = "activerecord"
|
|
|
|
RUBY_FORGE_USER = "webster132"
|
|
|
|
|
2008-04-21 00:40:16 -04:00
|
|
|
MYSQL_DB_USER = 'rails'
|
|
|
|
|
2004-11-23 20:04:44 -05:00
|
|
|
PKG_FILES = FileList[
|
2006-04-07 10:08:03 -04:00
|
|
|
"lib/**/*", "test/**/*", "examples/**/*", "doc/**/*", "[A-Z]*", "install.rb", "Rakefile"
|
2004-11-23 20:04:44 -05:00
|
|
|
].exclude(/\bCVS\b|~$/)
|
|
|
|
|
2009-08-27 14:04:08 -04:00
|
|
|
def run_without_aborting(*tasks)
|
|
|
|
errors = []
|
|
|
|
|
|
|
|
tasks.each do |task|
|
|
|
|
begin
|
|
|
|
Rake::Task[task].invoke
|
|
|
|
rescue Exception
|
|
|
|
errors << task
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
abort "Errors running #{errors.join(', ')}" if errors.any?
|
|
|
|
end
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2007-10-14 20:10:09 -04:00
|
|
|
desc 'Run mysql, sqlite, and postgresql tests by default'
|
|
|
|
task :default => :test
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2007-10-14 20:10:09 -04:00
|
|
|
desc 'Run mysql, sqlite, and postgresql tests'
|
2009-08-27 14:04:08 -04:00
|
|
|
task :test do
|
|
|
|
tasks = defined?(JRUBY_VERSION) ?
|
|
|
|
%w(test_jdbcmysql test_jdbcsqlite3 test_jdbcpostgresql) :
|
|
|
|
%w(test_mysql test_sqlite3 test_postgresql)
|
|
|
|
run_without_aborting(*tasks)
|
|
|
|
end
|
|
|
|
|
|
|
|
task :isolated_test do
|
|
|
|
tasks = defined?(JRUBY_VERSION) ?
|
|
|
|
%w(isolated_test_jdbcmysql isolated_test_jdbcsqlite3 isolated_test_jdbcpostgresql) :
|
|
|
|
%w(isolated_test_mysql isolated_test_sqlite3 isolated_test_postgresql)
|
|
|
|
run_without_aborting(*tasks)
|
|
|
|
end
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2009-08-17 08:56:59 -04:00
|
|
|
%w( mysql postgresql sqlite3 firebird db2 oracle sybase openbase frontbase jdbcmysql jdbcpostgresql jdbcsqlite3 jdbcderby jdbch2 jdbchsqldb ).each do |adapter|
|
2005-03-27 09:10:42 -05:00
|
|
|
Rake::TestTask.new("test_#{adapter}") { |t|
|
2009-05-13 04:06:53 -04:00
|
|
|
connection_path = "test/connections/#{adapter =~ /jdbc/ ? 'jdbc' : 'native'}_#{adapter}"
|
2007-05-11 20:44:50 -04:00
|
|
|
adapter_short = adapter == 'db2' ? adapter : adapter[/^[a-z]+/]
|
2009-05-13 04:06:53 -04:00
|
|
|
t.libs << "test" << connection_path
|
2008-02-19 21:27:40 -05:00
|
|
|
t.test_files=Dir.glob( "test/cases/**/*_test{,_#{adapter_short}}.rb" ).sort
|
2005-03-27 09:10:42 -05:00
|
|
|
t.verbose = true
|
|
|
|
}
|
2007-10-08 01:29:09 -04:00
|
|
|
|
2009-05-13 04:06:53 -04:00
|
|
|
task "isolated_test_#{adapter}" do
|
|
|
|
connection_path = "test/connections/#{adapter =~ /jdbc/ ? 'jdbc' : 'native'}_#{adapter}"
|
|
|
|
adapter_short = adapter == 'db2' ? adapter : adapter[/^[a-z]+/]
|
|
|
|
puts [adapter, adapter_short, connection_path].inspect
|
|
|
|
ruby = File.join(*RbConfig::CONFIG.values_at('bindir', 'RUBY_INSTALL_NAME'))
|
|
|
|
Dir["test/cases/**/*_test{,_#{adapter_short}}.rb"].all? do |file|
|
|
|
|
system(ruby, "-Ilib:test:#{connection_path}", file)
|
|
|
|
end or raise "Failures"
|
|
|
|
end
|
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
namespace adapter do
|
|
|
|
task :test => "test_#{adapter}"
|
2009-05-13 04:06:53 -04:00
|
|
|
task :isolated_test => "isolated_test_#{adapter}"
|
2007-10-08 01:29:09 -04:00
|
|
|
end
|
2005-03-27 09:10:42 -05:00
|
|
|
end
|
2005-02-07 09:06:00 -05:00
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
namespace :mysql do
|
|
|
|
desc 'Build the MySQL test databases'
|
|
|
|
task :build_databases do
|
2009-08-08 22:49:57 -04:00
|
|
|
%x( echo "create DATABASE activerecord_unittest DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci " | mysql --user=#{MYSQL_DB_USER})
|
|
|
|
%x( echo "create DATABASE activerecord_unittest2 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci " | mysql --user=#{MYSQL_DB_USER})
|
2007-10-08 01:29:09 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
desc 'Drop the MySQL test databases'
|
|
|
|
task :drop_databases do
|
2008-04-21 00:40:16 -04:00
|
|
|
%x( mysqladmin --user=#{MYSQL_DB_USER} -f drop activerecord_unittest )
|
|
|
|
%x( mysqladmin --user=#{MYSQL_DB_USER} -f drop activerecord_unittest2 )
|
2007-10-08 01:29:09 -04:00
|
|
|
end
|
2005-11-20 02:45:04 -05:00
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
desc 'Rebuild the MySQL test databases'
|
|
|
|
task :rebuild_databases => [:drop_databases, :build_databases]
|
2005-11-20 02:45:04 -05:00
|
|
|
end
|
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
task :build_mysql_databases => 'mysql:build_databases'
|
|
|
|
task :drop_mysql_databases => 'mysql:drop_databases'
|
2007-10-14 23:30:47 -04:00
|
|
|
task :rebuild_mysql_databases => 'mysql:rebuild_databases'
|
2005-11-20 02:45:04 -05:00
|
|
|
|
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
namespace :postgresql do
|
|
|
|
desc 'Build the PostgreSQL test databases'
|
|
|
|
task :build_databases do
|
2009-08-15 22:04:16 -04:00
|
|
|
%x( createdb -E UTF8 activerecord_unittest )
|
|
|
|
%x( createdb -E UTF8 activerecord_unittest2 )
|
2007-10-08 01:29:09 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
desc 'Drop the PostgreSQL test databases'
|
|
|
|
task :drop_databases do
|
2008-02-19 19:40:34 -05:00
|
|
|
%x( dropdb activerecord_unittest )
|
|
|
|
%x( dropdb activerecord_unittest2 )
|
2007-10-08 01:29:09 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
desc 'Rebuild the PostgreSQL test databases'
|
|
|
|
task :rebuild_databases => [:drop_databases, :build_databases]
|
2005-11-20 02:45:04 -05:00
|
|
|
end
|
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
task :build_postgresql_databases => 'postgresql:build_databases'
|
|
|
|
task :drop_postgresql_databases => 'postgresql:drop_databases'
|
2007-10-14 23:30:47 -04:00
|
|
|
task :rebuild_postgresql_databases => 'postgresql:rebuild_databases'
|
2005-02-23 08:34:57 -05:00
|
|
|
|
2006-04-27 18:39:45 -04:00
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
namespace :frontbase do
|
|
|
|
desc 'Build the FrontBase test databases'
|
|
|
|
task :build_databases => :rebuild_frontbase_databases
|
2006-04-27 18:39:45 -04:00
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
desc 'Rebuild the FrontBase test databases'
|
|
|
|
task :rebuild_databases do
|
|
|
|
build_frontbase_database = Proc.new do |db_name, sql_definition_file|
|
|
|
|
%(
|
|
|
|
STOP DATABASE #{db_name};
|
|
|
|
DELETE DATABASE #{db_name};
|
|
|
|
CREATE DATABASE #{db_name};
|
2006-04-27 18:39:45 -04:00
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
CONNECT TO #{db_name} AS SESSION_NAME USER _SYSTEM;
|
|
|
|
SET COMMIT FALSE;
|
2006-04-27 18:39:45 -04:00
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
CREATE USER RAILS;
|
|
|
|
CREATE SCHEMA RAILS AUTHORIZATION RAILS;
|
|
|
|
COMMIT;
|
2006-04-27 18:39:45 -04:00
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
SET SESSION AUTHORIZATION RAILS;
|
|
|
|
SCRIPT '#{sql_definition_file}';
|
2006-04-27 18:39:45 -04:00
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
COMMIT;
|
|
|
|
|
|
|
|
DISCONNECT ALL;
|
|
|
|
)
|
|
|
|
end
|
2008-01-21 12:20:51 -05:00
|
|
|
create_activerecord_unittest = build_frontbase_database['activerecord_unittest', File.join(SCHEMA_ROOT, 'frontbase.sql')]
|
|
|
|
create_activerecord_unittest2 = build_frontbase_database['activerecord_unittest2', File.join(SCHEMA_ROOT, 'frontbase2.sql')]
|
2007-10-08 01:29:09 -04:00
|
|
|
execute_frontbase_sql = Proc.new do |sql|
|
|
|
|
system(<<-SHELL)
|
|
|
|
/Library/FrontBase/bin/sql92 <<-SQL
|
|
|
|
#{sql}
|
|
|
|
SQL
|
|
|
|
SHELL
|
|
|
|
end
|
|
|
|
execute_frontbase_sql[create_activerecord_unittest]
|
|
|
|
execute_frontbase_sql[create_activerecord_unittest2]
|
2006-04-27 18:39:45 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
task :build_frontbase_databases => 'frontbase:build_databases'
|
|
|
|
task :rebuild_frontbase_databases => 'frontbase:rebuild_databases'
|
|
|
|
|
|
|
|
|
2004-11-23 20:04:44 -05:00
|
|
|
# Generate the RDoc documentation
|
|
|
|
|
|
|
|
Rake::RDocTask.new { |rdoc|
|
|
|
|
rdoc.rdoc_dir = 'doc'
|
|
|
|
rdoc.title = "Active Record -- Object-relation mapping put on rails"
|
2006-02-25 18:09:07 -05:00
|
|
|
rdoc.options << '--line-numbers' << '--inline-source' << '-A cattr_accessor=object'
|
2007-05-28 18:55:14 -04:00
|
|
|
rdoc.options << '--charset' << 'utf-8'
|
2008-06-22 13:38:25 -04:00
|
|
|
rdoc.template = ENV['template'] ? "#{ENV['template']}.rb" : '../doc/template/horo'
|
2004-11-23 20:04:44 -05:00
|
|
|
rdoc.rdoc_files.include('README', 'RUNNING_UNIT_TESTS', 'CHANGELOG')
|
|
|
|
rdoc.rdoc_files.include('lib/**/*.rb')
|
|
|
|
rdoc.rdoc_files.exclude('lib/active_record/vendor/*')
|
|
|
|
rdoc.rdoc_files.include('dev-utils/*.rb')
|
|
|
|
}
|
|
|
|
|
2005-04-30 11:55:25 -04:00
|
|
|
# Enhance rdoc task to copy referenced images also
|
|
|
|
task :rdoc do
|
|
|
|
FileUtils.mkdir_p "doc/files/examples/"
|
|
|
|
FileUtils.copy "examples/associations.png", "doc/files/examples/associations.png"
|
|
|
|
end
|
|
|
|
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2009-09-25 01:46:04 -04:00
|
|
|
spec = eval(File.read('activerecord.gemspec'))
|
2007-10-08 01:29:09 -04:00
|
|
|
|
2004-11-23 20:04:44 -05:00
|
|
|
Rake::GemPackageTask.new(spec) do |p|
|
|
|
|
p.gem_spec = spec
|
|
|
|
p.need_tar = true
|
|
|
|
p.need_zip = true
|
|
|
|
end
|
|
|
|
|
2005-04-13 01:06:40 -04:00
|
|
|
task :lines do
|
|
|
|
lines, codelines, total_lines, total_codelines = 0, 0, 0, 0
|
|
|
|
|
|
|
|
for file_name in FileList["lib/active_record/**/*.rb"]
|
|
|
|
next if file_name =~ /vendor/
|
|
|
|
f = File.open(file_name)
|
|
|
|
|
|
|
|
while line = f.gets
|
|
|
|
lines += 1
|
|
|
|
next if line =~ /^\s*$/
|
|
|
|
next if line =~ /^\s*#/
|
|
|
|
codelines += 1
|
|
|
|
end
|
|
|
|
puts "L: #{sprintf("%4d", lines)}, LOC #{sprintf("%4d", codelines)} | #{file_name}"
|
2007-10-08 01:29:09 -04:00
|
|
|
|
2005-04-13 01:06:40 -04:00
|
|
|
total_lines += lines
|
|
|
|
total_codelines += codelines
|
2007-10-08 01:29:09 -04:00
|
|
|
|
2005-04-13 01:06:40 -04:00
|
|
|
lines, codelines = 0, 0
|
|
|
|
end
|
|
|
|
|
|
|
|
puts "Total: Lines #{total_lines}, LOC #{total_codelines}"
|
|
|
|
end
|
|
|
|
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2005-03-27 08:33:54 -05:00
|
|
|
# Publishing ------------------------------------------------------
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2005-03-27 08:33:54 -05:00
|
|
|
desc "Publish the beta gem"
|
2007-10-08 01:29:09 -04:00
|
|
|
task :pgem => [:package] do
|
2009-05-01 00:02:11 -04:00
|
|
|
require 'rake/contrib/sshpublisher'
|
2008-10-23 14:18:11 -04:00
|
|
|
Rake::SshFilePublisher.new("gems.rubyonrails.org", "/u/sites/gems/gems", "pkg", "#{PKG_FILE_NAME}.gem").upload
|
2008-10-23 14:29:25 -04:00
|
|
|
`ssh gems.rubyonrails.org '/u/sites/gems/gemupdate.sh'`
|
2005-03-27 08:33:54 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
desc "Publish the API documentation"
|
2007-10-08 01:29:09 -04:00
|
|
|
task :pdoc => [:rdoc] do
|
2009-05-01 00:02:11 -04:00
|
|
|
require 'rake/contrib/sshpublisher'
|
2008-06-18 22:56:22 -04:00
|
|
|
Rake::SshDirPublisher.new("wrath.rubyonrails.org", "public_html/ar", "doc").upload
|
2004-11-23 20:04:44 -05:00
|
|
|
end
|
2005-03-27 08:33:54 -05:00
|
|
|
|
|
|
|
desc "Publish the release files to RubyForge."
|
2006-04-09 18:14:08 -04:00
|
|
|
task :release => [ :package ] do
|
2007-04-21 13:06:16 -04:00
|
|
|
require 'rubyforge'
|
2008-01-02 21:58:43 -05:00
|
|
|
require 'rake/contrib/rubyforgepublisher'
|
2005-03-27 08:33:54 -05:00
|
|
|
|
2007-04-21 13:06:16 -04:00
|
|
|
packages = %w( gem tgz zip ).collect{ |ext| "pkg/#{PKG_NAME}-#{PKG_VERSION}.#{ext}" }
|
|
|
|
|
|
|
|
rubyforge = RubyForge.new
|
|
|
|
rubyforge.login
|
|
|
|
rubyforge.add_release(PKG_NAME, PKG_NAME, "REL #{PKG_VERSION}", *packages)
|
2007-05-11 20:44:50 -04:00
|
|
|
end
|