# Copyright 2015 gRPC authors. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. 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(: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 describe '#cancel' do it 'completes ok' do call = make_test_call expect { call.cancel }.not_to raise_error end it 'completes ok when the call is closed' do call = make_test_call call.close expect { call.cancel }.not_to raise_error end end describe '#cancel_with_status' do it 'completes ok' do call = make_test_call expect do call.cancel_with_status(0, 'test status') end.not_to raise_error expect do call.cancel_with_status(0, nil) end.to raise_error(TypeError) end it 'completes ok when the call is closed' do call = make_test_call call.close expect do call.cancel_with_status(0, 'test status') end.not_to raise_error end end def make_test_call @ch.create_call(nil, nil, 'dummy_method', nil, deadline) end def deadline Time.now + 2 # in 2 seconds; arbitrary end end