| Index: webkit/renderer/compositor_bindings/webkit_time_unittest.cc
|
| diff --git a/webkit/renderer/compositor_bindings/webkit_time_unittest.cc b/webkit/renderer/compositor_bindings/webkit_time_unittest.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..04dc94c3655cbf3e9e329963eb628fdc599cfbc1
|
| --- /dev/null
|
| +++ b/webkit/renderer/compositor_bindings/webkit_time_unittest.cc
|
| @@ -0,0 +1,65 @@
|
| +// Copyright (c) 2012 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 "webkit/renderer/compositor_bindings/webkit_time.h"
|
| +
|
| +#include <cmath>
|
| +#include <limits>
|
| +
|
| +#include "base/time/time.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +
|
| +using base::TimeTicks;
|
| +
|
| +TEST(WebKitTime, Conversion) {
|
| + double double_zero = 0;
|
| + double double_max = std::numeric_limits<double>::max();
|
| + double double_min = std::numeric_limits<double>::lowest();
|
| + double double_positive_inf = std::numeric_limits<double>::infinity();
|
| + double double_negative_inf = -std::numeric_limits<double>::infinity();
|
| +
|
| + base::TimeTicks ticks_null = base::TimeTicks();
|
| + base::TimeTicks ticks_min =
|
| + base::TimeTicks::FromInternalValue(std::numeric_limits<int64>::min());
|
| + base::TimeTicks ticks_max =
|
| + base::TimeTicks::FromInternalValue(std::numeric_limits<int64>::max());
|
| +
|
| +#if ENABLE_DCHECK
|
| + EXPECT_EQ(double_zero, webkit::ToWebKitMonotonicTime(ticks_null));
|
| + EXPECT_EQ(ticks_null, webkit::ToWebKitMonotonicTime(double_zero));
|
| +#else
|
| + ASSERT_DEATH(webkit::FromWebKitMonotonicTime(double_zero), "Check failed");
|
| + ASSERT_DEATH(webkit::FromWebKitMonotonicTime(double_max), "Check failed");
|
| + ASSERT_DEATH(webkit::FromWebKitMonotonicTime(double_min), "Check failed");
|
| + ASSERT_DEATH(webkit::FromWebKitMonotonicTime(double_positive_inf),
|
| + "Check failed");
|
| + ASSERT_DEATH(webkit::FromWebKitMonotonicTime(double_negative_inf),
|
| + "Check failed");
|
| +
|
| + ASSERT_DEATH(webkit::ToWebKitMonotonicTime(ticks_null), "Check failed");
|
| + ASSERT_DEATH(webkit::ToWebKitMonotonicTime(ticks_min), "Check failed");
|
| + ASSERT_DEATH(webkit::ToWebKitMonotonicTime(ticks_max), "Check failed");
|
| +#endif
|
| +
|
| + // Round trip some values
|
| + // Outside of 2**53 the int64->double->int64 round trip isn't exact.
|
| + for (int i = -52; i < 52; i++) {
|
| + if (!i)
|
| + continue;
|
| +
|
| + SCOPED_TRACE(i);
|
| + double i_abs = abs(static_cast<double>(i));
|
| +
|
| + base::TimeTicks ticks_value = base::TimeTicks::FromInternalValue(
|
| + static_cast<int64>((i / i_abs) * pow(2.0, i_abs)));
|
| + EXPECT_EQ(webkit::FromWebKitMonotonicTime(
|
| + webkit::ToWebKitMonotonicTime(ticks_value)),
|
| + ticks_value);
|
| +
|
| + double double_value = (i / i_abs) * pow(2.0, i_abs) / 1e6;
|
| + EXPECT_EQ(webkit::ToWebKitMonotonicTime(
|
| + webkit::FromWebKitMonotonicTime(double_value)),
|
| + double_value);
|
| + }
|
| +}
|
|
|