mirror of https://github.com/grpc/grpc.git
The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#)
https://grpc.io/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
162 lines
5.4 KiB
162 lines
5.4 KiB
// |
|
// |
|
// 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. |
|
// |
|
// |
|
|
|
#include "src/core/lib/channel/channelz.h" |
|
|
|
#include <string> |
|
|
|
#include "gmock/gmock.h" |
|
#include "gtest/gtest.h" |
|
|
|
#include <grpc/grpc.h> |
|
#include <grpc/status.h> |
|
|
|
#include "src/core/lib/channel/channel_args.h" |
|
#include "src/core/lib/gprpp/time.h" |
|
#include "src/core/lib/surface/channel.h" |
|
#include "src/core/lib/surface/server.h" |
|
#include "test/core/end2end/end2end_tests.h" |
|
|
|
using testing::HasSubstr; |
|
using testing::Not; |
|
|
|
namespace grpc_core { |
|
namespace { |
|
|
|
void RunOneRequest(CoreEnd2endTest& test, bool request_is_success) { |
|
auto c = test.NewClientCall("/foo").Timeout(Duration::Seconds(5)).Create(); |
|
CoreEnd2endTest::IncomingMetadata server_initial_metadata; |
|
CoreEnd2endTest::IncomingStatusOnClient server_status; |
|
c.NewBatch(1) |
|
.SendInitialMetadata({}) |
|
.SendCloseFromClient() |
|
.RecvInitialMetadata(server_initial_metadata) |
|
.RecvStatusOnClient(server_status); |
|
auto s = test.RequestCall(101); |
|
test.Expect(101, true); |
|
test.Step(); |
|
CoreEnd2endTest::IncomingCloseOnServer client_close; |
|
s.NewBatch(102) |
|
.SendInitialMetadata({}) |
|
.SendStatusFromServer( |
|
request_is_success ? GRPC_STATUS_OK : GRPC_STATUS_UNIMPLEMENTED, |
|
"xyz", {}) |
|
.RecvCloseOnServer(client_close); |
|
test.Expect(102, true); |
|
test.Expect(1, true); |
|
test.Step(); |
|
EXPECT_EQ(server_status.message(), "xyz"); |
|
EXPECT_EQ(s.method(), "/foo"); |
|
} |
|
|
|
TEST_P(CoreEnd2endTest, Channelz) { |
|
auto args = ChannelArgs() |
|
.Set(GRPC_ARG_MAX_CHANNEL_TRACE_EVENT_MEMORY_PER_NODE, 0) |
|
.Set(GRPC_ARG_ENABLE_CHANNELZ, true); |
|
InitServer(args); |
|
InitClient(args); |
|
|
|
channelz::ChannelNode* channelz_channel = |
|
grpc_channel_get_channelz_node(client()); |
|
ASSERT_NE(channelz_channel, nullptr); |
|
|
|
channelz::ServerNode* channelz_server = |
|
Server::FromC(server())->channelz_node(); |
|
ASSERT_NE(channelz_server, nullptr); |
|
|
|
std::string json = channelz_channel->RenderJsonString(); |
|
// nothing is present yet |
|
EXPECT_THAT(json, Not(HasSubstr("\"callsStarted\""))); |
|
EXPECT_THAT(json, Not(HasSubstr("\"callsFailed\""))); |
|
EXPECT_THAT(json, Not(HasSubstr("\"callsSucceeded\""))); |
|
|
|
// one successful request |
|
RunOneRequest(*this, true); |
|
|
|
json = channelz_channel->RenderJsonString(); |
|
EXPECT_THAT(json, HasSubstr("\"callsStarted\":\"1\"")); |
|
EXPECT_THAT(json, HasSubstr("\"callsSucceeded\":\"1\"")); |
|
|
|
// one failed request |
|
RunOneRequest(*this, false); |
|
|
|
json = channelz_channel->RenderJsonString(); |
|
EXPECT_THAT(json, HasSubstr("\"callsStarted\":\"2\"")); |
|
EXPECT_THAT(json, HasSubstr("\"callsFailed\":\"1\"")); |
|
EXPECT_THAT(json, HasSubstr("\"callsSucceeded\":\"1\"")); |
|
// channel tracing is not enabled, so these should not be preset. |
|
EXPECT_THAT(json, Not(HasSubstr("\"trace\""))); |
|
EXPECT_THAT(json, Not(HasSubstr("\"description\":\"Channel created\""))); |
|
EXPECT_THAT(json, Not(HasSubstr("\"severity\":\"CT_INFO\""))); |
|
|
|
json = channelz_server->RenderJsonString(); |
|
EXPECT_THAT(json, HasSubstr("\"callsStarted\":\"2\"")); |
|
EXPECT_THAT(json, HasSubstr("\"callsFailed\":\"1\"")); |
|
EXPECT_THAT(json, HasSubstr("\"callsSucceeded\":\"1\"")); |
|
// channel tracing is not enabled, so these should not be preset. |
|
EXPECT_THAT(json, Not(HasSubstr("\"trace\""))); |
|
EXPECT_THAT(json, Not(HasSubstr("\"description\":\"Channel created\""))); |
|
EXPECT_THAT(json, Not(HasSubstr("\"severity\":\"CT_INFO\""))); |
|
|
|
json = channelz_server->RenderServerSockets(0, 100); |
|
EXPECT_THAT(json, HasSubstr("\"end\":true")); |
|
} |
|
|
|
TEST_P(CoreEnd2endTest, ChannelzWithChannelTrace) { |
|
auto args = |
|
ChannelArgs() |
|
.Set(GRPC_ARG_MAX_CHANNEL_TRACE_EVENT_MEMORY_PER_NODE, 1024 * 1024) |
|
.Set(GRPC_ARG_ENABLE_CHANNELZ, true); |
|
InitServer(args); |
|
InitClient(args); |
|
|
|
channelz::ChannelNode* channelz_channel = |
|
grpc_channel_get_channelz_node(client()); |
|
ASSERT_NE(channelz_channel, nullptr); |
|
|
|
channelz::ServerNode* channelz_server = |
|
Server::FromC(server())->channelz_node(); |
|
ASSERT_NE(channelz_server, nullptr); |
|
|
|
RunOneRequest(*this, true); |
|
|
|
std::string json = channelz_channel->RenderJsonString(); |
|
EXPECT_THAT(json, HasSubstr("\"trace\"")); |
|
EXPECT_THAT(json, HasSubstr("\"description\":\"Channel created\"")); |
|
EXPECT_THAT(json, HasSubstr("\"severity\":\"CT_INFO\"")); |
|
|
|
json = channelz_server->RenderJsonString(); |
|
EXPECT_THAT(json, HasSubstr("\"trace\"")); |
|
EXPECT_THAT(json, HasSubstr("\"description\":\"Server created\"")); |
|
EXPECT_THAT(json, HasSubstr("\"severity\":\"CT_INFO\"")); |
|
} |
|
|
|
TEST_P(CoreEnd2endTest, ChannelzDisabled) { |
|
auto args = ChannelArgs() |
|
.Set(GRPC_ARG_MAX_CHANNEL_TRACE_EVENT_MEMORY_PER_NODE, 0) |
|
.Set(GRPC_ARG_ENABLE_CHANNELZ, false); |
|
InitServer(args); |
|
InitClient(args); |
|
channelz::ChannelNode* channelz_channel = |
|
grpc_channel_get_channelz_node(client()); |
|
EXPECT_EQ(channelz_channel, nullptr); |
|
RunOneRequest(*this, true); |
|
} |
|
|
|
} // namespace |
|
} // namespace grpc_core
|
|
|