diff options
author | Yusuke Nakamura <yusuke1994525@gmail.com> | 2021-12-21 17:14:30 +0900 |
---|---|---|
committer | Yusuke Nakamura <yusuke1994525@gmail.com> | 2021-12-21 23:40:46 +0900 |
commit | 7541a66911042127a591d070d2072a452251ec32 (patch) | |
tree | 638c7d934519481ef6cd41d026367cfd3c9bb5d3 | |
parent | 4beb383b33d8d8786114e977fbbbff9e1231aa23 (diff) | |
download | ruby-openssl-7541a66911042127a591d070d2072a452251ec32.tar.gz |
Add tast cases to OpenSSL::BN using ractor
OpenSSL::BN has been make ractor-safed in 9e7cf9e ,
but there was no test.
And to use 'ractor' annotation, update test-unit to v3.4.6 or higher.
-rw-r--r-- | Gemfile | 2 | ||||
-rw-r--r-- | test/openssl/test_bn.rb | 25 |
2 files changed, 26 insertions, 1 deletions
@@ -4,5 +4,5 @@ gemspec gem "rake" gem "rake-compiler" -gem "test-unit", "~> 3.0", ">= 3.4.3" +gem "test-unit", "~> 3.0", ">= 3.4.6" gem "rdoc" diff --git a/test/openssl/test_bn.rb b/test/openssl/test_bn.rb index 3f0622f9..346602da 100644 --- a/test/openssl/test_bn.rb +++ b/test/openssl/test_bn.rb @@ -334,6 +334,31 @@ class OpenSSL::TestBN < OpenSSL::TestCase e.set_flags(0) assert_equal(4, e.get_flags(OpenSSL::BN::CONSTTIME)) end + + if respond_to?(:ractor) + ractor + def test_ractor + assert_equal(@e1, Ractor.new { OpenSSL::BN.new("999") }.take) + assert_equal(@e3, Ractor.new { OpenSSL::BN.new("\a\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 2) }.take) + assert_equal("999", Ractor.new(@e1) { |e1| e1.to_s }.take) + assert_equal("07FFFFFFFFFFFFFFFFFFFFFFFFFF", Ractor.new(@e3) { |e3| e3.to_s(16) }.take) + assert_equal(2**107-1, Ractor.new(@e3) { _1.to_i }.take) + assert_equal([1000, -999], Ractor.new(@e2) { _1.coerce(1000) }.take) + assert_equal(false, Ractor.new { 1.to_bn.zero? }.take) + assert_equal(true, Ractor.new { 1.to_bn.one? }.take) + assert_equal(true, Ractor.new(@e2) { _1.negative? }.take) + assert_equal("-03E7", Ractor.new(@e2) { _1.to_s(16) }.take) + assert_equal(2**107-1, Ractor.new(@e3) { _1.to_i }.take) + assert_equal([1000, -999], Ractor.new(@e2) { _1.coerce(1000) }.take) + assert_equal(true, Ractor.new { 0.to_bn.zero? }.take) + assert_equal(true, Ractor.new { 1.to_bn.one? }.take ) + assert_equal(false,Ractor.new { 2.to_bn.odd? }.take) + assert_equal(true, Ractor.new(@e2) { _1.negative? }.take) + assert_include(128..255, Ractor.new { OpenSSL::BN.rand(8)}.take) + assert_include(0...2**32, Ractor.new { OpenSSL::BN.generate_prime(32) }.take) + assert_equal(0, Ractor.new { OpenSSL::BN.new(999).get_flags(OpenSSL::BN::CONSTTIME) }.take) + end + end end end |