mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
0a523ab20d
* ext/openssl/extconf.rb: Check existence of accessor functions that don't exist in OpenSSL 0.9.8. OpenSSL 1.1.0 made most of its structures opaque and requires use of these accessor functions. [ruby-core:75225] [Feature #12324] * ext/openssl/openssl_missing.[ch]: Implement them if missing. * ext/openssl/ossl*.c: Use these accessor functions. * test/openssl/test_hmac.rb: Add missing test for HMAC#reset. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55287 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
46 lines
1.4 KiB
Ruby
46 lines
1.4 KiB
Ruby
# coding: UTF-8
|
|
# frozen_string_literal: false
|
|
|
|
require_relative 'utils'
|
|
|
|
class OpenSSL::TestHMAC < OpenSSL::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 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
|
|
|
|
def test_reset_keep_key
|
|
first = @h1.update("test").hexdigest
|
|
@h2.reset
|
|
second = @h2.update("test").hexdigest
|
|
assert_equal first, second
|
|
end
|
|
end if defined?(OpenSSL::TestUtils)
|