2008-05-17 23:22:34 -05:00
|
|
|
require 'abstract_unit'
|
2007-12-21 01:48:59 -06:00
|
|
|
require 'action_view/helpers/benchmark_helper'
|
2007-01-22 07:43:50 -06:00
|
|
|
|
2008-05-17 23:22:34 -05:00
|
|
|
class BenchmarkHelperTest < ActionView::TestCase
|
|
|
|
tests ActionView::Helpers::BenchmarkHelper
|
2007-01-22 07:43:50 -06:00
|
|
|
|
|
|
|
class MockLogger
|
|
|
|
attr_reader :logged
|
|
|
|
|
|
|
|
def initialize
|
|
|
|
@logged = []
|
|
|
|
end
|
|
|
|
|
|
|
|
def method_missing(method, *args)
|
|
|
|
@logged << [method, args]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2008-05-17 23:22:34 -05:00
|
|
|
def controller
|
|
|
|
@controller ||= Struct.new(:logger).new(MockLogger.new)
|
2007-01-22 07:43:50 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_without_block
|
|
|
|
assert_raise(LocalJumpError) { benchmark }
|
2008-05-17 23:22:34 -05:00
|
|
|
assert controller.logger.logged.empty?
|
2007-01-22 07:43:50 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_defaults
|
|
|
|
i_was_run = false
|
|
|
|
benchmark { i_was_run = true }
|
|
|
|
assert i_was_run
|
2008-05-17 23:22:34 -05:00
|
|
|
assert 1, controller.logger.logged.size
|
2007-01-22 07:43:50 -06:00
|
|
|
assert_last_logged
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_with_message
|
|
|
|
i_was_run = false
|
|
|
|
benchmark('test_run') { i_was_run = true }
|
|
|
|
assert i_was_run
|
2008-05-17 23:22:34 -05:00
|
|
|
assert 1, controller.logger.logged.size
|
2007-01-22 07:43:50 -06:00
|
|
|
assert_last_logged 'test_run'
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_with_message_and_level
|
|
|
|
i_was_run = false
|
|
|
|
benchmark('debug_run', :debug) { i_was_run = true }
|
|
|
|
assert i_was_run
|
2008-05-17 23:22:34 -05:00
|
|
|
assert 1, controller.logger.logged.size
|
2007-01-22 07:43:50 -06:00
|
|
|
assert_last_logged 'debug_run', :debug
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
def assert_last_logged(message = 'Benchmarking', level = :info)
|
2008-05-17 23:22:34 -05:00
|
|
|
last = controller.logger.logged.last
|
2007-01-22 07:43:50 -06:00
|
|
|
assert 2, last.size
|
|
|
|
assert_equal level, last.first
|
|
|
|
assert 1, last[1].size
|
|
|
|
assert last[1][0] =~ /^#{message} \(.*\)$/
|
|
|
|
end
|
|
|
|
end
|