mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
84eac5dab8
We used to support the `BACKTRACE` environment variable but when
we switched to MiniTest it got removed: f9382cd794
This commit adds back the functionality to show the unfiltered backtrace when needed.
This also works when you run your tests with `rake`:
* `BACKTRACE=1 bin/rake test`
* `BACKTRACE=1 ruby -Itest ...`
96 lines
2.2 KiB
Ruby
96 lines
2.2 KiB
Ruby
require 'isolation/abstract_unit'
|
|
|
|
module ApplicationTests
|
|
class TestTest < ActiveSupport::TestCase
|
|
include ActiveSupport::Testing::Isolation
|
|
|
|
def setup
|
|
build_app
|
|
boot_rails
|
|
end
|
|
|
|
def teardown
|
|
teardown_app
|
|
end
|
|
|
|
test "truth" do
|
|
app_file 'test/unit/foo_test.rb', <<-RUBY
|
|
require 'test_helper'
|
|
|
|
class FooTest < ActiveSupport::TestCase
|
|
def test_truth
|
|
assert true
|
|
end
|
|
end
|
|
RUBY
|
|
|
|
assert_successful_test_run 'unit/foo_test.rb'
|
|
end
|
|
|
|
test "integration test" do
|
|
controller 'posts', <<-RUBY
|
|
class PostsController < ActionController::Base
|
|
end
|
|
RUBY
|
|
|
|
app_file 'app/views/posts/index.html.erb', <<-HTML
|
|
Posts#index
|
|
HTML
|
|
|
|
app_file 'test/integration/posts_test.rb', <<-RUBY
|
|
require 'test_helper'
|
|
|
|
class PostsTest < ActionDispatch::IntegrationTest
|
|
def test_index
|
|
get '/posts'
|
|
assert_response :success
|
|
assert_template "index"
|
|
end
|
|
end
|
|
RUBY
|
|
|
|
assert_successful_test_run 'integration/posts_test.rb'
|
|
end
|
|
|
|
test "enable full backtraces on test failures" do
|
|
app_file 'test/unit/failing_test.rb', <<-RUBY
|
|
require 'test_helper'
|
|
|
|
class FailingTest < ActiveSupport::TestCase
|
|
def test_failure
|
|
raise "fail"
|
|
end
|
|
end
|
|
RUBY
|
|
|
|
output = run_test_file('unit/failing_test.rb', env: { "BACKTRACE" => "1" })
|
|
assert_match %r{/app/test/unit/failing_test\.rb}, output
|
|
end
|
|
|
|
private
|
|
def assert_successful_test_run(name)
|
|
result = run_test_file(name)
|
|
assert_equal 0, $?.to_i, result
|
|
end
|
|
|
|
def run_test_file(name, options = {})
|
|
ruby '-Itest', "#{app_path}/test/#{name}", options
|
|
end
|
|
|
|
def ruby(*args)
|
|
options = args.extract_options!
|
|
env = options.fetch(:env, {})
|
|
env["RUBYLIB"] = $:.join(':')
|
|
|
|
Dir.chdir(app_path) do
|
|
`#{env_string(env)} #{Gem.ruby} #{args.join(' ')}`
|
|
end
|
|
end
|
|
|
|
def env_string(variables)
|
|
variables.map do |key, value|
|
|
"#{key}='#{value}'"
|
|
end.join " "
|
|
end
|
|
end
|
|
end
|