Rakefile 6.7 KB
Newer Older
1
#!/usr/bin/env rake
D
Initial  
David Heinemeier Hansson 已提交
2 3
require 'rake/testtask'
require 'rake/packagetask'
4
require 'rubygems/package_task'
5 6

require File.expand_path(File.dirname(__FILE__)) + "/test/config"
7
require File.expand_path(File.dirname(__FILE__)) + "/test/support/config"
8

9 10 11 12 13 14 15 16 17 18 19 20 21
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 已提交
22

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

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

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

43
%w( mysql mysql2 postgresql sqlite3 sqlite3_mem firebird db2 oracle sybase openbase frontbase jdbcmysql jdbcpostgresql jdbcsqlite3 jdbcderby jdbch2 jdbchsqldb ).each do |adapter|
44
  Rake::TestTask.new("test_#{adapter}") { |t|
B
Brian Lopez 已提交
45
    adapter_short = adapter == 'db2' ? adapter : adapter[/^[a-z0-9]+/]
A
Aaron Patterson 已提交
46
    t.libs << 'test'
47 48 49 50
    t.test_files = (Dir.glob( "test/cases/**/*_test.rb" ).reject {
      |x| x =~ /\/adapters\//
    } + Dir.glob("test/cases/adapters/#{adapter_short}/**/*_test.rb")).sort

51
    t.verbose = true
52
    t.warning = true
53
    t.ruby_opts = ["-r#{File.expand_path('../', __FILE__)}/test/connections/#{adapter}"]
54
  }
55

J
Jeremy Kemper 已提交
56
  task "isolated_test_#{adapter}" do
B
Brian Lopez 已提交
57
    adapter_short = adapter == 'db2' ? adapter : adapter[/^[a-z0-9]+/]
58
    puts [adapter, adapter_short].inspect
J
Jeremy Kemper 已提交
59
    ruby = File.join(*RbConfig::CONFIG.values_at('bindir', 'RUBY_INSTALL_NAME'))
60 61 62
    (Dir["test/cases/**/*_test.rb"].reject {
      |x| x =~ /\/adapters\//
    } + Dir["test/cases/adapters/#{adapter_short}/**/*_test.rb"]).all? do |file|
63
      sh(ruby, "-Itest", "-r#{File.expand_path('../', __FILE__)}/test/connections/#{adapter}", file)
J
Jeremy Kemper 已提交
64 65 66
    end or raise "Failures"
  end

67 68
  namespace adapter do
    task :test => "test_#{adapter}"
J
Jeremy Kemper 已提交
69
    task :isolated_test => "isolated_test_#{adapter}"
70
  end
71
end
72

73 74 75 76 77 78 79 80 81
rule '.sqlite3' do |t|
  sh %Q{sqlite3 "#{t.name}" "create table a (a integer); drop table a;"}
end

task :test_sqlite3 => [
  'test/fixtures/fixture_database.sqlite3',
  'test/fixtures/fixture_database_2.sqlite3'
]

82 83 84
namespace :mysql do
  desc 'Build the MySQL test databases'
  task :build_databases do
85 86 87
    config = ARTest.config['connections']['mysql']
    %x( mysql --user=#{config['arunit']['username']} -e "create DATABASE #{config['arunit']['database']} DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci ")
    %x( mysql --user=#{config['arunit2']['username']} -e "create DATABASE #{config['arunit2']['database']} DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci ")
88 89 90 91
  end

  desc 'Drop the MySQL test databases'
  task :drop_databases do
92 93 94
    config = ARTest.config['connections']['mysql']
    %x( mysqladmin --user=#{config['arunit']['username']} -f drop #{config['arunit']['database']} )
    %x( mysqladmin --user=#{config['arunit2']['username']} -f drop #{config['arunit2']['database']} )
95
  end
96

97 98
  desc 'Rebuild the MySQL test databases'
  task :rebuild_databases => [:drop_databases, :build_databases]
99 100
end

101 102
task :build_mysql_databases => 'mysql:build_databases'
task :drop_mysql_databases => 'mysql:drop_databases'
103
task :rebuild_mysql_databases => 'mysql:rebuild_databases'
104 105


106 107 108
namespace :postgresql do
  desc 'Build the PostgreSQL test databases'
  task :build_databases do
109 110 111
    config = ARTest.config['connections']['postgresql']
    %x( createdb -E UTF8 #{config['arunit']['database']} )
    %x( createdb -E UTF8 #{config['arunit2']['database']} )
112 113 114 115
  end

  desc 'Drop the PostgreSQL test databases'
  task :drop_databases do
116 117 118
    config = ARTest.config['connections']['postgresql']
    %x( dropdb #{config['arunit']['database']} )
    %x( dropdb #{config['arunit2']['database']} )
119 120 121 122
  end

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

125 126
task :build_postgresql_databases => 'postgresql:build_databases'
task :drop_postgresql_databases => 'postgresql:drop_databases'
127
task :rebuild_postgresql_databases => 'postgresql:rebuild_databases'
128

129

130 131 132
namespace :frontbase do
  desc 'Build the FrontBase test databases'
  task :build_databases => :rebuild_frontbase_databases
133

134 135 136 137 138 139 140
  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};
141

142 143
        CONNECT TO #{db_name} AS SESSION_NAME USER _SYSTEM;
        SET COMMIT FALSE;
144

145 146 147
        CREATE USER RAILS;
        CREATE SCHEMA RAILS AUTHORIZATION RAILS;
        COMMIT;
148

149 150
        SET SESSION AUTHORIZATION RAILS;
        SCRIPT '#{sql_definition_file}';
151

152 153 154 155 156
        COMMIT;

        DISCONNECT ALL;
      )
    end
157 158 159
    config = ARTest.config['connections']['frontbase']
    create_activerecord_unittest  = build_frontbase_database[config['arunit']['database'],  File.join(SCHEMA_ROOT, 'frontbase.sql')]
    create_activerecord_unittest2 = build_frontbase_database[config['arunit2']['database'], File.join(SCHEMA_ROOT, 'frontbase2.sql')]
160 161 162 163 164 165 166 167 168
    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]
169 170 171
  end
end

172 173 174
task :build_frontbase_databases => 'frontbase:build_databases'
task :rebuild_frontbase_databases => 'frontbase:rebuild_databases'

175
spec = eval(File.read('activerecord.gemspec'))
176

177
Gem::PackageTask.new(spec) do |p|
D
Initial  
David Heinemeier Hansson 已提交
178 179 180
  p.gem_spec = spec
end

181 182 183 184 185 186 187 188 189 190 191 192 193 194
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}"
195

196 197
    total_lines     += lines
    total_codelines += codelines
198

199 200 201 202 203 204
    lines, codelines = 0, 0
  end

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

D
Initial  
David Heinemeier Hansson 已提交
205

206
# Publishing ------------------------------------------------------
D
Initial  
David Heinemeier Hansson 已提交
207

208
desc "Release to gemcutter"
209 210 211 212 213
task :release => :package do
  require 'rake/gemcutter'
  Rake::Gemcutter::Tasks.new(spec).define
  Rake::Task['gem:push'].invoke
end