blob: 09507218d01a22fdb9866734a0b5eccf63e3dc20 [file] [log] [blame]
Sudheer Shanka9b735c52017-05-09 18:26:18 -07001/*
2 * Copyright (C) 2017 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
17package com.android.internal.os;
18
Sudheer Shankab8ad5942017-08-08 12:16:09 -070019import static org.junit.Assert.assertArrayEquals;
20import static org.junit.Assert.assertEquals;
21import static org.junit.Assert.assertFalse;
Mike Ma2ab01442018-02-13 14:22:47 -080022import static org.junit.Assert.assertNotNull;
Sudheer Shankab8ad5942017-08-08 12:16:09 -070023import static org.junit.Assert.assertTrue;
Sudheer Shanka9b735c52017-05-09 18:26:18 -070024import static org.mockito.Mockito.verifyNoMoreInteractions;
Sudheer Shanka59f5c002017-05-15 10:57:15 -070025import static org.mockito.Mockito.verifyZeroInteractions;
Sudheer Shanka9b735c52017-05-09 18:26:18 -070026import static org.mockito.Mockito.when;
27
28import android.support.test.filters.SmallTest;
29import android.support.test.runner.AndroidJUnit4;
Mike Ma2ab01442018-02-13 14:22:47 -080030import android.util.SparseArray;
Sudheer Shanka9b735c52017-05-09 18:26:18 -070031
32import org.junit.Before;
33import org.junit.Test;
34import org.junit.runner.RunWith;
35import org.mockito.Mock;
Sudheer Shanka59f5c002017-05-15 10:57:15 -070036import org.mockito.Mockito;
Sudheer Shanka9b735c52017-05-09 18:26:18 -070037import org.mockito.MockitoAnnotations;
38
39import java.io.BufferedReader;
Mike Ma2ab01442018-02-13 14:22:47 -080040import java.nio.ByteBuffer;
41import java.nio.ByteOrder;
Sudheer Shankab8ad5942017-08-08 12:16:09 -070042import java.util.Arrays;
Sudheer Shanka9b735c52017-05-09 18:26:18 -070043
44/**
45 * Test class for {@link KernelUidCpuFreqTimeReader}.
46 *
47 * To run the tests, use
48 *
49 * runtest -c com.android.internal.os.KernelUidCpuFreqTimeReaderTest frameworks-core
50 *
51 * or the following steps:
52 *
53 * Build: m FrameworksCoreTests
54 * Install: adb install -r \
Mike Ma2ab01442018-02-13 14:22:47 -080055 * ${ANDROID_PRODUCT_OUT}/data/app/FrameworksCoreTests/FrameworksCoreTests.apk
Sudheer Shanka9b735c52017-05-09 18:26:18 -070056 * Run: adb shell am instrument -e class com.android.internal.os.KernelUidCpuFreqTimeReaderTest -w \
Mike Ma2ab01442018-02-13 14:22:47 -080057 * com.android.frameworks.coretests/android.support.test.runner.AndroidJUnitRunner
Sudheer Shankab8ad5942017-08-08 12:16:09 -070058 *
59 * or
60 *
61 * bit FrameworksCoreTests:com.android.internal.os.KernelUidCpuFreqTimeReaderTest
Sudheer Shanka9b735c52017-05-09 18:26:18 -070062 */
63@SmallTest
64@RunWith(AndroidJUnit4.class)
65public class KernelUidCpuFreqTimeReaderTest {
Mike Ma2ab01442018-02-13 14:22:47 -080066 @Mock
67 private BufferedReader mBufferedReader;
68 @Mock
69 private KernelUidCpuFreqTimeReader.Callback mCallback;
70 @Mock
71 private PowerProfile mPowerProfile;
72 @Mock
73 private KernelCpuProcReader mProcReader;
Sudheer Shanka9b735c52017-05-09 18:26:18 -070074
75 private KernelUidCpuFreqTimeReader mKernelUidCpuFreqTimeReader;
76
77 @Before
78 public void setUp() {
79 MockitoAnnotations.initMocks(this);
Mike Ma2ab01442018-02-13 14:22:47 -080080 mKernelUidCpuFreqTimeReader = new KernelUidCpuFreqTimeReader(mProcReader);
81 mKernelUidCpuFreqTimeReader.setThrottleInterval(0);
Sudheer Shanka9b735c52017-05-09 18:26:18 -070082 }
83
84 @Test
Sudheer Shankab8ad5942017-08-08 12:16:09 -070085 public void testReadFreqs_perClusterTimesNotAvailable() throws Exception {
86 final long[][] freqs = {
87 {1, 12, 123, 1234},
88 {1, 12, 123, 23, 123, 1234, 12345, 123456},
89 {1, 12, 123, 23, 123, 1234, 12345, 123456, 12, 123, 12345},
90 {1, 12, 123, 23, 2345, 234567}
91 };
92 final int[] numClusters = {2, 2, 3, 1};
93 final int[][] numFreqs = {{3, 6}, {4, 5}, {3, 5, 4}, {3}};
94 for (int i = 0; i < freqs.length; ++i) {
95 setCpuClusterFreqs(numClusters[i], numFreqs[i]);
96 when(mBufferedReader.readLine()).thenReturn(getFreqsLine(freqs[i]));
97 long[] actualFreqs = mKernelUidCpuFreqTimeReader.readFreqs(
98 mBufferedReader, mPowerProfile);
99 assertArrayEquals(freqs[i], actualFreqs);
100 verifyZeroInteractions(mCallback);
101 final String errMsg = String.format("Freqs=%s, nClusters=%d, nFreqs=%s",
102 Arrays.toString(freqs[i]), numClusters[i], Arrays.toString(numFreqs[i]));
103 assertFalse(errMsg, mKernelUidCpuFreqTimeReader.perClusterTimesAvailable());
104
105 // Verify that a second call won't read the proc file again
106 Mockito.reset(mBufferedReader);
107 actualFreqs = mKernelUidCpuFreqTimeReader.readFreqs(mPowerProfile);
108 assertArrayEquals(freqs[i], actualFreqs);
109 assertFalse(errMsg, mKernelUidCpuFreqTimeReader.perClusterTimesAvailable());
110
111 // Prepare for next iteration
112 Mockito.reset(mBufferedReader, mPowerProfile);
113 }
114 }
115
116 @Test
117 public void testReadFreqs_perClusterTimesAvailable() throws Exception {
118 final long[][] freqs = {
119 {1, 12, 123, 1234},
120 {1, 12, 123, 23, 123, 1234, 12345, 123456},
121 {1, 12, 123, 23, 123, 1234, 12345, 123456, 12, 123, 12345, 1234567}
122 };
123 final int[] numClusters = {1, 2, 3};
124 final int[][] numFreqs = {{4}, {3, 5}, {3, 5, 4}};
125 for (int i = 0; i < freqs.length; ++i) {
126 setCpuClusterFreqs(numClusters[i], numFreqs[i]);
127 when(mBufferedReader.readLine()).thenReturn(getFreqsLine(freqs[i]));
128 long[] actualFreqs = mKernelUidCpuFreqTimeReader.readFreqs(
129 mBufferedReader, mPowerProfile);
130 assertArrayEquals(freqs[i], actualFreqs);
131 verifyZeroInteractions(mCallback);
132 final String errMsg = String.format("Freqs=%s, nClusters=%d, nFreqs=%s",
133 Arrays.toString(freqs[i]), numClusters[i], Arrays.toString(numFreqs[i]));
134 assertTrue(errMsg, mKernelUidCpuFreqTimeReader.perClusterTimesAvailable());
135
136 // Verify that a second call won't read the proc file again
137 Mockito.reset(mBufferedReader);
138 actualFreqs = mKernelUidCpuFreqTimeReader.readFreqs(mPowerProfile);
139 assertArrayEquals(freqs[i], actualFreqs);
140 assertTrue(errMsg, mKernelUidCpuFreqTimeReader.perClusterTimesAvailable());
141
142 // Prepare for next iteration
143 Mockito.reset(mBufferedReader, mPowerProfile);
144 }
145 }
146
147 @Test
Sudheer Shanka9b735c52017-05-09 18:26:18 -0700148 public void testReadDelta() throws Exception {
149 final long[] freqs = {1, 12, 123, 1234, 12345, 123456};
150 final int[] uids = {1, 22, 333, 4444, 5555};
151 final long[][] times = new long[uids.length][freqs.length];
152 for (int i = 0; i < uids.length; ++i) {
153 for (int j = 0; j < freqs.length; ++j) {
154 times[i][j] = uids[i] * freqs[j] * 10;
155 }
156 }
Sudheer Shankab8ad5942017-08-08 12:16:09 -0700157 when(mBufferedReader.readLine()).thenReturn(getFreqsLine(freqs));
158 long[] actualFreqs = mKernelUidCpuFreqTimeReader.readFreqs(mBufferedReader, mPowerProfile);
159
160 assertArrayEquals(freqs, actualFreqs);
Sudheer Shanka9b735c52017-05-09 18:26:18 -0700161 when(mBufferedReader.readLine())
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700162 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, times));
Sudheer Shanka9b735c52017-05-09 18:26:18 -0700163 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, mCallback);
Sudheer Shanka9b735c52017-05-09 18:26:18 -0700164 for (int i = 0; i < uids.length; ++i) {
Mike Ma2ab01442018-02-13 14:22:47 -0800165 Mockito.verify(mCallback).onUidCpuFreqTime(uids[i], times[i]);
Sudheer Shanka9b735c52017-05-09 18:26:18 -0700166 }
167 verifyNoMoreInteractions(mCallback);
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700168
169 // Verify that a second call will only return deltas.
170 Mockito.reset(mCallback, mBufferedReader);
171 final long[][] newTimes1 = new long[uids.length][freqs.length];
172 for (int i = 0; i < uids.length; ++i) {
173 for (int j = 0; j < freqs.length; ++j) {
174 newTimes1[i][j] = (times[i][j] + uids[i] + freqs[j]) * 10;
175 }
176 }
177 when(mBufferedReader.readLine())
178 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, newTimes1));
179 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, mCallback);
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700180 for (int i = 0; i < uids.length; ++i) {
Mike Ma2ab01442018-02-13 14:22:47 -0800181 Mockito.verify(mCallback).onUidCpuFreqTime(uids[i], subtract(newTimes1[i], times[i]));
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700182 }
183 verifyNoMoreInteractions(mCallback);
184
Sudheer Shanka00857522017-07-06 18:28:14 -0700185 // Verify that there won't be a callback if the proc file values didn't change.
186 Mockito.reset(mCallback, mBufferedReader);
187 when(mBufferedReader.readLine())
188 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, newTimes1));
189 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, mCallback);
Sudheer Shanka00857522017-07-06 18:28:14 -0700190 verifyNoMoreInteractions(mCallback);
191
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700192 // Verify that calling with a null callback doesn't result in any crashes
193 Mockito.reset(mCallback, mBufferedReader);
194 final long[][] newTimes2 = new long[uids.length][freqs.length];
195 for (int i = 0; i < uids.length; ++i) {
196 for (int j = 0; j < freqs.length; ++j) {
197 newTimes2[i][j] = (newTimes1[i][j] + uids[i] * freqs[j]) * 10;
198 }
199 }
200 when(mBufferedReader.readLine())
201 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, newTimes2));
202 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, null);
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700203
204 // Verify that the readDelta call will only return deltas when
205 // the previous call had null callback.
206 Mockito.reset(mCallback, mBufferedReader);
207 final long[][] newTimes3 = new long[uids.length][freqs.length];
208 for (int i = 0; i < uids.length; ++i) {
209 for (int j = 0; j < freqs.length; ++j) {
210 newTimes3[i][j] = (newTimes2[i][j] * (uids[i] + freqs[j])) * 10;
211 }
212 }
213 when(mBufferedReader.readLine())
214 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, newTimes3));
215 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, mCallback);
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700216 for (int i = 0; i < uids.length; ++i) {
Mike Ma2ab01442018-02-13 14:22:47 -0800217 Mockito.verify(mCallback).onUidCpuFreqTime(uids[i],
218 subtract(newTimes3[i], newTimes2[i]));
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700219 }
220 verifyNoMoreInteractions(mCallback);
221 }
222
Sudheer Shanka00857522017-07-06 18:28:14 -0700223 @Test
Mike Ma2ab01442018-02-13 14:22:47 -0800224 public void testReadDelta_Binary() throws Exception {
225 VerifiableCallback cb = new VerifiableCallback();
226 final long[] freqs = {110, 123, 145, 167, 289, 997};
227 final int[] uids = {1, 22, 333, 444, 555};
228 final long[][] times = new long[uids.length][freqs.length];
229 for (int i = 0; i < uids.length; ++i) {
230 for (int j = 0; j < freqs.length; ++j) {
231 times[i][j] = uids[i] * freqs[j] * 10;
232 }
233 }
234 when(mBufferedReader.readLine()).thenReturn(getFreqsLine(freqs));
235 long[] actualFreqs = mKernelUidCpuFreqTimeReader.readFreqs(mBufferedReader, mPowerProfile);
236
237 assertArrayEquals(freqs, actualFreqs);
238 when(mProcReader.readBytes()).thenReturn(getUidTimesBytes(uids, times));
239 mKernelUidCpuFreqTimeReader.readDeltaBinary(cb);
240 for (int i = 0; i < uids.length; ++i) {
241 cb.verify(uids[i], times[i]);
242 }
243 cb.verifyNoMoreInteractions();
244
245 // Verify that a second call will only return deltas.
246 cb.clear();
247 Mockito.reset(mProcReader);
248 final long[][] newTimes1 = new long[uids.length][freqs.length];
249 for (int i = 0; i < uids.length; ++i) {
250 for (int j = 0; j < freqs.length; ++j) {
251 newTimes1[i][j] = times[i][j] + (uids[i] + freqs[j]) * 50;
252 }
253 }
254 when(mProcReader.readBytes()).thenReturn(getUidTimesBytes(uids, newTimes1));
255 mKernelUidCpuFreqTimeReader.readDeltaBinary(cb);
256 for (int i = 0; i < uids.length; ++i) {
257 cb.verify(uids[i], subtract(newTimes1[i], times[i]));
258 }
259 cb.verifyNoMoreInteractions();
260
261 // Verify that there won't be a callback if the proc file values didn't change.
262 cb.clear();
263 Mockito.reset(mProcReader);
264 when(mProcReader.readBytes()).thenReturn(getUidTimesBytes(uids, newTimes1));
265 mKernelUidCpuFreqTimeReader.readDeltaBinary(cb);
266 cb.verifyNoMoreInteractions();
267
268 // Verify that calling with a null callback doesn't result in any crashes
269 cb.clear();
270 Mockito.reset(mProcReader);
271 final long[][] newTimes2 = new long[uids.length][freqs.length];
272 for (int i = 0; i < uids.length; ++i) {
273 for (int j = 0; j < freqs.length; ++j) {
274 newTimes2[i][j] = newTimes1[i][j] + (uids[i] * freqs[j]) * 30;
275 }
276 }
277 when(mProcReader.readBytes()).thenReturn(getUidTimesBytes(uids, newTimes2));
278 mKernelUidCpuFreqTimeReader.readDeltaBinary(null);
279 cb.verifyNoMoreInteractions();
280
281 // Verify that the readDelta call will only return deltas when
282 // the previous call had null callback.
283 cb.clear();
284 Mockito.reset(mProcReader);
285 final long[][] newTimes3 = new long[uids.length][freqs.length];
286 for (int i = 0; i < uids.length; ++i) {
287 for (int j = 0; j < freqs.length; ++j) {
288 newTimes3[i][j] = newTimes2[i][j] + (uids[i] + freqs[j]) * 40;
289 }
290 }
291 when(mProcReader.readBytes()).thenReturn(getUidTimesBytes(uids, newTimes3));
292 mKernelUidCpuFreqTimeReader.readDeltaBinary(cb);
293 for (int i = 0; i < uids.length; ++i) {
294 cb.verify(uids[i], subtract(newTimes3[i], newTimes2[i]));
295 }
296 cb.verifyNoMoreInteractions();
297 }
298
299 @Test
Sudheer Shanka00857522017-07-06 18:28:14 -0700300 public void testReadDelta_malformedData() throws Exception {
301 final long[] freqs = {1, 12, 123, 1234, 12345, 123456};
302 final int[] uids = {1, 22, 333, 4444, 5555};
303 final long[][] times = new long[uids.length][freqs.length];
304 for (int i = 0; i < uids.length; ++i) {
305 for (int j = 0; j < freqs.length; ++j) {
306 times[i][j] = uids[i] * freqs[j] * 10;
307 }
308 }
Sudheer Shankab8ad5942017-08-08 12:16:09 -0700309 when(mBufferedReader.readLine()).thenReturn(getFreqsLine(freqs));
310 long[] actualFreqs = mKernelUidCpuFreqTimeReader.readFreqs(mBufferedReader, mPowerProfile);
311
312 assertArrayEquals(freqs, actualFreqs);
Sudheer Shanka00857522017-07-06 18:28:14 -0700313 when(mBufferedReader.readLine())
314 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, times));
315 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, mCallback);
Sudheer Shanka00857522017-07-06 18:28:14 -0700316 for (int i = 0; i < uids.length; ++i) {
Mike Ma2ab01442018-02-13 14:22:47 -0800317 Mockito.verify(mCallback).onUidCpuFreqTime(uids[i], times[i]);
Sudheer Shanka00857522017-07-06 18:28:14 -0700318 }
319 verifyNoMoreInteractions(mCallback);
320
321 // Verify that there is no callback if any value in the proc file is -ve.
322 Mockito.reset(mCallback, mBufferedReader);
323 final long[][] newTimes1 = new long[uids.length][freqs.length];
324 for (int i = 0; i < uids.length; ++i) {
325 for (int j = 0; j < freqs.length; ++j) {
326 newTimes1[i][j] = (times[i][j] + uids[i] + freqs[j]) * 10;
327 }
328 }
329 newTimes1[uids.length - 1][freqs.length - 1] *= -1;
330 when(mBufferedReader.readLine())
331 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, newTimes1));
332 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, mCallback);
Sudheer Shanka00857522017-07-06 18:28:14 -0700333 for (int i = 0; i < uids.length; ++i) {
334 if (i == uids.length - 1) {
335 continue;
336 }
Mike Ma2ab01442018-02-13 14:22:47 -0800337 Mockito.verify(mCallback).onUidCpuFreqTime(uids[i], subtract(newTimes1[i], times[i]));
Sudheer Shanka00857522017-07-06 18:28:14 -0700338 }
339 verifyNoMoreInteractions(mCallback);
340
341 // Verify that the internal state was not modified when the proc file had -ve value.
342 Mockito.reset(mCallback, mBufferedReader);
343 for (int i = 0; i < freqs.length; ++i) {
344 newTimes1[uids.length - 1][i] = times[uids.length - 1][i];
345 }
346 when(mBufferedReader.readLine())
347 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, newTimes1));
348 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, mCallback);
Sudheer Shanka00857522017-07-06 18:28:14 -0700349 verifyNoMoreInteractions(mCallback);
350
351 // Verify that there is no callback if the values in the proc file are decreased.
352 Mockito.reset(mCallback, mBufferedReader);
353 final long[][] newTimes2 = new long[uids.length][freqs.length];
354 for (int i = 0; i < uids.length; ++i) {
355 for (int j = 0; j < freqs.length; ++j) {
356 newTimes2[i][j] = (newTimes1[i][j] + uids[i] * freqs[j]) * 10;
357 }
358 }
359 newTimes2[uids.length - 1][freqs.length - 1] =
360 newTimes1[uids.length - 1][freqs.length - 1] - 222;
361 when(mBufferedReader.readLine())
362 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, newTimes2));
363 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, mCallback);
Sudheer Shanka00857522017-07-06 18:28:14 -0700364 for (int i = 0; i < uids.length; ++i) {
365 if (i == uids.length - 1) {
366 continue;
367 }
Mike Ma2ab01442018-02-13 14:22:47 -0800368 Mockito.verify(mCallback).onUidCpuFreqTime(uids[i],
369 subtract(newTimes2[i], newTimes1[i]));
Sudheer Shanka00857522017-07-06 18:28:14 -0700370 }
371 verifyNoMoreInteractions(mCallback);
372
373 // Verify that the internal state was not modified when the proc file had decreasing values.
374 Mockito.reset(mCallback, mBufferedReader);
375 for (int i = 0; i < freqs.length; ++i) {
376 newTimes2[uids.length - 1][i] = newTimes1[uids.length - 1][i];
377 }
378 when(mBufferedReader.readLine())
379 .thenReturn(getFreqsLine(freqs), getUidTimesLines(uids, newTimes2));
380 mKernelUidCpuFreqTimeReader.readDelta(mBufferedReader, mCallback);
Sudheer Shanka00857522017-07-06 18:28:14 -0700381 verifyNoMoreInteractions(mCallback);
382 }
383
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700384 private long[] subtract(long[] a1, long[] a2) {
385 long[] val = new long[a1.length];
386 for (int i = 0; i < val.length; ++i) {
387 val[i] = a1[i] - a2[i];
388 }
389 return val;
Sudheer Shanka9b735c52017-05-09 18:26:18 -0700390 }
391
392 private String getFreqsLine(long[] freqs) {
393 final StringBuilder sb = new StringBuilder();
394 sb.append("uid:");
395 for (int i = 0; i < freqs.length; ++i) {
396 sb.append(" " + freqs[i]);
397 }
398 return sb.toString();
399 }
400
401 private String[] getUidTimesLines(int[] uids, long[][] times) {
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700402 final String[] lines = new String[uids.length + 1];
Sudheer Shanka9b735c52017-05-09 18:26:18 -0700403 final StringBuilder sb = new StringBuilder();
404 for (int i = 0; i < uids.length; ++i) {
405 sb.setLength(0);
406 sb.append(uids[i] + ":");
407 for (int j = 0; j < times[i].length; ++j) {
408 sb.append(" " + times[i][j] / 10);
409 }
410 lines[i] = sb.toString();
411 }
Sudheer Shanka59f5c002017-05-15 10:57:15 -0700412 lines[uids.length] = null;
Sudheer Shanka9b735c52017-05-09 18:26:18 -0700413 return lines;
414 }
Sudheer Shankab8ad5942017-08-08 12:16:09 -0700415
Mike Ma2ab01442018-02-13 14:22:47 -0800416 private ByteBuffer getUidTimesBytes(int[] uids, long[][] times) {
417 int size = (1 + uids.length + uids.length * times[0].length) * 4;
418 ByteBuffer buf = ByteBuffer.allocate(size);
419 buf.order(ByteOrder.nativeOrder());
420 buf.putInt(times[0].length);
421 for (int i = 0; i < uids.length; i++) {
422 buf.putInt(uids[i]);
423 for (int j = 0; j < times[i].length; j++) {
424 buf.putInt((int) (times[i][j] / 10));
425 }
426 }
427 buf.flip();
428 return buf.asReadOnlyBuffer().order(ByteOrder.nativeOrder());
429 }
430
Sudheer Shankab8ad5942017-08-08 12:16:09 -0700431 private void setCpuClusterFreqs(int numClusters, int... clusterFreqs) {
432 assertEquals(numClusters, clusterFreqs.length);
433 when(mPowerProfile.getNumCpuClusters()).thenReturn(numClusters);
434 for (int i = 0; i < numClusters; ++i) {
435 when(mPowerProfile.getNumSpeedStepsInCpuCluster(i)).thenReturn(clusterFreqs[i]);
436 }
437 }
Mike Ma2ab01442018-02-13 14:22:47 -0800438
439 private class VerifiableCallback implements KernelUidCpuFreqTimeReader.Callback {
440
441 SparseArray<long[]> mData = new SparseArray<>();
442 int count = 0;
443
444 public void verify(int uid, long[] cpuFreqTimeMs) {
445 long[] array = mData.get(uid);
446 assertNotNull(array);
447 assertArrayEquals(cpuFreqTimeMs, array);
448 count++;
449 }
450
451 public void clear() {
452 mData.clear();
453 count = 0;
454 }
455
456 @Override
457 public void onUidCpuFreqTime(int uid, long[] cpuFreqTimeMs) {
458 long[] array = new long[cpuFreqTimeMs.length];
459 System.arraycopy(cpuFreqTimeMs, 0, array, 0, array.length);
460 mData.put(uid, array);
461 }
462
463 public void verifyNoMoreInteractions() {
464 assertEquals(mData.size(), count);
465 }
466 }
Sudheer Shanka9b735c52017-05-09 18:26:18 -0700467}