Rakefile 6.9 KB
Newer Older
S
Santiago Pastorino 已提交
1
gem 'rdoc', '>= 2.5.10'
2
require 'rdoc'
D
Initial  
David Heinemeier Hansson 已提交
3 4
require 'rake'
require 'rake/testtask'
A
Aaron Patterson 已提交
5
require 'rdoc/task'
D
Initial  
David Heinemeier Hansson 已提交
6 7
require 'rake/packagetask'
require 'rake/gempackagetask'
8 9

require File.expand_path(File.dirname(__FILE__)) + "/test/config"
D
Initial  
David Heinemeier Hansson 已提交
10

11 12
MYSQL_DB_USER = 'rails'

13 14 15 16 17 18 19 20 21 22 23 24 25
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
D
Initial  
David Heinemeier Hansson 已提交
26

B
Brian Lopez 已提交
27
desc 'Run mysql, mysql2, sqlite, and postgresql tests by default'
J
Jeremy Kemper 已提交
28
task :default => :test
D
Initial  
David Heinemeier Hansson 已提交
29

B
Brian Lopez 已提交
30
desc 'Run mysql, mysql2, sqlite, and postgresql tests'
31 32 33
task :test do
  tasks = defined?(JRUBY_VERSION) ?
    %w(test_jdbcmysql test_jdbcsqlite3 test_jdbcpostgresql) :
B
Brian Lopez 已提交
34
    %w(test_mysql test_mysql2 test_sqlite3 test_postgresql)
35 36 37
  run_without_aborting(*tasks)
end

38 39 40 41
namespace :test do
  task :isolated do
    tasks = defined?(JRUBY_VERSION) ?
      %w(isolated_test_jdbcmysql isolated_test_jdbcsqlite3 isolated_test_jdbcpostgresql) :
B
Brian Lopez 已提交
42
      %w(isolated_test_mysql isolated_test_mysql2 isolated_test_sqlite3 isolated_test_postgresql)
43 44
    run_without_aborting(*tasks)
  end
45
end
D
Initial  
David Heinemeier Hansson 已提交
46

B
Brian Lopez 已提交
47
%w( mysql mysql2 postgresql sqlite3 firebird db2 oracle sybase openbase frontbase jdbcmysql jdbcpostgresql jdbcsqlite3 jdbcderby jdbch2 jdbchsqldb ).each do |adapter|
48
  Rake::TestTask.new("test_#{adapter}") { |t|
J
Jeremy Kemper 已提交
49
    connection_path = "test/connections/#{adapter =~ /jdbc/ ? 'jdbc' : 'native'}_#{adapter}"
B
Brian Lopez 已提交
50
    adapter_short = adapter == 'db2' ? adapter : adapter[/^[a-z0-9]+/]
J
Jeremy Kemper 已提交
51
    t.libs << "test" << connection_path
52 53 54 55
    t.test_files = (Dir.glob( "test/cases/**/*_test.rb" ).reject {
      |x| x =~ /\/adapters\//
    } + Dir.glob("test/cases/adapters/#{adapter_short}/**/*_test.rb")).sort

56
    t.verbose = true
57
    t.warning = true
58
  }
59

J
Jeremy Kemper 已提交
60 61
  task "isolated_test_#{adapter}" do
    connection_path = "test/connections/#{adapter =~ /jdbc/ ? 'jdbc' : 'native'}_#{adapter}"
B
Brian Lopez 已提交
62
    adapter_short = adapter == 'db2' ? adapter : adapter[/^[a-z0-9]+/]
J
Jeremy Kemper 已提交
63 64
    puts [adapter, adapter_short, connection_path].inspect
    ruby = File.join(*RbConfig::CONFIG.values_at('bindir', 'RUBY_INSTALL_NAME'))
65 66 67
    (Dir["test/cases/**/*_test.rb"].reject {
      |x| x =~ /\/adapters\//
    } + Dir["test/cases/adapters/#{adapter_short}/**/*_test.rb"]).all? do |file|
J
Jeremy Kemper 已提交
68 69 70 71
      system(ruby, "-Ilib:test:#{connection_path}", file)
    end or raise "Failures"
  end

72 73
  namespace adapter do
    task :test => "test_#{adapter}"
J
Jeremy Kemper 已提交
74
    task :isolated_test => "isolated_test_#{adapter}"
75
  end
76
end
77

78 79 80
namespace :mysql do
  desc 'Build the MySQL test databases'
  task :build_databases do
81 82
    %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})
83 84 85 86
  end

  desc 'Drop the MySQL test databases'
  task :drop_databases do
