mirror of
https://github.com/thoughtbot/shoulda-matchers.git
synced 2022-11-09 12:01:38 -05:00

git-svn-id: https://svn.thoughtbot.com/plugins/shoulda/trunk@491 7bbfaf0e-4d1d-0410-9690-a8bb5f8ef2aa
118 lines
4.4 KiB
Ruby
118 lines
4.4 KiB
Ruby
module ThoughtBot # :nodoc:
|
|
module Shoulda # :nodoc:
|
|
module General
|
|
def self.included(other) # :nodoc:
|
|
other.class_eval do
|
|
extend ThoughtBot::Shoulda::General::ClassMethods
|
|
end
|
|
end
|
|
|
|
module ClassMethods
|
|
# Loads all fixture files (<tt>test/fixtures/*.yml</tt>)
|
|
def load_all_fixtures
|
|
all_fixtures = Dir.glob(File.join(Test::Unit::TestCase.fixture_path, "*.yml")).collect do |f|
|
|
File.basename(f, '.yml').to_sym
|
|
end
|
|
fixtures *all_fixtures
|
|
end
|
|
end
|
|
|
|
# Prints a message to stdout, tagged with the name of the calling method.
|
|
def report!(msg = "")
|
|
puts("#{caller.first}: #{msg}")
|
|
end
|
|
|
|
# Asserts that two arrays contain the same elements, the same number of times. Essentially ==, but unordered.
|
|
#
|
|
# assert_same_elements([:a, :b, :c], [:c, :a, :b]) => passes
|
|
def assert_same_elements(a1, a2, msg = nil)
|
|
[:select, :inject, :size].each do |m|
|
|
[a1, a2].each {|a| assert_respond_to(a, m, "Are you sure that #{a.inspect} is an array? It doesn't respond to #{m}.") }
|
|
end
|
|
|
|
assert a1h = a1.inject({}) { |h,e| h[e] = a1.select { |i| i == e }.size; h }
|
|
assert a2h = a2.inject({}) { |h,e| h[e] = a2.select { |i| i == e }.size; h }
|
|
|
|
assert_equal(a1h, a2h, msg)
|
|
end
|
|
|
|
# Asserts that the given collection contains item x. If x is a regular expression, ensure that
|
|
# at least one element from the collection matches x. +extra_msg+ is appended to the error message if the assertion fails.
|
|
#
|
|
# assert_contains(['a', '1'], /\d/) => passes
|
|
# assert_contains(['a', '1'], 'a') => passes
|
|
# assert_contains(['a', '1'], /not there/) => fails
|
|
def assert_contains(collection, x, extra_msg = "")
|
|
collection = [collection] unless collection.is_a?(Array)
|
|
msg = "#{x.inspect} not found in #{collection.to_a.inspect} #{extra_msg}"
|
|
case x
|
|
when Regexp: assert(collection.detect { |e| e =~ x }, msg)
|
|
else assert(collection.include?(x), msg)
|
|
end
|
|
end
|
|
|
|
# Asserts that the given collection does not contain item x. If x is a regular expression, ensure that
|
|
# none of the elements from the collection match x.
|
|
def assert_does_not_contain(collection, x, extra_msg = "")
|
|
collection = [collection] unless collection.is_a?(Array)
|
|
msg = "#{x.inspect} found in #{collection.to_a.inspect} " + extra_msg
|
|
case x
|
|
when Regexp: assert(!collection.detect { |e| e =~ x }, msg)
|
|
else assert(!collection.include?(x), msg)
|
|
end
|
|
end
|
|
|
|
# Asserts that the given object can be saved
|
|
#
|
|
# assert_save User.new(params)
|
|
def assert_save(obj)
|
|
assert obj.save, "Errors: #{pretty_error_messages obj}"
|
|
obj.reload
|
|
end
|
|
|
|
# Asserts that the given object is valid
|
|
#
|
|
# assert_valid User.new(params)
|
|
def assert_valid(obj)
|
|
assert obj.valid?, "Errors: #{pretty_error_messages obj}"
|
|
end
|
|
|
|
# Asserts that an email was delivered. Can take a block that can further
|
|
# narrow down the types of emails you're expecting.
|
|
#
|
|
# assert_sent_email
|
|
#
|
|
# Passes if ActionMailer::Base.deliveries has an email
|
|
#
|
|
# assert_sent_email do |email|
|
|
# email.subject =~ /hi there/ && email.to.include?('none@none.com')
|
|
# end
|
|
#
|
|
# Passes if there is an email with subject containing 'hi there' and
|
|
# 'none@none.com' as one of the recipients.
|
|
#
|
|
def assert_sent_email
|
|
emails = ActionMailer::Base.deliveries
|
|
assert !emails.empty?, "No emails were sent"
|
|
if block_given?
|
|
matching_emails = emails.select {|email| yield email }
|
|
assert !matching_emails.empty?, "None of the emails matched."
|
|
end
|
|
end
|
|
|
|
# Asserts that no ActionMailer mails were delivered
|
|
#
|
|
# assert_did_not_send_email
|
|
def assert_did_not_send_email
|
|
msg = "Sent #{ActionMailer::Base.deliveries.size} emails.\n"
|
|
ActionMailer::Base.deliveries.each { |m| msg << " '#{m.subject}' sent to #{m.to.to_sentence}\n" }
|
|
assert ActionMailer::Base.deliveries.empty?, msg
|
|
end
|
|
|
|
def pretty_error_messages(obj)
|
|
obj.errors.map { |a, m| "#{a} #{m} (#{obj.send(a).inspect})" }
|
|
end
|
|
|
|
end
|
|
end
|
|
end
|