| /* | 
 |  *  Copyright 2024 The WebRTC project authors. All Rights Reserved. | 
 |  * | 
 |  *  Use of this source code is governed by a BSD-style license | 
 |  *  that can be found in the LICENSE file in the root of the source | 
 |  *  tree. An additional intellectual property rights grant can be found | 
 |  *  in the file PATENTS.  All contributing project authors may | 
 |  *  be found in the AUTHORS file in the root of the source tree. | 
 |  */ | 
 |  | 
 | #ifndef TEST_WAIT_UNTIL_INTERNAL_H_ | 
 | #define TEST_WAIT_UNTIL_INTERNAL_H_ | 
 |  | 
 | #include <string> | 
 |  | 
 | #include "absl/base/nullability.h" | 
 | #include "absl/strings/string_view.h" | 
 | #include "test/gmock.h" | 
 | #include "test/gtest.h" | 
 |  | 
 | namespace webrtc { | 
 | namespace wait_until_internal { | 
 |  | 
 | // Explains the match result of `matcher` against `value` to `listener`. | 
 | // `value_name` is the name of the value to be used in the error message. | 
 | // This is inspired by testing::ExplainMatchResult and | 
 | // testing::internal::MatchPrintAndExplain. | 
 | template <typename T, typename M> | 
 | bool ExplainMatchResult(const M& matcher, | 
 |                         const T& value, | 
 |                         ::testing::StringMatchResultListener* absl_nonnull | 
 |                             listener, | 
 |                         absl::string_view value_name) { | 
 |   // SafeMatcherCast is required for matchers whose type does not match the | 
 |   // argument type. | 
 |   ::testing::Matcher<const T&> safe_matcher = | 
 |       ::testing::SafeMatcherCast<const T&>(matcher); | 
 |  | 
 |   auto* ss = listener->stream(); | 
 |   *ss << "Value of: " << value_name << "\n"; | 
 |   *ss << "Expected: "; | 
 |   safe_matcher.DescribeTo(ss); | 
 |   *ss << "\nActual: "; | 
 |   ::testing::StringMatchResultListener inner_listener; | 
 |   if (::testing::ExplainMatchResult(safe_matcher, value, &inner_listener)) { | 
 |     return true; | 
 |   } | 
 |   *ss << ::testing::PrintToString(value); | 
 |   if (const std::string& inner_message = inner_listener.str(); | 
 |       !inner_message.empty()) { | 
 |     *ss << ", " << inner_message; | 
 |   } | 
 |   return false; | 
 | } | 
 |  | 
 | }  // namespace wait_until_internal | 
 | }  // namespace webrtc | 
 |  | 
 | #endif  // TEST_WAIT_UNTIL_INTERNAL_H_ |