aboutsummaryrefslogtreecommitdiffstats
path: root/test/cases/parameters_test.rb
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2014-05-19 08:29:29 -0300
committerRafael Mendonça França <rafaelmfranca@gmail.com>2014-05-19 08:29:29 -0300
commit70419b5ec3016eb5592a1fb57c2098b261e82998 (patch)
tree96167136fefb9e38f2b5f9754d01b070b1aaa030 /test/cases/parameters_test.rb
parent3a932bf03c56eecf15ba89e6b46846b02b34ad47 (diff)
parent575a837de1ba4bc2d0ff41c9b5b6d10f011f4c7a (diff)
downloadrails-70419b5ec3016eb5592a1fb57c2098b261e82998.tar.gz
rails-70419b5ec3016eb5592a1fb57c2098b261e82998.tar.bz2
rails-70419b5ec3016eb5592a1fb57c2098b261e82998.zip
Merge pull request #18 from mperham/param_whitelist
Whitelist legal job parameter types
Diffstat (limited to 'test/cases/parameters_test.rb')
-rw-r--r--test/cases/parameters_test.rb15
1 files changed, 11 insertions, 4 deletions
diff --git a/test/cases/parameters_test.rb b/test/cases/parameters_test.rb
index eafa5a052b..3fbdf8adee 100644
--- a/test/cases/parameters_test.rb
+++ b/test/cases/parameters_test.rb
@@ -6,11 +6,18 @@ class ParameterSerializationTest < ActiveSupport::TestCase
test 'should make no change to regular values' do
assert_equal [ 1, "something" ], ActiveJob::Parameters.serialize([ 1, "something" ])
end
-
+
+ test 'should not allow complex objects' do
+ err = assert_raises RuntimeError do
+ ActiveJob::Parameters.serialize([ 1, self ])
+ end
+ assert_equal "Unsupported parameter type: #{self.class.name}", err.message
+ end
+
test 'should serialize records with global id' do
assert_equal [ Person.find(5).gid ], ActiveJob::Parameters.serialize([ Person.find(5) ])
end
-
+
test 'should serialize values and records together' do
assert_equal [ 3, Person.find(5).gid ], ActiveJob::Parameters.serialize([ 3, Person.find(5) ])
end
@@ -20,11 +27,11 @@ class ParameterDeserializationTest < ActiveSupport::TestCase
test 'should make no change to regular values' do
assert_equal [ 1, "something" ], ActiveJob::Parameters.deserialize([ 1, "something" ])
end
-
+
test 'should deserialize records with global id' do
assert_equal [ Person.find(5) ], ActiveJob::Parameters.deserialize([ Person.find(5).gid ])
end
-
+
test 'should serialize values and records together' do
assert_equal [ 3, Person.find(5) ], ActiveJob::Parameters.deserialize([ 3, Person.find(5).gid ])
end