2015-12-16 00:07:31 -05:00
|
|
|
# frozen_string_literal: false
|
2010-02-02 08:58:56 -05:00
|
|
|
require_relative 'drbtest'
|
2004-01-08 23:26:05 -05:00
|
|
|
|
|
|
|
begin
|
|
|
|
require 'drb/ssl'
|
|
|
|
rescue LoadError
|
|
|
|
end
|
|
|
|
|
2014-05-31 23:07:58 -04:00
|
|
|
module DRbTests
|
|
|
|
|
2007-11-19 13:30:18 -05:00
|
|
|
if Object.const_defined?("OpenSSL")
|
2004-01-08 23:26:05 -05:00
|
|
|
|
2003-10-20 11:24:00 -04:00
|
|
|
|
2003-10-21 10:42:15 -04:00
|
|
|
class DRbSSLService < DRbService
|
|
|
|
%w(ut_drb_drbssl.rb ut_array_drbssl.rb).each do |nm|
|
2004-03-19 02:13:01 -05:00
|
|
|
add_service_command(nm)
|
2003-10-21 10:42:15 -04:00
|
|
|
end
|
|
|
|
|
2018-10-20 09:14:02 -04:00
|
|
|
def start
|
|
|
|
config = Hash.new
|
|
|
|
|
|
|
|
config[:SSLVerifyMode] = OpenSSL::SSL::VERIFY_PEER
|
|
|
|
config[:SSLVerifyCallback] = lambda{ |ok,x509_store|
|
|
|
|
true
|
|
|
|
}
|
|
|
|
begin
|
|
|
|
data = open("sample.key"){|io| io.read }
|
|
|
|
config[:SSLPrivateKey] = OpenSSL::PKey::RSA.new(data)
|
|
|
|
data = open("sample.crt"){|io| io.read }
|
|
|
|
config[:SSLCertificate] = OpenSSL::X509::Certificate.new(data)
|
|
|
|
rescue
|
|
|
|
# $stderr.puts "Switching to use self-signed certificate"
|
|
|
|
config[:SSLCertName] =
|
|
|
|
[ ["C","JP"], ["O","Foo.DRuby.Org"], ["CN", "Sample"] ]
|
|
|
|
end
|
|
|
|
|
|
|
|
@server = DRb::DRbServer.new('drbssl://:0', manager, config)
|
|
|
|
end
|
2003-10-20 11:24:00 -04:00
|
|
|
end
|
|
|
|
|
2003-10-21 10:42:15 -04:00
|
|
|
class TestDRbSSLCore < Test::Unit::TestCase
|
|
|
|
include DRbCore
|
2003-10-20 11:24:00 -04:00
|
|
|
def setup
|
2018-10-20 09:14:02 -04:00
|
|
|
@drb_service = DRbSSLService.new
|
2014-06-02 07:34:50 -04:00
|
|
|
super
|
2018-10-20 09:14:02 -04:00
|
|
|
setup_service 'ut_drb_drbssl.rb'
|
2014-06-02 07:34:50 -04:00
|
|
|
end
|
|
|
|
|
2003-10-20 11:24:00 -04:00
|
|
|
def test_02_unknown
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_01_02_loop
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_05_eq
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2003-10-21 10:42:15 -04:00
|
|
|
class TestDRbSSLAry < Test::Unit::TestCase
|
|
|
|
include DRbAry
|
2003-10-20 11:24:00 -04:00
|
|
|
def setup
|
test/drb/test_drbssl.rb: skip LeakChecker as openssl keeps /dev/random
and /dev/urandom intentionally. OpenSSL::PKey::RSA.new opens the two
random generators and keeps the file descriptors.
https://github.com/openssl/openssl/blob/93f99b681ab5a1cf7062053323e09b0cad5ff854/crypto/rand/rand_unix.c#L674
They are detected by the LeakChecker as fd leak, but it is intentional.
http://rubyci.s3.amazonaws.com/graviton2/ruby-master/log/20200526T160005Z.log.html.gz
```
[ 597/20199] DRbTests::TestDRbSSLAry#test_01 = 0.29 s
Leaked file descriptor: DRbTests::TestDRbSSLAry#test_01: 8 #<File::Stat dev=0x6, ino=11, mode=020666, nlink=1, uid=0, gid=0, rdev=0x109, size=0, blksize=4096, blocks=0, atime=2020-05-23 14:45:13.751999995 +0000, mtime=2020-05-23 14:45:13.751999995 +0000, ctime=2020-05-23 14:45:13.751999995 +0000>
Leaked file descriptor: DRbTests::TestDRbSSLAry#test_01: 9 #<File::Stat dev=0x6, ino=10, mode=020666, nlink=1, uid=0, gid=0, rdev=0x108, size=0, blksize=4096, blocks=0, atime=2020-05-23 14:45:13.755999995 +0000, mtime=2020-05-23 14:45:13.755999995 +0000, ctime=2020-05-23 14:45:13.755999995 +0000>
```
2020-05-26 13:07:38 -04:00
|
|
|
LeakChecker.skip if defined?(LeakChecker)
|
2018-10-20 09:14:02 -04:00
|
|
|
@drb_service = DRbSSLService.new
|
2014-06-02 07:34:50 -04:00
|
|
|
super
|
2018-10-20 09:14:02 -04:00
|
|
|
setup_service 'ut_array_drbssl.rb'
|
2014-06-02 07:34:50 -04:00
|
|
|
end
|
2003-10-20 11:24:00 -04:00
|
|
|
end
|
2004-01-08 23:26:05 -05:00
|
|
|
|
|
|
|
|
2014-05-31 23:07:58 -04:00
|
|
|
end
|
|
|
|
|
2004-01-08 23:26:05 -05:00
|
|
|
end
|