blob: 5b397de36a8690c8184c605d94881b668bc7685f [file] [log] [blame]
Jorim Jaggi10f328c2021-01-19 00:08:02 +01001/*
2 * Copyright (C) 2021 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include <gtest/gtest.h>
18#include <gmock/gmock.h>
19
20#include <JankTracker.h>
21#include <utils/TimeUtils.h>
22
23using namespace android;
24using namespace android::uirenderer;
25
26class TestFrameMetricsObserver : public FrameMetricsObserver {
27public:
28 void notify(const int64_t*) {}
29};
30
31TEST(JankTracker, noJank) {
32 std::mutex mutex;
33 ProfileDataContainer container(mutex);
34 JankTracker jankTracker(&container);
35 std::unique_ptr<FrameMetricsReporter> reporter = std::make_unique<FrameMetricsReporter>();
36
Pablo Gamito0aa775e2021-08-26 00:57:23 +020037 uint64_t frameNumber = 0;
38 uint32_t surfaceId = 0;
39
Jorim Jaggi10f328c2021-01-19 00:08:02 +010040 FrameInfo* info = jankTracker.startFrame();
41 info->set(FrameInfoIndex::IntendedVsync) = 100_ms;
42 info->set(FrameInfoIndex::Vsync) = 101_ms;
43 info->set(FrameInfoIndex::SwapBuffersCompleted) = 115_ms;
44 info->set(FrameInfoIndex::GpuCompleted) = 115_ms;
45 info->set(FrameInfoIndex::FrameCompleted) = 115_ms;
46 info->set(FrameInfoIndex::FrameInterval) = 16_ms;
47 info->set(FrameInfoIndex::FrameDeadline) = 120_ms;
Pablo Gamito0aa775e2021-08-26 00:57:23 +020048 jankTracker.finishFrame(*info, reporter, frameNumber, surfaceId);
Jorim Jaggi10f328c2021-01-19 00:08:02 +010049
50 info = jankTracker.startFrame();
51 info->set(FrameInfoIndex::IntendedVsync) = 116_ms;
52 info->set(FrameInfoIndex::Vsync) = 117_ms;
53 info->set(FrameInfoIndex::SwapBuffersCompleted) = 129_ms;
54 info->set(FrameInfoIndex::GpuCompleted) = 131_ms;
55 info->set(FrameInfoIndex::FrameCompleted) = 131_ms;
56 info->set(FrameInfoIndex::FrameInterval) = 16_ms;
57 info->set(FrameInfoIndex::FrameDeadline) = 136_ms;
Pablo Gamito0aa775e2021-08-26 00:57:23 +020058 jankTracker.finishFrame(*info, reporter, frameNumber, surfaceId);
Jorim Jaggi10f328c2021-01-19 00:08:02 +010059
60 ASSERT_EQ(2, container.get()->totalFrameCount());
61 ASSERT_EQ(0, container.get()->jankFrameCount());
62}
63
64
65TEST(JankTracker, jank) {
66 std::mutex mutex;
67 ProfileDataContainer container(mutex);
68 JankTracker jankTracker(&container);
69 std::unique_ptr<FrameMetricsReporter> reporter = std::make_unique<FrameMetricsReporter>();
70
Pablo Gamito0aa775e2021-08-26 00:57:23 +020071 uint64_t frameNumber = 0;
72 uint32_t surfaceId = 0;
73
Jorim Jaggi10f328c2021-01-19 00:08:02 +010074 FrameInfo* info = jankTracker.startFrame();
75 info->set(FrameInfoIndex::IntendedVsync) = 100_ms;
76 info->set(FrameInfoIndex::Vsync) = 101_ms;
77 info->set(FrameInfoIndex::SwapBuffersCompleted) = 115_ms;
78 info->set(FrameInfoIndex::GpuCompleted) = 121_ms;
79 info->set(FrameInfoIndex::FrameCompleted) = 121_ms;
80 info->set(FrameInfoIndex::FrameInterval) = 16_ms;
81 info->set(FrameInfoIndex::FrameDeadline) = 120_ms;
Pablo Gamito0aa775e2021-08-26 00:57:23 +020082 jankTracker.finishFrame(*info, reporter, frameNumber, surfaceId);
Jorim Jaggi10f328c2021-01-19 00:08:02 +010083
84 ASSERT_EQ(1, container.get()->totalFrameCount());
85 ASSERT_EQ(1, container.get()->jankFrameCount());
86}
87
88TEST(JankTracker, legacyJankButNoRealJank) {
89 std::mutex mutex;
90 ProfileDataContainer container(mutex);
91 JankTracker jankTracker(&container);
92 std::unique_ptr<FrameMetricsReporter> reporter = std::make_unique<FrameMetricsReporter>();
93
Pablo Gamito0aa775e2021-08-26 00:57:23 +020094 uint64_t frameNumber = 0;
95 uint32_t surfaceId = 0;
96
Jorim Jaggi10f328c2021-01-19 00:08:02 +010097 FrameInfo* info = jankTracker.startFrame();
98 info->set(FrameInfoIndex::IntendedVsync) = 100_ms;
99 info->set(FrameInfoIndex::Vsync) = 101_ms;
100 info->set(FrameInfoIndex::SwapBuffersCompleted) = 117_ms;
101 info->set(FrameInfoIndex::GpuCompleted) = 118_ms;
102 info->set(FrameInfoIndex::FrameCompleted) = 118_ms;
103 info->set(FrameInfoIndex::FrameInterval) = 16_ms;
104 info->set(FrameInfoIndex::FrameDeadline) = 120_ms;
Pablo Gamito0aa775e2021-08-26 00:57:23 +0200105 jankTracker.finishFrame(*info, reporter, frameNumber, surfaceId);
Jorim Jaggi10f328c2021-01-19 00:08:02 +0100106
107 ASSERT_EQ(1, container.get()->totalFrameCount());
108 ASSERT_EQ(0, container.get()->jankFrameCount());
109 ASSERT_EQ(1, container.get()->jankLegacyFrameCount());
110}
111
112TEST(JankTracker, doubleStuffed) {
113 std::mutex mutex;
114 ProfileDataContainer container(mutex);
115 JankTracker jankTracker(&container);
116 std::unique_ptr<FrameMetricsReporter> reporter = std::make_unique<FrameMetricsReporter>();
117
Pablo Gamito0aa775e2021-08-26 00:57:23 +0200118 uint64_t frameNumber = 0;
119 uint32_t surfaceId = 0;
120
Jorim Jaggi10f328c2021-01-19 00:08:02 +0100121 // First frame janks
122 FrameInfo* info = jankTracker.startFrame();
123 info->set(FrameInfoIndex::IntendedVsync) = 100_ms;
124 info->set(FrameInfoIndex::Vsync) = 101_ms;
125 info->set(FrameInfoIndex::SwapBuffersCompleted) = 115_ms;
126 info->set(FrameInfoIndex::GpuCompleted) = 121_ms;
127 info->set(FrameInfoIndex::FrameCompleted) = 121_ms;
128 info->set(FrameInfoIndex::FrameInterval) = 16_ms;
129 info->set(FrameInfoIndex::FrameDeadline) = 120_ms;
Pablo Gamito0aa775e2021-08-26 00:57:23 +0200130 jankTracker.finishFrame(*info, reporter, frameNumber, surfaceId);
Jorim Jaggi10f328c2021-01-19 00:08:02 +0100131
132 ASSERT_EQ(1, container.get()->jankFrameCount());
133
134 // Second frame is long, but doesn't jank because double-stuffed.
135 info = jankTracker.startFrame();
136 info->set(FrameInfoIndex::IntendedVsync) = 116_ms;
137 info->set(FrameInfoIndex::Vsync) = 122_ms;
138 info->set(FrameInfoIndex::SwapBuffersCompleted) = 129_ms;
139 info->set(FrameInfoIndex::GpuCompleted) = 137_ms;
140 info->set(FrameInfoIndex::FrameCompleted) = 137_ms;
141 info->set(FrameInfoIndex::FrameInterval) = 16_ms;
142 info->set(FrameInfoIndex::FrameDeadline) = 136_ms;
Pablo Gamito0aa775e2021-08-26 00:57:23 +0200143 jankTracker.finishFrame(*info, reporter, frameNumber, surfaceId);
Jorim Jaggi10f328c2021-01-19 00:08:02 +0100144
145 ASSERT_EQ(2, container.get()->totalFrameCount());
146 ASSERT_EQ(1, container.get()->jankFrameCount());
147}
148
149TEST(JankTracker, doubleStuffedThenPauseThenJank) {
150 std::mutex mutex;
151 ProfileDataContainer container(mutex);
152 JankTracker jankTracker(&container);
153 std::unique_ptr<FrameMetricsReporter> reporter = std::make_unique<FrameMetricsReporter>();
154
Pablo Gamito0aa775e2021-08-26 00:57:23 +0200155 uint64_t frameNumber = 0;
156 uint32_t surfaceId = 0;
157
Jorim Jaggi10f328c2021-01-19 00:08:02 +0100158 // First frame janks
159 FrameInfo* info = jankTracker.startFrame();
160 info->set(FrameInfoIndex::IntendedVsync) = 100_ms;
161 info->set(FrameInfoIndex::Vsync) = 101_ms;
162 info->set(FrameInfoIndex::SwapBuffersCompleted) = 115_ms;
163 info->set(FrameInfoIndex::GpuCompleted) = 121_ms;
164 info->set(FrameInfoIndex::FrameCompleted) = 121_ms;
165 info->set(FrameInfoIndex::FrameInterval) = 16_ms;
166 info->set(FrameInfoIndex::FrameDeadline) = 120_ms;
Pablo Gamito0aa775e2021-08-26 00:57:23 +0200167 jankTracker.finishFrame(*info, reporter, frameNumber, surfaceId);
Jorim Jaggi10f328c2021-01-19 00:08:02 +0100168
169 ASSERT_EQ(1, container.get()->jankFrameCount());
170
171 // Second frame is long, but doesn't jank because double-stuffed.
172 info = jankTracker.startFrame();
173 info->set(FrameInfoIndex::IntendedVsync) = 116_ms;
174 info->set(FrameInfoIndex::Vsync) = 122_ms;
175 info->set(FrameInfoIndex::SwapBuffersCompleted) = 129_ms;
176 info->set(FrameInfoIndex::GpuCompleted) = 137_ms;
177 info->set(FrameInfoIndex::FrameCompleted) = 137_ms;
178 info->set(FrameInfoIndex::FrameInterval) = 16_ms;
179 info->set(FrameInfoIndex::FrameDeadline) = 136_ms;
Pablo Gamito0aa775e2021-08-26 00:57:23 +0200180 jankTracker.finishFrame(*info, reporter, frameNumber, surfaceId);
Jorim Jaggi10f328c2021-01-19 00:08:02 +0100181
182 ASSERT_EQ(1, container.get()->jankFrameCount());
183
184 // Thirdframe is long and skips one frame some double stuffed logic gets reset
185 info = jankTracker.startFrame();
186 info->set(FrameInfoIndex::IntendedVsync) = 148_ms;
187 info->set(FrameInfoIndex::Vsync) = 148_ms;
188 info->set(FrameInfoIndex::SwapBuffersCompleted) = 160_ms;
189 info->set(FrameInfoIndex::GpuCompleted) = 169_ms;
190 info->set(FrameInfoIndex::FrameCompleted) = 169_ms;
191 info->set(FrameInfoIndex::FrameInterval) = 16_ms;
192 info->set(FrameInfoIndex::FrameDeadline) = 168_ms;
Pablo Gamito0aa775e2021-08-26 00:57:23 +0200193 jankTracker.finishFrame(*info, reporter, frameNumber, surfaceId);
Jorim Jaggi10f328c2021-01-19 00:08:02 +0100194
195 ASSERT_EQ(3, container.get()->totalFrameCount());
196 ASSERT_EQ(2, container.get()->jankFrameCount());
Pablo Gamito0aa775e2021-08-26 00:57:23 +0200197}