Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(190)

Side by Side Diff: third_party/grpc/test/cpp/common/channel_arguments_test.cc

Issue 1932353002: Initial checkin of gRPC to third_party/ Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 /*
2 *
3 * Copyright 2015-2016, Google Inc.
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are
8 * met:
9 *
10 * * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * * Redistributions in binary form must reproduce the above
13 * copyright notice, this list of conditions and the following disclaimer
14 * in the documentation and/or other materials provided with the
15 * distribution.
16 * * Neither the name of Google Inc. nor the names of its
17 * contributors may be used to endorse or promote products derived from
18 * this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 *
32 */
33
34 #include <grpc++/support/channel_arguments.h>
35
36 #include <grpc/grpc.h>
37 #include <gtest/gtest.h>
38
39 namespace grpc {
40 namespace testing {
41
42 class ChannelArgumentsTest : public ::testing::Test {
43 protected:
44 ChannelArgumentsTest()
45 : pointer_vtable_({&ChannelArguments::PointerVtableMembers::Copy,
46 &ChannelArguments::PointerVtableMembers::Destroy,
47 &ChannelArguments::PointerVtableMembers::Compare}) {}
48
49 void SetChannelArgs(const ChannelArguments& channel_args,
50 grpc_channel_args* args) {
51 channel_args.SetChannelArgs(args);
52 }
53
54 grpc::string GetDefaultUserAgentPrefix() {
55 std::ostringstream user_agent_prefix;
56 user_agent_prefix << "grpc-c++/" << grpc_version_string();
57 return user_agent_prefix.str();
58 }
59
60 void VerifyDefaultChannelArgs() {
61 grpc_channel_args args;
62 SetChannelArgs(channel_args_, &args);
63 EXPECT_EQ(static_cast<size_t>(1), args.num_args);
64 EXPECT_STREQ(GRPC_ARG_PRIMARY_USER_AGENT_STRING, args.args[0].key);
65 EXPECT_EQ(GetDefaultUserAgentPrefix(),
66 grpc::string(args.args[0].value.string));
67 }
68
69 bool HasArg(grpc_arg expected_arg) {
70 grpc_channel_args args;
71 SetChannelArgs(channel_args_, &args);
72 for (size_t i = 0; i < args.num_args; i++) {
73 const grpc_arg& arg = args.args[i];
74 if (arg.type == expected_arg.type &&
75 grpc::string(arg.key) == expected_arg.key) {
76 if (arg.type == GRPC_ARG_INTEGER) {
77 return arg.value.integer == expected_arg.value.integer;
78 } else if (arg.type == GRPC_ARG_STRING) {
79 return grpc::string(arg.value.string) == expected_arg.value.string;
80 } else if (arg.type == GRPC_ARG_POINTER) {
81 return arg.value.pointer.p == expected_arg.value.pointer.p &&
82 arg.value.pointer.vtable->copy ==
83 expected_arg.value.pointer.vtable->copy &&
84 arg.value.pointer.vtable->destroy ==
85 expected_arg.value.pointer.vtable->destroy;
86 }
87 }
88 }
89 return false;
90 }
91 grpc_arg_pointer_vtable pointer_vtable_;
92 ChannelArguments channel_args_;
93 };
94
95 TEST_F(ChannelArgumentsTest, SetInt) {
96 VerifyDefaultChannelArgs();
97 grpc::string key0("key0");
98 grpc_arg arg0;
99 arg0.type = GRPC_ARG_INTEGER;
100 arg0.key = const_cast<char*>(key0.c_str());
101 arg0.value.integer = 0;
102 grpc::string key1("key1");
103 grpc_arg arg1;
104 arg1.type = GRPC_ARG_INTEGER;
105 arg1.key = const_cast<char*>(key1.c_str());
106 arg1.value.integer = 1;
107
108 grpc::string arg_key0(key0);
109 channel_args_.SetInt(arg_key0, arg0.value.integer);
110 // Clear key early to make sure channel_args takes a copy
111 arg_key0.clear();
112 EXPECT_TRUE(HasArg(arg0));
113
114 grpc::string arg_key1(key1);
115 channel_args_.SetInt(arg_key1, arg1.value.integer);
116 arg_key1.clear();
117 EXPECT_TRUE(HasArg(arg0));
118 EXPECT_TRUE(HasArg(arg1));
119 }
120
121 TEST_F(ChannelArgumentsTest, SetString) {
122 VerifyDefaultChannelArgs();
123 grpc::string key0("key0");
124 grpc::string val0("val0");
125 grpc_arg arg0;
126 arg0.type = GRPC_ARG_STRING;
127 arg0.key = const_cast<char*>(key0.c_str());
128 arg0.value.string = const_cast<char*>(val0.c_str());
129 grpc::string key1("key1");
130 grpc::string val1("val1");
131 grpc_arg arg1;
132 arg1.type = GRPC_ARG_STRING;
133 arg1.key = const_cast<char*>(key1.c_str());
134 arg1.value.string = const_cast<char*>(val1.c_str());
135
136 grpc::string key(key0);
137 grpc::string val(val0);
138 channel_args_.SetString(key, val);
139 // Clear key/val early to make sure channel_args takes a copy
140 key = "";
141 val = "";
142 EXPECT_TRUE(HasArg(arg0));
143
144 key = key1;
145 val = val1;
146 channel_args_.SetString(key, val);
147 // Clear key/val early to make sure channel_args takes a copy
148 key = "";
149 val = "";
150 EXPECT_TRUE(HasArg(arg0));
151 EXPECT_TRUE(HasArg(arg1));
152 }
153
154 TEST_F(ChannelArgumentsTest, SetPointer) {
155 VerifyDefaultChannelArgs();
156 grpc::string key0("key0");
157 grpc_arg arg0;
158 arg0.type = GRPC_ARG_POINTER;
159 arg0.key = const_cast<char*>(key0.c_str());
160 arg0.value.pointer.p = &key0;
161 arg0.value.pointer.vtable = &pointer_vtable_;
162
163 grpc::string key(key0);
164 channel_args_.SetPointer(key, arg0.value.pointer.p);
165 EXPECT_TRUE(HasArg(arg0));
166 }
167
168 TEST_F(ChannelArgumentsTest, SetUserAgentPrefix) {
169 VerifyDefaultChannelArgs();
170 grpc::string prefix("prefix");
171 grpc::string whole_prefix = prefix + " " + GetDefaultUserAgentPrefix();
172 grpc_arg arg0;
173 arg0.type = GRPC_ARG_STRING;
174 arg0.key = const_cast<char*>(GRPC_ARG_PRIMARY_USER_AGENT_STRING);
175 arg0.value.string = const_cast<char*>(whole_prefix.c_str());
176
177 channel_args_.SetUserAgentPrefix(prefix);
178 EXPECT_TRUE(HasArg(arg0));
179 }
180
181 } // namespace testing
182 } // namespace grpc
183
184 int main(int argc, char** argv) {
185 ::testing::InitGoogleTest(&argc, argv);
186 return RUN_ALL_TESTS();
187 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698