blob: 0285e0405ea15957b43fd7649742434de6101645 [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());
132 if (mLnbId) {
133 ASSERT_TRUE(mFrontendTests.setLnb(*mLnbId));
134 }
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]));
165 mLnbId = &ids[0];
166 } else {
167 mLnbId = (int32_t*)malloc(sizeof(int32_t));
168 ASSERT_TRUE(mLnbTests.openLnbByName(lnbConf.name, *mLnbId));
169 }
170 ASSERT_TRUE(mLnbTests.setLnbCallback());
171 ASSERT_TRUE(mLnbTests.setVoltage(lnbConf.voltage));
172 ASSERT_TRUE(mLnbTests.setTone(lnbConf.tone));
173 ASSERT_TRUE(mLnbTests.setSatellitePosition(lnbConf.position));
174 broadcastSingleFilterTest(filterConf, frontendConf);
175 ASSERT_TRUE(mLnbTests.closeLnb());
176 mLnbId = nullptr;
177}
178
179void TunerBroadcastAidlTest::mediaFilterUsingSharedMemoryTest(FilterConfig filterConf,
180 FrontendConfig frontendConf) {
181 int32_t feId;
182 int32_t demuxId;
183 std::shared_ptr<IDemux> demux;
184 int64_t filterId;
185
186 mFrontendTests.getFrontendIdByType(frontendConf.type, feId);
187 ASSERT_TRUE(feId != INVALID_ID);
188 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
189 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
190 if (frontendConf.isSoftwareFe) {
191 mFrontendTests.setSoftwareFrontendDvrConfig(dvrMap[live.dvrSoftwareFeId]);
192 }
193 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
194 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
195 mFrontendTests.setDemux(demux);
196 mFilterTests.setDemux(demux);
197 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
198 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
199 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
200 ASSERT_TRUE(mFilterTests.getSharedAvMemoryHandle(filterId));
201 ASSERT_TRUE(mFilterTests.configAvFilterStreamType(filterConf.streamType, filterId));
202 ASSERT_TRUE(mFilterTests.getFilterMQDescriptor(filterId, filterConf.getMqDesc));
203 ASSERT_TRUE(mFilterTests.startFilter(filterId));
204 // tune test
205 ASSERT_TRUE(mFrontendTests.tuneFrontend(frontendConf, true /*testWithDemux*/));
206 ASSERT_TRUE(filterDataOutputTest());
207 ASSERT_TRUE(mFrontendTests.stopTuneFrontend(true /*testWithDemux*/));
208 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
209 ASSERT_TRUE(mFilterTests.releaseShareAvHandle(filterId));
210 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
211 ASSERT_TRUE(mDemuxTests.closeDemux());
212 ASSERT_TRUE(mFrontendTests.closeFrontend());
213}
214
215void TunerPlaybackAidlTest::playbackSingleFilterTest(FilterConfig filterConf, DvrConfig dvrConf) {
216 int32_t demuxId;
217 std::shared_ptr<IDemux> demux;
218 int64_t filterId;
219
220 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
221 mFilterTests.setDemux(demux);
222 mDvrTests.setDemux(demux);
223 ASSERT_TRUE(mDvrTests.openDvrInDemux(dvrConf.type, dvrConf.bufferSize));
224 ASSERT_TRUE(mDvrTests.configDvrPlayback(dvrConf.settings));
225 ASSERT_TRUE(mDvrTests.getDvrPlaybackMQDescriptor());
226 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
227 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
228 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
229 ASSERT_TRUE(mFilterTests.getFilterMQDescriptor(filterId, filterConf.getMqDesc));
230 mDvrTests.startPlaybackInputThread(dvrConf.playbackInputFile,
231 dvrConf.settings.get<DvrSettings::Tag::playback>());
232 ASSERT_TRUE(mDvrTests.startDvrPlayback());
233 ASSERT_TRUE(mFilterTests.startFilter(filterId));
234 ASSERT_TRUE(filterDataOutputTest());
235 mDvrTests.stopPlaybackThread();
236 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
237 ASSERT_TRUE(mDvrTests.stopDvrPlayback());
238 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
239 mDvrTests.closeDvrPlayback();
240 ASSERT_TRUE(mDemuxTests.closeDemux());
241}
242
243void TunerRecordAidlTest::recordSingleFilterTestWithLnb(FilterConfig filterConf,
244 FrontendConfig frontendConf,
245 DvrConfig dvrConf, LnbConfig lnbConf) {
246 if (lnbConf.name.compare(emptyHardwareId) == 0) {
247 vector<int32_t> ids;
248 ASSERT_TRUE(mLnbTests.getLnbIds(ids));
249 ASSERT_TRUE(ids.size() > 0);
250 ASSERT_TRUE(mLnbTests.openLnbById(ids[0]));
251 mLnbId = &ids[0];
252 } else {
253 mLnbId = (int32_t*)malloc(sizeof(int32_t));
254 ASSERT_TRUE(mLnbTests.openLnbByName(lnbConf.name, *mLnbId));
255 }
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());
265 mLnbId = nullptr;
266}
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;
504
505 if (lnbMap[lnbLive.lnbId].name.compare(emptyHardwareId) == 0) {
506 vector<int32_t> ids;
507 ASSERT_TRUE(mLnbTests.getLnbIds(ids));
508 ASSERT_TRUE(ids.size() > 0);
509 ASSERT_TRUE(mLnbTests.openLnbById(ids[0]));
510 } else {
511 int32_t id;
512 ASSERT_TRUE(mLnbTests.openLnbByName(lnbMap[lnbLive.lnbId].name, id));
513 }
514 ASSERT_TRUE(mLnbTests.setLnbCallback());
515 ASSERT_TRUE(mLnbTests.setVoltage(lnbMap[lnbLive.lnbId].voltage));
516 ASSERT_TRUE(mLnbTests.setTone(lnbMap[lnbLive.lnbId].tone));
517 ASSERT_TRUE(mLnbTests.setSatellitePosition(lnbMap[lnbLive.lnbId].position));
518 for (auto msgName : lnbLive.diseqcMsgs) {
519 ASSERT_TRUE(mLnbTests.sendDiseqcMessage(diseqcMsgMap[msgName]));
520 }
521 ASSERT_TRUE(mLnbTests.closeLnb());
Hongguang600a6ae2021-07-08 18:51:51 -0700522 }
Hongguang600a6ae2021-07-08 18:51:51 -0700523}
524
525TEST_P(TunerDemuxAidlTest, openDemux) {
526 description("Open and close a Demux.");
527 if (!live.hasFrontendConnection) {
528 return;
529 }
530 int32_t feId;
531 int32_t demuxId;
532 std::shared_ptr<IDemux> demux;
533 mFrontendTests.getFrontendIdByType(frontendMap[live.frontendId].type, feId);
534 ASSERT_TRUE(feId != INVALID_ID);
535 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
536 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
537 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
538 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
539 ASSERT_TRUE(mDemuxTests.closeDemux());
540 ASSERT_TRUE(mFrontendTests.closeFrontend());
541}
542
543TEST_P(TunerDemuxAidlTest, getAvSyncTime) {
544 description("Get the A/V sync time from a PCR filter.");
545 if (!live.hasFrontendConnection) {
546 return;
547 }
548 if (live.pcrFilterId.compare(emptyHardwareId) == 0) {
549 return;
550 }
551 int32_t feId;
552 int32_t demuxId;
553 std::shared_ptr<IDemux> demux;
554 int64_t mediaFilterId;
555 int64_t pcrFilterId;
556 int32_t avSyncHwId;
557 std::shared_ptr<IFilter> mediaFilter;
558
559 mFrontendTests.getFrontendIdByType(frontendMap[live.frontendId].type, feId);
560 ASSERT_TRUE(feId != INVALID_ID);
561 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
562 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
563 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
564 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
565 mFilterTests.setDemux(demux);
566 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterMap[live.videoFilterId].type,
567 filterMap[live.videoFilterId].bufferSize));
568 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(mediaFilterId));
569 ASSERT_TRUE(mFilterTests.configFilter(filterMap[live.videoFilterId].settings, mediaFilterId));
570 mediaFilter = mFilterTests.getFilterById(mediaFilterId);
571 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterMap[live.pcrFilterId].type,
572 filterMap[live.pcrFilterId].bufferSize));
573 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(pcrFilterId));
574 ASSERT_TRUE(mFilterTests.configFilter(filterMap[live.pcrFilterId].settings, pcrFilterId));
575 ASSERT_TRUE(mDemuxTests.getAvSyncId(mediaFilter, avSyncHwId));
576 ASSERT_TRUE(pcrFilterId == avSyncHwId);
577 ASSERT_TRUE(mDemuxTests.getAvSyncTime(pcrFilterId));
578 ASSERT_TRUE(mFilterTests.closeFilter(pcrFilterId));
579 ASSERT_TRUE(mFilterTests.closeFilter(mediaFilterId));
580 ASSERT_TRUE(mDemuxTests.closeDemux());
581 ASSERT_TRUE(mFrontendTests.closeFrontend());
582}
583
584TEST_P(TunerFilterAidlTest, StartFilterInDemux) {
585 description("Open and start a filter in Demux.");
586 if (!live.hasFrontendConnection) {
587 return;
588 }
589 // TODO use parameterized tests
590 configSingleFilterInDemuxTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
591}
592
593TEST_P(TunerFilterAidlTest, ConfigIpFilterInDemuxWithCid) {
594 description("Open and configure an ip filter in Demux.");
595 // TODO use parameterized tests
596 if (!live.hasFrontendConnection) {
597 return;
598 }
599 if (live.ipFilterId.compare(emptyHardwareId) == 0) {
600 return;
601 }
602 configSingleFilterInDemuxTest(filterMap[live.ipFilterId], frontendMap[live.frontendId]);
603}
604
605TEST_P(TunerFilterAidlTest, ReconfigFilterToReceiveStartId) {
606 description("Recofigure and restart a filter to test start id.");
607 if (!live.hasFrontendConnection) {
608 return;
609 }
610 // TODO use parameterized tests
611 reconfigSingleFilterInDemuxTest(filterMap[live.videoFilterId], filterMap[live.videoFilterId],
612 frontendMap[live.frontendId]);
613}
614
615TEST_P(TunerFilterAidlTest, SetFilterLinkage) {
616 description("Pick up all the possible linkages from the demux caps and set them up.");
617 DemuxCapabilities caps;
618 int32_t demuxId;
619 std::shared_ptr<IDemux> demux;
620 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
621 ASSERT_TRUE(mDemuxTests.getDemuxCaps(caps));
622 mFilterTests.setDemux(demux);
623 for (int i = 0; i < caps.linkCaps.size(); i++) {
624 uint32_t bitMask = 1;
625 for (int j = 0; j < FILTER_MAIN_TYPE_BIT_COUNT; j++) {
626 if (caps.linkCaps[i] & (bitMask << j)) {
627 int64_t sourceFilterId;
628 int64_t sinkFilterId;
629 ASSERT_TRUE(mFilterTests.openFilterInDemux(getLinkageFilterType(i), FMQ_SIZE_16M));
630 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(sourceFilterId));
631 ASSERT_TRUE(mFilterTests.openFilterInDemux(getLinkageFilterType(j), FMQ_SIZE_16M));
632 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(sinkFilterId));
633 ASSERT_TRUE(mFilterTests.setFilterDataSource(sourceFilterId, sinkFilterId));
634 ASSERT_TRUE(mFilterTests.setFilterDataSourceToDemux(sinkFilterId));
635 ASSERT_TRUE(mFilterTests.closeFilter(sinkFilterId));
636 ASSERT_TRUE(mFilterTests.closeFilter(sourceFilterId));
637 }
638 }
639 }
640 ASSERT_TRUE(mDemuxTests.closeDemux());
641}
642
643TEST_P(TunerFilterAidlTest, testTimeFilter) {
644 description("Open a timer filter in Demux and set time stamp.");
645 if (!timeFilter.support) {
646 return;
647 }
648 // TODO use parameterized tests
649 testTimeFilter(timeFilterMap[timeFilter.timeFilterId]);
650}
651
Gareth Fenn9a808452022-03-31 08:40:00 +0100652static bool isEventProducingFilter(const FilterConfig& filterConfig) {
653 switch (filterConfig.type.mainType) {
654 case DemuxFilterMainType::TS: {
655 auto tsFilterType =
656 filterConfig.type.subType.get<DemuxFilterSubType::Tag::tsFilterType>();
657 return (tsFilterType == DemuxTsFilterType::SECTION ||
658 tsFilterType == DemuxTsFilterType::PES ||
659 tsFilterType == DemuxTsFilterType::AUDIO ||
660 tsFilterType == DemuxTsFilterType::VIDEO ||
661 tsFilterType == DemuxTsFilterType::RECORD ||
662 tsFilterType == DemuxTsFilterType::TEMI);
663 }
664 case DemuxFilterMainType::MMTP: {
665 auto mmtpFilterType =
666 filterConfig.type.subType.get<DemuxFilterSubType::Tag::mmtpFilterType>();
667 return (mmtpFilterType == DemuxMmtpFilterType::SECTION ||
668 mmtpFilterType == DemuxMmtpFilterType::PES ||
669 mmtpFilterType == DemuxMmtpFilterType::AUDIO ||
670 mmtpFilterType == DemuxMmtpFilterType::VIDEO ||
671 mmtpFilterType == DemuxMmtpFilterType::RECORD ||
672 mmtpFilterType == DemuxMmtpFilterType::DOWNLOAD);
673 }
674 case DemuxFilterMainType::IP: {
675 auto ipFilterType =
676 filterConfig.type.subType.get<DemuxFilterSubType::Tag::ipFilterType>();
677 return (ipFilterType == DemuxIpFilterType::SECTION);
678 }
679 case DemuxFilterMainType::TLV: {
680 auto tlvFilterType =
681 filterConfig.type.subType.get<DemuxFilterSubType::Tag::tlvFilterType>();
682 return (tlvFilterType == DemuxTlvFilterType::SECTION);
683 }
684 case DemuxFilterMainType::ALP: {
685 auto alpFilterType =
686 filterConfig.type.subType.get<DemuxFilterSubType::Tag::alpFilterType>();
687 return (alpFilterType == DemuxAlpFilterType::SECTION);
688 }
689 default:
690 return false;
691 }
692}
693
Patrick Rohr1586d212021-11-23 00:40:56 +0100694static bool isMediaFilter(const FilterConfig& filterConfig) {
695 switch (filterConfig.type.mainType) {
696 case DemuxFilterMainType::TS: {
697 // TS Audio and Video filters are media filters
698 auto tsFilterType =
699 filterConfig.type.subType.get<DemuxFilterSubType::Tag::tsFilterType>();
700 return (tsFilterType == DemuxTsFilterType::AUDIO ||
701 tsFilterType == DemuxTsFilterType::VIDEO);
702 }
703 case DemuxFilterMainType::MMTP: {
704 // MMTP Audio and Video filters are media filters
705 auto mmtpFilterType =
706 filterConfig.type.subType.get<DemuxFilterSubType::Tag::mmtpFilterType>();
707 return (mmtpFilterType == DemuxMmtpFilterType::AUDIO ||
708 mmtpFilterType == DemuxMmtpFilterType::VIDEO);
709 }
710 default:
711 return false;
712 }
713}
Patrick Rohr149b0872021-11-20 00:39:37 +0100714
Patrick Rohr1586d212021-11-23 00:40:56 +0100715static int getDemuxFilterEventDataLength(const DemuxFilterEvent& event) {
716 switch (event.getTag()) {
717 case DemuxFilterEvent::Tag::section:
718 return event.get<DemuxFilterEvent::Tag::section>().dataLength;
719 case DemuxFilterEvent::Tag::media:
720 return event.get<DemuxFilterEvent::Tag::media>().dataLength;
721 case DemuxFilterEvent::Tag::pes:
722 return event.get<DemuxFilterEvent::Tag::pes>().dataLength;
723 case DemuxFilterEvent::Tag::download:
724 return event.get<DemuxFilterEvent::Tag::download>().dataLength;
725 case DemuxFilterEvent::Tag::ipPayload:
726 return event.get<DemuxFilterEvent::Tag::ipPayload>().dataLength;
727
728 case DemuxFilterEvent::Tag::tsRecord:
729 case DemuxFilterEvent::Tag::mmtpRecord:
730 case DemuxFilterEvent::Tag::temi:
731 case DemuxFilterEvent::Tag::monitorEvent:
732 case DemuxFilterEvent::Tag::startId:
733 return 0;
734 }
735}
736
737// TODO: move boilerplate into text fixture
738void TunerFilterAidlTest::testDelayHint(const FilterConfig& filterConf) {
Gareth Fenn9a808452022-03-31 08:40:00 +0100739 if (!filterConf.timeDelayInMs && !filterConf.dataDelayInBytes) {
740 return;
741 }
742 if (!isEventProducingFilter(filterConf)) {
743 return;
744 }
Patrick Rohr149b0872021-11-20 00:39:37 +0100745 int32_t feId;
746 int32_t demuxId;
747 std::shared_ptr<IDemux> demux;
748 int64_t filterId;
749
750 mFrontendTests.getFrontendIdByType(frontendMap[live.frontendId].type, feId);
751 ASSERT_TRUE(feId != INVALID_ID);
752 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
753 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
754 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
755 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
756 mFilterTests.setDemux(demux);
757
Patrick Rohr149b0872021-11-20 00:39:37 +0100758 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
759 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
Patrick Rohr149b0872021-11-20 00:39:37 +0100760
Patrick Rohr1586d212021-11-23 00:40:56 +0100761 bool mediaFilter = isMediaFilter(filterConf);
Patrick Rohr149b0872021-11-20 00:39:37 +0100762 auto filter = mFilterTests.getFilterById(filterId);
763
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100764 // startTime needs to be set before calling setDelayHint.
765 auto startTime = std::chrono::steady_clock::now();
766
Gareth Fenn9a808452022-03-31 08:40:00 +0100767 int timeDelayInMs = filterConf.timeDelayInMs;
768 if (timeDelayInMs > 0) {
Patrick Rohr1586d212021-11-23 00:40:56 +0100769 FilterDelayHint delayHint;
770 delayHint.hintType = FilterDelayHintType::TIME_DELAY_IN_MS;
Gareth Fenn9a808452022-03-31 08:40:00 +0100771 delayHint.hintValue = timeDelayInMs;
Patrick Rohr149b0872021-11-20 00:39:37 +0100772
Patrick Rohr1586d212021-11-23 00:40:56 +0100773 // setDelayHint should fail for media filters.
774 ASSERT_EQ(filter->setDelayHint(delayHint).isOk(), !mediaFilter);
775 }
Patrick Rohr149b0872021-11-20 00:39:37 +0100776
Patrick Rohr1586d212021-11-23 00:40:56 +0100777 int dataDelayInBytes = filterConf.dataDelayInBytes;
778 if (dataDelayInBytes > 0) {
779 FilterDelayHint delayHint;
780 delayHint.hintType = FilterDelayHintType::DATA_SIZE_DELAY_IN_BYTES;
781 delayHint.hintValue = dataDelayInBytes;
Patrick Rohr149b0872021-11-20 00:39:37 +0100782
Patrick Rohr1586d212021-11-23 00:40:56 +0100783 // setDelayHint should fail for media filters.
784 ASSERT_EQ(filter->setDelayHint(delayHint).isOk(), !mediaFilter);
785 }
Patrick Rohr149b0872021-11-20 00:39:37 +0100786
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100787 // start and stop filter (and wait for first callback) in order to
788 // circumvent callback scheduler race conditions after adjusting filter
789 // delays.
790 auto cb = mFilterTests.getFilterCallbacks().at(filterId);
791 auto future =
792 cb->verifyFilterCallback([](const std::vector<DemuxFilterEvent>&) { return true; });
Gareth Fenn9a808452022-03-31 08:40:00 +0100793
794 // The configure stage can also produce events, so we should set the delay
795 // hint beforehand.
796 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
Patrick Rohr1586d212021-11-23 00:40:56 +0100797 mFilterTests.startFilter(filterId);
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100798
799 auto timeout = std::chrono::seconds(30);
800 ASSERT_EQ(future.wait_for(timeout), std::future_status::ready);
801
Patrick Rohr1586d212021-11-23 00:40:56 +0100802 mFilterTests.stopFilter(filterId);
Patrick Rohr149b0872021-11-20 00:39:37 +0100803
Patrick Rohr1586d212021-11-23 00:40:56 +0100804 if (!mediaFilter) {
Patrick Rohr1586d212021-11-23 00:40:56 +0100805 int callbackSize = 0;
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100806 future = cb->verifyFilterCallback(
Patrick Rohr1586d212021-11-23 00:40:56 +0100807 [&callbackSize](const std::vector<DemuxFilterEvent>& events) {
808 for (const auto& event : events) {
809 callbackSize += getDemuxFilterEventDataLength(event);
810 }
811 return true;
812 });
813
Patrick Rohr1586d212021-11-23 00:40:56 +0100814 ASSERT_TRUE(mFilterTests.startFilter(filterId));
815
816 // block and wait for callback to be received.
Patrick Rohr1586d212021-11-23 00:40:56 +0100817 ASSERT_EQ(future.wait_for(timeout), std::future_status::ready);
Patrick Rohr1586d212021-11-23 00:40:56 +0100818
Gareth Fenn9a808452022-03-31 08:40:00 +0100819 auto duration = std::chrono::steady_clock::now() - startTime;
820 bool delayHintTest = duration >= std::chrono::milliseconds(timeDelayInMs);
Patrick Rohr1586d212021-11-23 00:40:56 +0100821 bool dataSizeTest = callbackSize >= dataDelayInBytes;
822
Gareth Fenn9a808452022-03-31 08:40:00 +0100823 if (timeDelayInMs > 0 && dataDelayInBytes > 0) {
Patrick Rohr1586d212021-11-23 00:40:56 +0100824 ASSERT_TRUE(delayHintTest || dataSizeTest);
825 } else {
826 // if only one of time delay / data delay is configured, one of them
827 // holds true by default, so we want both assertions to be true.
828 ASSERT_TRUE(delayHintTest && dataSizeTest);
829 }
830
831 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
832 }
833
Patrick Rohr149b0872021-11-20 00:39:37 +0100834 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
835 ASSERT_TRUE(mDemuxTests.closeDemux());
836 ASSERT_TRUE(mFrontendTests.closeFrontend());
837}
838
Patrick Rohr1586d212021-11-23 00:40:56 +0100839TEST_P(TunerFilterAidlTest, FilterDelayHintTest) {
840 description("Test filter time delay hint.");
Gareth Fenn9a808452022-03-31 08:40:00 +0100841 if (!live.hasFrontendConnection) {
842 return;
843 }
Patrick Rohr1586d212021-11-23 00:40:56 +0100844 for (const auto& obj : filterMap) {
845 testDelayHint(obj.second);
846 }
847}
848
Hongguang600a6ae2021-07-08 18:51:51 -0700849TEST_P(TunerPlaybackAidlTest, PlaybackDataFlowWithTsSectionFilterTest) {
850 description("Feed ts data from playback and configure Ts section filter to get output");
Frankie Lizcanoa53f5542022-07-07 17:32:06 +0000851 if (!playback.support) {
Hongguang600a6ae2021-07-08 18:51:51 -0700852 return;
853 }
Frankie Lizcanoa53f5542022-07-07 17:32:06 +0000854 vector<DvrPlaybackHardwareConnections> playback_configs = generatePlaybackConfigs();
855 for (auto& configuration : playback_configs) {
856 if (configuration.sectionFilterId.compare(emptyHardwareId) != 0) {
857 playback = configuration;
858 playbackSingleFilterTest(filterMap[playback.sectionFilterId], dvrMap[playback.dvrId]);
859 }
860 }
Hongguang600a6ae2021-07-08 18:51:51 -0700861}
862
863TEST_P(TunerPlaybackAidlTest, PlaybackDataFlowWithTsAudioFilterTest) {
864 description("Feed ts data from playback and configure Ts audio filter to get output");
865 if (!playback.support) {
866 return;
867 }
Frankie Lizcanoa53f5542022-07-07 17:32:06 +0000868 vector<DvrPlaybackHardwareConnections> playback_configs = generatePlaybackConfigs();
869 for (auto& configuration : playback_configs) {
870 playback = configuration;
871 playbackSingleFilterTest(filterMap[playback.audioFilterId], dvrMap[playback.dvrId]);
872 }
Hongguang600a6ae2021-07-08 18:51:51 -0700873}
874
875TEST_P(TunerPlaybackAidlTest, PlaybackDataFlowWithTsVideoFilterTest) {
876 description("Feed ts data from playback and configure Ts video filter to get output");
877 if (!playback.support) {
878 return;
879 }
Frankie Lizcanoa53f5542022-07-07 17:32:06 +0000880 vector<DvrPlaybackHardwareConnections> playback_configs = generatePlaybackConfigs();
881 for (auto& configuration : playback_configs) {
882 playback = configuration;
883 playbackSingleFilterTest(filterMap[playback.videoFilterId], dvrMap[playback.dvrId]);
884 }
Hongguang600a6ae2021-07-08 18:51:51 -0700885}
886
887TEST_P(TunerRecordAidlTest, RecordDataFlowWithTsRecordFilterTest) {
888 description("Feed ts data from frontend to recording and test with ts record filter");
889 if (!record.support) {
890 return;
891 }
892 recordSingleFilterTest(filterMap[record.recordFilterId], frontendMap[record.frontendId],
893 dvrMap[record.dvrRecordId]);
894}
895
896TEST_P(TunerRecordAidlTest, AttachFiltersToRecordTest) {
897 description("Attach a single filter to the record dvr test.");
898 // TODO use parameterized tests
899 if (!record.support) {
900 return;
901 }
902 attachSingleFilterToRecordDvrTest(filterMap[record.recordFilterId],
903 frontendMap[record.frontendId], dvrMap[record.dvrRecordId]);
904}
905
906TEST_P(TunerRecordAidlTest, LnbRecordDataFlowWithTsRecordFilterTest) {
907 description("Feed ts data from Fe with Lnb to recording and test with ts record filter");
908 if (!lnbRecord.support) {
909 return;
910 }
911 recordSingleFilterTestWithLnb(filterMap[lnbRecord.recordFilterId],
912 frontendMap[lnbRecord.frontendId], dvrMap[lnbRecord.dvrRecordId],
913 lnbMap[lnbRecord.lnbId]);
914}
915
916TEST_P(TunerFrontendAidlTest, TuneFrontend) {
917 description("Tune one Frontend with specific setting and check Lock event");
918 if (!live.hasFrontendConnection) {
919 return;
920 }
921 mFrontendTests.tuneTest(frontendMap[live.frontendId]);
922}
923
924TEST_P(TunerFrontendAidlTest, AutoScanFrontend) {
925 description("Run an auto frontend scan with specific setting and check lock scanMessage");
926 if (!scan.hasFrontendConnection) {
927 return;
928 }
929 mFrontendTests.scanTest(frontendMap[scan.frontendId], FrontendScanType::SCAN_AUTO);
930}
931
932TEST_P(TunerFrontendAidlTest, BlindScanFrontend) {
933 description("Run an blind frontend scan with specific setting and check lock scanMessage");
934 if (!scan.hasFrontendConnection) {
935 return;
936 }
937 mFrontendTests.scanTest(frontendMap[scan.frontendId], FrontendScanType::SCAN_BLIND);
938}
939
940TEST_P(TunerFrontendAidlTest, TuneFrontendWithFrontendSettings) {
941 description("Tune one Frontend with setting and check Lock event");
942 if (!live.hasFrontendConnection) {
943 return;
944 }
945 mFrontendTests.tuneTest(frontendMap[live.frontendId]);
946}
947
948TEST_P(TunerFrontendAidlTest, BlindScanFrontendWithEndFrequency) {
949 description("Run an blind frontend scan with setting and check lock scanMessage");
950 if (!scan.hasFrontendConnection) {
951 return;
952 }
953 mFrontendTests.scanTest(frontendMap[scan.frontendId], FrontendScanType::SCAN_BLIND);
954}
955
956TEST_P(TunerFrontendAidlTest, LinkToCiCam) {
957 description("Test Frontend link to CiCam");
958 if (!live.hasFrontendConnection) {
959 return;
960 }
961 if (!frontendMap[live.frontendId].canConnectToCiCam) {
962 return;
963 }
964 mFrontendTests.tuneTest(frontendMap[live.frontendId]);
965}
966
Hongguangfcedda02021-12-13 17:08:02 -0800967TEST_P(TunerFrontendAidlTest, getHardwareInfo) {
968 description("Test Frontend get hardware info");
969 if (!live.hasFrontendConnection) {
970 return;
971 }
972 mFrontendTests.debugInfoTest(frontendMap[live.frontendId]);
973}
974
Hongguang5766ddf2021-12-23 11:40:37 -0800975TEST_P(TunerFrontendAidlTest, maxNumberOfFrontends) {
976 description("Test Max Frontend number");
977 if (!live.hasFrontendConnection) {
978 return;
979 }
980 mFrontendTests.maxNumberOfFrontendsTest();
981}
982
Hongguang881190f2022-01-14 13:23:37 -0800983TEST_P(TunerFrontendAidlTest, statusReadinessTest) {
984 description("Test Max Frontend status readiness");
985 if (!live.hasFrontendConnection) {
986 return;
987 }
988 mFrontendTests.statusReadinessTest(frontendMap[live.frontendId]);
989}
990
Hongguang600a6ae2021-07-08 18:51:51 -0700991TEST_P(TunerBroadcastAidlTest, BroadcastDataFlowVideoFilterTest) {
992 description("Test Video Filter functionality in Broadcast use case.");
993 if (!live.hasFrontendConnection) {
994 return;
995 }
996 broadcastSingleFilterTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
997}
998
999TEST_P(TunerBroadcastAidlTest, BroadcastDataFlowAudioFilterTest) {
1000 description("Test Audio Filter functionality in Broadcast use case.");
1001 if (!live.hasFrontendConnection) {
1002 return;
1003 }
1004 broadcastSingleFilterTest(filterMap[live.audioFilterId], frontendMap[live.frontendId]);
1005}
1006
1007TEST_P(TunerBroadcastAidlTest, BroadcastDataFlowSectionFilterTest) {
1008 description("Test Section Filter functionality in Broadcast use case.");
1009 if (!live.hasFrontendConnection) {
1010 return;
1011 }
1012 if (live.sectionFilterId.compare(emptyHardwareId) == 0) {
1013 return;
1014 }
1015 broadcastSingleFilterTest(filterMap[live.sectionFilterId], frontendMap[live.frontendId]);
1016}
1017
1018TEST_P(TunerBroadcastAidlTest, IonBufferTest) {
1019 description("Test the av filter data bufferring.");
1020 if (!live.hasFrontendConnection) {
1021 return;
1022 }
1023 broadcastSingleFilterTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
1024}
1025
1026TEST_P(TunerBroadcastAidlTest, LnbBroadcastDataFlowVideoFilterTest) {
1027 description("Test Video Filter functionality in Broadcast with Lnb use case.");
1028 if (!lnbLive.support) {
1029 return;
1030 }
Frankie Lizcano1e283b32022-07-08 21:07:42 +00001031 vector<LnbLiveHardwareConnections> lnbLive_configs = generateLnbLiveConfigurations();
1032 if (lnbLive_configs.empty()) {
1033 ALOGD("No frontends that support satellites.");
1034 return;
1035 }
1036 for (auto& combination : lnbLive_configs) {
1037 lnbLive = combination;
1038 broadcastSingleFilterTestWithLnb(filterMap[lnbLive.videoFilterId],
1039 frontendMap[lnbLive.frontendId], lnbMap[lnbLive.lnbId]);
1040 }
Hongguang600a6ae2021-07-08 18:51:51 -07001041}
1042
1043TEST_P(TunerBroadcastAidlTest, MediaFilterWithSharedMemoryHandle) {
1044 description("Test the Media Filter with shared memory handle");
1045 if (!live.hasFrontendConnection) {
1046 return;
1047 }
1048 mediaFilterUsingSharedMemoryTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
1049}
1050
1051TEST_P(TunerDescramblerAidlTest, CreateDescrambler) {
1052 description("Create Descrambler");
1053 if (!descrambling.support) {
1054 return;
1055 }
1056 int32_t demuxId;
1057 std::shared_ptr<IDemux> demux;
1058 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
1059
1060 if (descrambling.hasFrontendConnection) {
1061 int32_t feId;
1062 mFrontendTests.getFrontendIdByType(frontendMap[descrambling.frontendId].type, feId);
1063 ASSERT_TRUE(feId != INVALID_ID);
1064 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
1065 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
1066 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
1067 }
1068
1069 ASSERT_TRUE(mDescramblerTests.openDescrambler(demuxId));
1070 ASSERT_TRUE(mDescramblerTests.closeDescrambler());
1071 ASSERT_TRUE(mDemuxTests.closeDemux());
1072
1073 if (descrambling.hasFrontendConnection) {
1074 ASSERT_TRUE(mFrontendTests.closeFrontend());
1075 }
1076}
1077
1078TEST_P(TunerDescramblerAidlTest, ScrambledBroadcastDataFlowMediaFiltersTest) {
1079 description("Test ts audio filter in scrambled broadcast use case");
1080 if (!descrambling.support) {
1081 return;
1082 }
1083 set<FilterConfig> filterConfs;
1084 filterConfs.insert(static_cast<FilterConfig>(filterMap[descrambling.audioFilterId]));
1085 filterConfs.insert(static_cast<FilterConfig>(filterMap[descrambling.videoFilterId]));
1086 scrambledBroadcastTest(filterConfs, frontendMap[descrambling.frontendId],
1087 descramblerMap[descrambling.descramblerId]);
1088}
1089
1090INSTANTIATE_TEST_SUITE_P(PerInstance, TunerBroadcastAidlTest,
1091 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1092 android::PrintInstanceNameToString);
1093
1094INSTANTIATE_TEST_SUITE_P(PerInstance, TunerFrontendAidlTest,
1095 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1096 android::PrintInstanceNameToString);
1097
1098INSTANTIATE_TEST_SUITE_P(PerInstance, TunerFilterAidlTest,
1099 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1100 android::PrintInstanceNameToString);
1101
1102INSTANTIATE_TEST_SUITE_P(PerInstance, TunerRecordAidlTest,
1103 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1104 android::PrintInstanceNameToString);
1105
1106INSTANTIATE_TEST_SUITE_P(PerInstance, TunerLnbAidlTest,
1107 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1108 android::PrintInstanceNameToString);
1109
1110INSTANTIATE_TEST_SUITE_P(PerInstance, TunerDemuxAidlTest,
1111 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1112 android::PrintInstanceNameToString);
1113
1114INSTANTIATE_TEST_SUITE_P(PerInstance, TunerPlaybackAidlTest,
1115 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1116 android::PrintInstanceNameToString);
1117
1118INSTANTIATE_TEST_SUITE_P(PerInstance, TunerDescramblerAidlTest,
1119 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1120 android::PrintInstanceNameToString);
1121
1122} // namespace
1123
1124// Start thread pool to receive callbacks from AIDL service.
1125int main(int argc, char** argv) {
1126 ::testing::InitGoogleTest(&argc, argv);
1127 ABinderProcess_setThreadPoolMaxThreadCount(1);
1128 ABinderProcess_startThreadPool();
1129 return RUN_ALL_TESTS();
1130}