Skip to content

Commit

Permalink
Merge pull request #529 from dprince/non_strict_format_validation
Browse files Browse the repository at this point in the history
Add support for non-strict validations, and nullable arrays/hashes.
  • Loading branch information
geemus committed Sep 29, 2011
2 parents a90eb43 + 20ccb7c commit 94a96ef
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 6 deletions.
20 changes: 14 additions & 6 deletions tests/helpers/formats_helper.rb
Expand Up @@ -9,6 +9,8 @@ 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)}
Expand All @@ -17,21 +19,23 @@ module Float; end
[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
Expand All @@ -49,23 +53,27 @@ def formats_kernel(original_data, original_format, original = true)
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("#{key.inspect} not Hash: #{datum.inspect}")
valid &&= formats_kernel(datum, value, false)
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
Expand Down
8 changes: 8 additions & 0 deletions tests/helpers/formats_helper_tests.rb
Expand Up @@ -20,6 +20,10 @@
formats_kernel([{:a => :b}], [{:a => Symbol}])
end

test('non strict extra data') do
formats_kernel({:a => :b, :b => :c}, {:a => Symbol}, true, false)
end

end

tests('returns false') do
Expand All @@ -36,6 +40,10 @@
!formats_kernel({}, {:a => String})
end

test('non strict extra data') do
!formats_kernel({:a => :b, :b => :c}, {:z => Symbol}, true, false)
end

end

end
Expand Down

0 comments on commit 94a96ef

Please sign in to comment.