Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "base/time/time.h" | 5 #include "base/time/time.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 #include <time.h> | 8 #include <time.h> |
| 9 #include <limits> | 9 #include <limits> |
| 10 #include <string> | 10 #include <string> |
| 11 | 11 |
| 12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
| 13 #include "base/logging.h" | 13 #include "base/logging.h" |
| 14 #include "base/macros.h" | 14 #include "base/macros.h" |
| 15 #include "base/strings/stringprintf.h" | 15 #include "base/strings/stringprintf.h" |
| 16 #include "base/threading/platform_thread.h" | 16 #include "base/threading/platform_thread.h" |
| 17 #include "build/build_config.h" | 17 #include "build/build_config.h" |
| 18 #include "testing/gtest/include/gtest/gtest.h" | 18 #include "testing/gtest/include/gtest/gtest.h" |
| 19 | 19 |
| 20 namespace base { | 20 namespace base { |
| 21 | 21 |
| 22 namespace { | 22 namespace { |
| 23 | 23 |
| 24 // For TimeDelta::ConstexprInitialization | |
| 25 enum { kExpectedDeltaInMilliseconds = 10 }; | |
|
miu
2016/08/11 21:48:56
Is it necessary for this to be an enum to trigger
liberato (no reviews please)
2016/08/11 22:10:35
it's not necessary.
originally, i had it as const
| |
| 26 constexpr TimeDelta kConstexprTimeDelta = | |
| 27 TimeDelta::FromMilliseconds(kExpectedDeltaInMilliseconds); | |
| 28 | |
| 24 TEST(TimeTestOutOfBounds, FromExplodedOutOfBoundsTime) { | 29 TEST(TimeTestOutOfBounds, FromExplodedOutOfBoundsTime) { |
| 25 // FromUTCExploded must set time to Time(0) and failure, if the day is set to | 30 // FromUTCExploded must set time to Time(0) and failure, if the day is set to |
| 26 // 31 on a 28-30 day month. Test |exploded| returns Time(0) on 31st of | 31 // 31 on a 28-30 day month. Test |exploded| returns Time(0) on 31st of |
| 27 // February and 31st of April. New implementation handles this. | 32 // February and 31st of April. New implementation handles this. |
| 28 | 33 |
| 29 const struct DateTestData { | 34 const struct DateTestData { |
| 30 Time::Exploded explode; | 35 Time::Exploded explode; |
| 31 bool is_valid; | 36 bool is_valid; |
| 32 } kDateTestData[] = { | 37 } kDateTestData[] = { |
| 33 // 31st of February | 38 // 31st of February |
| (...skipping 1052 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1086 | 1091 |
| 1087 Time time_now = Time::Now(); | 1092 Time time_now = Time::Now(); |
| 1088 EXPECT_EQ(one_second, (time_now + one_second) - time_now); | 1093 EXPECT_EQ(one_second, (time_now + one_second) - time_now); |
| 1089 EXPECT_EQ(-one_second, (time_now - one_second) - time_now); | 1094 EXPECT_EQ(-one_second, (time_now - one_second) - time_now); |
| 1090 | 1095 |
| 1091 TimeTicks ticks_now = TimeTicks::Now(); | 1096 TimeTicks ticks_now = TimeTicks::Now(); |
| 1092 EXPECT_EQ(-one_second, (ticks_now - one_second) - ticks_now); | 1097 EXPECT_EQ(-one_second, (ticks_now - one_second) - ticks_now); |
| 1093 EXPECT_EQ(one_second, (ticks_now + one_second) - ticks_now); | 1098 EXPECT_EQ(one_second, (ticks_now + one_second) - ticks_now); |
| 1094 } | 1099 } |
| 1095 | 1100 |
| 1101 TEST(TimeDelta, ConstexprInitialization) { | |
|
miu
2016/08/11 21:48:56
Please put these changes in time_win_unittest.cc i
liberato (no reviews please)
2016/08/11 22:10:35
Done.
| |
| 1102 // Make sure that TimeDelta works around crbug.com/635974 | |
| 1103 EXPECT_EQ(kExpectedDeltaInMilliseconds, kConstexprTimeDelta.InMilliseconds()); | |
| 1104 } | |
| 1105 | |
| 1096 TEST(TimeDeltaLogging, DCheckEqCompiles) { | 1106 TEST(TimeDeltaLogging, DCheckEqCompiles) { |
| 1097 DCHECK_EQ(TimeDelta(), TimeDelta()); | 1107 DCHECK_EQ(TimeDelta(), TimeDelta()); |
| 1098 } | 1108 } |
| 1099 | 1109 |
| 1100 TEST(TimeDeltaLogging, EmptyIsZero) { | 1110 TEST(TimeDeltaLogging, EmptyIsZero) { |
| 1101 TimeDelta zero; | 1111 TimeDelta zero; |
| 1102 EXPECT_EQ("0s", AnyToString(zero)); | 1112 EXPECT_EQ("0s", AnyToString(zero)); |
| 1103 } | 1113 } |
| 1104 | 1114 |
| 1105 TEST(TimeDeltaLogging, FiveHundredMs) { | 1115 TEST(TimeDeltaLogging, FiveHundredMs) { |
| (...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1173 | 1183 |
| 1174 TEST(TimeTicksLogging, DoesNotMakeStreamBad) { | 1184 TEST(TimeTicksLogging, DoesNotMakeStreamBad) { |
| 1175 std::ostringstream oss; | 1185 std::ostringstream oss; |
| 1176 oss << TimeTicks(); | 1186 oss << TimeTicks(); |
| 1177 EXPECT_TRUE(oss.good()); | 1187 EXPECT_TRUE(oss.good()); |
| 1178 } | 1188 } |
| 1179 | 1189 |
| 1180 } // namespace | 1190 } // namespace |
| 1181 | 1191 |
| 1182 } // namespace base | 1192 } // namespace base |
| OLD | NEW |