require 'rubygems'
require 'test/unit'
require 'shoulda'
require 'mocha'
require 'rack/test'
require 'webrat'
$LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
$LOAD_PATH.unshift(File.dirname(__FILE__))
require 'active_support_helpers'
require 'sinatra_more'
class Test::Unit::TestCase
include Sinatra::MarkupPlugin::OutputHelpers
include Sinatra::MarkupPlugin::TagHelpers
include Sinatra::MarkupPlugin::AssetTagHelpers
include Rack::Test::Methods
include Webrat::Methods
include Webrat::Matchers
Webrat.configure do |config|
config.mode = :rack
end
def stop_time_for_test
time = Time.now
Time.stubs(:now).returns(time)
return time
end
# assert_has_tag(:h1, :content => "yellow") { "
yellow
" }
# In this case, block is the html to evaluate
def assert_has_tag(name, attributes = {}, &block)
html = block && block.call
matcher = HaveSelector.new(name, attributes)
raise "Please specify a block!" if html.blank?
assert matcher.matches?(html), matcher.failure_message
end
# assert_has_no_tag, tag(:h1, :content => "yellow") { "green
" }
# In this case, block is the html to evaluate
def assert_has_no_tag(name, attributes = {}, &block)
html = block && block.call
attributes.merge!(:count => 0)
matcher = HaveSelector.new(name, attributes)
raise "Please specify a block!" if html.blank?
assert matcher.matches?(html), matcher.failure_message
end
# Silences the output by redirecting to stringIO
# silence_logger { ...commands... } => "...output..."
def silence_logger(&block)
orig_stdout = $stdout
$stdout = log_buffer = StringIO.new
block.call
$stdout = orig_stdout
log_buffer.rewind && log_buffer.read
end
# Asserts that a file matches the pattern
def assert_match_in_file(pattern, file)
assert File.exist?(file), "File '#{file}' does not exist!"
assert_match pattern, File.read(file)
end
end
module Webrat
module Logging
def logger # :nodoc:
@logger = nil
end
end
end