null / not_null predicates accept false
This commit is contained in:
parent
99840fcc28
commit
e383f0cea7
|
@ -2,6 +2,7 @@ module Ransack
|
|||
module Constants
|
||||
TRUE_VALUES = [true, 1, '1', 't', 'T', 'true', 'TRUE'].to_set
|
||||
FALSE_VALUES = [false, 0, '0', 'f', 'F', 'false', 'FALSE'].to_set
|
||||
BOOLEAN_VALUES = TRUE_VALUES + FALSE_VALUES
|
||||
|
||||
AREL_PREDICATES = %w(eq not_eq matches does_not_match lt lteq gt gteq in not_in)
|
||||
|
||||
|
@ -68,18 +69,18 @@ module Ransack
|
|||
}
|
||||
],
|
||||
['null', {
|
||||
:arel_predicate => 'eq',
|
||||
:arel_predicate => proc { |v| v ? 'eq' : 'not_eq' },
|
||||
:compounds => false,
|
||||
:type => :boolean,
|
||||
:validator => proc { |v| TRUE_VALUES.include?(v)},
|
||||
:validator => proc { |v| BOOLEAN_VALUES.include?(v)},
|
||||
:formatter => proc { |v| nil }
|
||||
}
|
||||
],
|
||||
['not_null', {
|
||||
:arel_predicate => 'not_eq',
|
||||
:arel_predicate => proc { |v| v ? 'not_eq' : 'eq' },
|
||||
:compounds => false,
|
||||
:type => :boolean,
|
||||
:validator => proc { |v| TRUE_VALUES.include?(v) },
|
||||
:validator => proc { |v| BOOLEAN_VALUES.include?(v) },
|
||||
:formatter => proc { |v| nil } }
|
||||
]
|
||||
]
|
||||
|
|
|
@ -86,6 +86,12 @@ module Ransack
|
|||
field = "#{quote_table_name("people")}.#{quote_column_name("name")}"
|
||||
@s.result.to_sql.should match /#{field} IS NULL/
|
||||
end
|
||||
|
||||
it 'generates a value IS NOT NULL query when assigned false' do
|
||||
@s.name_null = false
|
||||
field = "#{quote_table_name("people")}.#{quote_column_name("name")}"
|
||||
@s.result.to_sql.should match /#{field} IS NOT NULL/
|
||||
end
|
||||
end
|
||||
|
||||
describe 'not_null' do
|
||||
|
@ -94,6 +100,12 @@ module Ransack
|
|||
field = "#{quote_table_name("people")}.#{quote_column_name("name")}"
|
||||
@s.result.to_sql.should match /#{field} IS NOT NULL/
|
||||
end
|
||||
|
||||
it 'generates a value IS NULL query when assigned false' do
|
||||
@s.name_not_null = false
|
||||
field = "#{quote_table_name("people")}.#{quote_column_name("name")}"
|
||||
@s.result.to_sql.should match /#{field} IS NULL/
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue