Use MessageDifferencer for proto comparison

Change-Id: Ifa4c56d09a7e9c5c71a37ec70f81d546fe58f0a9
This commit is contained in:
KongQun Yang 2018-05-02 21:21:44 -07:00
parent 440ba442f6
commit a78c3d3224
4 changed files with 27 additions and 46 deletions

View File

@ -8,6 +8,7 @@
#include <gmock/gmock.h> #include <gmock/gmock.h>
#include <google/protobuf/text_format.h> #include <google/protobuf/text_format.h>
#include <google/protobuf/util/message_differencer.h>
#include <gtest/gtest.h> #include <gtest/gtest.h>
#include <algorithm> #include <algorithm>
#include <vector> #include <vector>
@ -92,7 +93,8 @@ class MpdNotifyMuxerListenerTest : public ::testing::TestWithParam<MpdType> {
MATCHER_P(ExpectMediaInfoEq, expected_text_format, "") { MATCHER_P(ExpectMediaInfoEq, expected_text_format, "") {
const MediaInfo expected = ConvertToMediaInfo(expected_text_format); const MediaInfo expected = ConvertToMediaInfo(expected_text_format);
return MediaInfoEqual(expected, arg); *result_listener << arg.ShortDebugString();
return ::google::protobuf::util::MessageDifferencer::Equals(arg, expected);
} }
TEST_F(MpdNotifyMuxerListenerTest, VodClearContent) { TEST_F(MpdNotifyMuxerListenerTest, VodClearContent) {

View File

@ -110,19 +110,5 @@ std::vector<ProtectionSystemSpecificInfo> GetDefaultKeySystemInfo() {
return key_system_info; return key_system_info;
} }
void ExpectMediaInfoEqual(const MediaInfo& expect, const MediaInfo& actual) {
ASSERT_TRUE(MediaInfoEqual(expect, actual));
}
bool MediaInfoEqual(const MediaInfo& expect, const MediaInfo& actual) {
// I found out here
// https://groups.google.com/forum/#!msg/protobuf/5sOExQkB2eQ/ZSBNZI0K54YJ
// that the best way to check equality is to serialize and check equality.
std::string expect_serialized = expect.SerializeAsString();
std::string actual_serialized = actual.SerializeAsString();
EXPECT_EQ(expect_serialized, actual_serialized);
return expect_serialized == actual_serialized;
}
} // namespace media } // namespace media
} // namespace shaka } // namespace shaka

View File

@ -100,12 +100,6 @@ std::vector<ProtectionSystemSpecificInfo> GetDefaultKeySystemInfo();
// Sets "default" values for muxer_options for testing. // Sets "default" values for muxer_options for testing.
void SetDefaultMuxerOptions(MuxerOptions* muxer_options); void SetDefaultMuxerOptions(MuxerOptions* muxer_options);
// Expect that expect and actual are equal.
void ExpectMediaInfoEqual(const MediaInfo& expect, const MediaInfo& actual);
// Returns true if expect and actual are equal.
bool MediaInfoEqual(const MediaInfo& expect, const MediaInfo& actual);
} // namespace media } // namespace media
} // namespace shaka } // namespace shaka

View File

