mirror of
https://github.com/TracksApp/tracks.git
synced 2025-12-26 03:58:49 +01:00
* Ran rake rails:update * Added old actionwebservice framework * Updated RSpec and RSpec-Rails * Removed asset_packager plugin (not compatible, Scott no longer maintaining), and replaced with bundle_fu. See the bundle_fu README for more info. * Hacks to UJS and ARTS plugins, which are no longer supported. Probably should move off both UJS and RJS. * Hack to flashobject_helper plugin (upgrade to Rails 2.2-compatible version if/when it comes out.) * Hack to skinny-spec plugin, for Rails 2.2 compatibility. Should check for official release. * Hacks to resource_feeder plugin, for Rails 2.2 compatibility. Should check for official release (not likely) or move off it. * Addressed some deprecation warnings. More to come. * My mobile mime type hackery is no longer necessary with new Rails features. Yay! * Updated environment.rb.tmpl with changes TODO: * Restore view specs marked pending * Fix failing integration tests. * Try selenium tests. * Investigate OpenID support. * Address deprecation warnings. * Consider moving parts of environment.rb to initializers * Address annoying config.gem warning about highline gem
148 lines
4.4 KiB
Ruby
148 lines
4.4 KiB
Ruby
module Spec
|
|
module Matchers
|
|
|
|
#Based on patch from Wilson Bilkovich
|
|
class Change #:nodoc:
|
|
def initialize(receiver=nil, message=nil, &block)
|
|
@message = message || "result"
|
|
@value_proc = block || lambda {
|
|
receiver.__send__(message)
|
|
}
|
|
end
|
|
|
|
def matches?(event_proc)
|
|
raise_block_syntax_error if block_given?
|
|
|
|
@before = evaluate_value_proc
|
|
event_proc.call
|
|
@after = evaluate_value_proc
|
|
|
|
return false if @from unless @from == @before
|
|
return false if @to unless @to == @after
|
|
return (@before + @amount == @after) if @amount
|
|
return ((@after - @before) >= @minimum) if @minimum
|
|
return ((@after - @before) <= @maximum) if @maximum
|
|
return @before != @after
|
|
end
|
|
|
|
def raise_block_syntax_error
|
|
raise MatcherError.new(<<-MESSAGE
|
|
block passed to should or should_not change must use {} instead of do/end
|
|
MESSAGE
|
|
)
|
|
end
|
|
|
|
def evaluate_value_proc
|
|
@value_proc.call
|
|
end
|
|
|
|
def failure_message
|
|
if @to
|
|
"#{@message} should have been changed to #{@to.inspect}, but is now #{@after.inspect}"
|
|
elsif @from
|
|
"#{@message} should have initially been #{@from.inspect}, but was #{@before.inspect}"
|
|
elsif @amount
|
|
"#{@message} should have been changed by #{@amount.inspect}, but was changed by #{actual_delta.inspect}"
|
|
elsif @minimum
|
|
"#{@message} should have been changed by at least #{@minimum.inspect}, but was changed by #{actual_delta.inspect}"
|
|
elsif @maximum
|
|
"#{@message} should have been changed by at most #{@maximum.inspect}, but was changed by #{actual_delta.inspect}"
|
|
else
|
|
"#{@message} should have changed, but is still #{@before.inspect}"
|
|
end
|
|
end
|
|
|
|
def actual_delta
|
|
@after - @before
|
|
end
|
|
|
|
def negative_failure_message
|
|
"#{@message} should not have changed, but did change from #{@before.inspect} to #{@after.inspect}"
|
|
end
|
|
|
|
def by(amount)
|
|
@amount = amount
|
|
self
|
|
end
|
|
|
|
def by_at_least(minimum)
|
|
@minimum = minimum
|
|
self
|
|
end
|
|
|
|
def by_at_most(maximum)
|
|
@maximum = maximum
|
|
self
|
|
end
|
|
|
|
def to(to)
|
|
@to = to
|
|
self
|
|
end
|
|
|
|
def from (from)
|
|
@from = from
|
|
self
|
|
end
|
|
end
|
|
|
|
# :call-seq:
|
|
# should change(receiver, message, &block)
|
|
# should change(receiver, message, &block).by(value)
|
|
# should change(receiver, message, &block).from(old).to(new)
|
|
# should_not change(receiver, message, &block)
|
|
#
|
|
# Allows you to specify that a Proc will cause some value to change.
|
|
#
|
|
# == Examples
|
|
#
|
|
# lambda {
|
|
# team.add_player(player)
|
|
# }.should change(roster, :count)
|
|
#
|
|
# lambda {
|
|
# team.add_player(player)
|
|
# }.should change(roster, :count).by(1)
|
|
#
|
|
# lambda {
|
|
# team.add_player(player)
|
|
# }.should change(roster, :count).by_at_least(1)
|
|
#
|
|
# lambda {
|
|
# team.add_player(player)
|
|
# }.should change(roster, :count).by_at_most(1)
|
|
#
|
|
# string = "string"
|
|
# lambda {
|
|
# string.reverse!
|
|
# }.should change { string }.from("string").to("gnirts")
|
|
#
|
|
# lambda {
|
|
# person.happy_birthday
|
|
# }.should change(person, :birthday).from(32).to(33)
|
|
#
|
|
# lambda {
|
|
# employee.develop_great_new_social_networking_app
|
|
# }.should change(employee, :title).from("Mail Clerk").to("CEO")
|
|
#
|
|
# Evaluates <tt>receiver.message</tt> or <tt>block</tt> before and after
|
|
# it evaluates the c object (generated by the lambdas in the examples
|
|
# above).
|
|
#
|
|
# Then compares the values before and after the <tt>receiver.message</tt>
|
|
# and evaluates the difference compared to the expected difference.
|
|
#
|
|
# == WARNING
|
|
# <tt>should_not change</tt> only supports the form with no
|
|
# subsequent calls to <tt>by</tt>, <tt>by_at_least</tt>,
|
|
# <tt>by_at_most</tt>, <tt>to</tt> or <tt>from</tt>.
|
|
#
|
|
# blocks passed to <tt>should</tt> <tt>change</tt> and <tt>should_not</tt>
|
|
# <tt>change</tt> must use the <tt>{}</tt> form (<tt>do/end</tt> is not
|
|
# supported).
|
|
#
|
|
def change(receiver=nil, message=nil, &block)
|
|
Matchers::Change.new(receiver, message, &block)
|
|
end
|
|
end
|
|
end
|