зеркало из https://github.com/github/ruby.git
42 строки
1.3 KiB
Ruby
42 строки
1.3 KiB
Ruby
# coding: UTF-8
|
|
|
|
require_relative 'utils'
|
|
|
|
class OpenSSL::TestHMAC < Test::Unit::TestCase
|
|
def setup
|
|
@digest = OpenSSL::Digest::MD5
|
|
@key = "KEY"
|
|
@data = "DATA"
|
|
@h1 = OpenSSL::HMAC.new(@key, @digest.new)
|
|
@h2 = OpenSSL::HMAC.new(@key, "MD5")
|
|
end
|
|
|
|
def teardown
|
|
end
|
|
|
|
def test_hmac
|
|
@h1.update(@data)
|
|
@h2.update(@data)
|
|
assert_equal(@h1.digest, @h2.digest)
|
|
|
|
assert_equal(OpenSSL::HMAC.digest(@digest.new, @key, @data), @h1.digest, "digest")
|
|
assert_equal(OpenSSL::HMAC.hexdigest(@digest.new, @key, @data), @h1.hexdigest, "hexdigest")
|
|
|
|
assert_equal(OpenSSL::HMAC.digest("MD5", @key, @data), @h2.digest, "digest")
|
|
assert_equal(OpenSSL::HMAC.hexdigest("MD5", @key, @data), @h2.hexdigest, "hexdigest")
|
|
end
|
|
|
|
def test_dup
|
|
@h1.update(@data)
|
|
h = @h1.dup
|
|
assert_equal(@h1.digest, h.digest, "dup digest")
|
|
end
|
|
|
|
def test_binary_update
|
|
data = "Lücíllé: Bût... yøü sáîd hé wås âlrîght.\nDr. Físhmån: Yés. Hé's løst hîs léft hånd, sø hé's gøîng tø bé åll rîght"
|
|
hmac = OpenSSL::HMAC.new("qShkcwN92rsM9nHfdnP4ugcVU2iI7iM/trovs01ZWok", "SHA256")
|
|
result = hmac.update(data).hexdigest
|
|
assert_equal "a13984b929a07912e4e21c5720876a8e150d6f67f854437206e7f86547248396", result
|
|
end
|
|
end if defined?(OpenSSL)
|