Index: webrtc/stats/rtcstats_unittest.cc |
diff --git a/webrtc/stats/rtcstats_unittest.cc b/webrtc/stats/rtcstats_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..bf76ead78cf7f36e37ddae457b3e0f17c1741865 |
--- /dev/null |
+++ b/webrtc/stats/rtcstats_unittest.cc |
@@ -0,0 +1,204 @@ |
+/* |
+ * Copyright 2016 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. |
+ */ |
+ |
+#include "webrtc/api/rtcstats.h" |
+#include "webrtc/api/rtcstatsreport.h" |
+ |
+#include "webrtc/base/checks.h" |
+#include "webrtc/base/gunit.h" |
+#include "webrtc/base/logging.h" |
+ |
+namespace webrtc { |
+ |
+class RTCTestStats : public RTCStats { |
+ public: |
+ static const char* const kType; |
+ |
+ RTCTestStats(const std::string& id, double timestamp) |
+ : RTCStats(id, timestamp), |
+ m_int32("mInt32"), |
+ m_uint32("mUint32"), |
+ m_int64("mInt64"), |
+ m_uint64("mUint64"), |
+ m_double("mDouble"), |
+ m_static_string("mStaticString"), |
+ m_string("mString"), |
+ m_sequence_int32("mSequenceInt32"), |
+ m_sequence_uint32("mSequenceUint32"), |
+ m_sequence_int64("mSequenceInt64"), |
+ m_sequence_uint64("mSequenceUint64"), |
+ m_sequence_double("mSequenceDouble"), |
+ m_sequence_static_string("mSequenceStaticString"), |
+ m_sequence_string("mSequenceString") { |
+ } |
+ std::unique_ptr<RTCStats> copy() const override { |
+ return std::unique_ptr<RTCStats>(new RTCTestStats(*this)); |
+ } |
+ |
+ const char* const* type() const override { return &kType; } |
+ const char* type_name() const override { return kType; } |
hta - Chromium
2016/08/15 15:14:57
Is there any chance that these could be different?
hbos
2016/08/15 22:46:43
It is possible to have default implementations, bu
|
+ std::vector<const RTCStatsMemberInterface*> Members() const override { |
+ const RTCStatsMemberInterface* members[] = { |
+ &m_int32, |
+ &m_uint32, |
+ &m_int64, |
+ &m_uint64, |
+ &m_double, |
+ &m_static_string, |
+ &m_string, |
+ &m_sequence_int32, |
+ &m_sequence_uint32, |
+ &m_sequence_int64, |
+ &m_sequence_uint64, |
+ &m_sequence_double, |
+ &m_sequence_static_string, |
+ &m_sequence_string |
+ }; |
+ return MembersVector(members, sizeof(members) / sizeof(members[0])); |
+ } |
+ |
+ RTCStatsMember<int32_t> m_int32; |
+ RTCStatsMember<uint32_t> m_uint32; |
+ RTCStatsMember<int64_t> m_int64; |
+ RTCStatsMember<uint64_t> m_uint64; |
+ RTCStatsMember<double> m_double; |
+ RTCStatsMember<const char*> m_static_string; |
+ RTCStatsMember<std::string> m_string; |
+ |
+ RTCStatsMember<std::vector<int32_t>> m_sequence_int32; |
+ RTCStatsMember<std::vector<uint32_t>> m_sequence_uint32; |
+ RTCStatsMember<std::vector<int64_t>> m_sequence_int64; |
+ RTCStatsMember<std::vector<uint64_t>> m_sequence_uint64; |
+ RTCStatsMember<std::vector<double>> m_sequence_double; |
+ RTCStatsMember<std::vector<const char*>> m_sequence_static_string; |
+ RTCStatsMember<std::vector<std::string>> m_sequence_string; |
+}; |
+ |
+const char* const RTCTestStats::kType = "test"; |
+ |
+class RTCTestStats2 : public RTCStats { |
+ public: |
+ static const char* const kType; |
+ |
+ RTCTestStats2(const std::string& id, double timestamp) |
+ : RTCStats(id, timestamp) { |
+ } |
+ std::unique_ptr<RTCStats> copy() const override { |
+ return std::unique_ptr<RTCStats>(new RTCTestStats2(*this)); |
+ } |
+ |
+ const char* const* type() const override { return &kType; } |
+ const char* type_name() const override { return kType; } |
+ std::vector<const RTCStatsMemberInterface*> Members() const override { |
+ return std::vector<const RTCStatsMemberInterface*>(); |
+ } |
+}; |
+ |
+const char* const RTCTestStats2::kType = "test2"; |
+ |
+class RTCTestStats3 : public RTCStats { |
+ public: |
+ static const char* const kType; |
+ |
+ RTCTestStats3(const std::string& id, double timestamp) |
+ : RTCStats(id, timestamp) { |
+ } |
+ std::unique_ptr<RTCStats> copy() const override { |
+ return std::unique_ptr<RTCStats>(new RTCTestStats3(*this)); |
+ } |
+ |
+ const char* const* type() const override { return &kType; } |
+ const char* type_name() const override { return kType; } |
+ std::vector<const RTCStatsMemberInterface*> Members() const override { |
+ return std::vector<const RTCStatsMemberInterface*>(); |
+ } |
+}; |
hta - Chromium
2016/08/15 15:14:57
For completeness, derive a class from RTCTestStats
hbos
2016/08/15 22:46:43
Done.
|
+ |
+const char* const RTCTestStats3::kType = "test3"; |
+ |
+class RTCStatsTest : public testing::Test { |
+}; |
+ |
+TEST_F(RTCStatsTest, TestRTCStatsAndMembers) { |
+ RTCTestStats stats("testId", 42.0); |
+ EXPECT_EQ(stats.id(), "testId"); |
+ EXPECT_EQ(stats.timestamp(), 42.0); |
+ std::vector<const RTCStatsMemberInterface*> members = stats.Members(); |
+ EXPECT_EQ(members.size(), static_cast<size_t>(14)); |
+ for (const RTCStatsMemberInterface* member : members) { |
+ EXPECT_FALSE(member->has_value()); |
+ } |
+ stats.m_int32 = 123; |
+ stats.m_uint32 = 123; |
+ stats.m_int64 = 123; |
+ stats.m_uint64 = 123; |
+ stats.m_double = 123.0; |
+ stats.m_static_string = "123"; |
+ stats.m_string = std::string("123"); |
+ stats.m_sequence_int32 = std::vector<int32_t>(); |
+ stats.m_sequence_uint32 = std::vector<uint32_t>(); |
+ stats.m_sequence_int64 = std::vector<int64_t>(); |
+ stats.m_sequence_uint64 = std::vector<uint64_t>(); |
+ stats.m_sequence_double = std::vector<double>(); |
+ stats.m_sequence_static_string = std::vector<const char*>(); |
hta - Chromium
2016/08/15 15:14:57
Might be nice to thrown in a test that stats.m_seq
hbos
2016/08/15 22:46:43
The for loop above has already tested all members'
|
+ stats.m_sequence_string = std::vector<std::string>(); |
+ for (const RTCStatsMemberInterface* member : members) { |
+ EXPECT_TRUE(member->has_value()); |
+ } |
+ EXPECT_EQ(*stats.m_int32, static_cast<int32_t>(123)); |
+ EXPECT_EQ(*stats.m_uint32, static_cast<uint32_t>(123)); |
+ EXPECT_EQ(*stats.m_int64, static_cast<int64_t>(123)); |
+ EXPECT_EQ(*stats.m_uint64, static_cast<uint64_t>(123)); |
+ EXPECT_EQ(*stats.m_double, 123.0); |
+ EXPECT_EQ(*stats.m_static_string, "123"); |
+ EXPECT_EQ(*stats.m_string, std::string("123")); |
+ EXPECT_EQ(*stats.m_sequence_int32, std::vector<int32_t>()); |
+ EXPECT_EQ(*stats.m_sequence_uint32, std::vector<uint32_t>()); |
+ EXPECT_EQ(*stats.m_sequence_int64, std::vector<int64_t>()); |
+ EXPECT_EQ(*stats.m_sequence_uint64, std::vector<uint64_t>()); |
+ EXPECT_EQ(*stats.m_sequence_double, std::vector<double>()); |
+ EXPECT_EQ(*stats.m_sequence_static_string, std::vector<const char*>()); |
+ EXPECT_EQ(*stats.m_sequence_string, std::vector<std::string>()); |
hta - Chromium
2016/08/15 15:14:57
Throw in a case where you give a value to a sequen
hbos
2016/08/15 22:46:43
Done.
|
+} |
+ |
+TEST_F(RTCStatsTest, TestRTCStatsReport) { |
+ rtc::scoped_refptr<RTCStatsReport> report = RTCStatsReport::Create(); |
+ EXPECT_EQ(report->size(), static_cast<size_t>(0)); |
+ report->AddStats(std::unique_ptr<RTCStats>(new RTCTestStats("a0", 1.0))); |
+ report->AddStats(std::unique_ptr<RTCStats>(new RTCTestStats("a1", 2.0))); |
+ report->AddStats(std::unique_ptr<RTCStats>(new RTCTestStats2("b0", 4.0))); |
+ report->AddStats(std::unique_ptr<RTCStats>(new RTCTestStats2("b1", 8.0))); |
+ report->AddStats(std::unique_ptr<RTCStats>(new RTCTestStats("a2", 16.0))); |
+ report->AddStats(std::unique_ptr<RTCStats>(new RTCTestStats2("b2", 32.0))); |
+ EXPECT_EQ(report->size(), static_cast<size_t>(6)); |
+ |
+ EXPECT_EQ((*report)["missing"], nullptr); |
+ EXPECT_EQ((*report)["a0"]->id(), "a0"); |
+ EXPECT_EQ((*report)["b2"]->id(), "b2"); |
+ |
+ std::vector<const RTCTestStats*> a = report->GetStatsOfType<RTCTestStats>(); |
+ EXPECT_EQ(a.size(), static_cast<size_t>(3)); |
+ uint32_t mask = 0; |
+ for (const RTCTestStats* stats : a) |
+ mask |= static_cast<uint32_t>(stats->timestamp()); |
+ EXPECT_EQ(mask, static_cast<uint32_t>(1 | 2 | 16)); |
+ |
+ std::vector<const RTCTestStats2*> b = report->GetStatsOfType<RTCTestStats2>(); |
+ EXPECT_EQ(b.size(), static_cast<size_t>(3)); |
+ mask = 0; |
+ for (const RTCTestStats2* stats : b) |
+ mask |= static_cast<uint32_t>(stats->timestamp()); |
+ EXPECT_EQ(mask, static_cast<uint32_t>(4 | 8 | 32)); |
+ |
+ EXPECT_EQ(report->GetStatsOfType<RTCTestStats3>().size(), |
+ static_cast<size_t>(0)); |
+} |
+ |
+} // namespace webrtc |