blob: 8739668bf4dec6ff81f267d94a5905778b834326 [file] [log] [blame]
Hongguang600a6ae2021-07-08 18:51:51 -07001/*
2 * Copyright 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 "VtsHalTvTunerTargetTest.h"
18
19#include <aidl/Gtest.h>
20#include <aidl/Vintf.h>
21#include <android/binder_manager.h>
22#include <android/binder_process.h>
23
24namespace {
25
26AssertionResult TunerBroadcastAidlTest::filterDataOutputTest() {
27 return filterDataOutputTestBase(mFilterTests);
28}
29
30AssertionResult TunerPlaybackAidlTest::filterDataOutputTest() {
31 return filterDataOutputTestBase(mFilterTests);
32}
33
34AssertionResult TunerDescramblerAidlTest::filterDataOutputTest() {
35 return filterDataOutputTestBase(mFilterTests);
36}
37
38void TunerFilterAidlTest::configSingleFilterInDemuxTest(FilterConfig filterConf,
39 FrontendConfig frontendConf) {
40 int32_t feId;
41 int32_t demuxId;
42 std::shared_ptr<IDemux> demux;
43 int64_t filterId;
44
45 mFrontendTests.getFrontendIdByType(frontendConf.type, feId);
46 ASSERT_TRUE(feId != INVALID_ID);
47 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
48 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
49 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
50 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
51 mFilterTests.setDemux(demux);
52 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
53 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
54 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
55 if (filterConf.type.mainType == DemuxFilterMainType::IP) {
56 ASSERT_TRUE(mFilterTests.configIpFilterCid(filterConf.ipCid, filterId));
57 }
58 if (filterConf.monitorEventTypes > 0) {
59 ASSERT_TRUE(mFilterTests.configureMonitorEvent(filterId, filterConf.monitorEventTypes));
60 }
61 ASSERT_TRUE(mFilterTests.getFilterMQDescriptor(filterId, filterConf.getMqDesc));
62 ASSERT_TRUE(mFilterTests.startFilter(filterId));
63 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
64 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
65 ASSERT_TRUE(mDemuxTests.closeDemux());
66 ASSERT_TRUE(mFrontendTests.closeFrontend());
67}
68
69void TunerFilterAidlTest::reconfigSingleFilterInDemuxTest(FilterConfig filterConf,
70 FilterConfig filterReconf,
71 FrontendConfig frontendConf) {
72 int32_t feId;
73 int32_t demuxId;
74 std::shared_ptr<IDemux> demux;
75 int64_t filterId;
76
77 mFrontendTests.getFrontendIdByType(frontendConf.type, feId);
78 ASSERT_TRUE(feId != INVALID_ID);
79 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
80 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
81 if (frontendConf.isSoftwareFe) {
82 mFrontendTests.setSoftwareFrontendDvrConfig(dvrMap[live.dvrSoftwareFeId]);
83 }
84 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
85 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
86 mFrontendTests.setDemux(demux);
87 mFilterTests.setDemux(demux);
88 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
89 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
90 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
91 ASSERT_TRUE(mFilterTests.getFilterMQDescriptor(filterId, filterConf.getMqDesc));
92 ASSERT_TRUE(mFilterTests.startFilter(filterId));
93 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
94 ASSERT_TRUE(mFilterTests.configFilter(filterReconf.settings, filterId));
95 ASSERT_TRUE(mFilterTests.startFilter(filterId));
96 ASSERT_TRUE(mFrontendTests.tuneFrontend(frontendConf, true /*testWithDemux*/));
97 ASSERT_TRUE(mFilterTests.startIdTest(filterId));
98 ASSERT_TRUE(mFrontendTests.stopTuneFrontend(true /*testWithDemux*/));
99 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
100 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
101 ASSERT_TRUE(mDemuxTests.closeDemux());
102 ASSERT_TRUE(mFrontendTests.closeFrontend());
103}
104
105void TunerFilterAidlTest::testTimeFilter(TimeFilterConfig filterConf) {
106 int32_t demuxId;
107 std::shared_ptr<IDemux> demux;
108 DemuxCapabilities caps;
109
110 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
111 ASSERT_TRUE(mDemuxTests.getDemuxCaps(caps));
112 ASSERT_TRUE(caps.bTimeFilter);
113 mFilterTests.setDemux(demux);
114 ASSERT_TRUE(mFilterTests.openTimeFilterInDemux());
115 ASSERT_TRUE(mFilterTests.setTimeStamp(filterConf.timeStamp));
116 ASSERT_TRUE(mFilterTests.getTimeStamp());
117 ASSERT_TRUE(mFilterTests.clearTimeStamp());
118 ASSERT_TRUE(mFilterTests.closeTimeFilter());
119 ASSERT_TRUE(mDemuxTests.closeDemux());
120}
121
122void TunerBroadcastAidlTest::broadcastSingleFilterTest(FilterConfig filterConf,
123 FrontendConfig frontendConf) {
124 int32_t feId;
125 int32_t demuxId;
126 std::shared_ptr<IDemux> demux;
127 int64_t filterId;
128
129 mFrontendTests.getFrontendIdByType(frontendConf.type, feId);
130 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
131 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
Frankie Lizcano87421812022-07-28 17:13:01 +0000132 if (mLnbId != INVALID_LNB_ID) {
133 ASSERT_TRUE(mFrontendTests.setLnb(mLnbId));
Hongguang600a6ae2021-07-08 18:51:51 -0700134 }
135 if (frontendConf.isSoftwareFe) {
136 mFrontendTests.setSoftwareFrontendDvrConfig(dvrMap[live.dvrSoftwareFeId]);
137 }
138 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
139 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
140 mFrontendTests.setDemux(demux);
141 mFilterTests.setDemux(demux);
142 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
143 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
144 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
145 ASSERT_TRUE(mFilterTests.getFilterMQDescriptor(filterId, filterConf.getMqDesc));
146 ASSERT_TRUE(mFilterTests.startFilter(filterId));
147 // tune test
148 ASSERT_TRUE(mFrontendTests.tuneFrontend(frontendConf, true /*testWithDemux*/));
149 ASSERT_TRUE(filterDataOutputTest());
150 ASSERT_TRUE(mFrontendTests.stopTuneFrontend(true /*testWithDemux*/));
151 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
152 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
153 ASSERT_TRUE(mDemuxTests.closeDemux());
154 ASSERT_TRUE(mFrontendTests.closeFrontend());
155}
156
157void TunerBroadcastAidlTest::broadcastSingleFilterTestWithLnb(FilterConfig filterConf,
158 FrontendConfig frontendConf,
159 LnbConfig lnbConf) {
160 if (lnbConf.name.compare(emptyHardwareId) == 0) {
161 vector<int32_t> ids;
162 ASSERT_TRUE(mLnbTests.getLnbIds(ids));
163 ASSERT_TRUE(ids.size() > 0);
164 ASSERT_TRUE(mLnbTests.openLnbById(ids[0]));
Frankie Lizcano87421812022-07-28 17:13:01 +0000165 mLnbId = ids[0];
Hongguang600a6ae2021-07-08 18:51:51 -0700166 } else {
Frankie Lizcano87421812022-07-28 17:13:01 +0000167 ASSERT_TRUE(mLnbTests.openLnbByName(lnbConf.name, mLnbId));
Hongguang600a6ae2021-07-08 18:51:51 -0700168 }
169 ASSERT_TRUE(mLnbTests.setLnbCallback());
170 ASSERT_TRUE(mLnbTests.setVoltage(lnbConf.voltage));
171 ASSERT_TRUE(mLnbTests.setTone(lnbConf.tone));
172 ASSERT_TRUE(mLnbTests.setSatellitePosition(lnbConf.position));
Frankie Lizcanod1f520e2022-07-26 20:05:46 +0000173 if (!frontendConf.isSoftwareFe) {
174 broadcastSingleFilterTest(filterConf, frontendConf);
175 }
Hongguang600a6ae2021-07-08 18:51:51 -0700176 ASSERT_TRUE(mLnbTests.closeLnb());
Frankie Lizcano87421812022-07-28 17:13:01 +0000177 mLnbId = INVALID_LNB_ID;
Hongguang600a6ae2021-07-08 18:51:51 -0700178}
179
180void TunerBroadcastAidlTest::mediaFilterUsingSharedMemoryTest(FilterConfig filterConf,
181 FrontendConfig frontendConf) {
182 int32_t feId;
183 int32_t demuxId;
184 std::shared_ptr<IDemux> demux;
185 int64_t filterId;
186
187 mFrontendTests.getFrontendIdByType(frontendConf.type, feId);
188 ASSERT_TRUE(feId != INVALID_ID);
189 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
190 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
191 if (frontendConf.isSoftwareFe) {
192 mFrontendTests.setSoftwareFrontendDvrConfig(dvrMap[live.dvrSoftwareFeId]);
193 }
194 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
195 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
196 mFrontendTests.setDemux(demux);
197 mFilterTests.setDemux(demux);
198 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
199 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
200 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
201 ASSERT_TRUE(mFilterTests.getSharedAvMemoryHandle(filterId));
202 ASSERT_TRUE(mFilterTests.configAvFilterStreamType(filterConf.streamType, filterId));
203 ASSERT_TRUE(mFilterTests.getFilterMQDescriptor(filterId, filterConf.getMqDesc));
204 ASSERT_TRUE(mFilterTests.startFilter(filterId));
205 // tune test
206 ASSERT_TRUE(mFrontendTests.tuneFrontend(frontendConf, true /*testWithDemux*/));
207 ASSERT_TRUE(filterDataOutputTest());
208 ASSERT_TRUE(mFrontendTests.stopTuneFrontend(true /*testWithDemux*/));
209 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
210 ASSERT_TRUE(mFilterTests.releaseShareAvHandle(filterId));
211 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
212 ASSERT_TRUE(mDemuxTests.closeDemux());
213 ASSERT_TRUE(mFrontendTests.closeFrontend());
214}
215
216void TunerPlaybackAidlTest::playbackSingleFilterTest(FilterConfig filterConf, DvrConfig dvrConf) {
217 int32_t demuxId;
218 std::shared_ptr<IDemux> demux;
219 int64_t filterId;
220
221 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
222 mFilterTests.setDemux(demux);
223 mDvrTests.setDemux(demux);
224 ASSERT_TRUE(mDvrTests.openDvrInDemux(dvrConf.type, dvrConf.bufferSize));
225 ASSERT_TRUE(mDvrTests.configDvrPlayback(dvrConf.settings));
226 ASSERT_TRUE(mDvrTests.getDvrPlaybackMQDescriptor());
227 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
228 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
229 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
230 ASSERT_TRUE(mFilterTests.getFilterMQDescriptor(filterId, filterConf.getMqDesc));
231 mDvrTests.startPlaybackInputThread(dvrConf.playbackInputFile,
232 dvrConf.settings.get<DvrSettings::Tag::playback>());
233 ASSERT_TRUE(mDvrTests.startDvrPlayback());
234 ASSERT_TRUE(mFilterTests.startFilter(filterId));
235 ASSERT_TRUE(filterDataOutputTest());
236 mDvrTests.stopPlaybackThread();
237 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
238 ASSERT_TRUE(mDvrTests.stopDvrPlayback());
239 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
240 mDvrTests.closeDvrPlayback();
241 ASSERT_TRUE(mDemuxTests.closeDemux());
242}
243
244void TunerRecordAidlTest::recordSingleFilterTestWithLnb(FilterConfig filterConf,
245 FrontendConfig frontendConf,
246 DvrConfig dvrConf, LnbConfig lnbConf) {
247 if (lnbConf.name.compare(emptyHardwareId) == 0) {
248 vector<int32_t> ids;
249 ASSERT_TRUE(mLnbTests.getLnbIds(ids));
250 ASSERT_TRUE(ids.size() > 0);
251 ASSERT_TRUE(mLnbTests.openLnbById(ids[0]));
Frankie Lizcano87421812022-07-28 17:13:01 +0000252 mLnbId = ids[0];
Hongguang600a6ae2021-07-08 18:51:51 -0700253 } else {
Frankie Lizcano87421812022-07-28 17:13:01 +0000254 ASSERT_TRUE(mLnbTests.openLnbByName(lnbConf.name, mLnbId));
Hongguang600a6ae2021-07-08 18:51:51 -0700255 }
256 ASSERT_TRUE(mLnbTests.setLnbCallback());
257 ASSERT_TRUE(mLnbTests.setVoltage(lnbConf.voltage));
258 ASSERT_TRUE(mLnbTests.setTone(lnbConf.tone));
259 ASSERT_TRUE(mLnbTests.setSatellitePosition(lnbConf.position));
260 for (auto msgName : lnbRecord.diseqcMsgs) {
261 ASSERT_TRUE(mLnbTests.sendDiseqcMessage(diseqcMsgMap[msgName]));
262 }
263 recordSingleFilterTest(filterConf, frontendConf, dvrConf);
264 ASSERT_TRUE(mLnbTests.closeLnb());
Frankie Lizcano87421812022-07-28 17:13:01 +0000265 mLnbId = INVALID_LNB_ID;
Hongguang600a6ae2021-07-08 18:51:51 -0700266}
267
268void TunerRecordAidlTest::attachSingleFilterToRecordDvrTest(FilterConfig filterConf,
269 FrontendConfig frontendConf,
270 DvrConfig dvrConf) {
271 int32_t demuxId;
272 std::shared_ptr<IDemux> demux;
273 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
274 mDvrTests.setDemux(demux);
275
276 DvrConfig dvrSourceConfig;
277 if (record.hasFrontendConnection) {
278 int32_t feId;
279 mFrontendTests.getFrontendIdByType(frontendConf.type, feId);
280 ASSERT_TRUE(feId != INVALID_ID);
281 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
282 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
283 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
284 } else {
285 dvrSourceConfig = dvrMap[record.dvrSourceId];
286 ASSERT_TRUE(mDvrTests.openDvrInDemux(dvrSourceConfig.type, dvrSourceConfig.bufferSize));
287 ASSERT_TRUE(mDvrTests.configDvrPlayback(dvrSourceConfig.settings));
288 ASSERT_TRUE(mDvrTests.getDvrPlaybackMQDescriptor());
289 }
290
291 int64_t filterId;
292 std::shared_ptr<IFilter> filter;
293 mFilterTests.setDemux(demux);
294
295 ASSERT_TRUE(mDvrTests.openDvrInDemux(dvrConf.type, dvrConf.bufferSize));
296 ASSERT_TRUE(mDvrTests.configDvrRecord(dvrConf.settings));
297 ASSERT_TRUE(mDvrTests.getDvrRecordMQDescriptor());
298
299 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
300 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
301 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
302 ASSERT_TRUE(mFilterTests.getFilterMQDescriptor(filterId, filterConf.getMqDesc));
303 filter = mFilterTests.getFilterById(filterId);
304 ASSERT_TRUE(filter != nullptr);
305 ASSERT_TRUE(mDvrTests.attachFilterToDvr(filter));
306 ASSERT_TRUE(mDvrTests.startDvrRecord());
307 ASSERT_TRUE(mFilterTests.startFilter(filterId));
308 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
309 ASSERT_TRUE(mDvrTests.stopDvrRecord());
310 ASSERT_TRUE(mDvrTests.detachFilterToDvr(filter));
311 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
312 mDvrTests.closeDvrRecord();
313 ASSERT_TRUE(mDemuxTests.closeDemux());
314
315 if (record.hasFrontendConnection) {
316 ASSERT_TRUE(mFrontendTests.closeFrontend());
317 }
318}
319
320void TunerRecordAidlTest::recordSingleFilterTest(FilterConfig filterConf,
321 FrontendConfig frontendConf, DvrConfig dvrConf) {
322 int32_t demuxId;
323 std::shared_ptr<IDemux> demux;
324 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
325 mDvrTests.setDemux(demux);
326
327 DvrConfig dvrSourceConfig;
328 if (record.hasFrontendConnection) {
329 int32_t feId;
330 mFrontendTests.getFrontendIdByType(frontendConf.type, feId);
331 ASSERT_TRUE(feId != INVALID_ID);
332 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
333 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
334 if (frontendConf.isSoftwareFe) {
335 mFrontendTests.setSoftwareFrontendDvrConfig(dvrMap[record.dvrSoftwareFeId]);
336 }
337 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
338 mFrontendTests.setDvrTests(&mDvrTests);
339 } else {
340 dvrSourceConfig = dvrMap[record.dvrSourceId];
341 ASSERT_TRUE(mDvrTests.openDvrInDemux(dvrSourceConfig.type, dvrSourceConfig.bufferSize));
342 ASSERT_TRUE(mDvrTests.configDvrPlayback(dvrSourceConfig.settings));
343 ASSERT_TRUE(mDvrTests.getDvrPlaybackMQDescriptor());
344 }
345
346 int64_t filterId;
347 std::shared_ptr<IFilter> filter;
348 mFilterTests.setDemux(demux);
349 ASSERT_TRUE(mDvrTests.openDvrInDemux(dvrConf.type, dvrConf.bufferSize));
350 ASSERT_TRUE(mDvrTests.configDvrRecord(dvrConf.settings));
351 ASSERT_TRUE(mDvrTests.getDvrRecordMQDescriptor());
352 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
353 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
354 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
355 ASSERT_TRUE(mFilterTests.getFilterMQDescriptor(filterId, filterConf.getMqDesc));
356 filter = mFilterTests.getFilterById(filterId);
357 ASSERT_TRUE(filter != nullptr);
358 mDvrTests.startRecordOutputThread(dvrConf.settings.get<DvrSettings::Tag::record>());
359 ASSERT_TRUE(mDvrTests.attachFilterToDvr(filter));
360 ASSERT_TRUE(mDvrTests.startDvrRecord());
361 ASSERT_TRUE(mFilterTests.startFilter(filterId));
362
363 if (record.hasFrontendConnection) {
364 ASSERT_TRUE(mFrontendTests.tuneFrontend(frontendConf, true /*testWithDemux*/));
365 } else {
366 // Start DVR Source
367 mDvrTests.startPlaybackInputThread(
368 dvrSourceConfig.playbackInputFile,
369 dvrSourceConfig.settings.get<DvrSettings::Tag::playback>());
370 ASSERT_TRUE(mDvrTests.startDvrPlayback());
371 }
372
373 mDvrTests.testRecordOutput();
374 mDvrTests.stopRecordThread();
375
376 if (record.hasFrontendConnection) {
377 ASSERT_TRUE(mFrontendTests.stopTuneFrontend(true /*testWithDemux*/));
378 } else {
379 mDvrTests.stopPlaybackThread();
380 ASSERT_TRUE(mDvrTests.stopDvrPlayback());
381 }
382
383 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
384 ASSERT_TRUE(mDvrTests.stopDvrRecord());
385 ASSERT_TRUE(mDvrTests.detachFilterToDvr(filter));
386 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
387 mDvrTests.closeDvrRecord();
388
389 if (record.hasFrontendConnection) {
390 ASSERT_TRUE(mFrontendTests.closeFrontend());
391 } else {
392 mDvrTests.closeDvrPlayback();
393 }
394
395 ASSERT_TRUE(mDemuxTests.closeDemux());
396}
397
398void TunerDescramblerAidlTest::scrambledBroadcastTest(set<struct FilterConfig> mediaFilterConfs,
399 FrontendConfig frontendConf,
400 DescramblerConfig descConfig) {
401 int32_t demuxId;
402 std::shared_ptr<IDemux> demux;
403 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
404
405 DvrConfig dvrSourceConfig;
406 if (descrambling.hasFrontendConnection) {
407 int32_t feId;
408 mFrontendTests.getFrontendIdByType(frontendConf.type, feId);
409 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
410 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
411 if (frontendConf.isSoftwareFe) {
412 mFrontendTests.setSoftwareFrontendDvrConfig(dvrMap[descrambling.dvrSoftwareFeId]);
413 }
414 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
415 mFrontendTests.setDemux(demux);
416 } else {
417 dvrSourceConfig = dvrMap[descrambling.dvrSourceId];
418 mDvrTests.setDemux(demux);
419 ASSERT_TRUE(mDvrTests.openDvrInDemux(dvrSourceConfig.type, dvrSourceConfig.bufferSize));
420 ASSERT_TRUE(mDvrTests.configDvrPlayback(dvrSourceConfig.settings));
421 ASSERT_TRUE(mDvrTests.getDvrPlaybackMQDescriptor());
422 }
423
424 set<int64_t> filterIds;
425 int64_t filterId;
426 set<struct FilterConfig>::iterator config;
427 set<int64_t>::iterator id;
428 mFilterTests.setDemux(demux);
429 for (config = mediaFilterConfs.begin(); config != mediaFilterConfs.end(); config++) {
430 ASSERT_TRUE(mFilterTests.openFilterInDemux((*config).type, (*config).bufferSize));
431 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
432 ASSERT_TRUE(mFilterTests.configFilter((*config).settings, filterId));
433 filterIds.insert(filterId);
434 }
435 ASSERT_TRUE(mDescramblerTests.openDescrambler(demuxId));
436 vector<uint8_t> token;
437 ASSERT_TRUE(mDescramblerTests.getKeyToken(descConfig.casSystemId, descConfig.provisionStr,
438 descConfig.hidlPvtData, token));
439 mDescramblerTests.setKeyToken(token);
440 vector<DemuxPid> pids;
441 DemuxPid pid;
442 for (config = mediaFilterConfs.begin(); config != mediaFilterConfs.end(); config++) {
443 ASSERT_TRUE(mDescramblerTests.getDemuxPidFromFilterSettings((*config).type,
444 (*config).settings, pid));
445 pids.push_back(pid);
446 ASSERT_TRUE(mDescramblerTests.addPid(pid, nullptr));
447 }
448 for (id = filterIds.begin(); id != filterIds.end(); id++) {
449 ASSERT_TRUE(mFilterTests.startFilter(*id));
450 }
451
452 if (descrambling.hasFrontendConnection) {
453 // tune test
454 ASSERT_TRUE(mFrontendTests.tuneFrontend(frontendConf, true /*testWithDemux*/));
455 } else {
456 // Start DVR Source
457 mDvrTests.startPlaybackInputThread(
458 dvrSourceConfig.playbackInputFile,
459 dvrSourceConfig.settings.get<DvrSettings::Tag::playback>());
460 ASSERT_TRUE(mDvrTests.startDvrPlayback());
461 }
462
463 ASSERT_TRUE(filterDataOutputTest());
464
465 if (descrambling.hasFrontendConnection) {
466 ASSERT_TRUE(mFrontendTests.stopTuneFrontend(true /*testWithDemux*/));
467 } else {
468 mDvrTests.stopPlaybackThread();
469 ASSERT_TRUE(mDvrTests.stopDvrPlayback());
470 }
471
472 for (id = filterIds.begin(); id != filterIds.end(); id++) {
473 ASSERT_TRUE(mFilterTests.stopFilter(*id));
474 }
475 for (auto pid : pids) {
476 ASSERT_TRUE(mDescramblerTests.removePid(pid, nullptr));
477 }
478 ASSERT_TRUE(mDescramblerTests.closeDescrambler());
479 for (id = filterIds.begin(); id != filterIds.end(); id++) {
480 ASSERT_TRUE(mFilterTests.closeFilter(*id));
481 }
482
483 if (descrambling.hasFrontendConnection) {
484 ASSERT_TRUE(mFrontendTests.closeFrontend());
485 } else {
486 mDvrTests.closeDvrPlayback();
487 }
488
489 ASSERT_TRUE(mDemuxTests.closeDemux());
490}
491
492TEST_P(TunerLnbAidlTest, SendDiseqcMessageToLnb) {
493 description("Open and configure an Lnb with specific settings then send a diseqc msg to it.");
494 if (!lnbLive.support) {
495 return;
496 }
Frankie Lizcano1e283b32022-07-08 21:07:42 +0000497 vector<LnbLiveHardwareConnections> lnbLive_configs = generateLnbLiveConfigurations();
498 if (lnbLive_configs.empty()) {
499 ALOGD("No frontends that support satellites.");
500 return;
Hongguang600a6ae2021-07-08 18:51:51 -0700501 }
Frankie Lizcano1e283b32022-07-08 21:07:42 +0000502 for (auto& combination : lnbLive_configs) {
503 lnbLive = combination;
Frankie Lizcano1e283b32022-07-08 21:07:42 +0000504 if (lnbMap[lnbLive.lnbId].name.compare(emptyHardwareId) == 0) {
505 vector<int32_t> ids;
506 ASSERT_TRUE(mLnbTests.getLnbIds(ids));
507 ASSERT_TRUE(ids.size() > 0);
508 ASSERT_TRUE(mLnbTests.openLnbById(ids[0]));
509 } else {
510 int32_t id;
511 ASSERT_TRUE(mLnbTests.openLnbByName(lnbMap[lnbLive.lnbId].name, id));
512 }
513 ASSERT_TRUE(mLnbTests.setLnbCallback());
514 ASSERT_TRUE(mLnbTests.setVoltage(lnbMap[lnbLive.lnbId].voltage));
515 ASSERT_TRUE(mLnbTests.setTone(lnbMap[lnbLive.lnbId].tone));
516 ASSERT_TRUE(mLnbTests.setSatellitePosition(lnbMap[lnbLive.lnbId].position));
517 for (auto msgName : lnbLive.diseqcMsgs) {
518 ASSERT_TRUE(mLnbTests.sendDiseqcMessage(diseqcMsgMap[msgName]));
519 }
520 ASSERT_TRUE(mLnbTests.closeLnb());
Hongguang600a6ae2021-07-08 18:51:51 -0700521 }
Hongguang600a6ae2021-07-08 18:51:51 -0700522}
523
524TEST_P(TunerDemuxAidlTest, openDemux) {
525 description("Open and close a Demux.");
526 if (!live.hasFrontendConnection) {
527 return;
528 }
529 int32_t feId;
530 int32_t demuxId;
531 std::shared_ptr<IDemux> demux;
532 mFrontendTests.getFrontendIdByType(frontendMap[live.frontendId].type, feId);
533 ASSERT_TRUE(feId != INVALID_ID);
534 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
535 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
536 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
537 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
538 ASSERT_TRUE(mDemuxTests.closeDemux());
539 ASSERT_TRUE(mFrontendTests.closeFrontend());
540}
541
542TEST_P(TunerDemuxAidlTest, getAvSyncTime) {
543 description("Get the A/V sync time from a PCR filter.");
544 if (!live.hasFrontendConnection) {
545 return;
546 }
547 if (live.pcrFilterId.compare(emptyHardwareId) == 0) {
548 return;
549 }
550 int32_t feId;
551 int32_t demuxId;
552 std::shared_ptr<IDemux> demux;
553 int64_t mediaFilterId;
554 int64_t pcrFilterId;
555 int32_t avSyncHwId;
556 std::shared_ptr<IFilter> mediaFilter;
557
558 mFrontendTests.getFrontendIdByType(frontendMap[live.frontendId].type, feId);
559 ASSERT_TRUE(feId != INVALID_ID);
560 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
561 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
562 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
563 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
564 mFilterTests.setDemux(demux);
565 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterMap[live.videoFilterId].type,
566 filterMap[live.videoFilterId].bufferSize));
567 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(mediaFilterId));
568 ASSERT_TRUE(mFilterTests.configFilter(filterMap[live.videoFilterId].settings, mediaFilterId));
569 mediaFilter = mFilterTests.getFilterById(mediaFilterId);
570 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterMap[live.pcrFilterId].type,
571 filterMap[live.pcrFilterId].bufferSize));
572 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(pcrFilterId));
573 ASSERT_TRUE(mFilterTests.configFilter(filterMap[live.pcrFilterId].settings, pcrFilterId));
574 ASSERT_TRUE(mDemuxTests.getAvSyncId(mediaFilter, avSyncHwId));
575 ASSERT_TRUE(pcrFilterId == avSyncHwId);
576 ASSERT_TRUE(mDemuxTests.getAvSyncTime(pcrFilterId));
577 ASSERT_TRUE(mFilterTests.closeFilter(pcrFilterId));
578 ASSERT_TRUE(mFilterTests.closeFilter(mediaFilterId));
579 ASSERT_TRUE(mDemuxTests.closeDemux());
580 ASSERT_TRUE(mFrontendTests.closeFrontend());
581}
582
583TEST_P(TunerFilterAidlTest, StartFilterInDemux) {
584 description("Open and start a filter in Demux.");
585 if (!live.hasFrontendConnection) {
586 return;
587 }
588 // TODO use parameterized tests
589 configSingleFilterInDemuxTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
590}
591
592TEST_P(TunerFilterAidlTest, ConfigIpFilterInDemuxWithCid) {
593 description("Open and configure an ip filter in Demux.");
594 // TODO use parameterized tests
595 if (!live.hasFrontendConnection) {
596 return;
597 }
598 if (live.ipFilterId.compare(emptyHardwareId) == 0) {
599 return;
600 }
601 configSingleFilterInDemuxTest(filterMap[live.ipFilterId], frontendMap[live.frontendId]);
602}
603
604TEST_P(TunerFilterAidlTest, ReconfigFilterToReceiveStartId) {
605 description("Recofigure and restart a filter to test start id.");
606 if (!live.hasFrontendConnection) {
607 return;
608 }
609 // TODO use parameterized tests
610 reconfigSingleFilterInDemuxTest(filterMap[live.videoFilterId], filterMap[live.videoFilterId],
611 frontendMap[live.frontendId]);
612}
613
614TEST_P(TunerFilterAidlTest, SetFilterLinkage) {
615 description("Pick up all the possible linkages from the demux caps and set them up.");
616 DemuxCapabilities caps;
617 int32_t demuxId;
618 std::shared_ptr<IDemux> demux;
619 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
620 ASSERT_TRUE(mDemuxTests.getDemuxCaps(caps));
621 mFilterTests.setDemux(demux);
622 for (int i = 0; i < caps.linkCaps.size(); i++) {
623 uint32_t bitMask = 1;
624 for (int j = 0; j < FILTER_MAIN_TYPE_BIT_COUNT; j++) {
625 if (caps.linkCaps[i] & (bitMask << j)) {
626 int64_t sourceFilterId;
627 int64_t sinkFilterId;
628 ASSERT_TRUE(mFilterTests.openFilterInDemux(getLinkageFilterType(i), FMQ_SIZE_16M));
629 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(sourceFilterId));
630 ASSERT_TRUE(mFilterTests.openFilterInDemux(getLinkageFilterType(j), FMQ_SIZE_16M));
631 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(sinkFilterId));
632 ASSERT_TRUE(mFilterTests.setFilterDataSource(sourceFilterId, sinkFilterId));
633 ASSERT_TRUE(mFilterTests.setFilterDataSourceToDemux(sinkFilterId));
634 ASSERT_TRUE(mFilterTests.closeFilter(sinkFilterId));
635 ASSERT_TRUE(mFilterTests.closeFilter(sourceFilterId));
636 }
637 }
638 }
639 ASSERT_TRUE(mDemuxTests.closeDemux());
640}
641
642TEST_P(TunerFilterAidlTest, testTimeFilter) {
643 description("Open a timer filter in Demux and set time stamp.");
644 if (!timeFilter.support) {
645 return;
646 }
647 // TODO use parameterized tests
648 testTimeFilter(timeFilterMap[timeFilter.timeFilterId]);
649}
650
Gareth Fenn9a808452022-03-31 08:40:00 +0100651static bool isEventProducingFilter(const FilterConfig& filterConfig) {
652 switch (filterConfig.type.mainType) {
653 case DemuxFilterMainType::TS: {
654 auto tsFilterType =
655 filterConfig.type.subType.get<DemuxFilterSubType::Tag::tsFilterType>();
656 return (tsFilterType == DemuxTsFilterType::SECTION ||
657 tsFilterType == DemuxTsFilterType::PES ||
658 tsFilterType == DemuxTsFilterType::AUDIO ||
659 tsFilterType == DemuxTsFilterType::VIDEO ||
660 tsFilterType == DemuxTsFilterType::RECORD ||
661 tsFilterType == DemuxTsFilterType::TEMI);
662 }
663 case DemuxFilterMainType::MMTP: {
664 auto mmtpFilterType =
665 filterConfig.type.subType.get<DemuxFilterSubType::Tag::mmtpFilterType>();
666 return (mmtpFilterType == DemuxMmtpFilterType::SECTION ||
667 mmtpFilterType == DemuxMmtpFilterType::PES ||
668 mmtpFilterType == DemuxMmtpFilterType::AUDIO ||
669 mmtpFilterType == DemuxMmtpFilterType::VIDEO ||
670 mmtpFilterType == DemuxMmtpFilterType::RECORD ||
671 mmtpFilterType == DemuxMmtpFilterType::DOWNLOAD);
672 }
673 case DemuxFilterMainType::IP: {
674 auto ipFilterType =
675 filterConfig.type.subType.get<DemuxFilterSubType::Tag::ipFilterType>();
676 return (ipFilterType == DemuxIpFilterType::SECTION);
677 }
678 case DemuxFilterMainType::TLV: {
679 auto tlvFilterType =
680 filterConfig.type.subType.get<DemuxFilterSubType::Tag::tlvFilterType>();
681 return (tlvFilterType == DemuxTlvFilterType::SECTION);
682 }
683 case DemuxFilterMainType::ALP: {
684 auto alpFilterType =
685 filterConfig.type.subType.get<DemuxFilterSubType::Tag::alpFilterType>();
686 return (alpFilterType == DemuxAlpFilterType::SECTION);
687 }
688 default:
689 return false;
690 }
691}
692
Patrick Rohr1586d212021-11-23 00:40:56 +0100693static bool isMediaFilter(const FilterConfig& filterConfig) {
694 switch (filterConfig.type.mainType) {
695 case DemuxFilterMainType::TS: {
696 // TS Audio and Video filters are media filters
697 auto tsFilterType =
698 filterConfig.type.subType.get<DemuxFilterSubType::Tag::tsFilterType>();
699 return (tsFilterType == DemuxTsFilterType::AUDIO ||
700 tsFilterType == DemuxTsFilterType::VIDEO);
701 }
702 case DemuxFilterMainType::MMTP: {
703 // MMTP Audio and Video filters are media filters
704 auto mmtpFilterType =
705 filterConfig.type.subType.get<DemuxFilterSubType::Tag::mmtpFilterType>();
706 return (mmtpFilterType == DemuxMmtpFilterType::AUDIO ||
707 mmtpFilterType == DemuxMmtpFilterType::VIDEO);
708 }
709 default:
710 return false;
711 }
712}
Patrick Rohr149b0872021-11-20 00:39:37 +0100713
Patrick Rohr1586d212021-11-23 00:40:56 +0100714static int getDemuxFilterEventDataLength(const DemuxFilterEvent& event) {
715 switch (event.getTag()) {
716 case DemuxFilterEvent::Tag::section:
717 return event.get<DemuxFilterEvent::Tag::section>().dataLength;
718 case DemuxFilterEvent::Tag::media:
719 return event.get<DemuxFilterEvent::Tag::media>().dataLength;
720 case DemuxFilterEvent::Tag::pes:
721 return event.get<DemuxFilterEvent::Tag::pes>().dataLength;
722 case DemuxFilterEvent::Tag::download:
723 return event.get<DemuxFilterEvent::Tag::download>().dataLength;
724 case DemuxFilterEvent::Tag::ipPayload:
725 return event.get<DemuxFilterEvent::Tag::ipPayload>().dataLength;
726
727 case DemuxFilterEvent::Tag::tsRecord:
728 case DemuxFilterEvent::Tag::mmtpRecord:
729 case DemuxFilterEvent::Tag::temi:
730 case DemuxFilterEvent::Tag::monitorEvent:
731 case DemuxFilterEvent::Tag::startId:
732 return 0;
733 }
734}
735
736// TODO: move boilerplate into text fixture
737void TunerFilterAidlTest::testDelayHint(const FilterConfig& filterConf) {
Gareth Fenn9a808452022-03-31 08:40:00 +0100738 if (!filterConf.timeDelayInMs && !filterConf.dataDelayInBytes) {
739 return;
740 }
741 if (!isEventProducingFilter(filterConf)) {
742 return;
743 }
Patrick Rohr149b0872021-11-20 00:39:37 +0100744 int32_t feId;
745 int32_t demuxId;
746 std::shared_ptr<IDemux> demux;
747 int64_t filterId;
748
749 mFrontendTests.getFrontendIdByType(frontendMap[live.frontendId].type, feId);
750 ASSERT_TRUE(feId != INVALID_ID);
751 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
752 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
753 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
754 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
755 mFilterTests.setDemux(demux);
756
Patrick Rohr149b0872021-11-20 00:39:37 +0100757 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
758 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
Patrick Rohr149b0872021-11-20 00:39:37 +0100759
Patrick Rohr1586d212021-11-23 00:40:56 +0100760 bool mediaFilter = isMediaFilter(filterConf);
Patrick Rohr149b0872021-11-20 00:39:37 +0100761 auto filter = mFilterTests.getFilterById(filterId);
762
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100763 // startTime needs to be set before calling setDelayHint.
764 auto startTime = std::chrono::steady_clock::now();
765
Gareth Fenn9a808452022-03-31 08:40:00 +0100766 int timeDelayInMs = filterConf.timeDelayInMs;
767 if (timeDelayInMs > 0) {
Patrick Rohr1586d212021-11-23 00:40:56 +0100768 FilterDelayHint delayHint;
769 delayHint.hintType = FilterDelayHintType::TIME_DELAY_IN_MS;
Gareth Fenn9a808452022-03-31 08:40:00 +0100770 delayHint.hintValue = timeDelayInMs;
Patrick Rohr149b0872021-11-20 00:39:37 +0100771
Patrick Rohr1586d212021-11-23 00:40:56 +0100772 // setDelayHint should fail for media filters.
773 ASSERT_EQ(filter->setDelayHint(delayHint).isOk(), !mediaFilter);
774 }
Patrick Rohr149b0872021-11-20 00:39:37 +0100775
Patrick Rohr1586d212021-11-23 00:40:56 +0100776 int dataDelayInBytes = filterConf.dataDelayInBytes;
777 if (dataDelayInBytes > 0) {
778 FilterDelayHint delayHint;
779 delayHint.hintType = FilterDelayHintType::DATA_SIZE_DELAY_IN_BYTES;
780 delayHint.hintValue = dataDelayInBytes;
Patrick Rohr149b0872021-11-20 00:39:37 +0100781
Patrick Rohr1586d212021-11-23 00:40:56 +0100782 // setDelayHint should fail for media filters.
783 ASSERT_EQ(filter->setDelayHint(delayHint).isOk(), !mediaFilter);
784 }
Patrick Rohr149b0872021-11-20 00:39:37 +0100785
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100786 // start and stop filter (and wait for first callback) in order to
787 // circumvent callback scheduler race conditions after adjusting filter
788 // delays.
789 auto cb = mFilterTests.getFilterCallbacks().at(filterId);
790 auto future =
791 cb->verifyFilterCallback([](const std::vector<DemuxFilterEvent>&) { return true; });
Gareth Fenn9a808452022-03-31 08:40:00 +0100792
793 // The configure stage can also produce events, so we should set the delay
794 // hint beforehand.
795 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
Patrick Rohr1586d212021-11-23 00:40:56 +0100796 mFilterTests.startFilter(filterId);
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100797
798 auto timeout = std::chrono::seconds(30);
799 ASSERT_EQ(future.wait_for(timeout), std::future_status::ready);
800
Patrick Rohr1586d212021-11-23 00:40:56 +0100801 mFilterTests.stopFilter(filterId);
Patrick Rohr149b0872021-11-20 00:39:37 +0100802
Patrick Rohr1586d212021-11-23 00:40:56 +0100803 if (!mediaFilter) {
Patrick Rohr1586d212021-11-23 00:40:56 +0100804 int callbackSize = 0;
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100805 future = cb->verifyFilterCallback(
Patrick Rohr1586d212021-11-23 00:40:56 +0100806 [&callbackSize](const std::vector<DemuxFilterEvent>& events) {
807 for (const auto& event : events) {
808 callbackSize += getDemuxFilterEventDataLength(event);
809 }
810 return true;
811 });
812
Patrick Rohr1586d212021-11-23 00:40:56 +0100813 ASSERT_TRUE(mFilterTests.startFilter(filterId));
814
815 // block and wait for callback to be received.
Patrick Rohr1586d212021-11-23 00:40:56 +0100816 ASSERT_EQ(future.wait_for(timeout), std::future_status::ready);
Patrick Rohr1586d212021-11-23 00:40:56 +0100817
Gareth Fenn9a808452022-03-31 08:40:00 +0100818 auto duration = std::chrono::steady_clock::now() - startTime;
819 bool delayHintTest = duration >= std::chrono::milliseconds(timeDelayInMs);
Patrick Rohr1586d212021-11-23 00:40:56 +0100820 bool dataSizeTest = callbackSize >= dataDelayInBytes;
821
Gareth Fenn9a808452022-03-31 08:40:00 +0100822 if (timeDelayInMs > 0 && dataDelayInBytes > 0) {
Patrick Rohr1586d212021-11-23 00:40:56 +0100823 ASSERT_TRUE(delayHintTest || dataSizeTest);
824 } else {
825 // if only one of time delay / data delay is configured, one of them
826 // holds true by default, so we want both assertions to be true.
827 ASSERT_TRUE(delayHintTest && dataSizeTest);
828 }
829
830 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
831 }
832
Patrick Rohr149b0872021-11-20 00:39:37 +0100833 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
834 ASSERT_TRUE(mDemuxTests.closeDemux());
835 ASSERT_TRUE(mFrontendTests.closeFrontend());
836}
837
Patrick Rohr1586d212021-11-23 00:40:56 +0100838TEST_P(TunerFilterAidlTest, FilterDelayHintTest) {
839 description("Test filter time delay hint.");
Gareth Fenn9a808452022-03-31 08:40:00 +0100840 if (!live.hasFrontendConnection) {
841 return;
842 }
Patrick Rohr1586d212021-11-23 00:40:56 +0100843 for (const auto& obj : filterMap) {
844 testDelayHint(obj.second);
845 }
846}
847
Hongguang600a6ae2021-07-08 18:51:51 -0700848TEST_P(TunerPlaybackAidlTest, PlaybackDataFlowWithTsSectionFilterTest) {
849 description("Feed ts data from playback and configure Ts section filter to get output");
Frankie Lizcanoa53f5542022-07-07 17:32:06 +0000850 if (!playback.support) {
Hongguang600a6ae2021-07-08 18:51:51 -0700851 return;
852 }
Frankie Lizcanoa53f5542022-07-07 17:32:06 +0000853 vector<DvrPlaybackHardwareConnections> playback_configs = generatePlaybackConfigs();
854 for (auto& configuration : playback_configs) {
855 if (configuration.sectionFilterId.compare(emptyHardwareId) != 0) {
856 playback = configuration;
857 playbackSingleFilterTest(filterMap[playback.sectionFilterId], dvrMap[playback.dvrId]);
858 }
859 }
Hongguang600a6ae2021-07-08 18:51:51 -0700860}
861
862TEST_P(TunerPlaybackAidlTest, PlaybackDataFlowWithTsAudioFilterTest) {
863 description("Feed ts data from playback and configure Ts audio filter to get output");
864 if (!playback.support) {
865 return;
866 }
Frankie Lizcanoa53f5542022-07-07 17:32:06 +0000867 vector<DvrPlaybackHardwareConnections> playback_configs = generatePlaybackConfigs();
868 for (auto& configuration : playback_configs) {
869 playback = configuration;
870 playbackSingleFilterTest(filterMap[playback.audioFilterId], dvrMap[playback.dvrId]);
871 }
Hongguang600a6ae2021-07-08 18:51:51 -0700872}
873
874TEST_P(TunerPlaybackAidlTest, PlaybackDataFlowWithTsVideoFilterTest) {
875 description("Feed ts data from playback and configure Ts video filter to get output");
876 if (!playback.support) {
877 return;
878 }
Frankie Lizcanoa53f5542022-07-07 17:32:06 +0000879 vector<DvrPlaybackHardwareConnections> playback_configs = generatePlaybackConfigs();
880 for (auto& configuration : playback_configs) {
881 playback = configuration;
882 playbackSingleFilterTest(filterMap[playback.videoFilterId], dvrMap[playback.dvrId]);
883 }
Hongguang600a6ae2021-07-08 18:51:51 -0700884}
885
886TEST_P(TunerRecordAidlTest, RecordDataFlowWithTsRecordFilterTest) {
887 description("Feed ts data from frontend to recording and test with ts record filter");
888 if (!record.support) {
889 return;
890 }
891 recordSingleFilterTest(filterMap[record.recordFilterId], frontendMap[record.frontendId],
892 dvrMap[record.dvrRecordId]);
893}
894
895TEST_P(TunerRecordAidlTest, AttachFiltersToRecordTest) {
896 description("Attach a single filter to the record dvr test.");
897 // TODO use parameterized tests
898 if (!record.support) {
899 return;
900 }
901 attachSingleFilterToRecordDvrTest(filterMap[record.recordFilterId],
902 frontendMap[record.frontendId], dvrMap[record.dvrRecordId]);
903}
904
905TEST_P(TunerRecordAidlTest, LnbRecordDataFlowWithTsRecordFilterTest) {
906 description("Feed ts data from Fe with Lnb to recording and test with ts record filter");
907 if (!lnbRecord.support) {
908 return;
909 }
Frankie Lizcanoecba02a2022-07-12 17:56:54 +0000910 vector<LnbRecordHardwareConnections> lnbRecord_configs = generateLnbRecordConfigurations();
911 if (lnbRecord_configs.empty()) {
912 ALOGD("No frontends that support satellites.");
913 return;
914 }
915 for (auto& configuration : lnbRecord_configs) {
916 lnbRecord = configuration;
917 recordSingleFilterTestWithLnb(filterMap[lnbRecord.recordFilterId],
918 frontendMap[lnbRecord.frontendId],
919 dvrMap[lnbRecord.dvrRecordId], lnbMap[lnbRecord.lnbId]);
920 }
Hongguang600a6ae2021-07-08 18:51:51 -0700921}
922
923TEST_P(TunerFrontendAidlTest, TuneFrontend) {
924 description("Tune one Frontend with specific setting and check Lock event");
925 if (!live.hasFrontendConnection) {
926 return;
927 }
928 mFrontendTests.tuneTest(frontendMap[live.frontendId]);
929}
930
931TEST_P(TunerFrontendAidlTest, AutoScanFrontend) {
932 description("Run an auto frontend scan with specific setting and check lock scanMessage");
933 if (!scan.hasFrontendConnection) {
934 return;
935 }
Frankie Lizcano3138d6b2022-07-11 22:06:45 +0000936 vector<ScanHardwareConnections> scan_configs = generateScanConfigurations();
937 for (auto& configuration : scan_configs) {
938 scan = configuration;
939 mFrontendTests.scanTest(frontendMap[scan.frontendId], FrontendScanType::SCAN_AUTO);
940 }
Hongguang600a6ae2021-07-08 18:51:51 -0700941}
942
943TEST_P(TunerFrontendAidlTest, BlindScanFrontend) {
944 description("Run an blind frontend scan with specific setting and check lock scanMessage");
945 if (!scan.hasFrontendConnection) {
946 return;
947 }
Frankie Lizcano3138d6b2022-07-11 22:06:45 +0000948 vector<ScanHardwareConnections> scan_configs = generateScanConfigurations();
949 for (auto& configuration : scan_configs) {
950 scan = configuration;
951 mFrontendTests.scanTest(frontendMap[scan.frontendId], FrontendScanType::SCAN_BLIND);
952 }
Hongguang600a6ae2021-07-08 18:51:51 -0700953}
954
955TEST_P(TunerFrontendAidlTest, TuneFrontendWithFrontendSettings) {
956 description("Tune one Frontend with setting and check Lock event");
957 if (!live.hasFrontendConnection) {
958 return;
959 }
960 mFrontendTests.tuneTest(frontendMap[live.frontendId]);
961}
962
963TEST_P(TunerFrontendAidlTest, BlindScanFrontendWithEndFrequency) {
964 description("Run an blind frontend scan with setting and check lock scanMessage");
965 if (!scan.hasFrontendConnection) {
966 return;
967 }
Frankie Lizcano3138d6b2022-07-11 22:06:45 +0000968 vector<ScanHardwareConnections> scan_configs = generateScanConfigurations();
969 for (auto& configuration : scan_configs) {
970 scan = configuration;
971 mFrontendTests.scanTest(frontendMap[scan.frontendId], FrontendScanType::SCAN_BLIND);
972 }
Hongguang600a6ae2021-07-08 18:51:51 -0700973}
974
975TEST_P(TunerFrontendAidlTest, LinkToCiCam) {
976 description("Test Frontend link to CiCam");
977 if (!live.hasFrontendConnection) {
978 return;
979 }
980 if (!frontendMap[live.frontendId].canConnectToCiCam) {
981 return;
982 }
983 mFrontendTests.tuneTest(frontendMap[live.frontendId]);
984}
985
Hongguangfcedda02021-12-13 17:08:02 -0800986TEST_P(TunerFrontendAidlTest, getHardwareInfo) {
987 description("Test Frontend get hardware info");
988 if (!live.hasFrontendConnection) {
989 return;
990 }
991 mFrontendTests.debugInfoTest(frontendMap[live.frontendId]);
992}
993
Hongguang5766ddf2021-12-23 11:40:37 -0800994TEST_P(TunerFrontendAidlTest, maxNumberOfFrontends) {
995 description("Test Max Frontend number");
996 if (!live.hasFrontendConnection) {
997 return;
998 }
999 mFrontendTests.maxNumberOfFrontendsTest();
1000}
1001
Hongguang881190f2022-01-14 13:23:37 -08001002TEST_P(TunerFrontendAidlTest, statusReadinessTest) {
1003 description("Test Max Frontend status readiness");
1004 if (!live.hasFrontendConnection) {
1005 return;
1006 }
1007 mFrontendTests.statusReadinessTest(frontendMap[live.frontendId]);
1008}
1009
Hongguang600a6ae2021-07-08 18:51:51 -07001010TEST_P(TunerBroadcastAidlTest, BroadcastDataFlowVideoFilterTest) {
1011 description("Test Video Filter functionality in Broadcast use case.");
1012 if (!live.hasFrontendConnection) {
1013 return;
1014 }
1015 broadcastSingleFilterTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
1016}
1017
1018TEST_P(TunerBroadcastAidlTest, BroadcastDataFlowAudioFilterTest) {
1019 description("Test Audio Filter functionality in Broadcast use case.");
1020 if (!live.hasFrontendConnection) {
1021 return;
1022 }
1023 broadcastSingleFilterTest(filterMap[live.audioFilterId], frontendMap[live.frontendId]);
1024}
1025
1026TEST_P(TunerBroadcastAidlTest, BroadcastDataFlowSectionFilterTest) {
1027 description("Test Section Filter functionality in Broadcast use case.");
1028 if (!live.hasFrontendConnection) {
1029 return;
1030 }
1031 if (live.sectionFilterId.compare(emptyHardwareId) == 0) {
1032 return;
1033 }
1034 broadcastSingleFilterTest(filterMap[live.sectionFilterId], frontendMap[live.frontendId]);
1035}
1036
1037TEST_P(TunerBroadcastAidlTest, IonBufferTest) {
1038 description("Test the av filter data bufferring.");
1039 if (!live.hasFrontendConnection) {
1040 return;
1041 }
1042 broadcastSingleFilterTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
1043}
1044
1045TEST_P(TunerBroadcastAidlTest, LnbBroadcastDataFlowVideoFilterTest) {
1046 description("Test Video Filter functionality in Broadcast with Lnb use case.");
1047 if (!lnbLive.support) {
1048 return;
1049 }
Frankie Lizcano1e283b32022-07-08 21:07:42 +00001050 vector<LnbLiveHardwareConnections> lnbLive_configs = generateLnbLiveConfigurations();
1051 if (lnbLive_configs.empty()) {
1052 ALOGD("No frontends that support satellites.");
1053 return;
1054 }
1055 for (auto& combination : lnbLive_configs) {
1056 lnbLive = combination;
1057 broadcastSingleFilterTestWithLnb(filterMap[lnbLive.videoFilterId],
1058 frontendMap[lnbLive.frontendId], lnbMap[lnbLive.lnbId]);
1059 }
Hongguang600a6ae2021-07-08 18:51:51 -07001060}
1061
1062TEST_P(TunerBroadcastAidlTest, MediaFilterWithSharedMemoryHandle) {
1063 description("Test the Media Filter with shared memory handle");
1064 if (!live.hasFrontendConnection) {
1065 return;
1066 }
1067 mediaFilterUsingSharedMemoryTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
1068}
1069
1070TEST_P(TunerDescramblerAidlTest, CreateDescrambler) {
1071 description("Create Descrambler");
1072 if (!descrambling.support) {
1073 return;
1074 }
Frankie Lizcanof4e07962022-07-13 20:54:34 +00001075 vector<DescramblingHardwareConnections> descrambling_configs =
1076 generateDescramblingConfigurations();
1077 if (descrambling_configs.empty()) {
1078 ALOGD("No valid descrambling combinations in the configuration file.");
1079 return;
Hongguang600a6ae2021-07-08 18:51:51 -07001080 }
Frankie Lizcanof4e07962022-07-13 20:54:34 +00001081 for (auto& combination : descrambling_configs) {
1082 descrambling = combination;
1083 int32_t demuxId;
1084 std::shared_ptr<IDemux> demux;
1085 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
Hongguang600a6ae2021-07-08 18:51:51 -07001086
Frankie Lizcanof4e07962022-07-13 20:54:34 +00001087 if (descrambling.hasFrontendConnection) {
1088 int32_t feId;
1089 mFrontendTests.getFrontendIdByType(frontendMap[descrambling.frontendId].type, feId);
1090 ASSERT_TRUE(feId != INVALID_ID);
1091 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
1092 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
1093 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
1094 }
Hongguang600a6ae2021-07-08 18:51:51 -07001095
Frankie Lizcanof4e07962022-07-13 20:54:34 +00001096 ASSERT_TRUE(mDescramblerTests.openDescrambler(demuxId));
1097 ASSERT_TRUE(mDescramblerTests.closeDescrambler());
1098 ASSERT_TRUE(mDemuxTests.closeDemux());
1099
1100 if (descrambling.hasFrontendConnection) {
1101 ASSERT_TRUE(mFrontendTests.closeFrontend());
1102 }
Hongguang600a6ae2021-07-08 18:51:51 -07001103 }
1104}
1105
1106TEST_P(TunerDescramblerAidlTest, ScrambledBroadcastDataFlowMediaFiltersTest) {
1107 description("Test ts audio filter in scrambled broadcast use case");
1108 if (!descrambling.support) {
1109 return;
1110 }
Frankie Lizcanof4e07962022-07-13 20:54:34 +00001111 vector<DescramblingHardwareConnections> descrambling_configs =
1112 generateDescramblingConfigurations();
1113 if (descrambling_configs.empty()) {
1114 ALOGD("No valid descrambling combinations in the configuration file.");
1115 return;
1116 }
1117 for (auto& combination : descrambling_configs) {
1118 descrambling = combination;
1119 set<FilterConfig> filterConfs;
1120 filterConfs.insert(static_cast<FilterConfig>(filterMap[descrambling.audioFilterId]));
1121 filterConfs.insert(static_cast<FilterConfig>(filterMap[descrambling.videoFilterId]));
1122 scrambledBroadcastTest(filterConfs, frontendMap[descrambling.frontendId],
1123 descramblerMap[descrambling.descramblerId]);
1124 }
Hongguang600a6ae2021-07-08 18:51:51 -07001125}
1126
1127INSTANTIATE_TEST_SUITE_P(PerInstance, TunerBroadcastAidlTest,
1128 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1129 android::PrintInstanceNameToString);
1130
1131INSTANTIATE_TEST_SUITE_P(PerInstance, TunerFrontendAidlTest,
1132 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1133 android::PrintInstanceNameToString);
1134
1135INSTANTIATE_TEST_SUITE_P(PerInstance, TunerFilterAidlTest,
1136 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1137 android::PrintInstanceNameToString);
1138
1139INSTANTIATE_TEST_SUITE_P(PerInstance, TunerRecordAidlTest,
1140 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1141 android::PrintInstanceNameToString);
1142
1143INSTANTIATE_TEST_SUITE_P(PerInstance, TunerLnbAidlTest,
1144 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1145 android::PrintInstanceNameToString);
1146
1147INSTANTIATE_TEST_SUITE_P(PerInstance, TunerDemuxAidlTest,
1148 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1149 android::PrintInstanceNameToString);
1150
1151INSTANTIATE_TEST_SUITE_P(PerInstance, TunerPlaybackAidlTest,
1152 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1153 android::PrintInstanceNameToString);
1154
1155INSTANTIATE_TEST_SUITE_P(PerInstance, TunerDescramblerAidlTest,
1156 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1157 android::PrintInstanceNameToString);
1158
1159} // namespace
1160
1161// Start thread pool to receive callbacks from AIDL service.
1162int main(int argc, char** argv) {
1163 ::testing::InitGoogleTest(&argc, argv);
1164 ABinderProcess_setThreadPoolMaxThreadCount(1);
1165 ABinderProcess_startThreadPool();
1166 return RUN_ALL_TESTS();
1167}