/* * 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 #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 bool ExplainMatchResult( const M& matcher, const T& value, absl::Nonnull<::testing::StringMatchResultListener*> listener, absl::string_view value_name) { // SafeMatcherCast is required for matchers whose type does not match the // argument type. ::testing::Matcher safe_matcher = ::testing::SafeMatcherCast(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_