2016-08-06 12:03:25 -04:00
|
|
|
require "abstract_unit"
|
|
|
|
require "openssl"
|
|
|
|
require "active_support/time"
|
|
|
|
require "active_support/json"
|
2009-11-14 14:37:06 -05:00
|
|
|
|
2011-09-15 15:51:30 -04:00
|
|
|
class MessageVerifierTest < ActiveSupport::TestCase
|
2011-09-15 13:15:21 -04:00
|
|
|
class JSONSerializer
|
|
|
|
def dump(value)
|
|
|
|
ActiveSupport::JSON.encode(value)
|
|
|
|
end
|
|
|
|
|
|
|
|
def load(value)
|
|
|
|
ActiveSupport::JSON.decode(value)
|
|
|
|
end
|
|
|
|
end
|
2013-11-19 19:20:35 -05:00
|
|
|
|
2008-11-23 09:29:11 -05:00
|
|
|
def setup
|
2009-09-25 02:13:56 -04:00
|
|
|
@verifier = ActiveSupport::MessageVerifier.new("Hey, I'm a secret!")
|
2016-08-06 13:38:33 -04:00
|
|
|
@data = { some: "data", now: Time.local(2010) }
|
2008-11-23 09:29:11 -05:00
|
|
|
end
|
2009-09-25 02:13:56 -04:00
|
|
|
|
2014-11-21 18:52:22 -05:00
|
|
|
def test_valid_message
|
|
|
|
data, hash = @verifier.generate(@data).split("--")
|
|
|
|
assert !@verifier.valid_message?(nil)
|
|
|
|
assert !@verifier.valid_message?("")
|
2015-06-04 18:16:02 -04:00
|
|
|
assert !@verifier.valid_message?("\xff") # invalid encoding
|
2014-11-21 18:52:22 -05:00
|
|
|
assert !@verifier.valid_message?("#{data.reverse}--#{hash}")
|
|
|
|
assert !@verifier.valid_message?("#{data}--#{hash.reverse}")
|
|
|
|
assert !@verifier.valid_message?("purejunk")
|
|
|
|
end
|
|
|
|
|
2008-11-23 09:29:11 -05:00
|
|
|
def test_simple_round_tripping
|
2008-11-23 10:33:56 -05:00
|
|
|
message = @verifier.generate(@data)
|
2014-11-21 18:52:22 -05:00
|
|
|
assert_equal @data, @verifier.verified(message)
|
2008-11-23 10:33:56 -05:00
|
|
|
assert_equal @data, @verifier.verify(message)
|
2008-11-23 09:29:11 -05:00
|
|
|
end
|
2014-12-03 20:05:02 -05:00
|
|
|
|
2014-11-21 18:52:22 -05:00
|
|
|
def test_verified_returns_false_on_invalid_message
|
|
|
|
assert !@verifier.verified("purejunk")
|
2009-10-05 08:27:54 -04:00
|
|
|
end
|
2014-12-03 20:05:02 -05:00
|
|
|
|
2014-11-21 18:52:22 -05:00
|
|
|
def test_verify_exception_on_invalid_message
|
|
|
|
assert_raise(ActiveSupport::MessageVerifier::InvalidSignature) do
|
|
|
|
@verifier.verify("purejunk")
|
|
|
|
end
|
2008-11-23 09:29:11 -05:00
|
|
|
end
|
2013-11-19 19:20:35 -05:00
|
|
|
|
2011-09-15 08:28:53 -04:00
|
|
|
def test_alternative_serialization_method
|
2013-05-03 18:37:18 -04:00
|
|
|
prev = ActiveSupport.use_standard_json_time_format
|
|
|
|
ActiveSupport.use_standard_json_time_format = true
|
2016-08-06 13:38:33 -04:00
|
|
|
verifier = ActiveSupport::MessageVerifier.new("Hey, I'm a secret!", serializer: JSONSerializer.new)
|
2016-08-06 13:44:11 -04:00
|
|
|
message = verifier.generate(:foo => 123, "bar" => Time.utc(2010))
|
2013-11-07 10:35:49 -05:00
|
|
|
exp = { "foo" => 123, "bar" => "2010-01-01T00:00:00.000Z" }
|
2014-11-21 18:52:22 -05:00
|
|
|
assert_equal exp, verifier.verified(message)
|
2013-05-03 18:37:18 -04:00
|
|
|
assert_equal exp, verifier.verify(message)
|
|
|
|
ensure
|
|
|
|
ActiveSupport.use_standard_json_time_format = prev
|
2011-09-15 08:28:53 -04:00
|
|
|
end
|
2013-11-19 19:20:35 -05:00
|
|
|
|
2013-12-07 13:56:09 -05:00
|
|
|
def test_raise_error_when_argument_class_is_not_loaded
|
|
|
|
# To generate the valid message below:
|
|
|
|
#
|
|
|
|
# AutoloadClass = Struct.new(:foo)
|
|
|
|
# valid_message = @verifier.generate(foo: AutoloadClass.new('foo'))
|
|
|
|
#
|
|
|
|
valid_message = "BAh7BjoIZm9vbzonTWVzc2FnZVZlcmlmaWVyVGVzdDo6QXV0b2xvYWRDbGFzcwY6CUBmb29JIghmb28GOgZFVA==--f3ef39a5241c365083770566dc7a9eb5d6ace914"
|
2014-11-21 18:52:22 -05:00
|
|
|
exception = assert_raise(ArgumentError, NameError) do
|
|
|
|
@verifier.verified(valid_message)
|
|
|
|
end
|
|
|
|
assert_includes ["uninitialized constant MessageVerifierTest::AutoloadClass",
|
|
|
|
"undefined class/module MessageVerifierTest::AutoloadClass"], exception.message
|
2013-12-07 13:56:09 -05:00
|
|
|
exception = assert_raise(ArgumentError, NameError) do
|
|
|
|
@verifier.verify(valid_message)
|
|
|
|
end
|
|
|
|
assert_includes ["uninitialized constant MessageVerifierTest::AutoloadClass",
|
|
|
|
"undefined class/module MessageVerifierTest::AutoloadClass"], exception.message
|
|
|
|
end
|
|
|
|
|
2014-09-12 08:58:04 -04:00
|
|
|
def test_raise_error_when_secret_is_nil
|
|
|
|
exception = assert_raise(ArgumentError) do
|
|
|
|
ActiveSupport::MessageVerifier.new(nil)
|
|
|
|
end
|
2016-08-06 12:03:25 -04:00
|
|
|
assert_equal exception.message, "Secret should not be nil."
|
2014-09-12 08:58:04 -04:00
|
|
|
end
|
2008-11-23 09:29:11 -05:00
|
|
|
end
|