87 88
    %x( mysqladmin --user=#{MYSQL_DB_USER} -f drop activerecord_unittest )
    %x( mysqladmin --user=#{MYSQL_DB_USER} -f drop activerecord_unittest2 )
89
  end
90

91 92
  desc 'Rebuild the MySQL test databases'
  task :rebuild_databases => [:drop_databases, :build_databases]
93 94
end

95 96
task :build_mysql_databases => 'mysql:build_databases'
task :drop_mysql_databases => 'mysql:drop_databases'
97
task :rebuild_mysql_databases => 'mysql:rebuild_databases'
98 99


100 101 102
namespace :postgresql do
  desc 'Build the PostgreSQL test databases'
  task :build_databases do
103 104
    %x( createdb -E UTF8 activerecord_unittest )
    %x( createdb -E UTF8 activerecord_unittest2 )
105 106 107 108
  end

  desc 'Drop the PostgreSQL test databases'
  task :drop_databases do
109 110
    %x( dropdb activerecord_unittest )
    %x( dropdb activerecord_unittest2 )
111 112 113 114
  end

  desc 'Rebuild the PostgreSQL test databases'
  task :rebuild_databases => [:drop_databases, :build_databases]
115 116
end

117 118
task :build_postgresql_databases => 'postgresql:build_databases'
task :drop_postgresql_databases => 'postgresql:drop_databases'
119
task :rebuild_postgresql_databases => 'postgresql:rebuild_databases'
120

121

122 123 124
namespace :frontbase do
  desc 'Build the FrontBase test databases'
  task :build_databases => :rebuild_frontbase_databases
125

126 127 128 129 130 131 132
  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};
133

134 135
        CONNECT TO #{db_name} AS SESSION_NAME USER _SYSTEM;
        SET COMMIT FALSE;
136

137 138 139
        CREATE USER RAILS;
        CREATE SCHEMA RAILS AUTHORIZATION RAILS;
        COMMIT;
140

141 142
        SET SESSION AUTHORIZATION RAILS;
        SCRIPT '#{sql_definition_file}';
143

144 145 146 147 148
        COMMIT;

        DISCONNECT ALL;
      )
    end
149 150
    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')]
151 152 153 154 155 156 157 158 159
    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]
160 161 162
  end
end

163 164 165 166
task :build_frontbase_databases => 'frontbase:build_databases'
task :rebuild_frontbase_databases => 'frontbase:rebuild_databases'


D
Initial  
David Heinemeier Hansson 已提交
167 168
# Generate the RDoc documentation

A
Aaron Patterson 已提交
169
RDoc::Task.new { |rdoc|
D
Initial  
David Heinemeier Hansson 已提交
170 171
  rdoc.rdoc_dir = 'doc'
  rdoc.title    = "Active Record -- Object-relation mapping put on rails"
A
Aaron Patterson 已提交
172 173
  rdoc.options << '-f' << 'horo'
  rdoc.options << '--main' << 'README.rdoc'
174
  rdoc.options << '--charset' << 'utf-8'
175
  rdoc.rdoc_files.include('README.rdoc', 'RUNNING_UNIT_TESTS', 'CHANGELOG')
D
Initial  
David Heinemeier Hansson 已提交
176 177 178 179 180
  rdoc.rdoc_files.include('lib/**/*.rb')
  rdoc.rdoc_files.exclude('lib/active_record/vendor/*')
  rdoc.rdoc_files.include('dev-utils/*.rb')
}

181 182 183 184 185 186
# 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

D
Initial  
David Heinemeier Hansson 已提交
187

188
spec = eval(File.read('activerecord.gemspec'))
189

D
Initial  
David Heinemeier Hansson 已提交
190 191 192 193
Rake::GemPackageTask.new(spec) do |p|
  p.gem_spec = spec
end

194 195 196 197 198 199 200 201 202 203 204 205 206 207
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}"
208

209 210
    total_lines     += lines
    total_codelines += codelines
211

212 213 214 215 216 217
    lines, codelines = 0, 0
  end

  puts "Total: Lines #{total_lines}, LOC #{total_codelines}"
end

D
Initial  
David Heinemeier Hansson 已提交
218

219
# Publishing ------------------------------------------------------
D
Initial  
David Heinemeier Hansson 已提交
220

221
desc "Release to gemcutter"
222 223 224 225 226
task :release => :package do
  require 'rake/gemcutter'
  Rake::Gemcutter::Tasks.new(spec).define
  Rake::Task['gem:push'].invoke
end