OLD | NEW |
(Empty) | |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #include "media/cast/common/rtp_time.h" |
| 6 #include "testing/gtest/include/gtest/gtest.h" |
| 7 |
| 8 namespace media { |
| 9 namespace cast { |
| 10 |
| 11 // Tests that conversions between base::TimeDelta and RtpTimeDelta are accurate. |
| 12 // Note that this implicitly tests the conversions to/from RtpTimeTicks as well |
| 13 // due to shared implementation. |
| 14 TEST(RtpTimeDeltaTest, ConversionToAndFromTimeDelta) { |
| 15 const int kTimebase = 48000; |
| 16 |
| 17 // Origin in both timelines is equivalent. |
| 18 ASSERT_EQ(RtpTimeDelta(), RtpTimeDelta::FromTicks(0)); |
| 19 ASSERT_EQ(RtpTimeDelta(), |
| 20 RtpTimeDelta::FromTimeDelta(base::TimeDelta(), kTimebase)); |
| 21 ASSERT_EQ(base::TimeDelta(), |
| 22 RtpTimeDelta::FromTicks(0).ToTimeDelta(kTimebase)); |
| 23 |
| 24 // Conversions that are exact (i.e., do not require rounding). |
| 25 ASSERT_EQ(RtpTimeDelta::FromTicks(480), |
| 26 RtpTimeDelta::FromTimeDelta(base::TimeDelta::FromMilliseconds(10), |
| 27 kTimebase)); |
| 28 ASSERT_EQ( |
| 29 RtpTimeDelta::FromTicks(96000), |
| 30 RtpTimeDelta::FromTimeDelta(base::TimeDelta::FromSeconds(2), kTimebase)); |
| 31 ASSERT_EQ(base::TimeDelta::FromMilliseconds(10), |
| 32 RtpTimeDelta::FromTicks(480).ToTimeDelta(kTimebase)); |
| 33 ASSERT_EQ(base::TimeDelta::FromSeconds(2), |
| 34 RtpTimeDelta::FromTicks(96000).ToTimeDelta(kTimebase)); |
| 35 |
| 36 // Conversions that are approximate (i.e., are rounded). |
| 37 for (int error_us = -3; error_us <= +3; ++error_us) { |
| 38 ASSERT_EQ(RtpTimeDelta::FromTicks(0), |
| 39 RtpTimeDelta::FromTimeDelta( |
| 40 base::TimeDelta::FromMicroseconds(0 + error_us), kTimebase)); |
| 41 ASSERT_EQ(RtpTimeDelta::FromTicks(1), |
| 42 RtpTimeDelta::FromTimeDelta( |
| 43 base::TimeDelta::FromMicroseconds(21 + error_us), kTimebase)); |
| 44 ASSERT_EQ(RtpTimeDelta::FromTicks(2), |
| 45 RtpTimeDelta::FromTimeDelta( |
| 46 base::TimeDelta::FromMicroseconds(42 + error_us), kTimebase)); |
| 47 ASSERT_EQ(RtpTimeDelta::FromTicks(3), |
| 48 RtpTimeDelta::FromTimeDelta( |
| 49 base::TimeDelta::FromMicroseconds(63 + error_us), kTimebase)); |
| 50 ASSERT_EQ(RtpTimeDelta::FromTicks(4), |
| 51 RtpTimeDelta::FromTimeDelta( |
| 52 base::TimeDelta::FromMicroseconds(83 + error_us), kTimebase)); |
| 53 ASSERT_EQ( |
| 54 RtpTimeDelta::FromTicks(11200000000000), |
| 55 RtpTimeDelta::FromTimeDelta(base::TimeDelta::FromMicroseconds( |
| 56 INT64_C(233333333333333) + error_us), |
| 57 kTimebase)); |
| 58 } |
| 59 ASSERT_EQ(base::TimeDelta::FromMicroseconds(21), |
| 60 RtpTimeDelta::FromTicks(1).ToTimeDelta(kTimebase)); |
| 61 ASSERT_EQ(base::TimeDelta::FromMicroseconds(42), |
| 62 RtpTimeDelta::FromTicks(2).ToTimeDelta(kTimebase)); |
| 63 ASSERT_EQ(base::TimeDelta::FromMicroseconds(63), |
| 64 RtpTimeDelta::FromTicks(3).ToTimeDelta(kTimebase)); |
| 65 ASSERT_EQ(base::TimeDelta::FromMicroseconds(83), |
| 66 RtpTimeDelta::FromTicks(4).ToTimeDelta(kTimebase)); |
| 67 ASSERT_EQ(base::TimeDelta::FromMicroseconds(INT64_C(233333333333333)), |
| 68 RtpTimeDelta::FromTicks(11200000000000).ToTimeDelta(kTimebase)); |
| 69 } |
| 70 |
| 71 } // namespace cast |
| 72 } // namespace media |
OLD | NEW |