|
|
|
/*
|
|
|
|
*
|
|
|
|
* 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_CLIENT_HELPER_H
|
|
|
|
#define GRPC_TEST_CPP_INTEROP_CLIENT_HELPER_H
|
|
|
|
|
|
|
|
#include <functional>
|
|
|
|
#include <memory>
|
|
|
|
#include <unordered_map>
|
|
|
|
|
|
|
|
#include <grpcpp/channel.h>
|
|
|
|
#include <grpcpp/client_context.h>
|
|
|
|
|
|
|
|
#include "src/core/lib/surface/call_test_only.h"
|
|
|
|
#include "src/core/lib/transport/byte_stream.h"
|
|
|
|
|
|
|
|
namespace grpc {
|
|
|
|
namespace testing {
|
|
|
|
|
|
|
|
std::string GetServiceAccountJsonKey();
|
|
|
|
|
|
|
|
std::string GetOauth2AccessToken();
|
|
|
|
|
|
|
|
void UpdateActions(
|
|
|
|
std::unordered_map<std::string, std::function<bool()>>* actions);
|
|
|
|
|
|
|
|
std::shared_ptr<Channel> CreateChannelForTestCase(
|
|
|
|
const std::string& test_case,
|
|
|
|
std::vector<
|
|
|
|
std::unique_ptr<experimental::ClientInterceptorFactoryInterface>>
|
|
|
|
interceptor_creators = {});
|
|
|
|
|
|
|
|
class InteropClientContextInspector {
|
|
|
|
public:
|
|
|
|
InteropClientContextInspector(const ::grpc::ClientContext& context)
|
|
|
|
: context_(context) {}
|
|
|
|
|
|
|
|
// Inspector methods, able to peek inside ClientContext, follow.
|
|
|
|
grpc_compression_algorithm GetCallCompressionAlgorithm() const {
|
|
|
|
return grpc_call_test_only_get_compression_algorithm(context_.call_);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool WasCompressed() const {
|
|
|
|
return (grpc_call_test_only_get_message_flags(context_.call_) &
|
|
|
|
GRPC_WRITE_INTERNAL_COMPRESS) ||
|
|
|
|
(grpc_call_test_only_get_message_flags(context_.call_) &
|
|
|
|
GRPC_WRITE_INTERNAL_TEST_ONLY_WAS_COMPRESSED);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
const ::grpc::ClientContext& context_;
|
|
|
|
};
|
|
|
|
|
|
|
|
class AdditionalMetadataInterceptor : public experimental::Interceptor {
|
|
|
|
public:
|
|
|
|
AdditionalMetadataInterceptor(
|
|
|
|
std::multimap<std::string, std::string> additional_metadata)
|
|
|
|
: additional_metadata_(std::move(additional_metadata)) {}
|
|
|
|
|
|
|
|
void Intercept(experimental::InterceptorBatchMethods* methods) override {
|
|
|
|
if (methods->QueryInterceptionHookPoint(
|
|
|
|
experimental::InterceptionHookPoints::PRE_SEND_INITIAL_METADATA)) {
|
|
|
|
std::multimap<std::string, std::string>* metadata =
|
|
|
|
methods->GetSendInitialMetadata();
|
|
|
|
for (const auto& entry : additional_metadata_) {
|
|
|
|
metadata->insert(entry);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
methods->Proceed();
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
const std::multimap<std::string, std::string> additional_metadata_;
|
|
|
|
};
|
|
|
|
|
|
|
|
class AdditionalMetadataInterceptorFactory
|
|
|
|
: public experimental::ClientInterceptorFactoryInterface {
|
|
|
|
public:
|
|
|
|
AdditionalMetadataInterceptorFactory(
|
|
|
|
std::multimap<std::string, std::string> additional_metadata)
|
|
|
|
: additional_metadata_(std::move(additional_metadata)) {}
|
|
|
|
|
|
|
|
experimental::Interceptor* CreateClientInterceptor(
|
|
|
|
experimental::ClientRpcInfo* /*info*/) override {
|
|
|
|
return new AdditionalMetadataInterceptor(additional_metadata_);
|
|
|
|
}
|
|
|
|
|
|
|
|
const std::multimap<std::string, std::string> additional_metadata_;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace testing
|
|
|
|
} // namespace grpc
|
|
|
|
|
|
|
|
#endif // GRPC_TEST_CPP_INTEROP_CLIENT_HELPER_H
|