fog--fog/tests/helpers/formats_helper.rb

75 lines
2.3 KiB
Ruby
Raw Normal View History

2011-01-04 22:01:31 +00:00
# format related hackery
# allows both true.is_a?(Fog::Boolean) and false.is_a?(Fog::Boolean)
# allows both nil.is_a?(Fog::Nullable::String) and ''.is_a?(Fog::Nullable::String)
module Fog
module Boolean; end
module Nullable
module Boolean; end
2011-01-04 23:17:05 +00:00
module Integer; end
2011-01-04 22:01:31 +00:00
module String; end
2011-02-14 22:55:47 +00:00
module Time; end
2011-01-04 22:01:31 +00:00
end
end
[FalseClass, TrueClass].each {|klass| klass.send(:include, Fog::Boolean)}
[NilClass, Fog::Boolean].each {|klass| klass.send(:include, Fog::Nullable::Boolean)}
2011-01-04 23:17:05 +00:00
[NilClass, String].each {|klass| klass.send(:include, Fog::Nullable::String)}
2011-02-14 22:55:47 +00:00
[NilClass, Time].each {|klass| klass.send(:include, Fog::Nullable::Time)}
2011-01-04 23:17:05 +00:00
[Integer, NilClass].each {|klass| klass.send(:include, Fog::Nullable::Integer)}
2011-01-04 22:01:31 +00:00
module Shindo
class Tests
def formats(format)
2011-01-09 03:53:54 +00:00
raise ArgumentError, 'format is nil' unless format
2011-01-04 22:01:31 +00:00
test('has proper format') do
formats_kernel(instance_eval(&Proc.new), format)
end
end
private
def formats_kernel(original_data, original_format, original = true)
valid = true
data = original_data.dup
format = original_format.dup
if format.is_a?(Array)
data = {:element => data}
format = {:element => format}
end
for key, value in format
datum = data.delete(key)
format.delete(key)
case value
when Array
2011-02-14 22:55:47 +00:00
valid &&= datum.is_a?(Array) || p("not Array: #{datum.inspect}")
if datum.is_a?(Array) && !value.empty?
2011-01-04 22:01:31 +00:00
for element in datum
type = value.first
if type.is_a?(Hash)
valid &&= formats_kernel({:element => element}, {:element => type}, false)
else
valid &&= element.is_a?(type)
end
end
end
when Hash
2011-02-14 22:55:47 +00:00
valid &&= datum.is_a?(Hash) || p("not Hash: #{datum.inspect}")
2011-01-04 22:01:31 +00:00
valid &&= formats_kernel(datum, value, false)
else
2011-02-14 22:55:47 +00:00
p "#{key} not #{value}: #{datum.inspect}" unless datum.is_a?(value)
2011-01-04 22:01:31 +00:00
valid &&= datum.is_a?(value)
end
end
p data unless data.empty?
p format unless format.empty?
valid &&= data.empty? && format.empty?
if !valid && original
@message = "#{original_data.inspect} does not match #{original_format.inspect}"
end
valid
end
end
end