Sha256: dbde5e7d15b86b8500cdd92ef398a34ffaa6b5c960165274b0df373ad8da42cc
Contents?: true
Size: 1.9 KB
Versions: 1
Compression:
Stored size: 1.9 KB
Contents
require File.join(File.dirname(__FILE__), 'allow_values_for_matcher') module Remarkable module ActiveRecord module Matchers class ValidateExclusionOfMatcher < AllowValuesForMatcher #:nodoc: default_options :message => :exclusion protected def valid_values if @in_range [ @options[:in].first - 1, @options[:in].last + 1 ] elsif @options[:in].empty? [] else [ @options[:in].map(&:to_s).max.to_s.next ] end end def invalid_values @options[:in] end end # Ensures that given values are not valid for the attribute. If a range # is given, ensures that the attribute is not valid in the given range. # # If you give that :username does not accept ["admin", "user"], it will # test that "uses" (the next of the array max value) is allowed. # # == Options # # * <tt>:in</tt> - values to test exclusion. # * <tt>:allow_nil</tt> - when supplied, validates if it allows nil or not. # * <tt>:allow_blank</tt> - when supplied, validates if it allows blank or not. # * <tt>:message</tt> - value the test expects to find in <tt>errors.on(:attribute)</tt>. # Regexp, string or symbol. Default = <tt>I18n.translate('activerecord.errors.messages.exclusion')</tt> # # == Examples # # it { should validate_exclusion_of(:username, :in => ["admin", "user"]) } # it { should validate_exclusion_of(:age, :in => 30..60) } # # should_validate_exclusion_of :username, :in => ["admin", "user"] # should_validate_exclusion_of :age, :in => 30..60 # def validate_exclusion_of(*args, &block) ValidateExclusionOfMatcher.new(*args, &block).spec(self) end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
remarkable_activerecord-3.1.7 | lib/remarkable_activerecord/matchers/validate_exclusion_of_matcher.rb |