|  | @@ -29,9 +29,9 @@
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  require 'grpc'
 | 
	
		
			
				|  |  |  require 'xray/thread_dump_signal_handler'
 | 
	
		
			
				|  |  | -require_relative '../port_picker'
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  NOOP = proc { |x| x }
 | 
	
		
			
				|  |  | +FAKE_HOST = 'localhost:0'
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  def wakey_thread(&blk)
 | 
	
		
			
				|  |  |    awake_mutex, awake_cond = Mutex.new, ConditionVariable.new
 | 
	
	
		
			
				|  | @@ -67,7 +67,7 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    describe '#new' do
 | 
	
		
			
				|  |  |      it 'can be created from a host and args' do
 | 
	
		
			
				|  |  | -      host = new_test_host
 | 
	
		
			
				|  |  | +      host = FAKE_HOST
 | 
	
		
			
				|  |  |        opts = { a_channel_arg: 'an_arg' }
 | 
	
		
			
				|  |  |        blk = proc do
 | 
	
		
			
				|  |  |          GRPC::ClientStub.new(host, @cq, **opts)
 | 
	
	
		
			
				|  | @@ -76,7 +76,7 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      it 'can be created with a default deadline' do
 | 
	
		
			
				|  |  | -      host = new_test_host
 | 
	
		
			
				|  |  | +      host = FAKE_HOST
 | 
	
		
			
				|  |  |        opts = { a_channel_arg: 'an_arg', deadline: 5 }
 | 
	
		
			
				|  |  |        blk = proc do
 | 
	
		
			
				|  |  |          GRPC::ClientStub.new(host, @cq, **opts)
 | 
	
	
		
			
				|  | @@ -85,7 +85,7 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      it 'can be created with an channel override' do
 | 
	
		
			
				|  |  | -      host = new_test_host
 | 
	
		
			
				|  |  | +      host = FAKE_HOST
 | 
	
		
			
				|  |  |        opts = { a_channel_arg: 'an_arg', channel_override: @ch }
 | 
	
		
			
				|  |  |        blk = proc do
 | 
	
		
			
				|  |  |          GRPC::ClientStub.new(host, @cq, **opts)
 | 
	
	
		
			
				|  | @@ -94,7 +94,7 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      it 'cannot be created with a bad channel override' do
 | 
	
		
			
				|  |  | -      host = new_test_host
 | 
	
		
			
				|  |  | +      host = FAKE_HOST
 | 
	
		
			
				|  |  |        blk = proc do
 | 
	
		
			
				|  |  |          opts = { a_channel_arg: 'an_arg', channel_override: Object.new }
 | 
	
		
			
				|  |  |          GRPC::ClientStub.new(host, @cq, **opts)
 | 
	
	
		
			
				|  | @@ -103,7 +103,7 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      it 'cannot be created with bad credentials' do
 | 
	
		
			
				|  |  | -      host = new_test_host
 | 
	
		
			
				|  |  | +      host = FAKE_HOST
 | 
	
		
			
				|  |  |        blk = proc do
 | 
	
		
			
				|  |  |          opts = { a_channel_arg: 'an_arg', creds: Object.new }
 | 
	
		
			
				|  |  |          GRPC::ClientStub.new(host, @cq, **opts)
 | 
	
	
		
			
				|  | @@ -113,7 +113,7 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      it 'can be created with test test credentials' do
 | 
	
		
			
				|  |  |        certs = load_test_certs
 | 
	
		
			
				|  |  | -      host = new_test_host
 | 
	
		
			
				|  |  | +      host = FAKE_HOST
 | 
	
		
			
				|  |  |        blk = proc do
 | 
	
		
			
				|  |  |          opts = {
 | 
	
		
			
				|  |  |            GRPC::Core::Channel::SSL_TARGET => 'foo.test.google.com',
 | 
	
	
		
			
				|  | @@ -133,16 +133,17 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      shared_examples 'request response' do
 | 
	
		
			
				|  |  |        it 'should send a request to/receive a reply from a server' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_request_response(host, @sent_msg, @resp, @pass)
 | 
	
		
			
				|  |  | -        stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        th = run_request_response(@sent_msg, @resp, @pass)
 | 
	
		
			
				|  |  | +        stub = GRPC::ClientStub.new("localhost:#{server_port}", @cq)
 | 
	
		
			
				|  |  |          expect(get_response(stub)).to eq(@resp)
 | 
	
		
			
				|  |  |          th.join
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should send metadata to the server ok' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_request_response(host, @sent_msg, @resp, @pass,
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_request_response(@sent_msg, @resp, @pass,
 | 
	
		
			
				|  |  |                                    k1: 'v1', k2: 'v2')
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          expect(get_response(stub)).to eq(@resp)
 | 
	
	
		
			
				|  | @@ -150,8 +151,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should update the sent metadata with a provided metadata updater' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_request_response(host, @sent_msg, @resp, @pass,
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_request_response(@sent_msg, @resp, @pass,
 | 
	
		
			
				|  |  |                                    k1: 'updated-v1', k2: 'v2')
 | 
	
		
			
				|  |  |          update_md = proc do |md|
 | 
	
		
			
				|  |  |            md[:k1] = 'updated-v1'
 | 
	
	
		
			
				|  | @@ -163,8 +165,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should send a request when configured using an override channel' do
 | 
	
		
			
				|  |  | -        alt_host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_request_response(alt_host, @sent_msg, @resp, @pass)
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        alt_host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_request_response(@sent_msg, @resp, @pass)
 | 
	
		
			
				|  |  |          ch = GRPC::Core::Channel.new(alt_host, nil)
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new('ignored-host', @cq, channel_override: ch)
 | 
	
		
			
				|  |  |          expect(get_response(stub)).to eq(@resp)
 | 
	
	
		
			
				|  | @@ -172,8 +175,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should raise an error if the status is not OK' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_request_response(host, @sent_msg, @resp, @fail)
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_request_response(@sent_msg, @resp, @fail)
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          blk = proc { get_response(stub) }
 | 
	
		
			
				|  |  |          expect(&blk).to raise_error(GRPC::BadStatus)
 | 
	
	
		
			
				|  | @@ -210,16 +214,18 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should send requests to/receive a reply from a server' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_client_streamer(host, @sent_msgs, @resp, @pass)
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_client_streamer(@sent_msgs, @resp, @pass)
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          expect(get_response(stub)).to eq(@resp)
 | 
	
		
			
				|  |  |          th.join
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should send metadata to the server ok' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_client_streamer(host, @sent_msgs, @resp, @pass,
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_client_streamer(@sent_msgs, @resp, @pass,
 | 
	
		
			
				|  |  |                                   k1: 'v1', k2: 'v2')
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          expect(get_response(stub)).to eq(@resp)
 | 
	
	
		
			
				|  | @@ -227,8 +233,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should update the sent metadata with a provided metadata updater' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_client_streamer(host, @sent_msgs, @resp, @pass,
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_client_streamer(@sent_msgs, @resp, @pass,
 | 
	
		
			
				|  |  |                                   k1: 'updated-v1', k2: 'v2')
 | 
	
		
			
				|  |  |          update_md = proc do |md|
 | 
	
		
			
				|  |  |            md[:k1] = 'updated-v1'
 | 
	
	
		
			
				|  | @@ -240,8 +247,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should raise an error if the status is not ok' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_client_streamer(host, @sent_msgs, @resp, @fail)
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_client_streamer(@sent_msgs, @resp, @fail)
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          blk = proc { get_response(stub) }
 | 
	
		
			
				|  |  |          expect(&blk).to raise_error(GRPC::BadStatus)
 | 
	
	
		
			
				|  | @@ -278,16 +286,18 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should send a request to/receive replies from a server' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_server_streamer(host, @sent_msg, @replys, @pass)
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_server_streamer(@sent_msg, @replys, @pass)
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          expect(get_responses(stub).collect { |r| r }).to eq(@replys)
 | 
	
		
			
				|  |  |          th.join
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should raise an error if the status is not ok' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_server_streamer(host, @sent_msg, @replys, @fail)
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_server_streamer(@sent_msg, @replys, @fail)
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          e = get_responses(stub)
 | 
	
		
			
				|  |  |          expect { e.collect { |r| r } }.to raise_error(GRPC::BadStatus)
 | 
	
	
		
			
				|  | @@ -295,8 +305,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should send metadata to the server ok' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_server_streamer(host, @sent_msg, @replys, @fail,
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_server_streamer(@sent_msg, @replys, @fail,
 | 
	
		
			
				|  |  |                                   k1: 'v1', k2: 'v2')
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          e = get_responses(stub)
 | 
	
	
		
			
				|  | @@ -305,8 +316,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'should update the sent metadata with a provided metadata updater' do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_server_streamer(host, @sent_msg, @replys, @pass,
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_server_streamer(@sent_msg, @replys, @pass,
 | 
	
		
			
				|  |  |                                   k1: 'updated-v1', k2: 'v2')
 | 
	
		
			
				|  |  |          update_md = proc do |md|
 | 
	
		
			
				|  |  |            md[:k1] = 'updated-v1'
 | 
	
	
		
			
				|  | @@ -352,8 +364,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'supports sending all the requests first', bidi: true do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_bidi_streamer_handle_inputs_first(host, @sent_msgs, @replys,
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_bidi_streamer_handle_inputs_first(@sent_msgs, @replys,
 | 
	
		
			
				|  |  |                                                     @pass)
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          e = get_responses(stub)
 | 
	
	
		
			
				|  | @@ -362,8 +375,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        it 'supports client-initiated ping pong', bidi: true do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_bidi_streamer_echo_ping_pong(host, @sent_msgs, @pass, true)
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_bidi_streamer_echo_ping_pong(@sent_msgs, @pass, true)
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          e = get_responses(stub)
 | 
	
		
			
				|  |  |          expect(e.collect { |r| r }).to eq(@sent_msgs)
 | 
	
	
		
			
				|  | @@ -377,8 +391,9 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |        # they receive a message from the client.  Without receiving all the
 | 
	
		
			
				|  |  |        # metadata, the server does not accept the call, so this test hangs.
 | 
	
		
			
				|  |  |        xit 'supports a server-initiated ping pong', bidi: true do
 | 
	
		
			
				|  |  | -        host = new_test_host
 | 
	
		
			
				|  |  | -        th = run_bidi_streamer_echo_ping_pong(host, @sent_msgs, @pass, false)
 | 
	
		
			
				|  |  | +        server_port = create_test_server
 | 
	
		
			
				|  |  | +        host = "localhost:#{server_port}"
 | 
	
		
			
				|  |  | +        th = run_bidi_streamer_echo_ping_pong(@sent_msgs, @pass, false)
 | 
	
		
			
				|  |  |          stub = GRPC::ClientStub.new(host, @cq)
 | 
	
		
			
				|  |  |          e = get_responses(stub)
 | 
	
		
			
				|  |  |          expect(e.collect { |r| r }).to eq(@sent_msgs)
 | 
	
	
		
			
				|  | @@ -410,10 +425,10 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |    end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  def run_server_streamer(hostname, expected_input, replys, status, **kw)
 | 
	
		
			
				|  |  | +  def run_server_streamer(expected_input, replys, status, **kw)
 | 
	
		
			
				|  |  |      wanted_metadata = kw.clone
 | 
	
		
			
				|  |  |      wakey_thread do |mtx, cnd|
 | 
	
		
			
				|  |  | -      c = expect_server_to_be_invoked(hostname, mtx, cnd)
 | 
	
		
			
				|  |  | +      c = expect_server_to_be_invoked(mtx, cnd)
 | 
	
		
			
				|  |  |        wanted_metadata.each do |k, v|
 | 
	
		
			
				|  |  |          expect(c.metadata[k.to_s]).to eq(v)
 | 
	
		
			
				|  |  |        end
 | 
	
	
		
			
				|  | @@ -423,20 +438,19 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |    end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  def run_bidi_streamer_handle_inputs_first(hostname, expected_inputs, replys,
 | 
	
		
			
				|  |  | +  def run_bidi_streamer_handle_inputs_first(expected_inputs, replys,
 | 
	
		
			
				|  |  |                                              status)
 | 
	
		
			
				|  |  |      wakey_thread do |mtx, cnd|
 | 
	
		
			
				|  |  | -      c = expect_server_to_be_invoked(hostname, mtx, cnd)
 | 
	
		
			
				|  |  | +      c = expect_server_to_be_invoked(mtx, cnd)
 | 
	
		
			
				|  |  |        expected_inputs.each { |i| expect(c.remote_read).to eq(i) }
 | 
	
		
			
				|  |  |        replys.each { |r| c.remote_send(r) }
 | 
	
		
			
				|  |  |        c.send_status(status, status == @pass ? 'OK' : 'NOK', true)
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |    end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  def run_bidi_streamer_echo_ping_pong(hostname, expected_inputs, status,
 | 
	
		
			
				|  |  | -                                       client_starts)
 | 
	
		
			
				|  |  | +  def run_bidi_streamer_echo_ping_pong(expected_inputs, status, client_starts)
 | 
	
		
			
				|  |  |      wakey_thread do |mtx, cnd|
 | 
	
		
			
				|  |  | -      c = expect_server_to_be_invoked(hostname, mtx, cnd)
 | 
	
		
			
				|  |  | +      c = expect_server_to_be_invoked(mtx, cnd)
 | 
	
		
			
				|  |  |        expected_inputs.each do |i|
 | 
	
		
			
				|  |  |          if client_starts
 | 
	
		
			
				|  |  |            expect(c.remote_read).to eq(i)
 | 
	
	
		
			
				|  | @@ -450,10 +464,10 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |    end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  def run_client_streamer(hostname, expected_inputs, resp, status, **kw)
 | 
	
		
			
				|  |  | +  def run_client_streamer(expected_inputs, resp, status, **kw)
 | 
	
		
			
				|  |  |      wanted_metadata = kw.clone
 | 
	
		
			
				|  |  |      wakey_thread do |mtx, cnd|
 | 
	
		
			
				|  |  | -      c = expect_server_to_be_invoked(hostname, mtx, cnd)
 | 
	
		
			
				|  |  | +      c = expect_server_to_be_invoked(mtx, cnd)
 | 
	
		
			
				|  |  |        expected_inputs.each { |i| expect(c.remote_read).to eq(i) }
 | 
	
		
			
				|  |  |        wanted_metadata.each do |k, v|
 | 
	
		
			
				|  |  |          expect(c.metadata[k.to_s]).to eq(v)
 | 
	
	
		
			
				|  | @@ -463,10 +477,10 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |    end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  def run_request_response(hostname, expected_input, resp, status, **kw)
 | 
	
		
			
				|  |  | +  def run_request_response(expected_input, resp, status, **kw)
 | 
	
		
			
				|  |  |      wanted_metadata = kw.clone
 | 
	
		
			
				|  |  |      wakey_thread do |mtx, cnd|
 | 
	
		
			
				|  |  | -      c = expect_server_to_be_invoked(hostname, mtx, cnd)
 | 
	
		
			
				|  |  | +      c = expect_server_to_be_invoked(mtx, cnd)
 | 
	
		
			
				|  |  |        expect(c.remote_read).to eq(expected_input)
 | 
	
		
			
				|  |  |        wanted_metadata.each do |k, v|
 | 
	
		
			
				|  |  |          expect(c.metadata[k.to_s]).to eq(v)
 | 
	
	
		
			
				|  | @@ -476,32 +490,30 @@ describe 'ClientStub' do
 | 
	
		
			
				|  |  |      end
 | 
	
		
			
				|  |  |    end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  def start_test_server(hostname, awake_mutex, awake_cond)
 | 
	
		
			
				|  |  | -    server_queue = GRPC::Core::CompletionQueue.new
 | 
	
		
			
				|  |  | -    @server = GRPC::Core::Server.new(server_queue, nil)
 | 
	
		
			
				|  |  | -    @server.add_http2_port(hostname)
 | 
	
		
			
				|  |  | +  def create_test_server
 | 
	
		
			
				|  |  | +    @server_queue = GRPC::Core::CompletionQueue.new
 | 
	
		
			
				|  |  | +    @server = GRPC::Core::Server.new(@server_queue, nil)
 | 
	
		
			
				|  |  | +    @server.add_http2_port('0.0.0.0:0')
 | 
	
		
			
				|  |  | +  end
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  def start_test_server(awake_mutex, awake_cond)
 | 
	
		
			
				|  |  |      @server.start
 | 
	
		
			
				|  |  |      @server_tag = Object.new
 | 
	
		
			
				|  |  |      @server.request_call(@server_tag)
 | 
	
		
			
				|  |  |      awake_mutex.synchronize { awake_cond.signal }
 | 
	
		
			
				|  |  | -    server_queue
 | 
	
		
			
				|  |  |    end
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  def expect_server_to_be_invoked(hostname, awake_mutex, awake_cond)
 | 
	
		
			
				|  |  | -    server_queue = start_test_server(hostname, awake_mutex, awake_cond)
 | 
	
		
			
				|  |  | -    ev = server_queue.pluck(@server_tag, INFINITE_FUTURE)
 | 
	
		
			
				|  |  | +  def expect_server_to_be_invoked(awake_mutex, awake_cond)
 | 
	
		
			
				|  |  | +    start_test_server(awake_mutex, awake_cond)
 | 
	
		
			
				|  |  | +    ev = @server_queue.pluck(@server_tag, INFINITE_FUTURE)
 | 
	
		
			
				|  |  |      fail OutOfTime if ev.nil?
 | 
	
		
			
				|  |  |      server_call = ev.call
 | 
	
		
			
				|  |  |      server_call.metadata = ev.result.metadata
 | 
	
		
			
				|  |  |      finished_tag = Object.new
 | 
	
		
			
				|  |  | -    server_call.server_accept(server_queue, finished_tag)
 | 
	
		
			
				|  |  | +    server_call.server_accept(@server_queue, finished_tag)
 | 
	
		
			
				|  |  |      server_call.server_end_initial_metadata
 | 
	
		
			
				|  |  | -    GRPC::ActiveCall.new(server_call, server_queue, NOOP, NOOP, INFINITE_FUTURE,
 | 
	
		
			
				|  |  | +    GRPC::ActiveCall.new(server_call, @server_queue, NOOP, NOOP,
 | 
	
		
			
				|  |  | +                         INFINITE_FUTURE,
 | 
	
		
			
				|  |  |                           finished_tag: finished_tag)
 | 
	
		
			
				|  |  |    end
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -  def new_test_host
 | 
	
		
			
				|  |  | -    port = find_unused_tcp_port
 | 
	
		
			
				|  |  | -    "localhost:#{port}"
 | 
	
		
			
				|  |  | -  end
 | 
	
		
			
				|  |  |  end
 |