| Index: third_party/grpc/src/ruby/spec/call_spec.rb
|
| diff --git a/third_party/grpc/src/ruby/spec/call_spec.rb b/third_party/grpc/src/ruby/spec/call_spec.rb
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..ae3ce0748a2bd1478ab75520d39860157a524610
|
| --- /dev/null
|
| +++ b/third_party/grpc/src/ruby/spec/call_spec.rb
|
| @@ -0,0 +1,163 @@
|
| +# Copyright 2015, Google Inc.
|
| +# All rights reserved.
|
| +#
|
| +# Redistribution and use in source and binary forms, with or without
|
| +# modification, are permitted provided that the following conditions are
|
| +# met:
|
| +#
|
| +# * Redistributions of source code must retain the above copyright
|
| +# notice, this list of conditions and the following disclaimer.
|
| +# * Redistributions in binary form must reproduce the above
|
| +# copyright notice, this list of conditions and the following disclaimer
|
| +# in the documentation and/or other materials provided with the
|
| +# distribution.
|
| +# * Neither the name of Google Inc. nor the names of its
|
| +# contributors may be used to endorse or promote products derived from
|
| +# this software without specific prior written permission.
|
| +#
|
| +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
| +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
| +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
| +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
| +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
| +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
| +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
| +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
| +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
| +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
| +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
| +
|
| +require 'grpc'
|
| +
|
| +include GRPC::Core::StatusCodes
|
| +
|
| +describe GRPC::Core::WriteFlags do
|
| + it 'should define the known write flag values' do
|
| + m = GRPC::Core::WriteFlags
|
| + expect(m.const_get(:BUFFER_HINT)).to_not be_nil
|
| + expect(m.const_get(:NO_COMPRESS)).to_not be_nil
|
| + end
|
| +end
|
| +
|
| +describe GRPC::Core::RpcErrors do
|
| + before(:each) do
|
| + @known_types = {
|
| + OK: 0,
|
| + ERROR: 1,
|
| + NOT_ON_SERVER: 2,
|
| + NOT_ON_CLIENT: 3,
|
| + ALREADY_ACCEPTED: 4,
|
| + ALREADY_INVOKED: 5,
|
| + NOT_INVOKED: 6,
|
| + ALREADY_FINISHED: 7,
|
| + TOO_MANY_OPERATIONS: 8,
|
| + INVALID_FLAGS: 9,
|
| + ErrorMessages: {
|
| + 0 => 'ok',
|
| + 1 => 'unknown error',
|
| + 2 => 'not available on a server',
|
| + 3 => 'not available on a client',
|
| + 4 => 'call is already accepted',
|
| + 5 => 'call is already invoked',
|
| + 6 => 'call is not yet invoked',
|
| + 7 => 'call is already finished',
|
| + 8 => 'outstanding read or write present',
|
| + 9 => 'a bad flag was given'
|
| + }
|
| + }
|
| + end
|
| +
|
| + it 'should have symbols for all the known error codes' do
|
| + m = GRPC::Core::RpcErrors
|
| + syms_and_codes = m.constants.collect { |c| [c, m.const_get(c)] }
|
| + expect(Hash[syms_and_codes]).to eq(@known_types)
|
| + end
|
| +end
|
| +
|
| +describe GRPC::Core::CallOps do
|
| + before(:each) do
|
| + @known_types = {
|
| + SEND_INITIAL_METADATA: 0,
|
| + SEND_MESSAGE: 1,
|
| + SEND_CLOSE_FROM_CLIENT: 2,
|
| + SEND_STATUS_FROM_SERVER: 3,
|
| + RECV_INITIAL_METADATA: 4,
|
| + RECV_MESSAGE: 5,
|
| + RECV_STATUS_ON_CLIENT: 6,
|
| + RECV_CLOSE_ON_SERVER: 7
|
| + }
|
| + end
|
| +
|
| + it 'should have symbols for all the known operation types' do
|
| + m = GRPC::Core::CallOps
|
| + syms_and_codes = m.constants.collect { |c| [c, m.const_get(c)] }
|
| + expect(Hash[syms_and_codes]).to eq(@known_types)
|
| + end
|
| +end
|
| +
|
| +describe GRPC::Core::Call do
|
| + let(:client_queue) { GRPC::Core::CompletionQueue.new }
|
| + let(:test_tag) { Object.new }
|
| + let(:fake_host) { 'localhost:10101' }
|
| +
|
| + before(:each) do
|
| + @ch = GRPC::Core::Channel.new(fake_host, nil, :this_channel_is_insecure)
|
| + end
|
| +
|
| + describe '#status' do
|
| + it 'can save the status and read it back' do
|
| + call = make_test_call
|
| + sts = Struct::Status.new(OK, 'OK')
|
| + expect { call.status = sts }.not_to raise_error
|
| + expect(call.status).to eq(sts)
|
| + end
|
| +
|
| + it 'must be set to a status' do
|
| + call = make_test_call
|
| + bad_sts = Object.new
|
| + expect { call.status = bad_sts }.to raise_error(TypeError)
|
| + end
|
| +
|
| + it 'can be set to nil' do
|
| + call = make_test_call
|
| + expect { call.status = nil }.not_to raise_error
|
| + end
|
| + end
|
| +
|
| + describe '#metadata' do
|
| + it 'can save the metadata hash and read it back' do
|
| + call = make_test_call
|
| + md = { 'k1' => 'v1', 'k2' => 'v2' }
|
| + expect { call.metadata = md }.not_to raise_error
|
| + expect(call.metadata).to be(md)
|
| + end
|
| +
|
| + it 'must be set with a hash' do
|
| + call = make_test_call
|
| + bad_md = Object.new
|
| + expect { call.metadata = bad_md }.to raise_error(TypeError)
|
| + end
|
| +
|
| + it 'can be set to nil' do
|
| + call = make_test_call
|
| + expect { call.metadata = nil }.not_to raise_error
|
| + end
|
| + end
|
| +
|
| + describe '#set_credentials!' do
|
| + it 'can set a valid CallCredentials object' do
|
| + call = make_test_call
|
| + auth_proc = proc { { 'plugin_key' => 'plugin_value' } }
|
| + creds = GRPC::Core::CallCredentials.new auth_proc
|
| + expect { call.set_credentials! creds }.not_to raise_error
|
| + end
|
| + end
|
| +
|
| + def make_test_call
|
| + @ch.create_call(client_queue, nil, nil, 'dummy_method', nil, deadline)
|
| + end
|
| +
|
| + def deadline
|
| + Time.now + 2 # in 2 seconds; arbitrary
|
| + end
|
| +end
|
|
|