blob: 07e3e3cbe2ae3753114b17f054bd5cf1c68d0e43 [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 }
497 if (lnbMap[lnbLive.lnbId].name.compare(emptyHardwareId) == 0) {
498 vector<int32_t> ids;
499 ASSERT_TRUE(mLnbTests.getLnbIds(ids));
500 ASSERT_TRUE(ids.size() > 0);
501 ASSERT_TRUE(mLnbTests.openLnbById(ids[0]));
502 } else {
503 int32_t id;
504 ASSERT_TRUE(mLnbTests.openLnbByName(lnbMap[lnbLive.lnbId].name, id));
505 }
506 ASSERT_TRUE(mLnbTests.setLnbCallback());
507 ASSERT_TRUE(mLnbTests.setVoltage(lnbMap[lnbLive.lnbId].voltage));
508 ASSERT_TRUE(mLnbTests.setTone(lnbMap[lnbLive.lnbId].tone));
509 ASSERT_TRUE(mLnbTests.setSatellitePosition(lnbMap[lnbLive.lnbId].position));
510 for (auto msgName : lnbLive.diseqcMsgs) {
511 ASSERT_TRUE(mLnbTests.sendDiseqcMessage(diseqcMsgMap[msgName]));
512 }
513 ASSERT_TRUE(mLnbTests.closeLnb());
514}
515
516TEST_P(TunerDemuxAidlTest, openDemux) {
517 description("Open and close a Demux.");
518 if (!live.hasFrontendConnection) {
519 return;
520 }
521 int32_t feId;
522 int32_t demuxId;
523 std::shared_ptr<IDemux> demux;
524 mFrontendTests.getFrontendIdByType(frontendMap[live.frontendId].type, feId);
525 ASSERT_TRUE(feId != INVALID_ID);
526 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
527 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
528 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
529 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
530 ASSERT_TRUE(mDemuxTests.closeDemux());
531 ASSERT_TRUE(mFrontendTests.closeFrontend());
532}
533
534TEST_P(TunerDemuxAidlTest, getAvSyncTime) {
535 description("Get the A/V sync time from a PCR filter.");
536 if (!live.hasFrontendConnection) {
537 return;
538 }
539 if (live.pcrFilterId.compare(emptyHardwareId) == 0) {
540 return;
541 }
542 int32_t feId;
543 int32_t demuxId;
544 std::shared_ptr<IDemux> demux;
545 int64_t mediaFilterId;
546 int64_t pcrFilterId;
547 int32_t avSyncHwId;
548 std::shared_ptr<IFilter> mediaFilter;
549
550 mFrontendTests.getFrontendIdByType(frontendMap[live.frontendId].type, feId);
551 ASSERT_TRUE(feId != INVALID_ID);
552 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
553 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
554 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
555 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
556 mFilterTests.setDemux(demux);
557 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterMap[live.videoFilterId].type,
558 filterMap[live.videoFilterId].bufferSize));
559 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(mediaFilterId));
560 ASSERT_TRUE(mFilterTests.configFilter(filterMap[live.videoFilterId].settings, mediaFilterId));
561 mediaFilter = mFilterTests.getFilterById(mediaFilterId);
562 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterMap[live.pcrFilterId].type,
563 filterMap[live.pcrFilterId].bufferSize));
564 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(pcrFilterId));
565 ASSERT_TRUE(mFilterTests.configFilter(filterMap[live.pcrFilterId].settings, pcrFilterId));
566 ASSERT_TRUE(mDemuxTests.getAvSyncId(mediaFilter, avSyncHwId));
567 ASSERT_TRUE(pcrFilterId == avSyncHwId);
568 ASSERT_TRUE(mDemuxTests.getAvSyncTime(pcrFilterId));
569 ASSERT_TRUE(mFilterTests.closeFilter(pcrFilterId));
570 ASSERT_TRUE(mFilterTests.closeFilter(mediaFilterId));
571 ASSERT_TRUE(mDemuxTests.closeDemux());
572 ASSERT_TRUE(mFrontendTests.closeFrontend());
573}
574
575TEST_P(TunerFilterAidlTest, StartFilterInDemux) {
576 description("Open and start a filter in Demux.");
577 if (!live.hasFrontendConnection) {
578 return;
579 }
580 // TODO use parameterized tests
581 configSingleFilterInDemuxTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
582}
583
584TEST_P(TunerFilterAidlTest, ConfigIpFilterInDemuxWithCid) {
585 description("Open and configure an ip filter in Demux.");
586 // TODO use parameterized tests
587 if (!live.hasFrontendConnection) {
588 return;
589 }
590 if (live.ipFilterId.compare(emptyHardwareId) == 0) {
591 return;
592 }
593 configSingleFilterInDemuxTest(filterMap[live.ipFilterId], frontendMap[live.frontendId]);
594}
595
596TEST_P(TunerFilterAidlTest, ReconfigFilterToReceiveStartId) {
597 description("Recofigure and restart a filter to test start id.");
598 if (!live.hasFrontendConnection) {
599 return;
600 }
601 // TODO use parameterized tests
602 reconfigSingleFilterInDemuxTest(filterMap[live.videoFilterId], filterMap[live.videoFilterId],
603 frontendMap[live.frontendId]);
604}
605
606TEST_P(TunerFilterAidlTest, SetFilterLinkage) {
607 description("Pick up all the possible linkages from the demux caps and set them up.");
608 DemuxCapabilities caps;
609 int32_t demuxId;
610 std::shared_ptr<IDemux> demux;
611 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
612 ASSERT_TRUE(mDemuxTests.getDemuxCaps(caps));
613 mFilterTests.setDemux(demux);
614 for (int i = 0; i < caps.linkCaps.size(); i++) {
615 uint32_t bitMask = 1;
616 for (int j = 0; j < FILTER_MAIN_TYPE_BIT_COUNT; j++) {
617 if (caps.linkCaps[i] & (bitMask << j)) {
618 int64_t sourceFilterId;
619 int64_t sinkFilterId;
620 ASSERT_TRUE(mFilterTests.openFilterInDemux(getLinkageFilterType(i), FMQ_SIZE_16M));
621 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(sourceFilterId));
622 ASSERT_TRUE(mFilterTests.openFilterInDemux(getLinkageFilterType(j), FMQ_SIZE_16M));
623 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(sinkFilterId));
624 ASSERT_TRUE(mFilterTests.setFilterDataSource(sourceFilterId, sinkFilterId));
625 ASSERT_TRUE(mFilterTests.setFilterDataSourceToDemux(sinkFilterId));
626 ASSERT_TRUE(mFilterTests.closeFilter(sinkFilterId));
627 ASSERT_TRUE(mFilterTests.closeFilter(sourceFilterId));
628 }
629 }
630 }
631 ASSERT_TRUE(mDemuxTests.closeDemux());
632}
633
634TEST_P(TunerFilterAidlTest, testTimeFilter) {
635 description("Open a timer filter in Demux and set time stamp.");
636 if (!timeFilter.support) {
637 return;
638 }
639 // TODO use parameterized tests
640 testTimeFilter(timeFilterMap[timeFilter.timeFilterId]);
641}
642
Gareth Fenn9a808452022-03-31 08:40:00 +0100643static bool isEventProducingFilter(const FilterConfig& filterConfig) {
644 switch (filterConfig.type.mainType) {
645 case DemuxFilterMainType::TS: {
646 auto tsFilterType =
647 filterConfig.type.subType.get<DemuxFilterSubType::Tag::tsFilterType>();
648 return (tsFilterType == DemuxTsFilterType::SECTION ||
649 tsFilterType == DemuxTsFilterType::PES ||
650 tsFilterType == DemuxTsFilterType::AUDIO ||
651 tsFilterType == DemuxTsFilterType::VIDEO ||
652 tsFilterType == DemuxTsFilterType::RECORD ||
653 tsFilterType == DemuxTsFilterType::TEMI);
654 }
655 case DemuxFilterMainType::MMTP: {
656 auto mmtpFilterType =
657 filterConfig.type.subType.get<DemuxFilterSubType::Tag::mmtpFilterType>();
658 return (mmtpFilterType == DemuxMmtpFilterType::SECTION ||
659 mmtpFilterType == DemuxMmtpFilterType::PES ||
660 mmtpFilterType == DemuxMmtpFilterType::AUDIO ||
661 mmtpFilterType == DemuxMmtpFilterType::VIDEO ||
662 mmtpFilterType == DemuxMmtpFilterType::RECORD ||
663 mmtpFilterType == DemuxMmtpFilterType::DOWNLOAD);
664 }
665 case DemuxFilterMainType::IP: {
666 auto ipFilterType =
667 filterConfig.type.subType.get<DemuxFilterSubType::Tag::ipFilterType>();
668 return (ipFilterType == DemuxIpFilterType::SECTION);
669 }
670 case DemuxFilterMainType::TLV: {
671 auto tlvFilterType =
672 filterConfig.type.subType.get<DemuxFilterSubType::Tag::tlvFilterType>();
673 return (tlvFilterType == DemuxTlvFilterType::SECTION);
674 }
675 case DemuxFilterMainType::ALP: {
676 auto alpFilterType =
677 filterConfig.type.subType.get<DemuxFilterSubType::Tag::alpFilterType>();
678 return (alpFilterType == DemuxAlpFilterType::SECTION);
679 }
680 default:
681 return false;
682 }
683}
684
Patrick Rohr1586d212021-11-23 00:40:56 +0100685static bool isMediaFilter(const FilterConfig& filterConfig) {
686 switch (filterConfig.type.mainType) {
687 case DemuxFilterMainType::TS: {
688 // TS Audio and Video filters are media filters
689 auto tsFilterType =
690 filterConfig.type.subType.get<DemuxFilterSubType::Tag::tsFilterType>();
691 return (tsFilterType == DemuxTsFilterType::AUDIO ||
692 tsFilterType == DemuxTsFilterType::VIDEO);
693 }
694 case DemuxFilterMainType::MMTP: {
695 // MMTP Audio and Video filters are media filters
696 auto mmtpFilterType =
697 filterConfig.type.subType.get<DemuxFilterSubType::Tag::mmtpFilterType>();
698 return (mmtpFilterType == DemuxMmtpFilterType::AUDIO ||
699 mmtpFilterType == DemuxMmtpFilterType::VIDEO);
700 }
701 default:
702 return false;
703 }
704}
Patrick Rohr149b0872021-11-20 00:39:37 +0100705
Patrick Rohr1586d212021-11-23 00:40:56 +0100706static int getDemuxFilterEventDataLength(const DemuxFilterEvent& event) {
707 switch (event.getTag()) {
708 case DemuxFilterEvent::Tag::section:
709 return event.get<DemuxFilterEvent::Tag::section>().dataLength;
710 case DemuxFilterEvent::Tag::media:
711 return event.get<DemuxFilterEvent::Tag::media>().dataLength;
712 case DemuxFilterEvent::Tag::pes:
713 return event.get<DemuxFilterEvent::Tag::pes>().dataLength;
714 case DemuxFilterEvent::Tag::download:
715 return event.get<DemuxFilterEvent::Tag::download>().dataLength;
716 case DemuxFilterEvent::Tag::ipPayload:
717 return event.get<DemuxFilterEvent::Tag::ipPayload>().dataLength;
718
719 case DemuxFilterEvent::Tag::tsRecord:
720 case DemuxFilterEvent::Tag::mmtpRecord:
721 case DemuxFilterEvent::Tag::temi:
722 case DemuxFilterEvent::Tag::monitorEvent:
723 case DemuxFilterEvent::Tag::startId:
724 return 0;
725 }
726}
727
728// TODO: move boilerplate into text fixture
729void TunerFilterAidlTest::testDelayHint(const FilterConfig& filterConf) {
Gareth Fenn9a808452022-03-31 08:40:00 +0100730 if (!filterConf.timeDelayInMs && !filterConf.dataDelayInBytes) {
731 return;
732 }
733 if (!isEventProducingFilter(filterConf)) {
734 return;
735 }
Patrick Rohr149b0872021-11-20 00:39:37 +0100736 int32_t feId;
737 int32_t demuxId;
738 std::shared_ptr<IDemux> demux;
739 int64_t filterId;
740
741 mFrontendTests.getFrontendIdByType(frontendMap[live.frontendId].type, feId);
742 ASSERT_TRUE(feId != INVALID_ID);
743 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
744 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
745 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
746 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
747 mFilterTests.setDemux(demux);
748
Patrick Rohr149b0872021-11-20 00:39:37 +0100749 ASSERT_TRUE(mFilterTests.openFilterInDemux(filterConf.type, filterConf.bufferSize));
750 ASSERT_TRUE(mFilterTests.getNewlyOpenedFilterId_64bit(filterId));
Patrick Rohr149b0872021-11-20 00:39:37 +0100751
Patrick Rohr1586d212021-11-23 00:40:56 +0100752 bool mediaFilter = isMediaFilter(filterConf);
Patrick Rohr149b0872021-11-20 00:39:37 +0100753 auto filter = mFilterTests.getFilterById(filterId);
754
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100755 // startTime needs to be set before calling setDelayHint.
756 auto startTime = std::chrono::steady_clock::now();
757
Gareth Fenn9a808452022-03-31 08:40:00 +0100758 int timeDelayInMs = filterConf.timeDelayInMs;
759 if (timeDelayInMs > 0) {
Patrick Rohr1586d212021-11-23 00:40:56 +0100760 FilterDelayHint delayHint;
761 delayHint.hintType = FilterDelayHintType::TIME_DELAY_IN_MS;
Gareth Fenn9a808452022-03-31 08:40:00 +0100762 delayHint.hintValue = timeDelayInMs;
Patrick Rohr149b0872021-11-20 00:39:37 +0100763
Patrick Rohr1586d212021-11-23 00:40:56 +0100764 // setDelayHint should fail for media filters.
765 ASSERT_EQ(filter->setDelayHint(delayHint).isOk(), !mediaFilter);
766 }
Patrick Rohr149b0872021-11-20 00:39:37 +0100767
Patrick Rohr1586d212021-11-23 00:40:56 +0100768 int dataDelayInBytes = filterConf.dataDelayInBytes;
769 if (dataDelayInBytes > 0) {
770 FilterDelayHint delayHint;
771 delayHint.hintType = FilterDelayHintType::DATA_SIZE_DELAY_IN_BYTES;
772 delayHint.hintValue = dataDelayInBytes;
Patrick Rohr149b0872021-11-20 00:39:37 +0100773
Patrick Rohr1586d212021-11-23 00:40:56 +0100774 // setDelayHint should fail for media filters.
775 ASSERT_EQ(filter->setDelayHint(delayHint).isOk(), !mediaFilter);
776 }
Patrick Rohr149b0872021-11-20 00:39:37 +0100777
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100778 // start and stop filter (and wait for first callback) in order to
779 // circumvent callback scheduler race conditions after adjusting filter
780 // delays.
781 auto cb = mFilterTests.getFilterCallbacks().at(filterId);
782 auto future =
783 cb->verifyFilterCallback([](const std::vector<DemuxFilterEvent>&) { return true; });
Gareth Fenn9a808452022-03-31 08:40:00 +0100784
785 // The configure stage can also produce events, so we should set the delay
786 // hint beforehand.
787 ASSERT_TRUE(mFilterTests.configFilter(filterConf.settings, filterId));
Patrick Rohr1586d212021-11-23 00:40:56 +0100788 mFilterTests.startFilter(filterId);
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100789
790 auto timeout = std::chrono::seconds(30);
791 ASSERT_EQ(future.wait_for(timeout), std::future_status::ready);
792
Patrick Rohr1586d212021-11-23 00:40:56 +0100793 mFilterTests.stopFilter(filterId);
Patrick Rohr149b0872021-11-20 00:39:37 +0100794
Patrick Rohr1586d212021-11-23 00:40:56 +0100795 if (!mediaFilter) {
Patrick Rohr1586d212021-11-23 00:40:56 +0100796 int callbackSize = 0;
Patrick Rohr2b0e9ee2021-12-27 13:55:16 +0100797 future = cb->verifyFilterCallback(
Patrick Rohr1586d212021-11-23 00:40:56 +0100798 [&callbackSize](const std::vector<DemuxFilterEvent>& events) {
799 for (const auto& event : events) {
800 callbackSize += getDemuxFilterEventDataLength(event);
801 }
802 return true;
803 });
804
Patrick Rohr1586d212021-11-23 00:40:56 +0100805 ASSERT_TRUE(mFilterTests.startFilter(filterId));
806
807 // block and wait for callback to be received.
Patrick Rohr1586d212021-11-23 00:40:56 +0100808 ASSERT_EQ(future.wait_for(timeout), std::future_status::ready);
Patrick Rohr1586d212021-11-23 00:40:56 +0100809
Gareth Fenn9a808452022-03-31 08:40:00 +0100810 auto duration = std::chrono::steady_clock::now() - startTime;
811 bool delayHintTest = duration >= std::chrono::milliseconds(timeDelayInMs);
Patrick Rohr1586d212021-11-23 00:40:56 +0100812 bool dataSizeTest = callbackSize >= dataDelayInBytes;
813
Gareth Fenn9a808452022-03-31 08:40:00 +0100814 if (timeDelayInMs > 0 && dataDelayInBytes > 0) {
Patrick Rohr1586d212021-11-23 00:40:56 +0100815 ASSERT_TRUE(delayHintTest || dataSizeTest);
816 } else {
817 // if only one of time delay / data delay is configured, one of them
818 // holds true by default, so we want both assertions to be true.
819 ASSERT_TRUE(delayHintTest && dataSizeTest);
820 }
821
822 ASSERT_TRUE(mFilterTests.stopFilter(filterId));
823 }
824
Patrick Rohr149b0872021-11-20 00:39:37 +0100825 ASSERT_TRUE(mFilterTests.closeFilter(filterId));
826 ASSERT_TRUE(mDemuxTests.closeDemux());
827 ASSERT_TRUE(mFrontendTests.closeFrontend());
828}
829
Patrick Rohr1586d212021-11-23 00:40:56 +0100830TEST_P(TunerFilterAidlTest, FilterDelayHintTest) {
831 description("Test filter time delay hint.");
Gareth Fenn9a808452022-03-31 08:40:00 +0100832 if (!live.hasFrontendConnection) {
833 return;
834 }
Patrick Rohr1586d212021-11-23 00:40:56 +0100835 for (const auto& obj : filterMap) {
836 testDelayHint(obj.second);
837 }
838}
839
Hongguang600a6ae2021-07-08 18:51:51 -0700840TEST_P(TunerPlaybackAidlTest, PlaybackDataFlowWithTsSectionFilterTest) {
841 description("Feed ts data from playback and configure Ts section filter to get output");
842 if (!playback.support || playback.sectionFilterId.compare(emptyHardwareId) == 0) {
843 return;
844 }
845 playbackSingleFilterTest(filterMap[playback.sectionFilterId], dvrMap[playback.dvrId]);
846}
847
848TEST_P(TunerPlaybackAidlTest, PlaybackDataFlowWithTsAudioFilterTest) {
849 description("Feed ts data from playback and configure Ts audio filter to get output");
850 if (!playback.support) {
851 return;
852 }
853 playbackSingleFilterTest(filterMap[playback.audioFilterId], dvrMap[playback.dvrId]);
854}
855
856TEST_P(TunerPlaybackAidlTest, PlaybackDataFlowWithTsVideoFilterTest) {
857 description("Feed ts data from playback and configure Ts video filter to get output");
858 if (!playback.support) {
859 return;
860 }
861 playbackSingleFilterTest(filterMap[playback.videoFilterId], dvrMap[playback.dvrId]);
862}
863
864TEST_P(TunerRecordAidlTest, RecordDataFlowWithTsRecordFilterTest) {
865 description("Feed ts data from frontend to recording and test with ts record filter");
866 if (!record.support) {
867 return;
868 }
869 recordSingleFilterTest(filterMap[record.recordFilterId], frontendMap[record.frontendId],
870 dvrMap[record.dvrRecordId]);
871}
872
873TEST_P(TunerRecordAidlTest, AttachFiltersToRecordTest) {
874 description("Attach a single filter to the record dvr test.");
875 // TODO use parameterized tests
876 if (!record.support) {
877 return;
878 }
879 attachSingleFilterToRecordDvrTest(filterMap[record.recordFilterId],
880 frontendMap[record.frontendId], dvrMap[record.dvrRecordId]);
881}
882
883TEST_P(TunerRecordAidlTest, LnbRecordDataFlowWithTsRecordFilterTest) {
884 description("Feed ts data from Fe with Lnb to recording and test with ts record filter");
885 if (!lnbRecord.support) {
886 return;
887 }
888 recordSingleFilterTestWithLnb(filterMap[lnbRecord.recordFilterId],
889 frontendMap[lnbRecord.frontendId], dvrMap[lnbRecord.dvrRecordId],
890 lnbMap[lnbRecord.lnbId]);
891}
892
893TEST_P(TunerFrontendAidlTest, TuneFrontend) {
894 description("Tune one Frontend with specific setting and check Lock event");
895 if (!live.hasFrontendConnection) {
896 return;
897 }
898 mFrontendTests.tuneTest(frontendMap[live.frontendId]);
899}
900
901TEST_P(TunerFrontendAidlTest, AutoScanFrontend) {
902 description("Run an auto frontend scan with specific setting and check lock scanMessage");
903 if (!scan.hasFrontendConnection) {
904 return;
905 }
906 mFrontendTests.scanTest(frontendMap[scan.frontendId], FrontendScanType::SCAN_AUTO);
907}
908
909TEST_P(TunerFrontendAidlTest, BlindScanFrontend) {
910 description("Run an blind frontend scan with specific setting and check lock scanMessage");
911 if (!scan.hasFrontendConnection) {
912 return;
913 }
914 mFrontendTests.scanTest(frontendMap[scan.frontendId], FrontendScanType::SCAN_BLIND);
915}
916
917TEST_P(TunerFrontendAidlTest, TuneFrontendWithFrontendSettings) {
918 description("Tune one Frontend with setting and check Lock event");
919 if (!live.hasFrontendConnection) {
920 return;
921 }
922 mFrontendTests.tuneTest(frontendMap[live.frontendId]);
923}
924
925TEST_P(TunerFrontendAidlTest, BlindScanFrontendWithEndFrequency) {
926 description("Run an blind frontend scan with setting and check lock scanMessage");
927 if (!scan.hasFrontendConnection) {
928 return;
929 }
930 mFrontendTests.scanTest(frontendMap[scan.frontendId], FrontendScanType::SCAN_BLIND);
931}
932
933TEST_P(TunerFrontendAidlTest, LinkToCiCam) {
934 description("Test Frontend link to CiCam");
935 if (!live.hasFrontendConnection) {
936 return;
937 }
938 if (!frontendMap[live.frontendId].canConnectToCiCam) {
939 return;
940 }
941 mFrontendTests.tuneTest(frontendMap[live.frontendId]);
942}
943
Hongguangfcedda02021-12-13 17:08:02 -0800944TEST_P(TunerFrontendAidlTest, getHardwareInfo) {
945 description("Test Frontend get hardware info");
946 if (!live.hasFrontendConnection) {
947 return;
948 }
949 mFrontendTests.debugInfoTest(frontendMap[live.frontendId]);
950}
951
Hongguang5766ddf2021-12-23 11:40:37 -0800952TEST_P(TunerFrontendAidlTest, maxNumberOfFrontends) {
953 description("Test Max Frontend number");
954 if (!live.hasFrontendConnection) {
955 return;
956 }
957 mFrontendTests.maxNumberOfFrontendsTest();
958}
959
Hongguang881190f2022-01-14 13:23:37 -0800960TEST_P(TunerFrontendAidlTest, statusReadinessTest) {
961 description("Test Max Frontend status readiness");
962 if (!live.hasFrontendConnection) {
963 return;
964 }
965 mFrontendTests.statusReadinessTest(frontendMap[live.frontendId]);
966}
967
Hongguang600a6ae2021-07-08 18:51:51 -0700968TEST_P(TunerBroadcastAidlTest, BroadcastDataFlowVideoFilterTest) {
969 description("Test Video Filter functionality in Broadcast use case.");
970 if (!live.hasFrontendConnection) {
971 return;
972 }
973 broadcastSingleFilterTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
974}
975
976TEST_P(TunerBroadcastAidlTest, BroadcastDataFlowAudioFilterTest) {
977 description("Test Audio Filter functionality in Broadcast use case.");
978 if (!live.hasFrontendConnection) {
979 return;
980 }
981 broadcastSingleFilterTest(filterMap[live.audioFilterId], frontendMap[live.frontendId]);
982}
983
984TEST_P(TunerBroadcastAidlTest, BroadcastDataFlowSectionFilterTest) {
985 description("Test Section Filter functionality in Broadcast use case.");
986 if (!live.hasFrontendConnection) {
987 return;
988 }
989 if (live.sectionFilterId.compare(emptyHardwareId) == 0) {
990 return;
991 }
992 broadcastSingleFilterTest(filterMap[live.sectionFilterId], frontendMap[live.frontendId]);
993}
994
995TEST_P(TunerBroadcastAidlTest, IonBufferTest) {
996 description("Test the av filter data bufferring.");
997 if (!live.hasFrontendConnection) {
998 return;
999 }
1000 broadcastSingleFilterTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
1001}
1002
1003TEST_P(TunerBroadcastAidlTest, LnbBroadcastDataFlowVideoFilterTest) {
1004 description("Test Video Filter functionality in Broadcast with Lnb use case.");
1005 if (!lnbLive.support) {
1006 return;
1007 }
1008 broadcastSingleFilterTestWithLnb(filterMap[lnbLive.videoFilterId],
1009 frontendMap[lnbLive.frontendId], lnbMap[lnbLive.lnbId]);
1010}
1011
1012TEST_P(TunerBroadcastAidlTest, MediaFilterWithSharedMemoryHandle) {
1013 description("Test the Media Filter with shared memory handle");
1014 if (!live.hasFrontendConnection) {
1015 return;
1016 }
1017 mediaFilterUsingSharedMemoryTest(filterMap[live.videoFilterId], frontendMap[live.frontendId]);
1018}
1019
1020TEST_P(TunerDescramblerAidlTest, CreateDescrambler) {
1021 description("Create Descrambler");
1022 if (!descrambling.support) {
1023 return;
1024 }
1025 int32_t demuxId;
1026 std::shared_ptr<IDemux> demux;
1027 ASSERT_TRUE(mDemuxTests.openDemux(demux, demuxId));
1028
1029 if (descrambling.hasFrontendConnection) {
1030 int32_t feId;
1031 mFrontendTests.getFrontendIdByType(frontendMap[descrambling.frontendId].type, feId);
1032 ASSERT_TRUE(feId != INVALID_ID);
1033 ASSERT_TRUE(mFrontendTests.openFrontendById(feId));
1034 ASSERT_TRUE(mFrontendTests.setFrontendCallback());
1035 ASSERT_TRUE(mDemuxTests.setDemuxFrontendDataSource(feId));
1036 }
1037
1038 ASSERT_TRUE(mDescramblerTests.openDescrambler(demuxId));
1039 ASSERT_TRUE(mDescramblerTests.closeDescrambler());
1040 ASSERT_TRUE(mDemuxTests.closeDemux());
1041
1042 if (descrambling.hasFrontendConnection) {
1043 ASSERT_TRUE(mFrontendTests.closeFrontend());
1044 }
1045}
1046
1047TEST_P(TunerDescramblerAidlTest, ScrambledBroadcastDataFlowMediaFiltersTest) {
1048 description("Test ts audio filter in scrambled broadcast use case");
1049 if (!descrambling.support) {
1050 return;
1051 }
1052 set<FilterConfig> filterConfs;
1053 filterConfs.insert(static_cast<FilterConfig>(filterMap[descrambling.audioFilterId]));
1054 filterConfs.insert(static_cast<FilterConfig>(filterMap[descrambling.videoFilterId]));
1055 scrambledBroadcastTest(filterConfs, frontendMap[descrambling.frontendId],
1056 descramblerMap[descrambling.descramblerId]);
1057}
1058
1059INSTANTIATE_TEST_SUITE_P(PerInstance, TunerBroadcastAidlTest,
1060 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1061 android::PrintInstanceNameToString);
1062
1063INSTANTIATE_TEST_SUITE_P(PerInstance, TunerFrontendAidlTest,
1064 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1065 android::PrintInstanceNameToString);
1066
1067INSTANTIATE_TEST_SUITE_P(PerInstance, TunerFilterAidlTest,
1068 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1069 android::PrintInstanceNameToString);
1070
1071INSTANTIATE_TEST_SUITE_P(PerInstance, TunerRecordAidlTest,
1072 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1073 android::PrintInstanceNameToString);
1074
1075INSTANTIATE_TEST_SUITE_P(PerInstance, TunerLnbAidlTest,
1076 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1077 android::PrintInstanceNameToString);
1078
1079INSTANTIATE_TEST_SUITE_P(PerInstance, TunerDemuxAidlTest,
1080 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1081 android::PrintInstanceNameToString);
1082
1083INSTANTIATE_TEST_SUITE_P(PerInstance, TunerPlaybackAidlTest,
1084 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1085 android::PrintInstanceNameToString);
1086
1087INSTANTIATE_TEST_SUITE_P(PerInstance, TunerDescramblerAidlTest,
1088 testing::ValuesIn(android::getAidlHalInstanceNames(ITuner::descriptor)),
1089 android::PrintInstanceNameToString);
1090
1091} // namespace
1092
1093// Start thread pool to receive callbacks from AIDL service.
1094int main(int argc, char** argv) {
1095 ::testing::InitGoogleTest(&argc, argv);
1096 ABinderProcess_setThreadPoolMaxThreadCount(1);
1097 ABinderProcess_startThreadPool();
1098 return RUN_ALL_TESTS();
1099}