blob: 586ed675e0c6423e3d7a9760937cd80e89943964 [file] [log] [blame]
Sham Rathod94aae5e2022-11-23 12:22:32 +05301/*
2 * Copyright (C) 2022 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
Shunkai Yaoe39cd362022-12-22 00:23:34 +000017#include <unordered_set>
18
Mikhail Naganov872d4a62023-03-09 18:19:01 -080019#define LOG_TAG "VtsHalVisualizerTest"
20#include <android-base/logging.h>
21#include <android/binder_enums.h>
Aayush Soni9eb548c2024-10-22 13:07:47 +000022#include <audio_utils/power.h>
Mikhail Naganov872d4a62023-03-09 18:19:01 -080023
Sham Rathod94aae5e2022-11-23 12:22:32 +053024#include "EffectHelper.h"
25
26using namespace android;
27
Aayush Sonibb001fb2024-09-11 13:51:14 +000028using aidl::android::hardware::audio::common::getChannelCount;
Sham Rathod94aae5e2022-11-23 12:22:32 +053029using aidl::android::hardware::audio::effect::Descriptor;
Shunkai Yaof8be1ac2023-03-06 18:41:27 +000030using aidl::android::hardware::audio::effect::getEffectTypeUuidVisualizer;
Sham Rathod94aae5e2022-11-23 12:22:32 +053031using aidl::android::hardware::audio::effect::IEffect;
32using aidl::android::hardware::audio::effect::IFactory;
Sham Rathod94aae5e2022-11-23 12:22:32 +053033using aidl::android::hardware::audio::effect::Parameter;
34using aidl::android::hardware::audio::effect::Visualizer;
Jaideep Sharma74498412023-09-13 15:25:25 +053035using android::hardware::audio::common::testing::detail::TestExecutionTracer;
Sham Rathod94aae5e2022-11-23 12:22:32 +053036
37/**
38 * Here we focus on specific parameter checking, general IEffect interfaces testing performed in
39 * VtsAudioEffectTargetTest.
40 */
41enum ParamName {
42 PARAM_INSTANCE_NAME,
43 PARAM_CAPTURE_SIZE,
44 PARAM_SCALING_MODE,
45 PARAM_MEASUREMENT_MODE,
46 PARAM_LATENCY,
47};
Aayush Soni9eb548c2024-10-22 13:07:47 +000048using VisualizerTestParam = std::tuple<std::pair<std::shared_ptr<IFactory>, Descriptor>, int,
49 Visualizer::ScalingMode, Visualizer::MeasurementMode, int>;
Sham Rathod94aae5e2022-11-23 12:22:32 +053050
Aayush Soni083aa972024-10-21 14:57:16 +000051class VisualizerTestHelper : public EffectHelper {
Sham Rathod94aae5e2022-11-23 12:22:32 +053052 public:
Aayush Soni083aa972024-10-21 14:57:16 +000053 VisualizerTestHelper(
54 std::pair<std::shared_ptr<IFactory>, Descriptor> descPair = {}, int captureSize = 128,
55 int latency = 0,
56 Visualizer::ScalingMode scalingMode = Visualizer::ScalingMode::NORMALIZED,
57 Visualizer::MeasurementMode measurementMode = Visualizer::MeasurementMode::NONE)
58 : mCaptureSize(captureSize),
59 mLatency(latency),
60 mScalingMode(scalingMode),
61 mMeasurementMode(measurementMode),
62 mInputBuffer(mBufferSizeInFrames),
63 mOutputBuffer(mBufferSizeInFrames) {
64 std::tie(mFactory, mDescriptor) = descPair;
Sham Rathod94aae5e2022-11-23 12:22:32 +053065 }
66
Aayush Soni083aa972024-10-21 14:57:16 +000067 void SetUpVisualizer() {
Sham Rathod94aae5e2022-11-23 12:22:32 +053068 ASSERT_NE(nullptr, mFactory);
69 ASSERT_NO_FATAL_FAILURE(create(mFactory, mEffect, mDescriptor));
70
Aayush Sonifbb5cd32024-11-21 10:51:46 +000071 AudioChannelLayout inputLayout = AudioChannelLayout::make<AudioChannelLayout::layoutMask>(
72 AudioChannelLayout::LAYOUT_MONO);
73 AudioChannelLayout outputLayout = inputLayout;
74
Shunkai Yao61f9dd22024-05-08 22:34:36 +000075 Parameter::Common common = createParamCommon(
Aayush Sonifbb5cd32024-11-21 10:51:46 +000076 0 /* session */, 1 /* ioHandle */, mBufferSizeInFrames /* iSampleRate */,
77 mBufferSizeInFrames /* oSampleRate */, kInputFrameCount /* iFrameCount */,
78 kOutputFrameCount /* oFrameCount */, inputLayout, outputLayout);
Aayush Sonibb001fb2024-09-11 13:51:14 +000079 ASSERT_NO_FATAL_FAILURE(open(mEffect, common, std::nullopt, &mOpenEffectReturn, EX_NONE));
Sham Rathod94aae5e2022-11-23 12:22:32 +053080 ASSERT_NE(nullptr, mEffect);
Aayush Sonibb001fb2024-09-11 13:51:14 +000081 mVersion = EffectFactoryHelper::getHalVersion(mFactory);
Sham Rathod94aae5e2022-11-23 12:22:32 +053082 }
83
Aayush Soni083aa972024-10-21 14:57:16 +000084 void TearDownVisualizer() {
Sham Rathod94aae5e2022-11-23 12:22:32 +053085 ASSERT_NO_FATAL_FAILURE(close(mEffect));
86 ASSERT_NO_FATAL_FAILURE(destroy(mFactory, mEffect));
Aayush Sonibb001fb2024-09-11 13:51:14 +000087 mOpenEffectReturn = IEffect::OpenEffectReturn{};
Sham Rathod94aae5e2022-11-23 12:22:32 +053088 }
Sham Rathod94aae5e2022-11-23 12:22:32 +053089
Aayush Soni083aa972024-10-21 14:57:16 +000090 void SetAndGetParameters(bool* allParamsValid = nullptr) {
91 if (allParamsValid != nullptr) *allParamsValid = true;
Sham Rathod94aae5e2022-11-23 12:22:32 +053092 for (auto& it : mCommonTags) {
93 auto& tag = it.first;
94 auto& vs = it.second;
95
96 // validate parameter
97 Descriptor desc;
98 ASSERT_STATUS(EX_NONE, mEffect->getDescriptor(&desc));
Shunkai Yao0a0c45e2023-02-13 17:41:11 +000099 const bool valid = isParameterValid<Visualizer, Range::visualizer>(vs, desc);
Sham Rathod94aae5e2022-11-23 12:22:32 +0530100 const binder_exception_t expected = valid ? EX_NONE : EX_ILLEGAL_ARGUMENT;
Aayush Soni083aa972024-10-21 14:57:16 +0000101 if (expected == EX_ILLEGAL_ARGUMENT && allParamsValid != nullptr) {
102 *allParamsValid = false;
103 }
Sham Rathod94aae5e2022-11-23 12:22:32 +0530104
105 // set parameter
106 Parameter expectParam;
107 Parameter::Specific specific;
108 specific.set<Parameter::Specific::visualizer>(vs);
109 expectParam.set<Parameter::specific>(specific);
110 EXPECT_STATUS(expected, mEffect->setParameter(expectParam)) << expectParam.toString();
111
112 // only get if parameter in range and set success
113 if (expected == EX_NONE) {
114 Parameter getParam;
115 Parameter::Id id;
116 Visualizer::Id vsId;
117 vsId.set<Visualizer::Id::commonTag>(tag);
118 id.set<Parameter::Id::visualizerTag>(vsId);
Shunkai Yao0a0c45e2023-02-13 17:41:11 +0000119 EXPECT_STATUS(EX_NONE, mEffect->getParameter(id, &getParam))
120 << " with: " << id.toString();
Sham Rathod94aae5e2022-11-23 12:22:32 +0530121 EXPECT_EQ(expectParam, getParam) << "\nexpect:" << expectParam.toString()
122 << "\ngetParam:" << getParam.toString();
123 }
124 }
125 }
126
Sham Rathod94aae5e2022-11-23 12:22:32 +0530127 void addCaptureSizeParam(int captureSize) {
Shunkai Yao0a0c45e2023-02-13 17:41:11 +0000128 mCommonTags.push_back({Visualizer::captureSamples,
129 Visualizer::make<Visualizer::captureSamples>(captureSize)});
Sham Rathod94aae5e2022-11-23 12:22:32 +0530130 }
131
132 void addScalingModeParam(Visualizer::ScalingMode scalingMode) {
Shunkai Yao0a0c45e2023-02-13 17:41:11 +0000133 mCommonTags.push_back(
134 {Visualizer::scalingMode, Visualizer::make<Visualizer::scalingMode>(scalingMode)});
Sham Rathod94aae5e2022-11-23 12:22:32 +0530135 }
136
137 void addMeasurementModeParam(Visualizer::MeasurementMode measurementMode) {
Shunkai Yao0a0c45e2023-02-13 17:41:11 +0000138 mCommonTags.push_back({Visualizer::measurementMode,
139 Visualizer::make<Visualizer::measurementMode>(measurementMode)});
Sham Rathod94aae5e2022-11-23 12:22:32 +0530140 }
141
142 void addLatencyParam(int latency) {
Shunkai Yao0a0c45e2023-02-13 17:41:11 +0000143 mCommonTags.push_back(
144 {Visualizer::latencyMs, Visualizer::make<Visualizer::latencyMs>(latency)});
Sham Rathod94aae5e2022-11-23 12:22:32 +0530145 }
146
Aayush Soni9eb548c2024-10-22 13:07:47 +0000147 static std::unordered_set<Visualizer::ScalingMode> getScalingModeValues() {
148 return {ndk::enum_range<Visualizer::ScalingMode>().begin(),
149 ndk::enum_range<Visualizer::ScalingMode>().end()};
150 }
151
Aayush Soni083aa972024-10-21 14:57:16 +0000152 static constexpr long kInputFrameCount = 0x100, kOutputFrameCount = 0x100;
153 const size_t mChannelCount =
154 getChannelCount(AudioChannelLayout::make<AudioChannelLayout::layoutMask>(
Aayush Soni9eb548c2024-10-22 13:07:47 +0000155 AudioChannelLayout::LAYOUT_MONO));
Aayush Soni083aa972024-10-21 14:57:16 +0000156 const size_t mBufferSizeInFrames = kInputFrameCount * mChannelCount;
157 const int mCaptureSize;
158 const int mLatency;
159 const Visualizer::ScalingMode mScalingMode;
160 const Visualizer::MeasurementMode mMeasurementMode;
161 int mVersion;
162 std::vector<float> mInputBuffer;
163 std::vector<float> mOutputBuffer;
164 std::shared_ptr<IEffect> mEffect;
165 std::shared_ptr<IFactory> mFactory;
166 Descriptor mDescriptor;
167 IEffect::OpenEffectReturn mOpenEffectReturn;
168
169 private:
170 std::vector<std::pair<Visualizer::Tag, Visualizer>> mCommonTags;
171 void CleanUp() { mCommonTags.clear(); }
172};
173
Aayush Soni9eb548c2024-10-22 13:07:47 +0000174class VisualizerParamTest : public ::testing::TestWithParam<VisualizerTestParam>,
Aayush Soni083aa972024-10-21 14:57:16 +0000175 public VisualizerTestHelper {
176 public:
177 VisualizerParamTest()
178 : VisualizerTestHelper(std::get<PARAM_INSTANCE_NAME>(GetParam()),
179 std::get<PARAM_CAPTURE_SIZE>(GetParam()),
180 std::get<PARAM_LATENCY>(GetParam()),
181 std::get<PARAM_SCALING_MODE>(GetParam()),
182 std::get<PARAM_MEASUREMENT_MODE>(GetParam())) {
183 generateInputBuffer(mInputBuffer, 0, true, mChannelCount, kMaxAudioSampleValue);
184 }
185
Aayush Soni63d6e2a2025-03-04 13:37:28 +0000186 void SetUp() override { ASSERT_NO_FATAL_FAILURE(SetUpVisualizer()); }
Aayush Soni083aa972024-10-21 14:57:16 +0000187
188 void TearDown() override { TearDownVisualizer(); }
189
Shunkai Yao883d75b2022-12-24 05:15:15 +0000190 static std::unordered_set<Visualizer::MeasurementMode> getMeasurementModeValues() {
191 return {ndk::enum_range<Visualizer::MeasurementMode>().begin(),
192 ndk::enum_range<Visualizer::MeasurementMode>().end()};
193 }
Sham Rathod94aae5e2022-11-23 12:22:32 +0530194};
195
196TEST_P(VisualizerParamTest, SetAndGetCaptureSize) {
Sneha Patil3587ae52025-01-06 05:59:08 +0000197 addCaptureSizeParam(mCaptureSize);
Aayush Sonibb001fb2024-09-11 13:51:14 +0000198 ASSERT_NO_FATAL_FAILURE(SetAndGetParameters());
Sham Rathod94aae5e2022-11-23 12:22:32 +0530199}
200
201TEST_P(VisualizerParamTest, SetAndGetScalingMode) {
Sneha Patil3587ae52025-01-06 05:59:08 +0000202 addScalingModeParam(mScalingMode);
Aayush Sonibb001fb2024-09-11 13:51:14 +0000203 ASSERT_NO_FATAL_FAILURE(SetAndGetParameters());
Sham Rathod94aae5e2022-11-23 12:22:32 +0530204}
205
206TEST_P(VisualizerParamTest, SetAndGetMeasurementMode) {
Sneha Patil3587ae52025-01-06 05:59:08 +0000207 addMeasurementModeParam(mMeasurementMode);
Aayush Sonibb001fb2024-09-11 13:51:14 +0000208 ASSERT_NO_FATAL_FAILURE(SetAndGetParameters());
Sham Rathod94aae5e2022-11-23 12:22:32 +0530209}
210
211TEST_P(VisualizerParamTest, SetAndGetLatency) {
Sneha Patil3587ae52025-01-06 05:59:08 +0000212 addLatencyParam(mLatency);
Aayush Sonibb001fb2024-09-11 13:51:14 +0000213 ASSERT_NO_FATAL_FAILURE(SetAndGetParameters());
214}
215
216TEST_P(VisualizerParamTest, testCaptureSampleBufferSizeAndOutput) {
Aayush Soni7956b832024-09-24 14:57:09 +0000217 SKIP_TEST_IF_DATA_UNSUPPORTED(mDescriptor.common.flags);
Aayush Soni083aa972024-10-21 14:57:16 +0000218
219 bool allParamsValid = true;
Sneha Patil3587ae52025-01-06 05:59:08 +0000220 addCaptureSizeParam(mCaptureSize);
221 addScalingModeParam(mScalingMode);
222 addMeasurementModeParam(mMeasurementMode);
223 addLatencyParam(mLatency);
Aayush Soni083aa972024-10-21 14:57:16 +0000224 ASSERT_NO_FATAL_FAILURE(SetAndGetParameters(&allParamsValid));
Aayush Sonibb001fb2024-09-11 13:51:14 +0000225
226 Parameter getParam;
227 Parameter::Id id;
228 Visualizer::Id vsId;
229 vsId.set<Visualizer::Id::commonTag>(Visualizer::captureSampleBuffer);
230 id.set<Parameter::Id::visualizerTag>(vsId);
231 EXPECT_STATUS(EX_NONE, mEffect->getParameter(id, &getParam)) << " with: " << id.toString();
232
233 ASSERT_NO_FATAL_FAILURE(processAndWriteToOutput(mInputBuffer, mOutputBuffer, mEffect,
234 &mOpenEffectReturn, mVersion));
235 ASSERT_EQ(mInputBuffer, mOutputBuffer);
236
Aayush Soni083aa972024-10-21 14:57:16 +0000237 if (allParamsValid) {
Aayush Sonibb001fb2024-09-11 13:51:14 +0000238 std::vector<uint8_t> captureBuffer = getParam.get<Parameter::specific>()
239 .get<Parameter::Specific::visualizer>()
240 .get<Visualizer::captureSampleBuffer>();
241 ASSERT_EQ((size_t)mCaptureSize, captureBuffer.size());
242 }
Sham Rathod94aae5e2022-11-23 12:22:32 +0530243}
244
Aayush Soni9eb548c2024-10-22 13:07:47 +0000245class VisualizerDataTest : public ::testing::TestWithParam<VisualizerTestParam>,
246 public VisualizerTestHelper {
247 public:
248 VisualizerDataTest()
249 : VisualizerTestHelper(std::get<PARAM_INSTANCE_NAME>(GetParam()),
250 std::get<PARAM_CAPTURE_SIZE>(GetParam()),
251 std::get<PARAM_LATENCY>(GetParam()),
252 std::get<PARAM_SCALING_MODE>(GetParam()),
253 std::get<PARAM_MEASUREMENT_MODE>(GetParam())) {}
254
Aayush Soni63d6e2a2025-03-04 13:37:28 +0000255 void SetUp() override { ASSERT_NO_FATAL_FAILURE(SetUpVisualizer()); }
Aayush Soni9eb548c2024-10-22 13:07:47 +0000256
257 void TearDown() override { TearDownVisualizer(); }
258};
259
260TEST_P(VisualizerDataTest, testScalingModeParameters) {
261 SKIP_TEST_IF_DATA_UNSUPPORTED(mDescriptor.common.flags);
262
263 // This test holds true for the following range
264 static_assert(kMaxAudioSampleValue <= 1.0 && kMaxAudioSampleValue > 0.0,
265 "Valid range of kMaxAudioSample value for the test: (0.0, 1.0]");
266
267 constexpr float kPowerToleranceDb = 0.5;
268
Aayush Sonifbb5cd32024-11-21 10:51:46 +0000269 ASSERT_NO_FATAL_FAILURE(generateSineWave(1000, mInputBuffer, 1.0, mBufferSizeInFrames,
270 AudioChannelLayout::LAYOUT_MONO));
Aayush Soni9eb548c2024-10-22 13:07:47 +0000271 const float expectedPowerNormalized = audio_utils_compute_power_mono(
272 mInputBuffer.data(), AUDIO_FORMAT_PCM_FLOAT, mInputBuffer.size());
273
274 const std::vector<float> testMaxAudioSampleValueList = {
275 0.25 * kMaxAudioSampleValue, 0.5 * kMaxAudioSampleValue, 0.75 * kMaxAudioSampleValue,
276 kMaxAudioSampleValue};
277
278 Parameter::Id idCsb;
279 Visualizer::Id vsIdCsb;
280 vsIdCsb.set<Visualizer::Id::commonTag>(Visualizer::captureSampleBuffer);
281 idCsb.set<Parameter::Id::visualizerTag>(vsIdCsb);
282
283 for (float maxAudioSampleValue : testMaxAudioSampleValueList) {
284 bool allParamsValid = true;
Sneha Patil3587ae52025-01-06 05:59:08 +0000285 addCaptureSizeParam(mCaptureSize);
286 addScalingModeParam(mScalingMode);
287 addLatencyParam(mLatency);
Aayush Soni9eb548c2024-10-22 13:07:47 +0000288 ASSERT_NO_FATAL_FAILURE(SetAndGetParameters(&allParamsValid));
289
Aayush Sonifbb5cd32024-11-21 10:51:46 +0000290 ASSERT_NO_FATAL_FAILURE(generateSineWave(std::vector<int>{1000}, mInputBuffer,
291 maxAudioSampleValue, mBufferSizeInFrames,
292 AudioChannelLayout::LAYOUT_MONO));
Aayush Soni9eb548c2024-10-22 13:07:47 +0000293
294 // The stop and reset calls to the effect are made towards the end in order to fetch the
295 // captureSampleBuffer values
296 ASSERT_NO_FATAL_FAILURE(processAndWriteToOutput(mInputBuffer, mOutputBuffer, mEffect,
297 &mOpenEffectReturn, mVersion, 1, false));
298 if (allParamsValid) {
299 Parameter getParam;
300 EXPECT_STATUS(EX_NONE, mEffect->getParameter(idCsb, &getParam))
301 << " with: " << idCsb.toString();
302 std::vector<uint8_t> captureBuffer = getParam.get<Parameter::specific>()
303 .get<Parameter::Specific::visualizer>()
304 .get<Visualizer::captureSampleBuffer>();
305 ASSERT_EQ((size_t)mCaptureSize, captureBuffer.size());
306
307 float currPowerCsb = audio_utils_compute_power_mono(
308 captureBuffer.data(), AUDIO_FORMAT_PCM_8_BIT, mCaptureSize);
309
310 if (mScalingMode == Visualizer::ScalingMode::NORMALIZED) {
311 EXPECT_NEAR(currPowerCsb, expectedPowerNormalized, kPowerToleranceDb);
312 } else {
313 float powerI = audio_utils_compute_power_mono(
314 mInputBuffer.data(), AUDIO_FORMAT_PCM_FLOAT, mInputBuffer.size());
315 EXPECT_NEAR(currPowerCsb, powerI, kPowerToleranceDb);
316 }
317 }
318 ASSERT_NO_FATAL_FAILURE(command(mEffect, CommandId::STOP));
319 ASSERT_NO_FATAL_FAILURE(command(mEffect, CommandId::RESET));
320 }
321}
322
Shunkai Yao0a0c45e2023-02-13 17:41:11 +0000323std::vector<std::pair<std::shared_ptr<IFactory>, Descriptor>> kDescPair;
Sham Rathod94aae5e2022-11-23 12:22:32 +0530324INSTANTIATE_TEST_SUITE_P(
Shunkai Yaoe39cd362022-12-22 00:23:34 +0000325 VisualizerParamTest, VisualizerParamTest,
Shunkai Yao0a0c45e2023-02-13 17:41:11 +0000326 ::testing::Combine(
327 testing::ValuesIn(kDescPair = EffectFactoryHelper::getAllEffectDescriptors(
Shunkai Yaof8be1ac2023-03-06 18:41:27 +0000328 IFactory::descriptor, getEffectTypeUuidVisualizer())),
Shunkai Yao0a0c45e2023-02-13 17:41:11 +0000329 testing::ValuesIn(EffectHelper::getTestValueSet<Visualizer, int, Range::visualizer,
330 Visualizer::captureSamples>(
331 kDescPair, EffectHelper::expandTestValueBasic<int>)),
Aayush Soni9eb548c2024-10-22 13:07:47 +0000332 testing::ValuesIn(VisualizerTestHelper::getScalingModeValues()),
Shunkai Yao0a0c45e2023-02-13 17:41:11 +0000333 testing::ValuesIn(VisualizerParamTest::getMeasurementModeValues()),
334 testing::ValuesIn(EffectHelper::getTestValueSet<Visualizer, int, Range::visualizer,
335 Visualizer::latencyMs>(
336 kDescPair, EffectHelper::expandTestValueBasic<int>))),
Sham Rathod94aae5e2022-11-23 12:22:32 +0530337 [](const testing::TestParamInfo<VisualizerParamTest::ParamType>& info) {
338 auto descriptor = std::get<PARAM_INSTANCE_NAME>(info.param).second;
339 std::string captureSize = std::to_string(std::get<PARAM_CAPTURE_SIZE>(info.param));
Shunkai Yao883d75b2022-12-24 05:15:15 +0000340 std::string scalingMode = aidl::android::hardware::audio::effect::toString(
341 std::get<PARAM_SCALING_MODE>(info.param));
342 std::string measurementMode = aidl::android::hardware::audio::effect::toString(
343 std::get<PARAM_MEASUREMENT_MODE>(info.param));
Sham Rathod94aae5e2022-11-23 12:22:32 +0530344 std::string latency = std::to_string(std::get<PARAM_LATENCY>(info.param));
345
Jaideep Sharmae4c7a962023-06-14 19:14:44 +0530346 std::string name = getPrefix(descriptor) + "_captureSize" + captureSize +
Sham Rathod94aae5e2022-11-23 12:22:32 +0530347 "_scalingMode" + scalingMode + "_measurementMode" + measurementMode +
348 "_latency" + latency;
349 std::replace_if(
350 name.begin(), name.end(), [](const char c) { return !std::isalnum(c); }, '_');
351 return name;
352 });
353
354GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(VisualizerParamTest);
355
Aayush Soni9eb548c2024-10-22 13:07:47 +0000356INSTANTIATE_TEST_SUITE_P(
357 VisualizerDataTest, VisualizerDataTest,
358 ::testing::Combine(
359 testing::ValuesIn(kDescPair = EffectFactoryHelper::getAllEffectDescriptors(
360 IFactory::descriptor, getEffectTypeUuidVisualizer())),
361 testing::Values(128), // captureSize
362 testing::ValuesIn(VisualizerTestHelper::getScalingModeValues()),
363 testing::Values(Visualizer::MeasurementMode::PEAK_RMS),
364 testing::Values(0) // latency
365 ),
366 [](const testing::TestParamInfo<VisualizerDataTest::ParamType>& info) {
367 auto descriptor = std::get<PARAM_INSTANCE_NAME>(info.param).second;
368 std::string captureSize = std::to_string(std::get<PARAM_CAPTURE_SIZE>(info.param));
369 std::string scalingMode = aidl::android::hardware::audio::effect::toString(
370 std::get<PARAM_SCALING_MODE>(info.param));
371 std::string measurementMode = aidl::android::hardware::audio::effect::toString(
372 std::get<PARAM_MEASUREMENT_MODE>(info.param));
373 std::string latency = std::to_string(std::get<PARAM_LATENCY>(info.param));
374
375 std::string name = getPrefix(descriptor) + "_captureSize" + captureSize +
376 "_scalingMode" + scalingMode + "_measurementMode" + measurementMode +
377 "_latency" + latency;
378 std::replace_if(
379 name.begin(), name.end(), [](const char c) { return !std::isalnum(c); }, '_');
380 return name;
381 });
382
383GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(VisualizerDataTest);
384
Sham Rathod94aae5e2022-11-23 12:22:32 +0530385int main(int argc, char** argv) {
386 ::testing::InitGoogleTest(&argc, argv);
Jaideep Sharma74498412023-09-13 15:25:25 +0530387 ::testing::UnitTest::GetInstance()->listeners().Append(new TestExecutionTracer());
Sham Rathod94aae5e2022-11-23 12:22:32 +0530388 ABinderProcess_setThreadPoolMaxThreadCount(1);
389 ABinderProcess_startThreadPool();
390 return RUN_ALL_TESTS();
Mikhail Naganov872d4a62023-03-09 18:19:01 -0800391}