lib/brightbox-cli/vendor/fog/tests/helpers/formats_helper.rb in brightbox-cli-0.14.1 vs lib/brightbox-cli/vendor/fog/tests/helpers/formats_helper.rb in brightbox-cli-0.15.0
- old
+ new
@@ -7,33 +7,37 @@
module Boolean; end
module Integer; end
module String; end
module Time; end
module Float; end
+ module Hash; end
+ module Array; end
end
end
[FalseClass, TrueClass].each {|klass| klass.send(:include, Fog::Boolean)}
[NilClass, Fog::Boolean].each {|klass| klass.send(:include, Fog::Nullable::Boolean)}
[NilClass, String].each {|klass| klass.send(:include, Fog::Nullable::String)}
[NilClass, Time].each {|klass| klass.send(:include, Fog::Nullable::Time)}
[Integer, NilClass].each {|klass| klass.send(:include, Fog::Nullable::Integer)}
[Float, NilClass].each {|klass| klass.send(:include, Fog::Nullable::Float)}
+[Hash, NilClass].each {|klass| klass.send(:include, Fog::Nullable::Hash)}
+[Array, NilClass].each {|klass| klass.send(:include, Fog::Nullable::Array)}
module Shindo
class Tests
- def formats(format)
+ def formats(format, strict=true)
raise ArgumentError, 'format is nil' unless format
test('has proper format') do
- formats_kernel(instance_eval(&Proc.new), format)
+ formats_kernel(instance_eval(&Proc.new), format, true, strict)
end
end
private
- def formats_kernel(original_data, original_format, original = true)
+ def formats_kernel(original_data, original_format, original = true, strict = true)
valid = true
data = original_data.dup
format = original_format.dup
if format.is_a?(Array)
data = {:element => data}
@@ -42,31 +46,35 @@
for key, value in format
datum = data.delete(key)
format.delete(key)
case value
when Array
- valid &&= datum.is_a?(Array) || p("not Array: #{datum.inspect}")
+ valid &&= datum.is_a?(Array) || p("#{key.inspect} not Array: #{datum.inspect}")
if datum.is_a?(Array) && !value.empty?
for element in datum
type = value.first
if type.is_a?(Hash)
- valid &&= formats_kernel({:element => element}, {:element => type}, false)
+ valid &&= formats_kernel({:element => element}, {:element => type}, false, strict)
else
valid &&= element.is_a?(type)
end
end
end
when Hash
- valid &&= datum.is_a?(Hash) || p("not Hash: #{datum.inspect}")
- valid &&= formats_kernel(datum, value, false)
+ valid &&= datum.is_a?(Hash) || p("#{key.inspect} not Hash: #{datum.inspect}")
+ valid &&= formats_kernel(datum, value, false, strict)
else
p "#{key.inspect} not #{value.inspect}: #{datum.inspect}" unless datum.is_a?(value)
valid &&= datum.is_a?(value)
end
end
p data unless data.empty?
p format unless format.empty?
- valid &&= data.empty? && format.empty?
+ if strict
+ valid &&= data.empty? && format.empty?
+ else
+ valid &&= format.empty?
+ end
if !valid && original
@message = "#{original_data.inspect} does not match #{original_format.inspect}"
end
valid
end