Chromium Code Reviews| Index: media/cast/common/rtp_time_unittest.cc |
| diff --git a/media/cast/common/rtp_time_unittest.cc b/media/cast/common/rtp_time_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..cdbd10f9cef694cd8ce2a197b1096507c73e000e |
| --- /dev/null |
| +++ b/media/cast/common/rtp_time_unittest.cc |
| @@ -0,0 +1,72 @@ |
| +// Copyright 2015 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "media/cast/common/rtp_time.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace media { |
| +namespace cast { |
| + |
| +// Tests that conversions between base::TimeDelta and RtpTimeDelta are accurate. |
| +// Note that this implicitly tests the conversions to/from RtpTimeTicks as well |
| +// due to shared implementation. |
| +TEST(RtpTimeDeltaTest, ConversionToAndFromTimeDelta) { |
|
Irfan
2015/12/09 21:24:28
perhaps cover some operator tests ?
miu
2015/12/10 00:38:36
I thought about this, but the tests would just be
|
| + const int kTimebase = 48000; |
| + |
| + // Origin in both timelines is equivalent. |
| + ASSERT_EQ(RtpTimeDelta(), RtpTimeDelta::FromTicks(0)); |
| + ASSERT_EQ(RtpTimeDelta(), |
| + RtpTimeDelta::FromTimeDelta(base::TimeDelta(), kTimebase)); |
| + ASSERT_EQ(base::TimeDelta(), |
| + RtpTimeDelta::FromTicks(0).ToTimeDelta(kTimebase)); |
| + |
| + // Conversions that are exact (i.e., do not require rounding). |
| + ASSERT_EQ(RtpTimeDelta::FromTicks(480), |
| + RtpTimeDelta::FromTimeDelta(base::TimeDelta::FromMilliseconds(10), |
| + kTimebase)); |
| + ASSERT_EQ( |
| + RtpTimeDelta::FromTicks(96000), |
| + RtpTimeDelta::FromTimeDelta(base::TimeDelta::FromSeconds(2), kTimebase)); |
| + ASSERT_EQ(base::TimeDelta::FromMilliseconds(10), |
| + RtpTimeDelta::FromTicks(480).ToTimeDelta(kTimebase)); |
| + ASSERT_EQ(base::TimeDelta::FromSeconds(2), |
| + RtpTimeDelta::FromTicks(96000).ToTimeDelta(kTimebase)); |
| + |
| + // Conversions that are approximate (i.e., are rounded). |
| + for (int error_us = -3; error_us <= +3; ++error_us) { |
| + ASSERT_EQ(RtpTimeDelta::FromTicks(0), |
| + RtpTimeDelta::FromTimeDelta( |
| + base::TimeDelta::FromMicroseconds(0 + error_us), kTimebase)); |
| + ASSERT_EQ(RtpTimeDelta::FromTicks(1), |
| + RtpTimeDelta::FromTimeDelta( |
| + base::TimeDelta::FromMicroseconds(21 + error_us), kTimebase)); |
| + ASSERT_EQ(RtpTimeDelta::FromTicks(2), |
| + RtpTimeDelta::FromTimeDelta( |
| + base::TimeDelta::FromMicroseconds(42 + error_us), kTimebase)); |
| + ASSERT_EQ(RtpTimeDelta::FromTicks(3), |
| + RtpTimeDelta::FromTimeDelta( |
| + base::TimeDelta::FromMicroseconds(63 + error_us), kTimebase)); |
| + ASSERT_EQ(RtpTimeDelta::FromTicks(4), |
| + RtpTimeDelta::FromTimeDelta( |
| + base::TimeDelta::FromMicroseconds(83 + error_us), kTimebase)); |
| + ASSERT_EQ( |
| + RtpTimeDelta::FromTicks(11200000000000), |
| + RtpTimeDelta::FromTimeDelta(base::TimeDelta::FromMicroseconds( |
| + INT64_C(233333333333333) + error_us), |
| + kTimebase)); |
| + } |
| + ASSERT_EQ(base::TimeDelta::FromMicroseconds(21), |
| + RtpTimeDelta::FromTicks(1).ToTimeDelta(kTimebase)); |
| + ASSERT_EQ(base::TimeDelta::FromMicroseconds(42), |
| + RtpTimeDelta::FromTicks(2).ToTimeDelta(kTimebase)); |
| + ASSERT_EQ(base::TimeDelta::FromMicroseconds(63), |
| + RtpTimeDelta::FromTicks(3).ToTimeDelta(kTimebase)); |
| + ASSERT_EQ(base::TimeDelta::FromMicroseconds(83), |
| + RtpTimeDelta::FromTicks(4).ToTimeDelta(kTimebase)); |
| + ASSERT_EQ(base::TimeDelta::FromMicroseconds(INT64_C(233333333333333)), |
| + RtpTimeDelta::FromTicks(11200000000000).ToTimeDelta(kTimebase)); |
| +} |
| + |
| +} // namespace cast |
| +} // namespace media |