tls_certificate_verifier_test.cc 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. //
  2. // Copyright 2021 gRPC authors.
  3. //
  4. // Licensed under the Apache License, Version 2.0 (the "License");
  5. // you may not use this file except in compliance with the License.
  6. // You may obtain a copy of the License at
  7. //
  8. // http://www.apache.org/licenses/LICENSE-2.0
  9. //
  10. // Unless required by applicable law or agreed to in writing, software
  11. // distributed under the License is distributed on an "AS IS" BASIS,
  12. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. // See the License for the specific language governing permissions and
  14. // limitations under the License.
  15. //
  16. #include <memory>
  17. #include <gmock/gmock.h>
  18. #include <gtest/gtest.h>
  19. #include <grpc/grpc.h>
  20. #include <grpc/grpc_security.h>
  21. #include <grpcpp/security/server_credentials.h>
  22. #include <grpcpp/security/tls_credentials_options.h>
  23. #include "src/cpp/client/secure_credentials.h"
  24. #include "test/core/util/port.h"
  25. #include "test/core/util/test_config.h"
  26. #include "test/cpp/util/tls_test_utils.h"
  27. namespace {
  28. using ::grpc::experimental::ExternalCertificateVerifier;
  29. using ::grpc::experimental::HostNameCertificateVerifier;
  30. using ::grpc::experimental::TlsCustomVerificationCheckRequest;
  31. } // namespace
  32. namespace grpc {
  33. namespace testing {
  34. namespace {
  35. TEST(TlsCertificateVerifierTest, SyncCertificateVerifierSucceeds) {
  36. grpc_tls_custom_verification_check_request request;
  37. auto verifier =
  38. ExternalCertificateVerifier::Create<SyncCertificateVerifier>(true);
  39. TlsCustomVerificationCheckRequest cpp_request(&request);
  40. grpc::Status sync_status;
  41. verifier->Verify(&cpp_request, nullptr, &sync_status);
  42. EXPECT_TRUE(sync_status.ok())
  43. << sync_status.error_code() << " " << sync_status.error_message();
  44. }
  45. TEST(TlsCertificateVerifierTest, SyncCertificateVerifierFails) {
  46. grpc_tls_custom_verification_check_request request;
  47. auto verifier =
  48. ExternalCertificateVerifier::Create<SyncCertificateVerifier>(false);
  49. TlsCustomVerificationCheckRequest cpp_request(&request);
  50. grpc::Status sync_status;
  51. verifier->Verify(&cpp_request, nullptr, &sync_status);
  52. EXPECT_EQ(sync_status.error_code(), grpc::StatusCode::UNAUTHENTICATED);
  53. EXPECT_EQ(sync_status.error_message(), "SyncCertificateVerifier failed");
  54. }
  55. TEST(TlsCertificateVerifierTest, AsyncCertificateVerifierSucceeds) {
  56. grpc_tls_custom_verification_check_request request;
  57. auto verifier =
  58. ExternalCertificateVerifier::Create<AsyncCertificateVerifier>(true);
  59. TlsCustomVerificationCheckRequest cpp_request(&request);
  60. std::function<void(grpc::Status)> callback = [](grpc::Status async_status) {
  61. EXPECT_TRUE(async_status.ok())
  62. << async_status.error_code() << " " << async_status.error_message();
  63. };
  64. grpc::Status sync_status;
  65. EXPECT_FALSE(verifier->Verify(&cpp_request, callback, &sync_status));
  66. }
  67. TEST(TlsCertificateVerifierTest, AsyncCertificateVerifierFails) {
  68. grpc_tls_custom_verification_check_request request;
  69. auto verifier =
  70. ExternalCertificateVerifier::Create<AsyncCertificateVerifier>(false);
  71. TlsCustomVerificationCheckRequest cpp_request(&request);
  72. std::function<void(grpc::Status)> callback = [](grpc::Status async_status) {
  73. EXPECT_EQ(async_status.error_code(), grpc::StatusCode::UNAUTHENTICATED);
  74. EXPECT_EQ(async_status.error_message(), "AsyncCertificateVerifier failed");
  75. };
  76. grpc::Status sync_status;
  77. EXPECT_FALSE(verifier->Verify(&cpp_request, callback, &sync_status));
  78. }
  79. TEST(TlsCertificateVerifierTest, HostNameCertificateVerifierSucceeds) {
  80. grpc_tls_custom_verification_check_request request;
  81. memset(&request, 0, sizeof(request));
  82. request.target_name = "foo.bar.com";
  83. request.peer_info.common_name = "foo.bar.com";
  84. auto verifier = std::make_shared<HostNameCertificateVerifier>();
  85. TlsCustomVerificationCheckRequest cpp_request(&request);
  86. grpc::Status sync_status;
  87. verifier->Verify(&cpp_request, nullptr, &sync_status);
  88. EXPECT_TRUE(sync_status.ok())
  89. << sync_status.error_code() << " " << sync_status.error_message();
  90. }
  91. TEST(TlsCertificateVerifierTest, HostNameCertificateVerifierFails) {
  92. grpc_tls_custom_verification_check_request request;
  93. memset(&request, 0, sizeof(request));
  94. request.target_name = "foo.bar.com";
  95. request.peer_info.common_name = "foo.baz.com";
  96. auto verifier = std::make_shared<HostNameCertificateVerifier>();
  97. TlsCustomVerificationCheckRequest cpp_request(&request);
  98. grpc::Status sync_status;
  99. verifier->Verify(&cpp_request, nullptr, &sync_status);
  100. EXPECT_EQ(sync_status.error_code(), grpc::StatusCode::UNAUTHENTICATED);
  101. EXPECT_EQ(sync_status.error_message(), "Hostname Verification Check failed.");
  102. }
  103. TEST(TlsCertificateVerifierTest,
  104. HostNameCertificateVerifierSucceedsMultipleFields) {
  105. grpc_tls_custom_verification_check_request request;
  106. memset(&request, 0, sizeof(request));
  107. request.target_name = "foo.bar.com";
  108. request.peer_info.common_name = "foo.baz.com";
  109. char* dns_names[] = {const_cast<char*>("*.bar.com")};
  110. request.peer_info.san_names.dns_names = dns_names;
  111. request.peer_info.san_names.dns_names_size = 1;
  112. auto verifier = std::make_shared<HostNameCertificateVerifier>();
  113. TlsCustomVerificationCheckRequest cpp_request(&request);
  114. grpc::Status sync_status;
  115. verifier->Verify(&cpp_request, nullptr, &sync_status);
  116. EXPECT_TRUE(sync_status.ok())
  117. << sync_status.error_code() << " " << sync_status.error_message();
  118. }
  119. TEST(TlsCertificateVerifierTest,
  120. HostNameCertificateVerifierFailsMultipleFields) {
  121. grpc_tls_custom_verification_check_request request;
  122. memset(&request, 0, sizeof(request));
  123. request.target_name = "foo.bar.com";
  124. request.peer_info.common_name = "foo.baz.com";
  125. char* dns_names[] = {const_cast<char*>("*.")};
  126. request.peer_info.san_names.dns_names = dns_names;
  127. request.peer_info.san_names.dns_names_size = 1;
  128. auto verifier = std::make_shared<HostNameCertificateVerifier>();
  129. TlsCustomVerificationCheckRequest cpp_request(&request);
  130. grpc::Status sync_status;
  131. verifier->Verify(&cpp_request, nullptr, &sync_status);
  132. EXPECT_EQ(sync_status.error_code(), grpc::StatusCode::UNAUTHENTICATED);
  133. EXPECT_EQ(sync_status.error_message(), "Hostname Verification Check failed.");
  134. }
  135. } // namespace
  136. } // namespace testing
  137. } // namespace grpc
  138. int main(int argc, char** argv) {
  139. ::testing::InitGoogleTest(&argc, argv);
  140. grpc::testing::TestEnvironment env(argc, argv);
  141. int ret = RUN_ALL_TESTS();
  142. return ret;
  143. }