bad_server_response_test.cc
Go to the documentation of this file.
1 /*
2  *
3  * Copyright 2016 gRPC authors.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  */
18 
19 #include <limits.h>
20 #include <string.h>
21 
22 #include <grpc/grpc.h>
23 #include <grpc/grpc_security.h>
24 #include <grpc/slice.h>
25 #include <grpc/support/alloc.h>
26 #include <grpc/support/log.h>
27 
32 #include "src/core/lib/gprpp/thd.h"
37 #include "test/core/util/port.h"
40 
41 #define HTTP1_RESP_400 \
42  "HTTP/1.0 400 Bad Request\n" \
43  "Content-Type: text/html; charset=UTF-8\n" \
44  "Content-Length: 0\n" \
45  "Date: Tue, 07 Jun 2016 17:43:20 GMT\n\n"
46 
47 #define HTTP2_SETTINGS_FRAME "\x00\x00\x00\x04\x00\x00\x00\x00\x00"
48 
49 #define HTTP2_RESP(STATUS_CODE) \
50  "\x00\x00>\x01\x04\x00\x00\x00\x01" \
51  "\x10\x0e" \
52  "content-length\x01" \
53  "0" \
54  "\x10\x0c" \
55  "content-type\x10" \
56  "application/grpc" \
57  "\x10\x07:status\x03" #STATUS_CODE
58 
59 #define UNPARSEABLE_RESP "Bad Request\n"
60 
61 #define HTTP2_DETAIL_MSG(STATUS_CODE) \
62  "Received http2 header with status: " #STATUS_CODE
63 
64 /* TODO(zyc) Check the content of incoming data instead of using this length */
65 /* The 'bad' server will start sending responses after reading this amount of
66  * data from the client. */
67 #define SERVER_INCOMING_DATA_LENGTH_LOWER_THRESHOLD (size_t)200
68 
69 struct rpc_state {
81  const char* response_payload;
84 };
85 
86 static int server_port;
87 static struct rpc_state state;
91 
92 static void* tag(intptr_t t) { return reinterpret_cast<void*>(t); }
93 
94 static void done_write(void* /*arg*/, grpc_error_handle error) {
96  gpr_atm_rel_store(&state.done_atm, 1);
97 }
98 
99 static void done_writing_settings_frame(void* /* arg */,
102  grpc_endpoint_read(state.tcp, &state.temp_incoming_buffer, &on_read,
103  /*urgent=*/false, /*min_progress_size=*/1);
104 }
105 
106 static void handle_write() {
108  state.response_payload, state.response_payload_length);
109 
110  grpc_slice_buffer_reset_and_unref(&state.outgoing_buffer);
111  grpc_slice_buffer_add(&state.outgoing_buffer, slice);
112  grpc_endpoint_write(state.tcp, &state.outgoing_buffer, &on_write, nullptr,
113  /*max_frame_size=*/INT_MAX);
114 }
115 
116 static void handle_read(void* /*arg*/, grpc_error_handle error) {
117  if (!GRPC_ERROR_IS_NONE(error)) {
118  gpr_log(GPR_ERROR, "handle_read error: %s",
120  return;
121  }
122  state.incoming_data_length += state.temp_incoming_buffer.length;
123 
124  size_t i;
125  for (i = 0; i < state.temp_incoming_buffer.count; i++) {
126  char* dump = grpc_dump_slice(state.temp_incoming_buffer.slices[i],
128  gpr_log(GPR_DEBUG, "Server received: %s", dump);
129  gpr_free(dump);
130  }
131 
133  "got %" PRIuPTR " bytes, expected %" PRIuPTR
134  " bytes or a non-HTTP2 response to be sent",
135  state.incoming_data_length,
137  if (state.incoming_data_length >=
139  !state.http2_response) {
140  handle_write();
141  } else {
142  grpc_endpoint_read(state.tcp, &state.temp_incoming_buffer, &on_read,
143  /*urgent=*/false, /*min_progress_size=*/1);
144  }
145 }
146 
147 static void on_connect(void* arg, grpc_endpoint* tcp,
148  grpc_pollset* /*accepting_pollset*/,
149  grpc_tcp_server_acceptor* acceptor) {
150  gpr_free(acceptor);
151  test_tcp_server* server = static_cast<test_tcp_server*>(arg);
152  GRPC_CLOSURE_INIT(&on_read, handle_read, nullptr, grpc_schedule_on_exec_ctx);
154  nullptr, grpc_schedule_on_exec_ctx);
155  GRPC_CLOSURE_INIT(&on_write, done_write, nullptr, grpc_schedule_on_exec_ctx);
156  grpc_slice_buffer_init(&state.temp_incoming_buffer);
157  grpc_slice_buffer_init(&state.outgoing_buffer);
158  state.connection_attempt_made = true;
159  state.tcp = tcp;
160  state.incoming_data_length = 0;
162  if (state.send_settings) {
163  // Send settings frame from server
166  grpc_slice_buffer_add(&state.outgoing_buffer, slice);
167  grpc_endpoint_write(state.tcp, &state.outgoing_buffer,
168  &on_writing_settings_frame, nullptr,
169  /*max_frame_size=*/INT_MAX);
170  } else {
171  grpc_endpoint_read(state.tcp, &state.temp_incoming_buffer, &on_read,
172  /*urgent=*/false, /*min_progress_size=*/1);
173  }
174 }
175 
179 }
180 
181 static void start_rpc(int target_port, grpc_status_code expected_status,
182  const char* expected_detail) {
183  grpc_op ops[6];
184  grpc_op* op;
189  cq_verifier* cqv;
191 
193  cqv = cq_verifier_create(state.cq);
194  state.target = grpc_core::JoinHostPort("127.0.0.1", target_port);
195 
197  state.channel = grpc_channel_create(state.target.c_str(), creds, nullptr);
199  grpc_slice host = grpc_slice_from_static_string("localhost");
200  // The default connect deadline is 20 seconds, so reduce the RPC deadline to 1
201  // second. This helps us verify - a) If the server responded with a non-HTTP2
202  // response, the connect fails immediately resulting in
203  // GRPC_STATUS_UNAVAILABLE instead of GRPC_STATUS_DEADLINE_EXCEEDED. b) If the
204  // server does not send a HTTP2 SETTINGs frame, the RPC fails with a
205  // DEADLINE_EXCEEDED.
207  state.channel, nullptr, GRPC_PROPAGATE_DEFAULTS, state.cq,
208  grpc_slice_from_static_string("/Service/Method"), &host,
209  n_sec_deadline(5), nullptr);
210 
213 
214  memset(ops, 0, sizeof(ops));
215  op = ops;
218  op->flags = 0;
219  op->reserved = nullptr;
220  op++;
222  op->flags = 0;
223  op->reserved = nullptr;
224  op++;
227  op->flags = 0;
228  op->reserved = nullptr;
229  op++;
234  op->flags = 0;
235  op->reserved = nullptr;
236  op++;
237  error = grpc_call_start_batch(state.call, ops, static_cast<size_t>(op - ops),
238  tag(1), nullptr);
239 
241 
242  CQ_EXPECT_COMPLETION(cqv, tag(1), 1);
243  cq_verify(cqv);
244 
245  GPR_ASSERT(status == expected_status);
246  if (expected_detail != nullptr) {
248  expected_detail)));
249  }
250 
254  cq_verifier_destroy(cqv);
255 }
256 
257 static void cleanup_rpc() {
258  grpc_event ev;
259  grpc_slice_buffer_destroy_internal(&state.temp_incoming_buffer);
260  grpc_slice_buffer_destroy_internal(&state.outgoing_buffer);
261  grpc_call_unref(state.call);
263  do {
264  ev = grpc_completion_queue_next(state.cq, n_sec_deadline(1), nullptr);
265  } while (ev.type != GRPC_QUEUE_SHUTDOWN);
267  grpc_channel_destroy(state.channel);
268  state.target.clear();
269 }
270 
271 typedef struct {
274 } poll_args;
275 
276 static void actually_poll_server(void* arg) {
277  poll_args* pa = static_cast<poll_args*>(arg);
278  gpr_timespec deadline = n_sec_deadline(5);
279  while (true) {
280  bool done = gpr_atm_acq_load(&state.done_atm) != 0;
281  gpr_timespec time_left =
283  gpr_log(GPR_DEBUG, "done=%d, time_left=%" PRId64 ".%09d", done,
284  time_left.tv_sec, time_left.tv_nsec);
285  if (done || gpr_time_cmp(time_left, gpr_time_0(GPR_TIMESPAN)) < 0) {
286  break;
287  }
288  test_tcp_server_poll(pa->server, 1000);
289  }
290  gpr_event_set(pa->signal_when_done, reinterpret_cast<void*>(1));
291  gpr_free(pa);
292 }
293 
295  test_tcp_server* server, gpr_event* signal_when_done) {
296  gpr_atm_rel_store(&state.done_atm, 0);
297  state.connection_attempt_made = false;
298  poll_args* pa = static_cast<poll_args*>(gpr_malloc(sizeof(*pa)));
299  pa->server = server;
300  pa->signal_when_done = signal_when_done;
301  auto* th =
302  new grpc_core::Thread("grpc_poll_server", actually_poll_server, pa);
303  th->Start();
304  return th;
305 }
306 
307 static void run_test(bool http2_response, bool send_settings,
308  const char* response_payload,
309  size_t response_payload_length,
310  grpc_status_code expected_status,
311  const char* expected_detail) {
314  gpr_event ev;
315 
316  grpc_init();
317  gpr_event_init(&ev);
321  state.http2_response = http2_response;
322  state.send_settings = send_settings;
323  state.response_payload = response_payload;
324  state.response_payload_length = response_payload_length;
325 
326  /* poll server until sending out the response */
327  std::unique_ptr<grpc_core::Thread> thdptr(
329  start_rpc(server_port, expected_status, expected_detail);
331  thdptr->Join();
332  /* Proof that the server accepted the TCP connection. */
333  GPR_ASSERT(state.connection_attempt_made == true);
334  /* clean up */
336  GRPC_ERROR_CREATE_FROM_STATIC_STRING("Test Shutdown"));
338  cleanup_rpc();
341 
342  grpc_shutdown();
343 }
344 
345 int main(int argc, char** argv) {
346  grpc::testing::TestEnvironment env(&argc, argv);
347  grpc_init();
348  /* status defined in hpack static table */
349  run_test(true, true, HTTP2_RESP(204), sizeof(HTTP2_RESP(204)) - 1,
351  run_test(true, true, HTTP2_RESP(206), sizeof(HTTP2_RESP(206)) - 1,
353  run_test(true, true, HTTP2_RESP(304), sizeof(HTTP2_RESP(304)) - 1,
355  run_test(true, true, HTTP2_RESP(400), sizeof(HTTP2_RESP(400)) - 1,
357  run_test(true, true, HTTP2_RESP(404), sizeof(HTTP2_RESP(404)) - 1,
359  run_test(true, true, HTTP2_RESP(500), sizeof(HTTP2_RESP(500)) - 1,
361 
362  /* status not defined in hpack static table */
363  run_test(true, true, HTTP2_RESP(401), sizeof(HTTP2_RESP(401)) - 1,
365  run_test(true, true, HTTP2_RESP(403), sizeof(HTTP2_RESP(403)) - 1,
367  run_test(true, true, HTTP2_RESP(429), sizeof(HTTP2_RESP(429)) - 1,
369  run_test(true, true, HTTP2_RESP(499), sizeof(HTTP2_RESP(499)) - 1,
371  run_test(true, true, HTTP2_RESP(502), sizeof(HTTP2_RESP(502)) - 1,
373  run_test(true, true, HTTP2_RESP(503), sizeof(HTTP2_RESP(503)) - 1,
375  run_test(true, true, HTTP2_RESP(504), sizeof(HTTP2_RESP(504)) - 1,
377  /* unparseable response. RPC should fail immediately due to a connect
378  * failure.
379  */
380  run_test(false, false, UNPARSEABLE_RESP, sizeof(UNPARSEABLE_RESP) - 1,
381  GRPC_STATUS_UNAVAILABLE, nullptr);
382 
383  /* http1 response. RPC should fail immediately due to a connect failure. */
384  run_test(false, false, HTTP1_RESP_400, sizeof(HTTP1_RESP_400) - 1,
385  GRPC_STATUS_UNAVAILABLE, nullptr);
386 
387  /* http2 response without sending a SETTINGs frame. RPC should fail with
388  * DEADLINE_EXCEEDED since the RPC deadline is lower than the connection
389  * attempt deadline. */
390  run_test(true, false, HTTP2_RESP(404), sizeof(HTTP2_RESP(404)) - 1,
392  grpc_shutdown();
393  return 0;
394 }
GRPC_CLOSURE_INIT
#define GRPC_CLOSURE_INIT(closure, cb, cb_arg, scheduler)
Definition: closure.h:115
gpr_timespec::tv_nsec
int32_t tv_nsec
Definition: gpr_types.h:52
GPR_TIMESPAN
@ GPR_TIMESPAN
Definition: gpr_types.h:45
grpc_slice_unref
GPRAPI void grpc_slice_unref(grpc_slice s)
Definition: slice_api.cc:32
absl::time_internal::cctz::seconds
std::chrono::duration< std::int_fast64_t > seconds
Definition: abseil-cpp/absl/time/internal/cctz/include/cctz/time_zone.h:40
gpr_timespec::tv_sec
int64_t tv_sec
Definition: gpr_types.h:51
poll_args::signal_when_done
gpr_event * signal_when_done
Definition: bad_server_response_test.cc:273
rpc_state::temp_incoming_buffer
grpc_slice_buffer temp_incoming_buffer
Definition: bad_server_response_test.cc:75
grpc_op::flags
uint32_t flags
Definition: grpc_types.h:644
test_tcp_server_init
void test_tcp_server_init(test_tcp_server *server, grpc_tcp_server_cb on_connect, void *user_data)
Definition: test_tcp_server.cc:43
grpc_call_error
grpc_call_error
Definition: grpc_types.h:464
run_test
static void run_test(bool http2_response, bool send_settings, const char *response_payload, size_t response_payload_length, grpc_status_code expected_status, const char *expected_detail)
Definition: bad_server_response_test.cc:307
grpc_op::grpc_op_data::grpc_op_recv_status_on_client::trailing_metadata
grpc_metadata_array * trailing_metadata
Definition: grpc_types.h:701
log.h
port.h
grpc_op::grpc_op_data::grpc_op_recv_status_on_client::status
grpc_status_code * status
Definition: grpc_types.h:702
GRPC_STATUS_UNAVAILABLE
@ GRPC_STATUS_UNAVAILABLE
Definition: include/grpc/impl/codegen/status.h:143
test_tcp_server_start
void test_tcp_server_start(test_tcp_server *server, int port)
Definition: test_tcp_server.cc:57
generate.env
env
Definition: generate.py:37
rpc_state::send_settings
bool send_settings
Definition: bad_server_response_test.cc:80
GRPC_STATUS_UNAUTHENTICATED
@ GRPC_STATUS_UNAUTHENTICATED
Definition: include/grpc/impl/codegen/status.h:72
memset
return memset(p, 0, total)
grpc_dump_slice
char * grpc_dump_slice(const grpc_slice &s, uint32_t flags)
Definition: slice_string_helpers.cc:25
grpc_op::grpc_op_data::send_initial_metadata
struct grpc_op::grpc_op_data::grpc_op_send_initial_metadata send_initial_metadata
slice.h
rpc_state::done_atm
gpr_atm done_atm
Definition: bad_server_response_test.cc:78
gpr_time_0
GPRAPI gpr_timespec gpr_time_0(gpr_clock_type type)
Definition: src/core/lib/gpr/time.cc:47
handle_write
static void handle_write()
Definition: bad_server_response_test.cc:106
grpc_metadata_array
Definition: grpc_types.h:579
poll_args::server
test_tcp_server * server
Definition: bad_server_response_test.cc:272
grpc_op::reserved
void * reserved
Definition: grpc_types.h:646
string.h
grpc_slice_slice
GPRAPI int grpc_slice_slice(grpc_slice haystack, grpc_slice needle)
Definition: slice/slice.cc:461
server_port
static int server_port
Definition: bad_server_response_test.cc:86
GRPC_STATUS_PERMISSION_DENIED
@ GRPC_STATUS_PERMISSION_DENIED
Definition: include/grpc/impl/codegen/status.h:68
gpr_event_set
GPRAPI void gpr_event_set(gpr_event *ev, void *value)
Definition: sync.cc:59
gpr_free
GPRAPI void gpr_free(void *ptr)
Definition: alloc.cc:51
test_server
Definition: test_server.py:1
grpc_endpoint_read
void grpc_endpoint_read(grpc_endpoint *ep, grpc_slice_buffer *slices, grpc_closure *cb, bool urgent, int min_progress_size)
Definition: endpoint.cc:25
testing::internal::string
::std::string string
Definition: bloaty/third_party/protobuf/third_party/googletest/googletest/include/gtest/internal/gtest-port.h:881
error
grpc_error_handle error
Definition: retry_filter.cc:499
grpc_status_code
grpc_status_code
Definition: include/grpc/impl/codegen/status.h:28
GRPC_QUEUE_SHUTDOWN
@ GRPC_QUEUE_SHUTDOWN
Definition: grpc_types.h:554
tcp
static uv_tcp_t tcp
Definition: test-connection-fail.c:29
HTTP2_RESP
#define HTTP2_RESP(STATUS_CODE)
Definition: bad_server_response_test.cc:49
gpr_malloc
GPRAPI void * gpr_malloc(size_t size)
Definition: alloc.cc:29
GRPC_CALL_OK
@ GRPC_CALL_OK
Definition: grpc_types.h:466
rpc_state::http2_response
bool http2_response
Definition: bad_server_response_test.cc:79
status
absl::Status status
Definition: rls.cc:251
gpr_inf_future
GPRAPI gpr_timespec gpr_inf_future(gpr_clock_type type)
Definition: src/core/lib/gpr/time.cc:55
GRPC_STATUS_DEADLINE_EXCEEDED
@ GRPC_STATUS_DEADLINE_EXCEEDED
Definition: include/grpc/impl/codegen/status.h:53
main
int main(int argc, char **argv)
Definition: bad_server_response_test.cc:345
GPR_DUMP_HEX
#define GPR_DUMP_HEX
Definition: string.h:34
grpc_security.h
done_writing_settings_frame
static void done_writing_settings_frame(void *, grpc_error_handle error)
Definition: bad_server_response_test.cc:99
sockaddr.h
test_tcp_server
Definition: test_tcp_server.h:30
GPR_DUMP_ASCII
#define GPR_DUMP_ASCII
Definition: string.h:35
grpc_op::data
union grpc_op::grpc_op_data data
test_tcp_server_destroy
void test_tcp_server_destroy(test_tcp_server *server)
Definition: test_tcp_server.cc:103
memory.h
grpc_metadata_array_destroy
GRPCAPI void grpc_metadata_array_destroy(grpc_metadata_array *array)
Definition: metadata_array.cc:35
trailing_metadata_recv
static grpc_metadata_array trailing_metadata_recv
Definition: test/core/fling/client.cc:43
test_tcp_server.h
server
std::unique_ptr< Server > server
Definition: channelz_service_test.cc:330
rpc_state::call
grpc_call * call
Definition: bad_server_response_test.cc:73
rpc_state
Definition: bad_server_response_test.cc:69
rpc_state::outgoing_buffer
grpc_slice_buffer outgoing_buffer
Definition: bad_server_response_test.cc:76
on_writing_settings_frame
static grpc_closure on_writing_settings_frame
Definition: bad_server_response_test.cc:89
GRPC_OP_RECV_INITIAL_METADATA
@ GRPC_OP_RECV_INITIAL_METADATA
Definition: grpc_types.h:617
on_read
static grpc_closure on_read
Definition: bad_server_response_test.cc:88
GPR_ASSERT
#define GPR_ASSERT(x)
Definition: include/grpc/impl/codegen/log.h:94
gpr_time_cmp
GPRAPI int gpr_time_cmp(gpr_timespec a, gpr_timespec b)
Definition: src/core/lib/gpr/time.cc:30
gen_stats_data.c_str
def c_str(s, encoding='ascii')
Definition: gen_stats_data.py:38
grpc_core::ExecCtx::Flush
bool Flush()
Definition: exec_ctx.cc:69
grpc_call_unref
GRPCAPI void grpc_call_unref(grpc_call *call)
Definition: call.cc:1770
gpr_time_sub
GPRAPI gpr_timespec gpr_time_sub(gpr_timespec a, gpr_timespec b)
Definition: src/core/lib/gpr/time.cc:168
rpc_state::connection_attempt_made
bool connection_attempt_made
Definition: bad_server_response_test.cc:83
slice
grpc_slice slice
Definition: src/core/lib/surface/server.cc:467
gpr_log
GPRAPI void gpr_log(const char *file, int line, gpr_log_severity severity, const char *format,...) GPR_PRINT_FORMAT_CHECK(4
grpc_event
Definition: grpc_types.h:564
grpc_completion_queue
Definition: completion_queue.cc:347
cq_verifier_destroy
void cq_verifier_destroy(cq_verifier *v)
Definition: cq_verifier.cc:92
grpc_slice_buffer_reset_and_unref
GPRAPI void grpc_slice_buffer_reset_and_unref(grpc_slice_buffer *sb)
Definition: slice_buffer_api.cc:32
grpc.h
grpc_call
struct grpc_call grpc_call
Definition: grpc_types.h:70
gpr_atm_acq_load
#define gpr_atm_acq_load(p)
Definition: impl/codegen/atm_gcc_atomic.h:52
HTTP2_DETAIL_MSG
#define HTTP2_DETAIL_MSG(STATUS_CODE)
Definition: bad_server_response_test.cc:61
on_connect
static void on_connect(void *arg, grpc_endpoint *tcp, grpc_pollset *, grpc_tcp_server_acceptor *acceptor)
Definition: bad_server_response_test.cc:147
grpc_core::JoinHostPort
std::string JoinHostPort(absl::string_view host, int port)
Definition: host_port.cc:32
grpc_slice_from_static_buffer
GPRAPI grpc_slice grpc_slice_from_static_buffer(const void *source, size_t len)
Definition: slice/slice.cc:85
grpc_insecure_credentials_create
GRPCAPI grpc_channel_credentials * grpc_insecure_credentials_create()
Definition: core/lib/security/credentials/insecure/insecure_credentials.cc:64
done
struct tab * done
Definition: bloaty/third_party/zlib/examples/enough.c:176
grpc_op
Definition: grpc_types.h:640
test_tcp_server_poll
void test_tcp_server_poll(test_tcp_server *server, int milliseconds)
Definition: test_tcp_server.cc:87
arg
Definition: cmdline.cc:40
grpc_slice_from_static_string
GPRAPI grpc_slice grpc_slice_from_static_string(const char *source)
Definition: slice/slice.cc:89
cq_verifier_create
cq_verifier * cq_verifier_create(grpc_completion_queue *cq)
Definition: cq_verifier.cc:86
gpr_atm_rel_store
#define gpr_atm_rel_store(p, value)
Definition: impl/codegen/atm_gcc_atomic.h:54
tag
static void * tag(intptr_t t)
Definition: bad_server_response_test.cc:92
grpc_slice
Definition: include/grpc/impl/codegen/slice.h:65
on_write
static grpc_closure on_write
Definition: bad_server_response_test.cc:90
intptr_t
_W64 signed int intptr_t
Definition: stdint-msvc2008.h:118
cq_verifier
Definition: cq_verifier.cc:76
gpr_event_init
GPRAPI void gpr_event_init(gpr_event *ev)
Definition: sync.cc:54
grpc_endpoint_shutdown
void grpc_endpoint_shutdown(grpc_endpoint *ep, grpc_error_handle why)
Definition: endpoint.cc:49
host_port.h
tests.unit.test_common.test_server
def test_server(max_workers=10, reuse_port=False)
Definition: test_common.py:103
CQ_EXPECT_COMPLETION
#define CQ_EXPECT_COMPLETION(v, tag, success)
Definition: cq_verifier.h:58
slice_internal.h
GPR_ERROR
#define GPR_ERROR
Definition: include/grpc/impl/codegen/log.h:57
grpc_pick_unused_port_or_die
int grpc_pick_unused_port_or_die(void)
cleanup_rpc
static void cleanup_rpc()
Definition: bad_server_response_test.cc:257
grpc_endpoint_destroy
void grpc_endpoint_destroy(grpc_endpoint *ep)
Definition: endpoint.cc:53
gpr_now
GPRAPI gpr_timespec gpr_now(gpr_clock_type clock)
grpc_core::ExecCtx
Definition: exec_ctx.h:97
n_sec_deadline
static gpr_timespec n_sec_deadline(int seconds)
Definition: bad_server_response_test.cc:176
grpc_slice_buffer_init
GPRAPI void grpc_slice_buffer_init(grpc_slice_buffer *sb)
Definition: slice/slice_buffer.cc:116
rpc_state::response_payload
const char * response_payload
Definition: bad_server_response_test.cc:81
gpr_event_wait
GPRAPI void * gpr_event_wait(gpr_event *ev, gpr_timespec abs_deadline)
Definition: sync.cc:73
grpc_op::op
grpc_op_type op
Definition: grpc_types.h:642
GRPC_ERROR_CREATE_FROM_STATIC_STRING
#define GRPC_ERROR_CREATE_FROM_STATIC_STRING(desc)
Definition: error.h:291
grpc_op::grpc_op_data::grpc_op_send_initial_metadata::count
size_t count
Definition: grpc_types.h:653
rpc_state::cq
grpc_completion_queue * cq
Definition: bad_server_response_test.cc:71
grpc_op::grpc_op_data::grpc_op_recv_status_on_client::status_details
grpc_slice * status_details
Definition: grpc_types.h:703
details
static grpc_slice details
Definition: test/core/fling/client.cc:46
test_config.h
grpc_channel_credentials_release
GRPCAPI void grpc_channel_credentials_release(grpc_channel_credentials *creds)
Definition: credentials.cc:36
grpc_channel_create_call
GRPCAPI grpc_call * grpc_channel_create_call(grpc_channel *channel, grpc_call *parent_call, uint32_t propagation_mask, grpc_completion_queue *completion_queue, grpc_slice method, const grpc_slice *host, gpr_timespec deadline, void *reserved)
Definition: channel.cc:311
gpr_atm
intptr_t gpr_atm
Definition: impl/codegen/atm_gcc_atomic.h:32
grpc_slice_buffer_add
GPRAPI void grpc_slice_buffer_add(grpc_slice_buffer *sb, grpc_slice slice)
Definition: slice/slice_buffer.cc:170
gpr_event
Definition: impl/codegen/sync_generic.h:31
grpc_channel_create
GRPCAPI grpc_channel * grpc_channel_create(const char *target, grpc_channel_credentials *creds, const grpc_channel_args *args)
Definition: chttp2_connector.cc:366
grpc_slice_from_copied_buffer
GPRAPI grpc_slice grpc_slice_from_copied_buffer(const char *source, size_t len)
Definition: slice/slice.cc:170
GRPC_PROPAGATE_DEFAULTS
#define GRPC_PROPAGATE_DEFAULTS
Definition: propagation_bits.h:45
poll_server_until_read_done
static grpc_core::Thread * poll_server_until_read_done(test_tcp_server *server, gpr_event *signal_when_done)
Definition: bad_server_response_test.cc:294
cq_verifier.h
HTTP2_SETTINGS_FRAME
#define HTTP2_SETTINGS_FRAME
Definition: bad_server_response_test.cc:47
rpc_state::target
std::string target
Definition: bad_server_response_test.cc:70
gpr_time_add
GPRAPI gpr_timespec gpr_time_add(gpr_timespec a, gpr_timespec b)
Definition: src/core/lib/gpr/time.cc:135
server
Definition: examples/python/async_streaming/server.py:1
grpc_completion_queue_destroy
GRPCAPI void grpc_completion_queue_destroy(grpc_completion_queue *cq)
Definition: completion_queue.cc:1424
GRPC_OP_SEND_INITIAL_METADATA
@ GRPC_OP_SEND_INITIAL_METADATA
Definition: grpc_types.h:598
grpc_tcp_server_acceptor
Definition: tcp_server.h:36
exec_ctx
grpc_core::ExecCtx exec_ctx
Definition: end2end_binder_transport_test.cc:75
grpc_error_std_string
std::string grpc_error_std_string(grpc_error_handle error)
Definition: error.cc:944
handle_read
static void handle_read(void *, grpc_error_handle error)
Definition: bad_server_response_test.cc:116
UNPARSEABLE_RESP
#define UNPARSEABLE_RESP
Definition: bad_server_response_test.cc:59
alloc.h
grpc_op::grpc_op_data::recv_status_on_client
struct grpc_op::grpc_op_data::grpc_op_recv_status_on_client recv_status_on_client
HTTP1_RESP_400
#define HTTP1_RESP_400
Definition: bad_server_response_test.cc:41
rpc_state::response_payload_length
size_t response_payload_length
Definition: bad_server_response_test.cc:82
grpc::testing::TestEnvironment
Definition: test/core/util/test_config.h:54
thd.h
done_write
static void done_write(void *, grpc_error_handle error)
Definition: bad_server_response_test.cc:94
grpc_completion_queue_next
GRPCAPI grpc_event grpc_completion_queue_next(grpc_completion_queue *cq, gpr_timespec deadline, void *reserved)
Definition: completion_queue.cc:1133
cq_verify
void cq_verify(cq_verifier *v, int timeout_sec)
Definition: cq_verifier.cc:268
grpc_completion_queue_shutdown
GRPCAPI void grpc_completion_queue_shutdown(grpc_completion_queue *cq)
Definition: completion_queue.cc:1416
arg
struct arg arg
grpc_channel_destroy
GRPCAPI void grpc_channel_destroy(grpc_channel *channel)
Definition: channel.cc:437
state
Definition: bloaty/third_party/zlib/contrib/blast/blast.c:41
grpc_core::Thread
Definition: thd.h:43
rpc_state::incoming_data_length
size_t incoming_data_length
Definition: bad_server_response_test.cc:74
rpc_state::channel
grpc_channel * channel
Definition: bad_server_response_test.cc:72
grpc_channel
struct grpc_channel grpc_channel
Definition: grpc_types.h:62
channel_args.h
GRPC_STATUS_UNIMPLEMENTED
@ GRPC_STATUS_UNIMPLEMENTED
Definition: include/grpc/impl/codegen/status.h:124
grpc_slice_buffer_destroy_internal
void grpc_slice_buffer_destroy_internal(grpc_slice_buffer *sb)
Definition: slice/slice_buffer.cc:123
grpc_endpoint_write
void grpc_endpoint_write(grpc_endpoint *ep, grpc_slice_buffer *slices, grpc_closure *cb, void *arg, int max_frame_size)
Definition: endpoint.cc:30
GPR_DEBUG
#define GPR_DEBUG
Definition: include/grpc/impl/codegen/log.h:55
GRPC_STATUS_INTERNAL
@ GRPC_STATUS_INTERNAL
Definition: include/grpc/impl/codegen/status.h:129
grpc_slice_buffer
Definition: include/grpc/impl/codegen/slice.h:83
grpc_completion_queue_create_for_next
GRPCAPI grpc_completion_queue * grpc_completion_queue_create_for_next(void *reserved)
Definition: completion_queue_factory.cc:62
grpc_op::grpc_op_data::recv_initial_metadata
struct grpc_op::grpc_op_data::grpc_op_recv_initial_metadata recv_initial_metadata
SERVER_INCOMING_DATA_LENGTH_LOWER_THRESHOLD
#define SERVER_INCOMING_DATA_LENGTH_LOWER_THRESHOLD
Definition: bad_server_response_test.cc:67
gpr_timespec
Definition: gpr_types.h:50
grpc_event::type
grpc_completion_type type
Definition: grpc_types.h:566
grpc_init
GRPCAPI void grpc_init(void)
Definition: init.cc:146
grpc_error
Definition: error_internal.h:42
GRPC_OP_RECV_STATUS_ON_CLIENT
@ GRPC_OP_RECV_STATUS_ON_CLIENT
Definition: grpc_types.h:627
rpc_state::tcp
grpc_endpoint * tcp
Definition: bad_server_response_test.cc:77
grpc_op::grpc_op_data::grpc_op_recv_initial_metadata::recv_initial_metadata
grpc_metadata_array * recv_initial_metadata
Definition: grpc_types.h:685
GPR_CLOCK_REALTIME
@ GPR_CLOCK_REALTIME
Definition: gpr_types.h:39
grpc_endpoint_add_to_pollset
void grpc_endpoint_add_to_pollset(grpc_endpoint *ep, grpc_pollset *pollset)
Definition: endpoint.cc:35
grpc_pollset
Definition: bm_cq_multiple_threads.cc:37
poll_args
Definition: bad_server_response_test.cc:271
actually_poll_server
static void actually_poll_server(void *arg)
Definition: bad_server_response_test.cc:276
grpc_closure
Definition: closure.h:56
op
static grpc_op * op
Definition: test/core/fling/client.cc:47
ops
static grpc_op ops[6]
Definition: test/core/fling/client.cc:39
initial_metadata_recv
static grpc_metadata_array initial_metadata_recv
Definition: test/core/fling/client.cc:42
grpc_call_start_batch
GRPCAPI grpc_call_error grpc_call_start_batch(grpc_call *call, const grpc_op *ops, size_t nops, void *tag, void *reserved)
Definition: call.cc:1831
grpc_endpoint
Definition: endpoint.h:105
grpc_shutdown
GRPCAPI void grpc_shutdown(void)
Definition: init.cc:209
grpc_channel_credentials
Definition: src/core/lib/security/credentials/credentials.h:96
start_rpc
static void start_rpc(int target_port, grpc_status_code expected_status, const char *expected_detail)
Definition: bad_server_response_test.cc:181
grpc_core::ExecCtx::Get
static ExecCtx * Get()
Definition: exec_ctx.h:205
GRPC_OP_SEND_CLOSE_FROM_CLIENT
@ GRPC_OP_SEND_CLOSE_FROM_CLIENT
Definition: grpc_types.h:607
slice_string_helpers.h
i
uint64_t i
Definition: abseil-cpp/absl/container/btree_benchmark.cc:230
GRPC_STATUS_UNKNOWN
@ GRPC_STATUS_UNKNOWN
Definition: include/grpc/impl/codegen/status.h:40
grpc_metadata_array_init
GRPCAPI void grpc_metadata_array_init(grpc_metadata_array *array)
Definition: metadata_array.cc:30
gpr_time_from_seconds
GPRAPI gpr_timespec gpr_time_from_seconds(int64_t s, gpr_clock_type clock_type)
Definition: src/core/lib/gpr/time.cc:123
GRPC_ERROR_IS_NONE
#define GRPC_ERROR_IS_NONE(err)
Definition: error.h:241


grpc
Author(s):
autogenerated on Thu Mar 13 2025 02:58:35