Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
R
rails_param
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Wiki
Wiki
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
ikcrm_common
rails_param
Commits
7b7c37bd
Commit
7b7c37bd
authored
Oct 28, 2014
by
cole bradley
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add recursion feature for validating nested attributes
add tests for nested attributes
parent
86c2ca0a
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
458 additions
and
364 deletions
+458
-364
lib/rails_param/param.rb
+111
-93
spec/fixtures/controllers.rb
+14
-0
spec/fixtures/fake_rails_application.rb
+1
-0
spec/rails_integration_spec.rb
+48
-0
spec/rails_param/param_spec.rb
+284
-271
No files found.
lib/rails_param/param.rb
View file @
7b7c37bd
module
RailsParam
module
Param
module
Param
DEFAULT_PRECISION
=
14
DEFAULT_PRECISION
=
14
class
InvalidParameterError
<
StandardError
attr_accessor
:param
,
:options
end
class
InvalidParameterError
<
StandardError
attr_accessor
:param
,
:options
end
class
MockController
include
RailsParam
::
Param
attr_accessor
:params
# def params
# end
end
def
param!
(
name
,
type
,
options
=
{})
name
=
name
.
to_s
def
param!
(
name
,
type
,
options
=
{})
name
=
name
.
to_s
return
unless
params
.
member?
(
name
)
||
options
[
:default
].
present?
||
options
[
:required
]
return
unless
params
.
member?
(
name
)
||
options
[
:default
].
present?
||
options
[
:required
]
begin
params
[
name
]
=
coerce
(
params
[
name
],
type
,
options
)
params
[
name
]
=
(
options
[
:default
].
call
if
options
[
:default
].
respond_to?
(
:call
))
||
options
[
:default
]
if
params
[
name
].
nil?
and
options
[
:default
]
params
[
name
]
=
options
[
:transform
].
to_proc
.
call
(
params
[
name
])
if
params
[
name
]
and
options
[
:transform
]
validate!
(
params
[
name
],
options
)
rescue
InvalidParameterError
=>
exception
exception
.
param
,
exception
.
options
=
name
,
options
raise
exception
end
end
begin
params
[
name
]
=
coerce
(
params
[
name
],
type
,
options
)
params
[
name
]
=
(
options
[
:default
].
call
if
options
[
:default
].
respond_to?
(
:call
))
||
options
[
:default
]
if
params
[
name
].
nil?
and
options
[
:default
]
params
[
name
]
=
options
[
:transform
].
to_proc
.
call
(
params
[
name
])
if
params
[
name
]
and
options
[
:transform
]
validate!
(
params
[
name
],
options
)
if
block_given?
controller
=
RailsParam
::
Param
::
MockController
.
new
controller
.
params
=
params
[
name
]
# begin
yield
(
controller
)
# exception.param, exception.options = name, options
# raise InvalidParameterError exception
# end
end
rescue
InvalidParameterError
=>
exception
exception
.
param
||=
name
exception
.
options
||=
options
raise
exception
end
end
# TODO: should we reintegrate this method?
# def one_of!(*names)
# count = 0
# names.each do |name|
# if params[name] and params[name].present?
# count += 1
# next unless count > 1
#
# error = "Parameters #{names.join(', ')} are mutually exclusive"
# if content_type and content_type.match(mime_type(:json))
# error = {message: error}.to_json
# end
#
# # do something with error object
# end
# end
# end
# TODO: should we reintegrate this method?
# def one_of!(*names)
# count = 0
# names.each do |name|
# if params[name] and params[name].present?
# count += 1
# next unless count > 1
#
# error = "Parameters #{names.join(', ')} are mutually exclusive"
# if content_type and content_type.match(mime_type(:json))
# error = {message: error}.to_json
# end
#
# # do something with error object
# end
# end
# end
private
private
def
coerce
(
param
,
type
,
options
=
{})
begin
return
nil
if
param
.
nil?
return
param
if
(
param
.
is_a?
(
type
)
rescue
false
)
return
Integer
(
param
)
if
type
==
Integer
return
Float
(
param
)
if
type
==
Float
return
String
(
param
)
if
type
==
String
return
Date
.
parse
(
param
)
if
type
==
Date
return
Time
.
parse
(
param
)
if
type
==
Time
return
DateTime
.
parse
(
param
)
if
type
==
DateTime
return
Array
(
param
.
split
(
options
[
:delimiter
]
||
","
))
if
type
==
Array
return
Hash
[
param
.
split
(
options
[
:delimiter
]
||
","
).
map
{
|
c
|
c
.
split
(
options
[
:separator
]
||
":"
)}]
if
type
==
Hash
return
(
/(false|f|no|n|0)$/i
===
param
.
to_s
?
false
:
(
/(true|t|yes|y|1)$/i
===
param
.
to_s
?
true
:
nil
))
if
type
==
TrueClass
||
type
==
FalseClass
||
type
==
:boolean
if
type
==
BigDecimal
param
=
param
.
delete
(
'$,'
).
strip
.
to_f
if
param
.
is_a?
(
String
)
return
BigDecimal
.
new
(
param
,
(
options
[
:precision
]
||
DEFAULT_PRECISION
))
if
type
==
BigDecimal
def
coerce
(
param
,
type
,
options
=
{})
begin
return
nil
if
param
.
nil?
return
param
if
(
param
.
is_a?
(
type
)
rescue
false
)
return
Integer
(
param
)
if
type
==
Integer
return
Float
(
param
)
if
type
==
Float
return
String
(
param
)
if
type
==
String
return
Date
.
parse
(
param
)
if
type
==
Date
return
Time
.
parse
(
param
)
if
type
==
Time
return
DateTime
.
parse
(
param
)
if
type
==
DateTime
return
Array
(
param
.
split
(
options
[
:delimiter
]
||
","
))
if
type
==
Array
return
Hash
[
param
.
split
(
options
[
:delimiter
]
||
","
).
map
{
|
c
|
c
.
split
(
options
[
:separator
]
||
":"
)}]
if
type
==
Hash
return
(
/(false|f|no|n|0)$/i
===
param
.
to_s
?
false
:
(
/(true|t|yes|y|1)$/i
===
param
.
to_s
?
true
:
nil
))
if
type
==
TrueClass
||
type
==
FalseClass
||
type
==
:boolean
if
type
==
BigDecimal
param
=
param
.
delete
(
'$,'
).
strip
.
to_f
if
param
.
is_a?
(
String
)
return
BigDecimal
.
new
(
param
,
(
options
[
:precision
]
||
DEFAULT_PRECISION
))
end
return
nil
rescue
ArgumentError
raise
InvalidParameterError
,
"'
#{
param
}
' is not a valid
#{
type
}
"
end
end
return
nil
rescue
ArgumentError
raise
InvalidParameterError
,
"'
#{
param
}
' is not a valid
#{
type
}
"
end
end
def
validate!
(
param
,
options
)
options
.
each
do
|
key
,
value
|
case
key
when
:required
raise
InvalidParameterError
,
"Parameter is required"
if
value
&&
param
.
nil?
when
:blank
raise
InvalidParameterError
,
"Parameter cannot be blank"
if
!
value
&&
case
param
when
String
!
(
/\S/
===
param
)
when
Array
,
Hash
param
.
empty?
else
param
.
nil?
def
validate!
(
param
,
options
)
options
.
each
do
|
key
,
value
|
case
key
when
:required
raise
InvalidParameterError
,
"Parameter is required"
if
value
&&
param
.
nil?
when
:blank
raise
InvalidParameterError
,
"Parameter cannot be blank"
if
!
value
&&
case
param
when
String
!
(
/\S/
===
param
)
when
Array
,
Hash
param
.
empty?
else
param
.
nil?
end
when
:format
raise
InvalidParameterError
,
"Parameter must be a string if using the format validation"
unless
param
.
kind_of?
(
String
)
raise
InvalidParameterError
,
"Parameter must match format
#{
value
}
"
unless
param
=~
value
when
:is
raise
InvalidParameterError
,
"Parameter must be
#{
value
}
"
unless
param
===
value
when
:in
,
:within
,
:range
raise
InvalidParameterError
,
"Parameter must be within
#{
value
}
"
unless
param
.
nil?
||
case
value
when
Range
value
.
include?
(
param
)
else
Array
(
value
).
include?
(
param
)
end
when
:min
raise
InvalidParameterError
,
"Parameter cannot be less than
#{
value
}
"
unless
param
.
nil?
||
value
<=
param
when
:max
raise
InvalidParameterError
,
"Parameter cannot be greater than
#{
value
}
"
unless
param
.
nil?
||
value
>=
param
when
:min_length
raise
InvalidParameterError
,
"Parameter cannot have length less than
#{
value
}
"
unless
param
.
nil?
||
value
<=
param
.
length
when
:max_length
raise
InvalidParameterError
,
"Parameter cannot have length greater than
#{
value
}
"
unless
param
.
nil?
||
value
>=
param
.
length
end
end
when
:format
raise
InvalidParameterError
,
"Parameter must be a string if using the format validation"
unless
param
.
kind_of?
(
String
)
raise
InvalidParameterError
,
"Parameter must match format
#{
value
}
"
unless
param
=~
value
when
:is
raise
InvalidParameterError
,
"Parameter must be
#{
value
}
"
unless
param
===
value
when
:in
,
:within
,
:range
raise
InvalidParameterError
,
"Parameter must be within
#{
value
}
"
unless
param
.
nil?
||
case
value
when
Range
value
.
include?
(
param
)
else
Array
(
value
).
include?
(
param
)
end
when
:min
raise
InvalidParameterError
,
"Parameter cannot be less than
#{
value
}
"
unless
param
.
nil?
||
value
<=
param
when
:max
raise
InvalidParameterError
,
"Parameter cannot be greater than
#{
value
}
"
unless
param
.
nil?
||
value
>=
param
when
:min_length
raise
InvalidParameterError
,
"Parameter cannot have length less than
#{
value
}
"
unless
param
.
nil?
||
value
<=
param
.
length
when
:max_length
raise
InvalidParameterError
,
"Parameter cannot have length greater than
#{
value
}
"
unless
param
.
nil?
||
value
>=
param
.
length
end
end
end
end
end
end
spec/fixtures/controllers.rb
View file @
7b7c37bd
...
...
@@ -17,4 +17,18 @@ class FakeController < ActionController::Base
def
new
render
text:
"new"
end
def
edit
param!
:book
,
Hash
,
required:
true
do
|
b
|
b
.
param!
:title
,
String
,
required:
true
b
.
param!
:author
,
Hash
do
|
a
|
a
.
param!
:first_name
,
String
,
required:
true
a
.
param!
:last_name
,
String
,
required:
true
a
.
param!
:age
,
Integer
,
required:
true
end
b
.
param!
:price
,
BigDecimal
,
required:
true
end
render
text: :book
end
end
spec/fixtures/fake_rails_application.rb
View file @
7b7c37bd
...
...
@@ -15,6 +15,7 @@ module Rails
get
'/fake/new'
=>
"fake#new"
get
'/fakes'
=>
"fake#index"
get
'/fake/(:id)'
=>
"fake#show"
get
'/fake/edit'
=>
"fake#edit"
end
@routes
end
...
...
spec/rails_integration_spec.rb
View file @
7b7c37bd
...
...
@@ -10,6 +10,54 @@ describe FakeController, type: :controller do
end
end
describe
"nested_hash"
do
it
"validates nested properties"
do
params
=
{
'book'
=>
{
'title'
=>
'One Hundred Years of Solitude'
,
'author'
=>
{
'first_name'
=>
'Garbriel Garcia'
,
'last_name'
=>
'Marquez'
,
'age'
=>
'70'
},
'price'
=>
'$1,000.00'
}}
get
:edit
,
params
expect
(
controller
.
params
[
:book
][
:author
][
:age
]).
to
eql
70
expect
(
controller
.
params
[
:book
][
:author
][
:age
]).
to
be_kind_of
Integer
expect
(
controller
.
params
[
:book
][
:price
]).
to
eql
1000.0
expect
(
controller
.
params
[
:book
][
:price
]).
to
be_instance_of
BigDecimal
end
it
"raises error when required nested attribute missing"
do
params
=
{
'book'
=>
{
'title'
=>
'One Hundred Years of Solitude'
,
'author'
=>
{
'last_name'
=>
'Marquez'
,
'age'
=>
'70'
},
'price'
=>
'$1,000.00'
}}
expect
{
get
:edit
,
params
}.
to
raise_error
{
|
error
|
expect
(
error
).
to
be_a
(
RailsParam
::
Param
::
InvalidParameterError
)
expect
(
error
.
param
).
to
eql
(
"first_name"
)
expect
(
error
.
options
).
to
eql
({
:required
=>
true
})
}
end
it
"passes when hash that's not required but has required attributes is missing"
do
params
=
{
'book'
=>
{
'title'
=>
'One Hundred Years of Solitude'
,
'price'
=>
'$1,000.00'
}}
get
:edit
,
params
expect
(
controller
.
params
[
:book
][
:price
]).
to
eql
1000.0
expect
(
controller
.
params
[
:book
][
:price
]).
to
be_instance_of
BigDecimal
end
end
describe
"InvalidParameterError"
do
it
"raises an exception with params attributes"
do
expect
{
get
:index
,
sort:
"foo"
}.
to
raise_error
{
|
error
|
...
...
spec/rails_param/param_spec.rb
View file @
7b7c37bd
...
...
@@ -2,292 +2,305 @@ require 'rails_param/param'
require
'action_controller'
class
MyController
<
ActionController
::
Base
include
RailsParam
::
Param
include
RailsParam
::
Param
def
params
;
end
def
params
;
end
end
describe
RailsParam
::
Param
do
describe
".param!"
do
let
(
:controller
)
{
MyController
.
new
}
it
"defines the method"
do
expect
(
controller
).
to
respond_to
(
:param!
)
end
describe
"transform"
do
context
"with a method"
do
it
"transforms the value"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
controller
.
param!
:word
,
String
,
transform: :upcase
expect
(
controller
.
params
[
"word"
]).
to
eql
(
"FOO"
)
end
end
context
"with a block"
do
it
"transforms the value"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"FOO"
})
controller
.
param!
:word
,
String
,
transform:
lambda
{
|
n
|
n
.
downcase
}
expect
(
controller
.
params
[
"word"
]).
to
eql
(
"foo"
)
end
end
end
describe
"default"
do
context
"with a value"
do
it
"defaults to the value"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
})
controller
.
param!
:word
,
String
,
default:
"foo"
expect
(
controller
.
params
[
"word"
]).
to
eql
(
"foo"
)
end
end
context
"with a block"
do
it
"defaults to the block value"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
})
controller
.
param!
:word
,
String
,
default:
lambda
{
"foo"
}
expect
(
controller
.
params
[
"word"
]).
to
eql
(
"foo"
)
end
end
end
describe
"coerce"
do
it
"converts to String"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
:bar
})
controller
.
param!
:foo
,
String
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
"bar"
)
end
it
"converts to Integer"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"42"
})
controller
.
param!
:foo
,
Integer
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
42
)
end
it
"converts to Float"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"42.22"
})
controller
.
param!
:foo
,
Float
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
42.22
)
end
it
"converts to Array"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"2,3,4,5"
})
controller
.
param!
:foo
,
Array
expect
(
controller
.
params
[
"foo"
]).
to
eql
([
"2"
,
"3"
,
"4"
,
"5"
])
end
it
"converts to Hash"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"key1:foo,key2:bar"
})
controller
.
param!
:foo
,
Hash
expect
(
controller
.
params
[
"foo"
]).
to
eql
({
"key1"
=>
"foo"
,
"key2"
=>
"bar"
})
end
it
"converts to Date"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"1984-01-10"
})
controller
.
param!
:foo
,
Date
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
Date
.
parse
(
"1984-01-10"
))
end
it
"converts to Time"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"2014-08-07T12:25:00.000+02:00"
})
controller
.
param!
:foo
,
Time
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
Time
.
parse
(
"2014-08-07T12:25:00.000+02:00"
))
end
it
"converts to DateTime"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"2014-08-07T12:25:00.000+02:00"
})
controller
.
param!
:foo
,
DateTime
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
DateTime
.
parse
(
"2014-08-07T12:25:00.000+02:00"
))
end
describe
"BigDecimals"
do
it
"converts to BigDecimal using default precision"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
12345.67890123456
})
controller
.
param!
:foo
,
BigDecimal
expect
(
controller
.
params
[
"foo"
]).
to
eql
12345.678901235
end
it
"converts to BigDecimal using precision option"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
12345.6789
})
controller
.
param!
:foo
,
BigDecimal
,
precision:
6
expect
(
controller
.
params
[
"foo"
]).
to
eql
12345.7
end
it
"converts formatted currency string to big decimal"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"$100,000"
})
controller
.
param!
:foo
,
BigDecimal
expect
(
controller
.
params
[
"foo"
]).
to
eql
100000.0
end
end
describe
"booleans"
do
it
"converts 1/0"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"1"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"0"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
it
"converts true/false"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"true"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"false"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
it
"converts t/f"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"t"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"f"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
it
"converts yes/no"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"yes"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"no"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
it
"converts y/n"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"y"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"n"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
end
it
"raises InvalidParameterError if the value is invalid"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"1984-01-32"
})
expect
{
controller
.
param!
:foo
,
Date
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"validation"
do
describe
"required parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
required:
true
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
})
expect
{
controller
.
param!
:price
,
Integer
,
required:
true
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"blank parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
String
,
blank:
false
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
""
})
expect
{
controller
.
param!
:price
,
String
,
blank:
false
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"format parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50$"
})
expect
{
controller
.
param!
:price
,
String
,
format:
/[0-9]+\$/
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
String
,
format:
/[0-9]+\$/
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
describe
".param!"
do
let
(
:controller
)
{
MyController
.
new
}
it
"defines the method"
do
expect
(
controller
).
to
respond_to
(
:param!
)
end
end
describe
"is parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
String
,
is:
"50"
}.
to_not
raise_error
describe
"transform"
do
context
"with a method"
do
it
"transforms the value"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
controller
.
param!
:word
,
String
,
transform: :upcase
expect
(
controller
.
params
[
"word"
]).
to
eql
(
"FOO"
)
end
end
context
"with a block"
do
it
"transforms the value"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"FOO"
})
controller
.
param!
:word
,
String
,
transform:
lambda
{
|
n
|
n
.
downcase
}
expect
(
controller
.
params
[
"word"
]).
to
eql
(
"foo"
)
end
end
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"51"
})
expect
{
controller
.
param!
:price
,
String
,
is:
"50"
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
describe
"default"
do
context
"with a value"
do
it
"defaults to the value"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({})
controller
.
param!
:word
,
String
,
default:
"foo"
expect
(
controller
.
params
[
"word"
]).
to
eql
(
"foo"
)
end
end
context
"with a block"
do
it
"defaults to the block value"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({})
controller
.
param!
:word
,
String
,
default:
lambda
{
"foo"
}
expect
(
controller
.
params
[
"word"
]).
to
eql
(
"foo"
)
end
end
end
end
describe
"min parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
min:
50
}.
to_not
raise_error
describe
"coerce"
do
it
"converts to String"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
:bar
})
controller
.
param!
:foo
,
String
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
"bar"
)
end
it
"converts to Integer"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"42"
})
controller
.
param!
:foo
,
Integer
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
42
)
end
it
"converts to Float"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"42.22"
})
controller
.
param!
:foo
,
Float
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
42.22
)
end
it
"converts to Array"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"2,3,4,5"
})
controller
.
param!
:foo
,
Array
expect
(
controller
.
params
[
"foo"
]).
to
eql
([
"2"
,
"3"
,
"4"
,
"5"
])
end
it
"converts to Hash"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"key1:foo,key2:bar"
})
controller
.
param!
:foo
,
Hash
expect
(
controller
.
params
[
"foo"
]).
to
eql
({
"key1"
=>
"foo"
,
"key2"
=>
"bar"
})
end
it
"converts to Date"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"1984-01-10"
})
controller
.
param!
:foo
,
Date
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
Date
.
parse
(
"1984-01-10"
))
end
it
"converts to Time"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"2014-08-07T12:25:00.000+02:00"
})
controller
.
param!
:foo
,
Time
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
Time
.
parse
(
"2014-08-07T12:25:00.000+02:00"
))
end
it
"converts to DateTime"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"2014-08-07T12:25:00.000+02:00"
})
controller
.
param!
:foo
,
DateTime
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
DateTime
.
parse
(
"2014-08-07T12:25:00.000+02:00"
))
end
describe
"BigDecimals"
do
it
"converts to BigDecimal using default precision"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
12345.67890123456
})
controller
.
param!
:foo
,
BigDecimal
expect
(
controller
.
params
[
"foo"
]).
to
eql
12345.678901235
end
it
"converts to BigDecimal using precision option"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
12345.6789
})
controller
.
param!
:foo
,
BigDecimal
,
precision:
6
expect
(
controller
.
params
[
"foo"
]).
to
eql
12345.7
end
it
"converts formatted currency string to big decimal"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"$100,000"
})
controller
.
param!
:foo
,
BigDecimal
expect
(
controller
.
params
[
"foo"
]).
to
eql
100000.0
end
end
describe
"booleans"
do
it
"converts 1/0"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"1"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"0"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
it
"converts true/false"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"true"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"false"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
it
"converts t/f"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"t"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"f"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
it
"converts yes/no"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"yes"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"no"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
it
"converts y/n"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"y"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
true
)
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"n"
})
controller
.
param!
:foo
,
TrueClass
expect
(
controller
.
params
[
"foo"
]).
to
eql
(
false
)
end
end
it
"raises InvalidParameterError if the value is invalid"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"foo"
=>
"1984-01-32"
})
expect
{
controller
.
param!
:foo
,
Date
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
min:
51
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"max parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
max:
50
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
max:
49
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"min_length parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
expect
{
controller
.
param!
:word
,
String
,
min_length:
3
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
expect
{
controller
.
param!
:word
,
String
,
min_length:
4
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"max_length parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
expect
{
controller
.
param!
:word
,
String
,
max_length:
3
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
expect
{
controller
.
param!
:word
,
String
,
max_length:
2
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"in, within, range parameters"
do
before
(
:each
)
{
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
}
it
"succeeds in the range"
do
controller
.
param!
:price
,
Integer
,
in:
1
..
100
expect
(
controller
.
params
[
"price"
]).
to
eql
(
50
)
describe
'validating nested hash'
do
it
'typecasts nested attribtues'
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
'foo'
=>
{
'bar'
=>
1
,
'baz'
=>
2
}})
controller
.
param!
:foo
,
Hash
do
|
p
|
p
.
param!
:bar
,
BigDecimal
p
.
param!
:baz
,
Float
end
expect
(
controller
.
params
[
'foo'
][
'bar'
]).
to
be_instance_of
BigDecimal
expect
(
controller
.
params
[
'foo'
][
'baz'
]).
to
be_instance_of
Float
end
end
it
"raises outside the range"
do
expect
{
controller
.
param!
:price
,
Integer
,
in:
51
..
100
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
describe
"validation"
do
describe
"required parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
required:
true
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({})
expect
{
controller
.
param!
:price
,
Integer
,
required:
true
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"blank parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
String
,
blank:
false
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
""
})
expect
{
controller
.
param!
:price
,
String
,
blank:
false
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"format parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50$"
})
expect
{
controller
.
param!
:price
,
String
,
format:
/[0-9]+\$/
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
String
,
format:
/[0-9]+\$/
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"is parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
String
,
is:
"50"
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"51"
})
expect
{
controller
.
param!
:price
,
String
,
is:
"50"
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"min parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
min:
50
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
min:
51
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"max parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
max:
50
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
expect
{
controller
.
param!
:price
,
Integer
,
max:
49
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"min_length parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
expect
{
controller
.
param!
:word
,
String
,
min_length:
3
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
expect
{
controller
.
param!
:word
,
String
,
min_length:
4
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"max_length parameter"
do
it
"succeeds"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
expect
{
controller
.
param!
:word
,
String
,
max_length:
3
}.
to_not
raise_error
end
it
"raises"
do
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"word"
=>
"foo"
})
expect
{
controller
.
param!
:word
,
String
,
max_length:
2
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
describe
"in, within, range parameters"
do
before
(
:each
)
{
allow
(
controller
).
to
receive
(
:params
).
and_return
({
"price"
=>
"50"
})
}
it
"succeeds in the range"
do
controller
.
param!
:price
,
Integer
,
in:
1
..
100
expect
(
controller
.
params
[
"price"
]).
to
eql
(
50
)
end
it
"raises outside the range"
do
expect
{
controller
.
param!
:price
,
Integer
,
in:
51
..
100
}.
to
raise_error
(
RailsParam
::
Param
::
InvalidParameterError
)
end
end
end
end
end
end
end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment