1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/actionview/Rakefile

138 lines
3.2 KiB
Text
Raw Normal View History

# frozen_string_literal: true
require "rake/testtask"
2017-02-21 13:41:17 -05:00
require "fileutils"
require "open3"
desc "Default Task"
2016-08-06 13:36:34 -04:00
task default: :test
task package: %w( assets:compile assets:verify )
# Run the unit tests
desc "Run all unit tests"
2016-08-06 13:36:34 -04:00
task test: ["test:template", "test:integration:action_pack", "test:integration:active_record"]
namespace :test do
2013-06-20 12:24:50 -04:00
task :isolated do
Dir.glob("test/{actionpack,activerecord,template}/**/*_test.rb").all? do |file|
sh(Gem.ruby, "-w", "-Ilib:test", file)
end || raise("Failures")
end
Rake::TestTask.new(:template) do |t|
t.libs << "test"
t.test_files = Dir.glob("test/template/**/*_test.rb")
2013-08-05 18:43:32 -04:00
t.warning = true
t.verbose = true
t.ruby_opts = ["--dev"] if defined?(JRUBY_VERSION)
end
desc "Run tests for rails-ujs"
2017-02-21 13:41:17 -05:00
task :ujs do
begin
Dir.mkdir("log")
pid = spawn("bundle exec rackup test/ujs/config.ru -p 4567 -s puma > log/test.log 2>&1", pgroup: true)
2017-02-21 13:41:17 -05:00
start_time = Time.now
loop do
2017-07-26 11:28:12 -04:00
break if system("lsof -i :4567", 1 => File::NULL)
2017-02-21 13:41:17 -05:00
if Time.now - start_time > 5
puts "Timed out after 5 seconds"
exit 1
end
end
system("npm run lint && bundle exec ruby ../ci/qunit-selenium-runner.rb http://localhost:4567/")
status = $?.exitstatus
2017-02-21 13:41:17 -05:00
ensure
Process.kill("KILL", -pid) if pid
FileUtils.rm_rf("log")
2017-02-21 13:41:17 -05:00
end
exit status
end
2013-08-05 18:43:32 -04:00
namespace :integration do
# Active Record Integration Tests
2013-08-05 18:43:32 -04:00
Rake::TestTask.new(:active_record) do |t|
t.libs << "test"
2013-08-05 18:43:32 -04:00
t.test_files = Dir.glob("test/activerecord/*_test.rb")
t.warning = true
t.verbose = true
t.ruby_opts = ["--dev"] if defined?(JRUBY_VERSION)
2013-08-05 18:43:32 -04:00
end
2013-08-05 18:47:49 -04:00
# Action Pack Integration Tests
2013-08-05 18:47:49 -04:00
Rake::TestTask.new(:action_pack) do |t|
t.libs << "test"
2013-08-13 16:28:51 -04:00
t.test_files = Dir.glob("test/actionpack/**/*_test.rb")
2013-08-05 18:47:49 -04:00
t.warning = true
t.verbose = true
t.ruby_opts = ["--dev"] if defined?(JRUBY_VERSION)
2013-08-05 18:47:49 -04:00
end
2013-08-05 18:43:32 -04:00
end
end
2016-11-25 23:42:29 -05:00
namespace :ujs do
desc "Starts the test server"
task :server do
system "bundle exec rackup test/ujs/config.ru -p 4567 -s puma"
2016-11-25 23:42:29 -05:00
end
end
namespace :assets do
desc "Compile Action View assets"
task :compile do
require "blade"
require "sprockets"
require "sprockets/export"
Blade.build
end
2017-03-31 08:25:18 -04:00
desc "Verify compiled Action View assets"
task :verify do
file = "lib/assets/compiled/rails-ujs.js"
pathname = Pathname.new("#{__dir__}/#{file}")
print "[verify] #{file} exists "
if pathname.exist?
puts "[OK]"
else
$stderr.puts "[FAIL]"
fail
end
print "[verify] #{file} is a UMD module "
if /module\.exports.*define\.amd/m.match?(pathname.read)
puts "[OK]"
else
$stderr.puts "[FAIL]"
fail
end
print "[verify] #{__dir__} can be required as a module "
js = <<-JS
window = { Event: class {} }
class Element {}
require('#{__dir__}')
JS
_, stderr, status = Open3.capture3("node", "--print", js)
if status.success?
puts "[OK]"
else
$stderr.puts "[FAIL]\n#{stderr}"
fail
end
end
end
task :lines do
load File.expand_path("../tools/line_statistics", __dir__)
files = FileList["lib/**/*.rb"]
CodeTools::LineStatistics.new(files).print_loc
end