2017-07-09 13:41:28 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-08-06 13:28:46 -04:00
|
|
|
require "rake/testtask"
|
2008-01-21 12:20:51 -05:00
|
|
|
|
2017-06-11 08:59:23 -04:00
|
|
|
require_relative "test/config"
|
|
|
|
require_relative "test/support/config"
|
2008-04-21 00:40:16 -04:00
|
|
|
|
2009-08-27 14:04:08 -04:00
|
|
|
def run_without_aborting(*tasks)
|
|
|
|
errors = []
|
|
|
|
|
|
|
|
tasks.each do |task|
|
2018-12-20 12:44:01 -05:00
|
|
|
Rake::Task[task].invoke
|
|
|
|
rescue Exception
|
|
|
|
errors << task
|
2009-08-27 14:04:08 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
abort "Errors running #{errors.join(', ')}" if errors.any?
|
|
|
|
end
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2016-08-06 13:28:46 -04:00
|
|
|
desc "Run mysql2, sqlite, and postgresql tests by default"
|
2016-08-06 13:37:57 -04:00
|
|
|
task default: :test
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2016-01-31 13:01:03 -05:00
|
|
|
task :package
|
|
|
|
|
2016-08-06 13:28:46 -04:00
|
|
|
desc "Run mysql2, 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) :
|
2015-12-15 17:01:30 -05:00
|
|
|
%w(test_mysql2 test_sqlite3 test_postgresql)
|
2009-08-27 14:04:08 -04:00
|
|
|
run_without_aborting(*tasks)
|
|
|
|
end
|
|
|
|
|
2009-11-10 19:50:15 -05:00
|
|
|
namespace :test do
|
|
|
|
task :isolated do
|
|
|
|
tasks = defined?(JRUBY_VERSION) ?
|
|
|
|
%w(isolated_test_jdbcmysql isolated_test_jdbcsqlite3 isolated_test_jdbcpostgresql) :
|
2015-12-15 17:01:30 -05:00
|
|
|
%w(isolated_test_mysql2 isolated_test_sqlite3 isolated_test_postgresql)
|
2009-11-10 19:50:15 -05:00
|
|
|
run_without_aborting(*tasks)
|
|
|
|
end
|
2009-08-27 14:04:08 -04:00
|
|
|
end
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2013-01-20 12:41:49 -05:00
|
|
|
namespace :db do
|
2018-04-03 01:23:47 -04:00
|
|
|
desc "Build MySQL and PostgreSQL test databases"
|
2016-08-06 13:37:57 -04:00
|
|
|
task create: ["db:mysql:build", "db:postgresql:build"]
|
2018-04-03 01:23:47 -04:00
|
|
|
|
|
|
|
desc "Drop MySQL and PostgreSQL test databases"
|
2016-08-06 13:37:57 -04:00
|
|
|
task drop: ["db:mysql:drop", "db:postgresql:drop"]
|
2013-01-20 12:41:49 -05:00
|
|
|
end
|
|
|
|
|
2015-12-15 17:01:30 -05:00
|
|
|
%w( mysql2 postgresql sqlite3 sqlite3_mem db2 oracle jdbcmysql jdbcpostgresql jdbcsqlite3 jdbcderby jdbch2 jdbchsqldb ).each do |adapter|
|
2014-05-03 14:15:11 -04:00
|
|
|
namespace :test do
|
|
|
|
Rake::TestTask.new(adapter => "#{adapter}:env") { |t|
|
2016-08-06 13:28:46 -04:00
|
|
|
adapter_short = adapter == "db2" ? adapter : adapter[/^[a-z0-9]+/]
|
|
|
|
t.libs << "test"
|
2016-10-28 23:05:58 -04:00
|
|
|
t.test_files = (Dir.glob("test/cases/**/*_test.rb").reject {
|
2016-08-06 13:28:46 -04:00
|
|
|
|x| x.include?("/adapters/")
|
2015-03-05 13:09:20 -05:00
|
|
|
} + Dir.glob("test/cases/adapters/#{adapter_short}/**/*_test.rb"))
|
2014-05-03 14:15:11 -04:00
|
|
|
|
|
|
|
t.warning = true
|
|
|
|
t.verbose = true
|
2014-09-27 10:37:44 -04:00
|
|
|
t.ruby_opts = ["--dev"] if defined?(JRUBY_VERSION)
|
2014-05-03 14:15:11 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace :isolated do
|
|
|
|
task adapter => "#{adapter}:env" do
|
2016-08-06 13:28:46 -04:00
|
|
|
adapter_short = adapter == "db2" ? adapter : adapter[/^[a-z0-9]+/]
|
2014-05-03 14:15:11 -04:00
|
|
|
puts [adapter, adapter_short].inspect
|
2019-02-13 08:28:55 -05:00
|
|
|
|
|
|
|
failing_files = []
|
|
|
|
|
|
|
|
test_files = (Dir["test/cases/**/*_test.rb"].reject {
|
2016-08-06 13:28:46 -04:00
|
|
|
|x| x.include?("/adapters/")
|
2019-02-13 08:28:55 -05:00
|
|
|
} + Dir["test/cases/adapters/#{adapter_short}/**/*_test.rb"]).sort
|
|
|
|
|
|
|
|
if ENV["BUILDKITE_PARALLEL_JOB_COUNT"]
|
|
|
|
n = ENV["BUILDKITE_PARALLEL_JOB"].to_i
|
|
|
|
m = ENV["BUILDKITE_PARALLEL_JOB_COUNT"].to_i
|
|
|
|
|
|
|
|
test_files = test_files.each_slice(m).map { |slice| slice[n] }.compact
|
|
|
|
end
|
|
|
|
|
|
|
|
test_files.each do |file|
|
|
|
|
puts "--- #{file}"
|
|
|
|
success = sh(Gem.ruby, "-w", "-Itest", file)
|
|
|
|
unless success
|
|
|
|
failing_files << file
|
|
|
|
puts "^^^ +++"
|
|
|
|
end
|
|
|
|
puts
|
|
|
|
end
|
|
|
|
|
|
|
|
puts "--- All tests completed"
|
|
|
|
unless failing_files.empty?
|
|
|
|
puts "^^^ +++"
|
|
|
|
puts
|
|
|
|
puts "Failed in:"
|
|
|
|
failing_files.each do |file|
|
|
|
|
puts " #{file}"
|
|
|
|
end
|
|
|
|
puts
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
end
|
2014-05-03 14:15:11 -04:00
|
|
|
end
|
|
|
|
end
|
2009-05-13 04:06:53 -04:00
|
|
|
end
|
|
|
|
|
2007-10-08 01:29:09 -04:00
|
|
|
namespace adapter do
|
2016-08-06 13:37:57 -04:00
|
|
|
task test: "test_#{adapter}"
|
|
|
|
task isolated_test: "isolated_test_#{adapter}"
|
2011-06-06 19:51:28 -04:00
|
|
|
|
|
|
|
# Set the connection environment for the adapter
|
2016-08-06 13:28:46 -04:00
|
|
|
task(:env) { ENV["ARCONN"] = adapter }
|
2007-10-08 01:29:09 -04:00
|
|
|
end
|
2011-06-06 19:51:28 -04:00
|
|
|
|
|
|
|
# Make sure the adapter test evaluates the env setting task
|
2014-05-03 14:15:11 -04:00
|
|
|
task "test_#{adapter}" => ["#{adapter}:env", "test:#{adapter}"]
|
|
|
|
task "isolated_test_#{adapter}" => ["#{adapter}:env", "test:isolated:#{adapter}"]
|
2005-03-27 09:10:42 -05:00
|
|
|
end
|
2005-02-07 09:06:00 -05:00
|
|
|
|
2014-05-03 14:15:11 -04:00
|
|
|
namespace :db do
|
|
|
|
namespace :mysql do
|
2019-02-05 09:50:06 -05:00
|
|
|
connection_arguments = lambda do |connection_name|
|
|
|
|
config = ARTest.config["connections"]["mysql2"][connection_name]
|
|
|
|
["--user=#{config["username"]}", "--password=#{config["password"]}", ("--host=#{config["host"]}" if config["host"])].join(" ")
|
|
|
|
end
|
|
|
|
|
2016-08-06 13:28:46 -04:00
|
|
|
desc "Build the MySQL test databases"
|
2014-05-03 14:15:11 -04:00
|
|
|
task :build do
|
2016-08-06 13:28:46 -04:00
|
|
|
config = ARTest.config["connections"]["mysql2"]
|
2019-02-05 09:50:06 -05:00
|
|
|
%x( mysql #{connection_arguments["arunit"]} -e "create DATABASE #{config["arunit"]["database"]} DEFAULT CHARACTER SET utf8mb4" )
|
|
|
|
%x( mysql #{connection_arguments["arunit2"]} -e "create DATABASE #{config["arunit2"]["database"]} DEFAULT CHARACTER SET utf8mb4" )
|
2014-05-03 14:15:11 -04:00
|
|
|
end
|
2014-05-03 14:08:15 -04:00
|
|
|
|
2016-08-06 13:28:46 -04:00
|
|
|
desc "Drop the MySQL test databases"
|
2014-05-03 14:15:11 -04:00
|
|
|
task :drop do
|
2016-08-06 13:28:46 -04:00
|
|
|
config = ARTest.config["connections"]["mysql2"]
|
2019-02-05 09:50:06 -05:00
|
|
|
%x( mysqladmin #{connection_arguments["arunit"]} -f drop #{config["arunit"]["database"]} )
|
|
|
|
%x( mysqladmin #{connection_arguments["arunit2"]} -f drop #{config["arunit2"]["database"]} )
|
2014-05-03 14:15:11 -04:00
|
|
|
end
|
2005-11-20 02:45:04 -05:00
|
|
|
|
2016-08-06 13:28:46 -04:00
|
|
|
desc "Rebuild the MySQL test databases"
|
2016-08-06 13:37:57 -04:00
|
|
|
task rebuild: [:drop, :build]
|
2014-05-03 14:15:11 -04:00
|
|
|
end
|
2005-11-20 02:45:04 -05:00
|
|
|
|
2014-05-03 14:15:11 -04:00
|
|
|
namespace :postgresql do
|
2016-08-06 13:28:46 -04:00
|
|
|
desc "Build the PostgreSQL test databases"
|
2014-05-03 14:15:11 -04:00
|
|
|
task :build do
|
2016-08-06 13:28:46 -04:00
|
|
|
config = ARTest.config["connections"]["postgresql"]
|
|
|
|
%x( createdb -E UTF8 -T template0 #{config["arunit"]["database"]} )
|
|
|
|
%x( createdb -E UTF8 -T template0 #{config["arunit2"]["database"]} )
|
2014-05-03 14:15:11 -04:00
|
|
|
end
|
2007-10-08 01:29:09 -04:00
|
|
|
|
2016-08-06 13:28:46 -04:00
|
|
|
desc "Drop the PostgreSQL test databases"
|
2014-05-03 14:15:11 -04:00
|
|
|
task :drop do
|
2016-08-06 13:28:46 -04:00
|
|
|
config = ARTest.config["connections"]["postgresql"]
|
|
|
|
%x( dropdb #{config["arunit"]["database"]} )
|
|
|
|
%x( dropdb #{config["arunit2"]["database"]} )
|
2014-05-03 13:34:18 -04:00
|
|
|
end
|
2007-10-08 01:29:09 -04:00
|
|
|
|
2016-08-06 13:28:46 -04:00
|
|
|
desc "Rebuild the PostgreSQL test databases"
|
2016-08-06 13:37:57 -04:00
|
|
|
task rebuild: [:drop, :build]
|
2014-05-03 13:34:18 -04:00
|
|
|
end
|
2005-11-20 02:45:04 -05:00
|
|
|
end
|
|
|
|
|
2016-08-06 13:37:57 -04:00
|
|
|
task build_mysql_databases: "db:mysql:build"
|
|
|
|
task drop_mysql_databases: "db:mysql:drop"
|
|
|
|
task rebuild_mysql_databases: "db:mysql:rebuild"
|
2006-04-27 18:39:45 -04:00
|
|
|
|
2016-08-06 13:37:57 -04:00
|
|
|
task build_postgresql_databases: "db:postgresql:build"
|
|
|
|
task drop_postgresql_databases: "db:postgresql:drop"
|
|
|
|
task rebuild_postgresql_databases: "db:postgresql:rebuild"
|
2004-11-23 20:04:44 -05:00
|
|
|
|
2005-04-13 01:06:40 -04:00
|
|
|
task :lines do
|
2017-05-15 10:17:28 -04:00
|
|
|
load File.expand_path("../tools/line_statistics", __dir__)
|
2013-06-28 00:18:30 -04:00
|
|
|
files = FileList["lib/active_record/**/*.rb"]
|
|
|
|
CodeTools::LineStatistics.new(files).print_loc
|
2005-04-13 01:06:40 -04:00
|
|
|
end
|