Sha256: 537546c2d606aa60a2b55f7a80894c4bb3ee96de8f8810f4516f3f69315806c4

Contents?: true

Size: 1.92 KB

Versions: 28

Compression:

Stored size: 1.92 KB

Contents

require 'em_test_helper'

class TestSslDhParam < Test::Unit::TestCase
  def setup
    $dir = File.dirname(File.expand_path(__FILE__)) + '/'
    $dhparam_file = File.join($dir, 'dhparam.pem')
  end

  module Client
    def post_init
      start_tls
    end

    def ssl_handshake_completed
      $client_handshake_completed = true
      $client_cipher_name = get_cipher_name
      close_connection
    end

    def unbind
      EM.stop_event_loop
    end
  end

  module Server
    def post_init
      start_tls(:dhparam => $dhparam_file, :cipher_list => "DHE,EDH")
    end

    def ssl_handshake_completed
      $server_handshake_completed = true
      $server_cipher_name = get_cipher_name
    end
  end

  module NoDhServer
    def post_init
      start_tls(:cipher_list => "DHE,EDH")
    end

    def ssl_handshake_completed
      $server_handshake_completed = true
      $server_cipher_name = get_cipher_name
    end
  end

  def test_no_dhparam
    omit_unless(EM.ssl?)
    omit_if(EM.library_type == :pure_ruby) # DH will work with defaults
    omit_if(rbx?)

    $client_handshake_completed, $server_handshake_completed = false, false
    $server_cipher_name, $client_cipher_name = nil, nil

    EM.run {
      EM.start_server("127.0.0.1", 16784, NoDhServer)
      EM.connect("127.0.0.1", 16784, Client)
    }

    assert(!$client_handshake_completed)
    assert(!$server_handshake_completed)
  end

  def test_dhparam
    omit_unless(EM.ssl?)
    omit_if(rbx?)

    $client_handshake_completed, $server_handshake_completed = false, false
    $server_cipher_name, $client_cipher_name = nil, nil

    EM.run {
      EM.start_server("127.0.0.1", 16784, Server)
      EM.connect("127.0.0.1", 16784, Client)
    }

    assert($client_handshake_completed)
    assert($server_handshake_completed)

    assert($client_cipher_name.length > 0)
    assert_equal($client_cipher_name, $server_cipher_name)

    assert_match(/^(DHE|EDH)/, $client_cipher_name)
  end
end

Version data entries

28 entries across 26 versions & 3 rubygems

Version Path
devcycle-ruby-server-sdk-1.1.0 examples/sinatra/vendor/bundle/ruby/2.6.0/gems/eventmachine-1.2.7/tests/test_ssl_dhparam.rb
devcycle-ruby-server-sdk-1.1.0 examples/sinatra/vendor/bundle/ruby/3.1.0/gems/eventmachine-1.2.7/tests/test_ssl_dhparam.rb
devcycle-ruby-server-sdk-1.1.0 examples/sinatra/vendor/bundle/ruby/3.0.0/gems/eventmachine-1.2.7/tests/test_ssl_dhparam.rb
eventmachine-1.2.7-java tests/test_ssl_dhparam.rb
eventmachine-1.2.7-x64-mingw32 tests/test_ssl_dhparam.rb
eventmachine-1.2.7-x86-mingw32 tests/test_ssl_dhparam.rb
eventmachine-1.2.7 tests/test_ssl_dhparam.rb
eventmachine-1.2.6-x64-mingw32 tests/test_ssl_dhparam.rb
eventmachine-1.2.6-x86-mingw32 tests/test_ssl_dhparam.rb
eventmachine-1.2.6-java tests/test_ssl_dhparam.rb
eventmachine-1.2.6 tests/test_ssl_dhparam.rb
eventmachine-1.2.5-x86-mingw32 tests/test_ssl_dhparam.rb
eventmachine-1.2.5-x64-mingw32 tests/test_ssl_dhparam.rb
eventmachine-1.2.5-java tests/test_ssl_dhparam.rb
eventmachine-1.2.5 tests/test_ssl_dhparam.rb
eventmachine-1.2.3-x64-mingw32 tests/test_ssl_dhparam.rb
eventmachine-1.2.3-x86-mingw32 tests/test_ssl_dhparam.rb
eventmachine-1.2.3-java tests/test_ssl_dhparam.rb
eventmachine-1.2.3 tests/test_ssl_dhparam.rb
eventmachine-1.2.2-java tests/test_ssl_dhparam.rb