message_verifier_test.rb 1.5 KB
Newer Older
1 2
require 'abstract_unit'

3 4 5 6 7 8 9
begin
  require 'openssl'
  OpenSSL::Digest::SHA1
rescue LoadError, NameError
  $stderr.puts "Skipping MessageVerifier test: broken OpenSSL install"
else

J
Jeremy Kemper 已提交
10
require 'active_support/time'
11
require 'active_support/json'
J
Jeremy Kemper 已提交
12

13
class MessageVerifierTest < ActiveSupport::TestCase
14 15 16 17 18 19 20 21 22 23 24
  
  class JSONSerializer
    def dump(value)
      ActiveSupport::JSON.encode(value)
    end

    def load(value)
      ActiveSupport::JSON.decode(value)
    end
  end
  
25
  def setup
26
    @verifier = ActiveSupport::MessageVerifier.new("Hey, I'm a secret!")
27
    @data = { :some => "data", :now => Time.local(2010) }
28
  end
29

30
  def test_simple_round_tripping
31 32
    message = @verifier.generate(@data)
    assert_equal @data, @verifier.verify(message)
33
  end
34

35 36 37 38 39
  def test_missing_signature_raises
    assert_not_verified(nil)
    assert_not_verified("")
  end

40
  def test_tampered_data_raises
41
    data, hash = @verifier.generate(@data).split("--")
42 43
    assert_not_verified("#{data.reverse}--#{hash}")
    assert_not_verified("#{data}--#{hash.reverse}")
44
    assert_not_verified("purejunk")
45
  end
46 47
  
  def test_alternative_serialization_method
48 49 50
    verifier = ActiveSupport::MessageVerifier.new("Hey, I'm a secret!", :serializer => JSONSerializer.new)
    message = verifier.generate({ :foo => 123, 'bar' => Time.utc(2010) })
    assert_equal verifier.verify(message), { "foo" => 123, "bar" => "2010-01-01T00:00:00Z" }
51
  end
52
  
53
  def assert_not_verified(message)
54
    assert_raise(ActiveSupport::MessageVerifier::InvalidSignature) do
55
      @verifier.verify(message)
56 57 58
    end
  end
end
59 60

end