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.
153 lines
5.8 KiB
153 lines
5.8 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. |
|
* |
|
*/ |
|
|
|
#ifndef GRPC_TEST_CPP_INTEROP_INTEROP_CLIENT_H |
|
#define GRPC_TEST_CPP_INTEROP_INTEROP_CLIENT_H |
|
|
|
#include <memory> |
|
|
|
#include <grpc/grpc.h> |
|
#include <grpcpp/channel.h> |
|
#include "src/proto/grpc/testing/messages.pb.h" |
|
#include "src/proto/grpc/testing/test.grpc.pb.h" |
|
|
|
namespace grpc { |
|
namespace testing { |
|
|
|
// Function pointer for custom checks. |
|
typedef std::function<void(const InteropClientContextInspector&, |
|
const SimpleRequest*, const SimpleResponse*)> |
|
CheckerFn; |
|
|
|
typedef std::function<std::shared_ptr<Channel>(void)> ChannelCreationFunc; |
|
|
|
class InteropClient { |
|
public: |
|
/// If new_stub_every_test_case is true, a new TestService::Stub object is |
|
/// created for every test case |
|
/// If do_not_abort_on_transient_failures is true, abort() is not called in |
|
/// case of transient failures (like connection failures) |
|
explicit InteropClient(ChannelCreationFunc channel_creation_func, |
|
bool new_stub_every_test_case, |
|
bool do_not_abort_on_transient_failures); |
|
~InteropClient() {} |
|
|
|
void Reset(const std::shared_ptr<Channel>& channel); |
|
|
|
bool DoEmpty(); |
|
bool DoLargeUnary(); |
|
bool DoServerCompressedUnary(); |
|
bool DoClientCompressedUnary(); |
|
bool DoPingPong(); |
|
bool DoHalfDuplex(); |
|
bool DoRequestStreaming(); |
|
bool DoResponseStreaming(); |
|
bool DoServerCompressedStreaming(); |
|
bool DoClientCompressedStreaming(); |
|
bool DoResponseStreamingWithSlowConsumer(); |
|
bool DoCancelAfterBegin(); |
|
bool DoCancelAfterFirstResponse(); |
|
bool DoTimeoutOnSleepingServer(); |
|
bool DoEmptyStream(); |
|
bool DoStatusWithMessage(); |
|
bool DoCustomMetadata(); |
|
bool DoUnimplementedMethod(); |
|
bool DoUnimplementedService(); |
|
bool DoCacheableUnary(); |
|
// all requests are sent to one server despite multiple servers are resolved |
|
bool DoPickFirstUnary(); |
|
|
|
// The following interop test are not yet part of the interop spec, and are |
|
// not implemented cross-language. They are considered experimental for now, |
|
// but at some point in the future, might be codified and implemented in all |
|
// languages |
|
bool DoChannelSoakTest(int32_t soak_iterations, int32_t max_failures, |
|
int64_t max_acceptable_per_iteration_latency_ms, |
|
int32_t overall_timeout_seconds); |
|
bool DoRpcSoakTest(int32_t soak_iterations, int32_t max_failures, |
|
int64_t max_acceptable_per_iteration_latency_ms, |
|
int32_t overall_timeout_seconds); |
|
bool DoLongLivedChannelTest(int32_t soak_iterations, |
|
int32_t iteration_interval); |
|
|
|
// Auth tests. |
|
// username is a string containing the user email |
|
bool DoJwtTokenCreds(const std::string& username); |
|
bool DoComputeEngineCreds(const std::string& default_service_account, |
|
const std::string& oauth_scope); |
|
// username the GCE default service account email |
|
bool DoOauth2AuthToken(const std::string& username, |
|
const std::string& oauth_scope); |
|
// username is a string containing the user email |
|
bool DoPerRpcCreds(const std::string& json_key); |
|
// default_service_account is the GCE default service account email |
|
bool DoGoogleDefaultCredentials(const std::string& default_service_account); |
|
|
|
private: |
|
class ServiceStub { |
|
public: |
|
// If new_stub_every_call = true, pointer to a new instance of |
|
// TestServce::Stub is returned by Get() everytime it is called |
|
ServiceStub(ChannelCreationFunc channel_creation_func, |
|
bool new_stub_every_call); |
|
|
|
TestService::Stub* Get(); |
|
UnimplementedService::Stub* GetUnimplementedServiceStub(); |
|
|
|
// forces channel to be recreated. |
|
void ResetChannel(); |
|
|
|
private: |
|
ChannelCreationFunc channel_creation_func_; |
|
std::unique_ptr<TestService::Stub> stub_; |
|
std::unique_ptr<UnimplementedService::Stub> unimplemented_service_stub_; |
|
std::shared_ptr<Channel> channel_; |
|
bool new_stub_every_call_; // If true, a new stub is returned by every |
|
// Get() call |
|
}; |
|
|
|
bool PerformLargeUnary(SimpleRequest* request, SimpleResponse* response); |
|
|
|
/// Run \a custom_check_fn as an additional check. |
|
bool PerformLargeUnary(SimpleRequest* request, SimpleResponse* response, |
|
const CheckerFn& custom_checks_fn); |
|
bool AssertStatusOk(const Status& s, |
|
const std::string& optional_debug_string); |
|
bool AssertStatusCode(const Status& s, StatusCode expected_code, |
|
const std::string& optional_debug_string); |
|
bool TransientFailureOrAbort(); |
|
|
|
std::tuple<bool, int32_t, std::string> PerformOneSoakTestIteration( |
|
const bool reset_channel, |
|
const int32_t max_acceptable_per_iteration_latency_ms); |
|
|
|
void PerformSoakTest(const bool reset_channel_per_iteration, |
|
const int32_t soak_iterations, |
|
const int32_t max_failures, |
|
const int32_t max_acceptable_per_iteration_latency_ms, |
|
const int32_t overall_timeout_seconds); |
|
|
|
ServiceStub serviceStub_; |
|
/// If true, abort() is not called for transient failures |
|
bool do_not_abort_on_transient_failures_; |
|
}; |
|
|
|
} // namespace testing |
|
} // namespace grpc |
|
|
|
#endif // GRPC_TEST_CPP_INTEROP_INTEROP_CLIENT_H
|
|
|