blob: dd3c45f7545209db25d7b0ce2beeb446136c8208 [file] [log] [blame]
Craig Tiller06059952015-02-18 08:34:56 -08001# Copyright 2015, Google Inc.
nnoble097ef9b2014-12-01 17:06:10 -08002# All rights reserved.
3#
4# Redistribution and use in source and binary forms, with or without
5# modification, are permitted provided that the following conditions are
6# met:
7#
8# * Redistributions of source code must retain the above copyright
9# notice, this list of conditions and the following disclaimer.
10# * Redistributions in binary form must reproduce the above
11# copyright notice, this list of conditions and the following disclaimer
12# in the documentation and/or other materials provided with the
13# distribution.
14# * Neither the name of Google Inc. nor the names of its
15# contributors may be used to endorse or promote products derived from
16# this software without specific prior written permission.
17#
18# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
30require 'grpc'
nnoble097ef9b2014-12-01 17:06:10 -080031
nnoble0c475f02014-12-05 15:37:39 -080032include GRPC::Core::StatusCodes
nnoble097ef9b2014-12-01 17:06:10 -080033
Tim Emiola7840a552015-08-20 13:12:33 -070034describe GRPC::Core::WriteFlags do
35 it 'should define the known write flag values' do
36 m = GRPC::Core::WriteFlags
37 expect(m.const_get(:BUFFER_HINT)).to_not be_nil
38 expect(m.const_get(:NO_COMPRESS)).to_not be_nil
39 end
40end
41
nnoble0c475f02014-12-05 15:37:39 -080042describe GRPC::Core::RpcErrors do
nnoble097ef9b2014-12-01 17:06:10 -080043 before(:each) do
44 @known_types = {
Tim Emiolae2860c52015-01-16 02:58:41 -080045 OK: 0,
46 ERROR: 1,
47 NOT_ON_SERVER: 2,
48 NOT_ON_CLIENT: 3,
49 ALREADY_ACCEPTED: 4,
50 ALREADY_INVOKED: 5,
51 NOT_INVOKED: 6,
52 ALREADY_FINISHED: 7,
53 TOO_MANY_OPERATIONS: 8,
54 INVALID_FLAGS: 9,
55 ErrorMessages: {
56 0 => 'ok',
57 1 => 'unknown error',
58 2 => 'not available on a server',
59 3 => 'not available on a client',
60 4 => 'call is already accepted',
61 5 => 'call is already invoked',
62 6 => 'call is not yet invoked',
63 7 => 'call is already finished',
64 8 => 'outstanding read or write present',
65 9 => 'a bad flag was given'
nnoble097ef9b2014-12-01 17:06:10 -080066 }
67 }
68 end
69
70 it 'should have symbols for all the known error codes' do
nnoble0c475f02014-12-05 15:37:39 -080071 m = GRPC::Core::RpcErrors
nnoble097ef9b2014-12-01 17:06:10 -080072 syms_and_codes = m.constants.collect { |c| [c, m.const_get(c)] }
73 expect(Hash[syms_and_codes]).to eq(@known_types)
74 end
nnoble097ef9b2014-12-01 17:06:10 -080075end
76
Tim Emiola37b09f42015-03-27 13:39:16 -070077describe GRPC::Core::CallOps do
78 before(:each) do
79 @known_types = {
80 SEND_INITIAL_METADATA: 0,
81 SEND_MESSAGE: 1,
82 SEND_CLOSE_FROM_CLIENT: 2,
83 SEND_STATUS_FROM_SERVER: 3,
84 RECV_INITIAL_METADATA: 4,
85 RECV_MESSAGE: 5,
86 RECV_STATUS_ON_CLIENT: 6,
Tim Emiola98a32d32015-03-28 01:48:44 -070087 RECV_CLOSE_ON_SERVER: 7
Tim Emiola37b09f42015-03-27 13:39:16 -070088 }
89 end
90
91 it 'should have symbols for all the known operation types' do
92 m = GRPC::Core::CallOps
93 syms_and_codes = m.constants.collect { |c| [c, m.const_get(c)] }
94 expect(Hash[syms_and_codes]).to eq(@known_types)
95 end
96end
97
nnoble0c475f02014-12-05 15:37:39 -080098describe GRPC::Core::Call do
Tim Emiola98a32d32015-03-28 01:48:44 -070099 let(:client_queue) { GRPC::Core::CompletionQueue.new }
100 let(:test_tag) { Object.new }
101 let(:fake_host) { 'localhost:10101' }
Tim Emiola564719d2015-03-27 13:07:34 -0700102
nnoble097ef9b2014-12-01 17:06:10 -0800103 before(:each) do
Tim Emiolad02d1d52015-01-26 18:36:17 -0800104 @ch = GRPC::Core::Channel.new(fake_host, nil)
nnoble097ef9b2014-12-01 17:06:10 -0800105 end
106
nnoble097ef9b2014-12-01 17:06:10 -0800107 describe '#status' do
108 it 'can save the status and read it back' do
109 call = make_test_call
temiola58327912014-12-15 17:51:16 -0800110 sts = Struct::Status.new(OK, 'OK')
nnoble097ef9b2014-12-01 17:06:10 -0800111 expect { call.status = sts }.not_to raise_error
temiola58327912014-12-15 17:51:16 -0800112 expect(call.status).to eq(sts)
nnoble097ef9b2014-12-01 17:06:10 -0800113 end
114
115 it 'must be set to a status' do
116 call = make_test_call
117 bad_sts = Object.new
118 expect { call.status = bad_sts }.to raise_error(TypeError)
119 end
120
121 it 'can be set to nil' do
122 call = make_test_call
123 expect { call.status = nil }.not_to raise_error
124 end
125 end
126
127 describe '#metadata' do
128 it 'can save the metadata hash and read it back' do
129 call = make_test_call
Tim Emiolae2860c52015-01-16 02:58:41 -0800130 md = { 'k1' => 'v1', 'k2' => 'v2' }
nnoble097ef9b2014-12-01 17:06:10 -0800131 expect { call.metadata = md }.not_to raise_error
132 expect(call.metadata).to be(md)
133 end
134
135 it 'must be set with a hash' do
136 call = make_test_call
137 bad_md = Object.new
138 expect { call.metadata = bad_md }.to raise_error(TypeError)
139 end
140
141 it 'can be set to nil' do
142 call = make_test_call
143 expect { call.metadata = nil }.not_to raise_error
144 end
145 end
146
nnoble097ef9b2014-12-01 17:06:10 -0800147 def make_test_call
Tim Emiolafde3dbf2015-08-11 16:35:41 -0700148 @ch.create_call(client_queue, nil, nil, 'dummy_method', nil, deadline)
nnoble097ef9b2014-12-01 17:06:10 -0800149 end
150
151 def deadline
152 Time.now + 2 # in 2 seconds; arbitrary
153 end
Craig Tiller190d3602015-02-18 09:23:38 -0800154end