OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 <string> | 5 #include <string> |
6 | 6 |
7 #include "cc/output/begin_frame_args.h" | 7 #include "cc/output/begin_frame_args.h" |
8 #include "cc/test/begin_frame_args_test.h" | 8 #include "cc/test/begin_frame_args_test.h" |
9 #include "testing/gtest/include/gtest/gtest-spi.h" | 9 #include "testing/gtest/include/gtest/gtest-spi.h" |
10 #include "testing/gtest/include/gtest/gtest.h" | 10 #include "testing/gtest/include/gtest/gtest.h" |
11 #include "ui/gfx/frame_time.h" | 11 #include "ui/gfx/frame_time.h" |
12 | 12 |
13 namespace cc { | 13 namespace cc { |
14 namespace { | 14 namespace { |
15 | 15 |
16 TEST(BeginFrameArgsTest, Helpers) { | 16 TEST(BeginFrameArgsTest, Helpers) { |
17 // Quick create methods work | 17 // Quick create methods work |
18 BeginFrameArgs args0 = CreateBeginFrameArgsForTesting(); | 18 BeginFrameArgs args0 = CreateBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE); |
19 EXPECT_TRUE(args0.IsValid()) << args0; | 19 EXPECT_TRUE(args0.IsValid()) << args0; |
20 | 20 |
21 BeginFrameArgs args1 = CreateBeginFrameArgsForTesting(0, 0, -1); | 21 BeginFrameArgs args1 = |
| 22 CreateBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE, 0, 0, -1); |
22 EXPECT_FALSE(args1.IsValid()) << args1; | 23 EXPECT_FALSE(args1.IsValid()) << args1; |
23 | 24 |
24 BeginFrameArgs args2 = CreateBeginFrameArgsForTesting(1, 2, 3); | 25 BeginFrameArgs args2 = |
| 26 CreateBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE, 1, 2, 3); |
25 EXPECT_TRUE(args2.IsValid()) << args2; | 27 EXPECT_TRUE(args2.IsValid()) << args2; |
26 EXPECT_EQ(1, args2.frame_time.ToInternalValue()); | 28 EXPECT_EQ(1, args2.frame_time.ToInternalValue()); |
27 EXPECT_EQ(2, args2.deadline.ToInternalValue()); | 29 EXPECT_EQ(2, args2.deadline.ToInternalValue()); |
28 EXPECT_EQ(3, args2.interval.ToInternalValue()); | 30 EXPECT_EQ(3, args2.interval.ToInternalValue()); |
29 EXPECT_EQ(BeginFrameArgs::NORMAL, args2.type); | 31 EXPECT_EQ(BeginFrameArgs::NORMAL, args2.type); |
30 | 32 |
31 BeginFrameArgs args3 = CreateExpiredBeginFrameArgsForTesting(); | 33 BeginFrameArgs args3 = |
| 34 CreateExpiredBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE); |
32 EXPECT_TRUE(args3.IsValid()) << args3; | 35 EXPECT_TRUE(args3.IsValid()) << args3; |
33 EXPECT_GT(gfx::FrameTime::Now(), args3.deadline); | 36 EXPECT_GT(gfx::FrameTime::Now(), args3.deadline); |
34 EXPECT_EQ(BeginFrameArgs::NORMAL, args3.type); | 37 EXPECT_EQ(BeginFrameArgs::NORMAL, args3.type); |
35 | 38 |
36 BeginFrameArgs args4 = | 39 BeginFrameArgs args4 = CreateBeginFrameArgsForTesting( |
37 CreateBeginFrameArgsForTesting(1, 2, 3, BeginFrameArgs::MISSED); | 40 BEGINFRAME_FROM_HERE, 1, 2, 3, BeginFrameArgs::MISSED); |
38 EXPECT_TRUE(args4.IsValid()) << args4; | 41 EXPECT_TRUE(args4.IsValid()) << args4; |
39 EXPECT_EQ(1, args4.frame_time.ToInternalValue()); | 42 EXPECT_EQ(1, args4.frame_time.ToInternalValue()); |
40 EXPECT_EQ(2, args4.deadline.ToInternalValue()); | 43 EXPECT_EQ(2, args4.deadline.ToInternalValue()); |
41 EXPECT_EQ(3, args4.interval.ToInternalValue()); | 44 EXPECT_EQ(3, args4.interval.ToInternalValue()); |
42 EXPECT_EQ(BeginFrameArgs::MISSED, args4.type); | 45 EXPECT_EQ(BeginFrameArgs::MISSED, args4.type); |
43 | 46 |
44 // operator== | 47 // operator== |
45 EXPECT_EQ(CreateBeginFrameArgsForTesting(4, 5, 6), | 48 EXPECT_EQ(CreateBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE, 4, 5, 6), |
46 CreateBeginFrameArgsForTesting(4, 5, 6)); | 49 CreateBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE, 4, 5, 6)); |
47 | 50 |
48 EXPECT_NONFATAL_FAILURE( | 51 EXPECT_NONFATAL_FAILURE( |
49 EXPECT_EQ(CreateBeginFrameArgsForTesting(7, 8, 9, BeginFrameArgs::MISSED), | 52 EXPECT_EQ(CreateBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE, 7, 8, 9, |
50 CreateBeginFrameArgsForTesting(7, 8, 9)), | 53 BeginFrameArgs::MISSED), |
| 54 CreateBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE, 7, 8, 9)), |
51 ""); | 55 ""); |
52 EXPECT_NONFATAL_FAILURE(EXPECT_EQ(CreateBeginFrameArgsForTesting(4, 5, 6), | 56 |
53 CreateBeginFrameArgsForTesting(7, 8, 9)), | 57 EXPECT_NONFATAL_FAILURE( |
54 ""); | 58 EXPECT_EQ(CreateBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE, 4, 5, 6), |
| 59 CreateBeginFrameArgsForTesting(BEGINFRAME_FROM_HERE, 7, 8, 9)), |
| 60 ""); |
55 | 61 |
56 // operator<< | 62 // operator<< |
57 std::stringstream out1; | 63 std::stringstream out1; |
58 out1 << args1; | 64 out1 << args1; |
59 EXPECT_EQ("BeginFrameArgs(NORMAL, 0, 0, -1us)", out1.str()); | 65 EXPECT_EQ("BeginFrameArgs(NORMAL, 0, 0, -1us)", out1.str()); |
60 std::stringstream out2; | 66 std::stringstream out2; |
61 out2 << args2; | 67 out2 << args2; |
62 EXPECT_EQ("BeginFrameArgs(NORMAL, 1, 2, 3us)", out2.str()); | 68 EXPECT_EQ("BeginFrameArgs(NORMAL, 1, 2, 3us)", out2.str()); |
63 | 69 |
64 // PrintTo | 70 // PrintTo |
65 EXPECT_EQ(std::string("BeginFrameArgs(NORMAL, 0, 0, -1us)"), | 71 EXPECT_EQ(std::string("BeginFrameArgs(NORMAL, 0, 0, -1us)"), |
66 ::testing::PrintToString(args1)); | 72 ::testing::PrintToString(args1)); |
67 EXPECT_EQ(std::string("BeginFrameArgs(NORMAL, 1, 2, 3us)"), | 73 EXPECT_EQ(std::string("BeginFrameArgs(NORMAL, 1, 2, 3us)"), |
68 ::testing::PrintToString(args2)); | 74 ::testing::PrintToString(args2)); |
69 } | 75 } |
70 | 76 |
71 TEST(BeginFrameArgsTest, Create) { | 77 TEST(BeginFrameArgsTest, Create) { |
72 // BeginFrames are not valid by default | 78 // BeginFrames are not valid by default |
73 BeginFrameArgs args1; | 79 BeginFrameArgs args1; |
74 EXPECT_FALSE(args1.IsValid()) << args1; | 80 EXPECT_FALSE(args1.IsValid()) << args1; |
75 | 81 |
76 BeginFrameArgs args2 = BeginFrameArgs::Create( | 82 BeginFrameArgs args2 = BeginFrameArgs::Create( |
77 base::TimeTicks::FromInternalValue(1), | 83 BEGINFRAME_FROM_HERE, base::TimeTicks::FromInternalValue(1), |
78 base::TimeTicks::FromInternalValue(2), | 84 base::TimeTicks::FromInternalValue(2), |
79 base::TimeDelta::FromInternalValue(3), BeginFrameArgs::NORMAL); | 85 base::TimeDelta::FromInternalValue(3), BeginFrameArgs::NORMAL); |
80 EXPECT_TRUE(args2.IsValid()) << args2; | 86 EXPECT_TRUE(args2.IsValid()) << args2; |
81 EXPECT_EQ(1, args2.frame_time.ToInternalValue()) << args2; | 87 EXPECT_EQ(1, args2.frame_time.ToInternalValue()) << args2; |
82 EXPECT_EQ(2, args2.deadline.ToInternalValue()) << args2; | 88 EXPECT_EQ(2, args2.deadline.ToInternalValue()) << args2; |
83 EXPECT_EQ(3, args2.interval.ToInternalValue()) << args2; | 89 EXPECT_EQ(3, args2.interval.ToInternalValue()) << args2; |
84 EXPECT_EQ(BeginFrameArgs::NORMAL, args2.type) << args2; | 90 EXPECT_EQ(BeginFrameArgs::NORMAL, args2.type) << args2; |
85 } | 91 } |
86 | 92 |
| 93 #ifndef NDEBUG |
| 94 TEST(BeginFrameArgsTest, Location) { |
| 95 tracked_objects::Location expected_location = BEGINFRAME_FROM_HERE; |
| 96 |
| 97 BeginFrameArgs args = CreateBeginFrameArgsForTesting(expected_location); |
| 98 EXPECT_EQ(expected_location.ToString(), args.created_from.ToString()); |
| 99 } |
| 100 #endif |
| 101 |
87 } // namespace | 102 } // namespace |
88 } // namespace cc | 103 } // namespace cc |
OLD | NEW |