@ -4,7 +4,9 @@
// license that can be found in the LICENSE file or at // license that can be found in the LICENSE file or at
// https://developers.google.com/open-source/licenses/bsd // https://developers.google.com/open-source/licenses/bsd
#include <gmock/gmock.h>
#include <google/protobuf/text_format.h> #include <google/protobuf/text_format.h>
#include <google/protobuf/util/message_differencer.h>
#include <gtest/gtest.h> #include <gtest/gtest.h>
#include <vector> #include <vector>
@ -39,19 +41,22 @@ namespace media {
namespace { namespace {
void ExpectTextFormatMediaInfoEqual(const std::string& expect, MATCHER_P(FileContentEqualsProto, expected_protobuf, "") {
const std::string& actual) { std::string temp_file_media_info_str;
MediaInfo expect_media_info; CHECK(File::ReadFileToString(arg.c_str(), &temp_file_media_info_str));
CHECK(!temp_file_media_info_str.empty());
MediaInfo expected_media_info;
MediaInfo actual_media_info; MediaInfo actual_media_info;
typedef ::google::protobuf::TextFormat TextFormat; typedef ::google::protobuf::TextFormat TextFormat;
ASSERT_TRUE(TextFormat::ParseFromString(expect, &expect_media_info)) CHECK(TextFormat::ParseFromString(expected_protobuf, &expected_media_info));
<< "Failed to parse " << std::endl << expect; CHECK(TextFormat::ParseFromString(temp_file_media_info_str,
ASSERT_TRUE(TextFormat::ParseFromString(actual, &actual_media_info)) &actual_media_info));
<< "Failed to parse " << std::endl << actual;
ASSERT_NO_FATAL_FAILURE( *result_listener << actual_media_info.ShortDebugString();
ExpectMediaInfoEqual(expect_media_info, actual_media_info))
<< "Expect:" << std::endl << expect << std::endl return ::google::protobuf::util::MessageDifferencer::Equals(
<< "Actual:" << std::endl << actual; actual_media_info, expected_media_info);
} }
} // namespace } // namespace
@ -103,16 +108,6 @@ class VodMediaInfoDumpMuxerListenerTest : public ::testing::Test {
listener_->OnMediaEnd(params.media_ranges, params.duration_seconds); listener_->OnMediaEnd(params.media_ranges, params.duration_seconds);
} }
void ExpectTempFileToEqual(const std::string& expected_protobuf) {
std::string temp_file_media_info_str;
ASSERT_TRUE(File::ReadFileToString(temp_file_path_.AsUTF8Unsafe().c_str(),
&temp_file_media_info_str));
ASSERT_TRUE(!temp_file_media_info_str.empty());
ASSERT_NO_FATAL_FAILURE((ExpectTextFormatMediaInfoEqual(
expected_protobuf, temp_file_media_info_str)));
}
protected: protected:
base::FilePath temp_file_path_; base::FilePath temp_file_path_;
std::unique_ptr<VodMediaInfoDumpMuxerListener> listener_; std::unique_ptr<VodMediaInfoDumpMuxerListener> listener_;
@ -151,7 +146,8 @@ TEST_F(VodMediaInfoDumpMuxerListenerTest, UnencryptedStream_Normal) {
"container_type: 1\n" "container_type: 1\n"
"media_file_name: 'test_output_file_name.mp4'\n" "media_file_name: 'test_output_file_name.mp4'\n"
"media_duration_seconds: 10.5\n"; "media_duration_seconds: 10.5\n";
ASSERT_NO_FATAL_FAILURE(ExpectTempFileToEqual(kExpectedProtobufOutput)); EXPECT_THAT(temp_file_path_.AsUTF8Unsafe(),
FileContentEqualsProto(kExpectedProtobufOutput));
} }
TEST_F(VodMediaInfoDumpMuxerListenerTest, EncryptedStream_Normal) { TEST_F(VodMediaInfoDumpMuxerListenerTest, EncryptedStream_Normal) {
@ -194,7 +190,8 @@ TEST_F(VodMediaInfoDumpMuxerListenerTest, EncryptedStream_Normal) {
" protection_scheme: 'cenc'\n" " protection_scheme: 'cenc'\n"
"}\n"; "}\n";
ASSERT_NO_FATAL_FAILURE(ExpectTempFileToEqual(kExpectedProtobufOutput)); EXPECT_THAT(temp_file_path_.AsUTF8Unsafe(),
FileContentEqualsProto(kExpectedProtobufOutput));
} }
// Verify that VideoStreamInfo with non-0 pixel_{width,height} is set in the // Verify that VideoStreamInfo with non-0 pixel_{width,height} is set in the
@ -231,7 +228,8 @@ TEST_F(VodMediaInfoDumpMuxerListenerTest, CheckPixelWidthAndHeightSet) {
"container_type: 1\n" "container_type: 1\n"
"media_file_name: 'test_output_file_name.mp4'\n" "media_file_name: 'test_output_file_name.mp4'\n"
"media_duration_seconds: 10.5\n"; "media_duration_seconds: 10.5\n";
ASSERT_NO_FATAL_FAILURE(ExpectTempFileToEqual(kExpectedProtobufOutput)); EXPECT_THAT(temp_file_path_.AsUTF8Unsafe(),
FileContentEqualsProto(kExpectedProtobufOutput));
} }
TEST_F(VodMediaInfoDumpMuxerListenerTest, CheckBandwidth) { TEST_F(VodMediaInfoDumpMuxerListenerTest, CheckBandwidth) {
@ -272,7 +270,8 @@ TEST_F(VodMediaInfoDumpMuxerListenerTest, CheckBandwidth) {
"container_type: 1\n" "container_type: 1\n"
"media_file_name: 'test_output_file_name.mp4'\n" "media_file_name: 'test_output_file_name.mp4'\n"
"media_duration_seconds: 10.5\n"; "media_duration_seconds: 10.5\n";
ASSERT_NO_FATAL_FAILURE(ExpectTempFileToEqual(kExpectedProtobufOutput)); EXPECT_THAT(temp_file_path_.AsUTF8Unsafe(),
FileContentEqualsProto(kExpectedProtobufOutput));
} }
} // namespace media } // namespace media