sequential_connectivity_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 <vector>
20 
21 #include <grpc/grpc.h>
22 #include <grpc/grpc_security.h>
24 #include <grpc/support/alloc.h>
25 #include <grpc/support/log.h>
26 
29 #include "src/core/lib/gprpp/thd.h"
32 #include "test/core/util/port.h"
34 
35 #define CA_CERT_PATH "src/core/tsi/test_creds/ca.pem"
36 #define SERVER_CERT_PATH "src/core/tsi/test_creds/server1.pem"
37 #define SERVER_KEY_PATH "src/core/tsi/test_creds/server1.key"
38 
39 typedef struct test_fixture {
40  const char* name;
41  void (*add_server_port)(grpc_server* server, const char* addr);
42  // Have the creds here so all the channels will share the same one to enabled
43  // subchannel sharing if needed.
45 } test_fixture;
46 
47 #define NUM_CONNECTIONS 100
48 
49 typedef struct {
53 
54 static void server_thread_func(void* args) {
55  server_thread_args* a = static_cast<server_thread_args*>(args);
57  a->cq, gpr_inf_future(GPR_CLOCK_REALTIME), nullptr);
59  GPR_ASSERT(ev.tag == nullptr);
60  GPR_ASSERT(ev.success == true);
61 }
62 
65  bool share_subchannel) {
66  grpc_channel* channel = nullptr;
67  std::vector<grpc_arg> args;
69  const_cast<char*>(GRPC_ARG_USE_LOCAL_SUBCHANNEL_POOL),
70  !share_subchannel));
71  if (creds != nullptr) {
73  const_cast<char*>(GRPC_SSL_TARGET_NAME_OVERRIDE_ARG),
74  const_cast<char*>("foo.test.google.fr")));
75  }
76  grpc_channel_args channel_args = {args.size(), args.data()};
77  if (creds != nullptr) {
78  channel = grpc_channel_create(addr, creds, &channel_args);
79  } else {
80  grpc_channel_credentials* insecure_creds =
82  channel = grpc_channel_create(addr, insecure_creds, &channel_args);
83  grpc_channel_credentials_release(insecure_creds);
84  }
85  return channel;
86 }
87 
88 static void run_test(const test_fixture* fixture, bool share_subchannel) {
89  gpr_log(GPR_INFO, "TEST: %s sharing subchannel: %d", fixture->name,
90  share_subchannel);
91 
94 
95  grpc_server* server = grpc_server_create(nullptr, nullptr);
96  fixture->add_server_port(server, addr.c_str());
97  grpc_completion_queue* server_cq =
99  grpc_server_register_completion_queue(server, server_cq, nullptr);
101 
102  server_thread_args sta = {server, server_cq};
103  grpc_core::Thread server_thread("grpc_server", server_thread_func, &sta);
104  server_thread.Start();
105 
107  grpc_channel* channels[NUM_CONNECTIONS];
108  for (size_t i = 0; i < NUM_CONNECTIONS; i++) {
109  channels[i] =
110  create_test_channel(addr.c_str(), fixture->creds, share_subchannel);
111 
112  gpr_timespec connect_deadline = grpc_timeout_seconds_to_deadline(30);
114  while ((state = grpc_channel_check_connectivity_state(channels[i], 1)) !=
117  connect_deadline, cq, nullptr);
120  /* check that the watcher from "watch state" was free'd */
122  0);
124  GPR_ASSERT(ev.tag == nullptr);
125  GPR_ASSERT(ev.success == true);
126  }
127  }
128 
129  grpc_server_shutdown_and_notify(server, server_cq, nullptr);
130  server_thread.Join();
131 
134 
135  while (grpc_completion_queue_next(server_cq,
138  }
140  nullptr)
142  }
143 
144  for (size_t i = 0; i < NUM_CONNECTIONS; i++) {
145  grpc_channel_destroy(channels[i]);
146  }
147 
151 }
152 
153 static void insecure_test_add_port(grpc_server* server, const char* addr) {
154  grpc_server_credentials* server_creds =
156  grpc_server_add_http2_port(server, addr, server_creds);
157  grpc_server_credentials_release(server_creds);
158 }
159 
160 static void secure_test_add_port(grpc_server* server, const char* addr) {
161  grpc_slice cert_slice, key_slice;
163  "load_file", grpc_load_file(SERVER_CERT_PATH, 1, &cert_slice)));
164  GPR_ASSERT(GRPC_LOG_IF_ERROR("load_file",
165  grpc_load_file(SERVER_KEY_PATH, 1, &key_slice)));
166  const char* server_cert =
167  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(cert_slice);
168  const char* server_key =
169  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(key_slice);
170  grpc_ssl_pem_key_cert_pair pem_key_cert_pair = {server_key, server_cert};
172  nullptr, &pem_key_cert_pair, 1, 0, nullptr);
173  grpc_slice_unref(cert_slice);
174  grpc_slice_unref(key_slice);
177 }
178 
179 int main(int argc, char** argv) {
180  grpc::testing::TestEnvironment env(&argc, argv);
181  grpc_init();
182 
183  const test_fixture insecure_test = {
184  "insecure",
186  nullptr,
187  };
188  run_test(&insecure_test, /*share_subchannel=*/true);
189  run_test(&insecure_test, /*share_subchannel=*/false);
190 
191  grpc_slice ca_slice;
192  GPR_ASSERT(GRPC_LOG_IF_ERROR("load_file",
193  grpc_load_file(CA_CERT_PATH, 1, &ca_slice)));
194  const char* test_root_cert =
195  reinterpret_cast<const char*> GRPC_SLICE_START_PTR(ca_slice);
196  grpc_channel_credentials* ssl_creds =
197  grpc_ssl_credentials_create(test_root_cert, nullptr, nullptr, nullptr);
198  grpc_slice_unref(ca_slice);
199  const test_fixture secure_test = {
200  "secure",
202  ssl_creds,
203  };
204  run_test(&secure_test, /*share_subchannel=*/true);
205  run_test(&secure_test, /*share_subchannel=*/false);
207 
208  grpc_shutdown();
209 }
grpc_slice_unref
GPRAPI void grpc_slice_unref(grpc_slice s)
Definition: slice_api.cc:32
GPR_INFO
#define GPR_INFO
Definition: include/grpc/impl/codegen/log.h:56
GRPC_CHANNEL_READY
@ GRPC_CHANNEL_READY
Definition: include/grpc/impl/codegen/connectivity_state.h:36
grpc_timeout_seconds_to_deadline
gpr_timespec grpc_timeout_seconds_to_deadline(int64_t time_s)
Definition: test/core/util/test_config.cc:81
log.h
port.h
grpc_load_file
grpc_error_handle grpc_load_file(const char *filename, int add_null_terminator, grpc_slice *output)
Definition: load_file.cc:33
generate.env
env
Definition: generate.py:37
load_file.h
test_fixture::name
const char * name
Definition: num_external_connectivity_watchers_test.cc:36
server_thread
void server_thread(void *vargs)
Definition: concurrent_connectivity_test.cc:107
grpc_channel_check_connectivity_state
GRPCAPI grpc_connectivity_state grpc_channel_check_connectivity_state(grpc_channel *channel, int try_to_connect)
Definition: channel_connectivity.cc:56
testing::internal::string
::std::string string
Definition: bloaty/third_party/protobuf/third_party/googletest/googletest/include/gtest/internal/gtest-port.h:881
insecure_test_add_port
static void insecure_test_add_port(grpc_server *server, const char *addr)
Definition: sequential_connectivity_test.cc:153
GRPC_QUEUE_SHUTDOWN
@ GRPC_QUEUE_SHUTDOWN
Definition: grpc_types.h:554
GRPC_OP_COMPLETE
@ GRPC_OP_COMPLETE
Definition: grpc_types.h:558
SERVER_CERT_PATH
#define SERVER_CERT_PATH
Definition: sequential_connectivity_test.cc:36
grpc_server_create
GRPCAPI grpc_server * grpc_server_create(const grpc_channel_args *args, void *reserved)
Definition: src/core/lib/surface/server.cc:1456
grpc_server_register_completion_queue
GRPCAPI void grpc_server_register_completion_queue(grpc_server *server, grpc_completion_queue *cq, void *reserved)
Definition: src/core/lib/surface/server.cc:1466
gpr_inf_future
GPRAPI gpr_timespec gpr_inf_future(gpr_clock_type type)
Definition: src/core/lib/gpr/time.cc:55
test_fixture::creds
grpc_channel_credentials * creds
Definition: sequential_connectivity_test.cc:44
GRPC_ARG_USE_LOCAL_SUBCHANNEL_POOL
#define GRPC_ARG_USE_LOCAL_SUBCHANNEL_POOL
Definition: grpc_types.h:443
GRPC_LOG_IF_ERROR
#define GRPC_LOG_IF_ERROR(what, error)
Definition: error.h:398
grpc_channel_arg_string_create
grpc_arg grpc_channel_arg_string_create(char *name, char *value)
Definition: channel_args.cc:476
a
int a
Definition: abseil-cpp/absl/container/internal/hash_policy_traits_test.cc:88
secure_test_add_port
static void secure_test_add_port(grpc_server *server, const char *addr)
Definition: sequential_connectivity_test.cc:160
run_test
static void run_test(const test_fixture *fixture, bool share_subchannel)
Definition: sequential_connectivity_test.cc:88
grpc_security.h
grpc_channel_args
Definition: grpc_types.h:132
grpc_connectivity_state
grpc_connectivity_state
Definition: include/grpc/impl/codegen/connectivity_state.h:30
grpc_ssl_credentials_create
GRPCAPI grpc_channel_credentials * grpc_ssl_credentials_create(const char *pem_root_certs, grpc_ssl_pem_key_cert_pair *pem_key_cert_pair, const verify_peer_options *verify_options, void *reserved)
Definition: ssl_credentials.cc:132
server_thread_args::server
grpc_server * server
Definition: sequential_connectivity_test.cc:50
grpc_types.h
grpc_insecure_server_credentials_create
GRPCAPI grpc_server_credentials * grpc_insecure_server_credentials_create()
Definition: core/lib/security/credentials/insecure/insecure_credentials.cc:71
server
std::unique_ptr< Server > server
Definition: channelz_service_test.cc:330
test_fixture
Definition: num_external_connectivity_watchers_test.cc:35
channel
wrapped_grpc_channel * channel
Definition: src/php/ext/grpc/call.h:33
asyncio_get_stats.args
args
Definition: asyncio_get_stats.py:40
server_thread_func
static void server_thread_func(void *args)
Definition: sequential_connectivity_test.cc:54
GPR_ASSERT
#define GPR_ASSERT(x)
Definition: include/grpc/impl/codegen/log.h:94
grpc_channel_num_external_connectivity_watchers
GRPCAPI int grpc_channel_num_external_connectivity_watchers(grpc_channel *channel)
Definition: channel_connectivity.cc:79
GRPC_SSL_TARGET_NAME_OVERRIDE_ARG
#define GRPC_SSL_TARGET_NAME_OVERRIDE_ARG
Definition: grpc_types.h:278
secure_test
static const test_fixture secure_test
Definition: num_external_connectivity_watchers_test.cc:195
fixture
static const char fixture[]
Definition: test-fs-copyfile.c:36
grpc_ssl_server_credentials_create
GRPCAPI grpc_server_credentials * grpc_ssl_server_credentials_create(const char *pem_root_certs, grpc_ssl_pem_key_cert_pair *pem_key_cert_pairs, size_t num_key_cert_pairs, int force_client_auth, void *reserved)
Definition: ssl_credentials.cc:319
grpc_server_credentials_release
GRPCAPI void grpc_server_credentials_release(grpc_server_credentials *creds)
Definition: credentials.cc:95
CA_CERT_PATH
#define CA_CERT_PATH
Definition: sequential_connectivity_test.cc:35
grpc_server_add_http2_port
GRPCAPI int grpc_server_add_http2_port(grpc_server *server, const char *addr, grpc_server_credentials *creds)
Definition: chttp2_server.cc:1029
insecure_test
static const test_fixture insecure_test
Definition: num_external_connectivity_watchers_test.cc:166
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
SERVER_KEY_PATH
#define SERVER_KEY_PATH
Definition: sequential_connectivity_test.cc:37
grpc.h
grpc_core::JoinHostPort
std::string JoinHostPort(absl::string_view host, int port)
Definition: host_port.cc:32
grpc_insecure_credentials_create
GRPCAPI grpc_channel_credentials * grpc_insecure_credentials_create()
Definition: core/lib/security/credentials/insecure/insecure_credentials.cc:64
GRPC_SLICE_START_PTR
#define GRPC_SLICE_START_PTR(slice)
Definition: include/grpc/impl/codegen/slice.h:101
grpc_slice
Definition: include/grpc/impl/codegen/slice.h:65
grpc_server
struct grpc_server grpc_server
Definition: grpc_types.h:65
grpc_server_destroy
GRPCAPI void grpc_server_destroy(grpc_server *server)
Definition: src/core/lib/surface/server.cc:1519
host_port.h
grpc_pick_unused_port_or_die
int grpc_pick_unused_port_or_die(void)
server_thread_args::cq
grpc_completion_queue * cq
Definition: sequential_connectivity_test.cc:51
create_test_channel
static grpc_channel * create_test_channel(const char *addr, grpc_channel_credentials *creds, bool share_subchannel)
Definition: sequential_connectivity_test.cc:63
test_config.h
grpc_channel_credentials_release
GRPCAPI void grpc_channel_credentials_release(grpc_channel_credentials *creds)
Definition: credentials.cc:36
grpc_server_credentials
Definition: src/core/lib/security/credentials/credentials.h:259
test_fixture
struct test_fixture test_fixture
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_channel_arg_integer_create
grpc_arg grpc_channel_arg_integer_create(char *name, int value)
Definition: channel_args.cc:484
main
int main(int argc, char **argv)
Definition: sequential_connectivity_test.cc:179
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
server_thread_args
Definition: sequential_connectivity_test.cc:49
alloc.h
grpc::testing::TestEnvironment
Definition: test/core/util/test_config.h:54
thd.h
grpc_server_shutdown_and_notify
GRPCAPI void grpc_server_shutdown_and_notify(grpc_server *server, grpc_completion_queue *cq, void *tag)
Definition: src/core/lib/surface/server.cc:1503
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
grpc_completion_queue_shutdown
GRPCAPI void grpc_completion_queue_shutdown(grpc_completion_queue *cq)
Definition: completion_queue.cc:1416
NUM_CONNECTIONS
#define NUM_CONNECTIONS
Definition: sequential_connectivity_test.cc:47
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
exec_ctx.h
grpc_core::Thread
Definition: thd.h:43
grpc_channel
struct grpc_channel grpc_channel
Definition: grpc_types.h:62
channel_args.h
grpc_channel_watch_connectivity_state
GRPCAPI void grpc_channel_watch_connectivity_state(grpc_channel *channel, grpc_connectivity_state last_observed_state, gpr_timespec deadline, grpc_completion_queue *cq, void *tag)
Definition: channel_connectivity.cc:227
test_root_cert
const char test_root_cert[]
grpc_completion_queue_create_for_next
GRPCAPI grpc_completion_queue * grpc_completion_queue_create_for_next(void *reserved)
Definition: completion_queue_factory.cc:62
asyncio_get_stats.type
type
Definition: asyncio_get_stats.py:37
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_server_start
GRPCAPI void grpc_server_start(grpc_server *server)
Definition: src/core/lib/surface/server.cc:1497
GPR_CLOCK_REALTIME
@ GPR_CLOCK_REALTIME
Definition: gpr_types.h:39
test_fixture::add_server_port
void(* add_server_port)(grpc_server *server, const char *addr)
Definition: sequential_connectivity_test.cc:41
grpc_event::success
int success
Definition: grpc_types.h:572
grpc_shutdown
GRPCAPI void grpc_shutdown(void)
Definition: init.cc:209
grpc_ssl_pem_key_cert_pair
Definition: grpc_security.h:173
grpc_channel_credentials
Definition: src/core/lib/security/credentials/credentials.h:96
addr
struct sockaddr_in addr
Definition: libuv/docs/code/tcp-echo-server/main.c:10
grpc_event::tag
void * tag
Definition: grpc_types.h:576
cq
static grpc_completion_queue * cq
Definition: test/core/fling/client.cc:37
i
uint64_t i
Definition: abseil-cpp/absl/container/btree_benchmark.cc:230
state
static struct rpc_state state
Definition: bad_server_response_test.cc:87


grpc
Author(s):
autogenerated on Thu Mar 13 2025 03:01:16