xref: /aosp_15_r20/frameworks/av/services/audiopolicy/tests/AudioPolicyTestClient.h (revision ec779b8e0859a360c3d303172224686826e6e0e1)
1 /*
2  * Copyright (C) 2017 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 #pragma once
17 
18 #include "AudioPolicyInterface.h"
19 
20 namespace android {
21 
22 class AudioPolicyTestClient : public AudioPolicyClientInterface
23 {
24 public:
25     virtual ~AudioPolicyTestClient() = default;
26 
27     // AudioPolicyClientInterface Implementation
getAudioPolicyConfig(media::AudioPolicyConfig *)28     status_t getAudioPolicyConfig(media::AudioPolicyConfig* /*config*/) override {
29         return INVALID_OPERATION;
30     }
loadHwModule(const char *)31     audio_module_handle_t loadHwModule(const char* /*name*/) override {
32         return AUDIO_MODULE_HANDLE_NONE;
33     }
openOutput(audio_module_handle_t,audio_io_handle_t *,audio_config_t *,audio_config_base_t *,const sp<DeviceDescriptorBase> &,uint32_t *,audio_output_flags_t *,audio_attributes_t)34     status_t openOutput(audio_module_handle_t /*module*/,
35                         audio_io_handle_t* /*output*/,
36                         audio_config_t* /*halConfig*/,
37                         audio_config_base_t* /*mixerConfig*/,
38                         const sp<DeviceDescriptorBase>& /*device*/,
39                         uint32_t* /*latencyMs*/,
40                         audio_output_flags_t* /*flags*/,
41                         audio_attributes_t /*attributes*/) override { return NO_INIT; }
openDuplicateOutput(audio_io_handle_t,audio_io_handle_t)42     audio_io_handle_t openDuplicateOutput(audio_io_handle_t /*output1*/,
43                                           audio_io_handle_t /*output2*/) override {
44         return AUDIO_IO_HANDLE_NONE;
45     }
closeOutput(audio_io_handle_t)46     status_t closeOutput(audio_io_handle_t /*output*/) override { return NO_INIT; }
suspendOutput(audio_io_handle_t)47     status_t suspendOutput(audio_io_handle_t /*output*/) override { return NO_INIT; }
restoreOutput(audio_io_handle_t)48     status_t restoreOutput(audio_io_handle_t /*output*/) override { return NO_INIT; }
openInput(audio_module_handle_t,audio_io_handle_t *,audio_config_t *,audio_devices_t *,const String8 &,audio_source_t,audio_input_flags_t)49     status_t openInput(audio_module_handle_t /*module*/,
50                        audio_io_handle_t* /*input*/,
51                        audio_config_t* /*config*/,
52                        audio_devices_t* /*device*/,
53                        const String8& /*address*/,
54                        audio_source_t /*source*/,
55                        audio_input_flags_t /*flags*/) override { return NO_INIT; }
closeInput(audio_io_handle_t)56     status_t closeInput(audio_io_handle_t /*input*/) override { return NO_INIT; }
setStreamVolume(audio_stream_type_t,float,bool,audio_io_handle_t,int)57     status_t setStreamVolume(audio_stream_type_t /*stream*/,
58                              float /*volume*/,
59                              bool /*muted*/,
60                              audio_io_handle_t /*output*/,
61                              int /*delayMs*/) override { return NO_INIT; }
62 
setPortsVolume(const std::vector<audio_port_handle_t> &,float,bool,audio_io_handle_t,int)63     status_t setPortsVolume(const std::vector<audio_port_handle_t> & /*ports*/, float /*volume*/,
64                             bool /*muted*/, audio_io_handle_t /*output*/,
65                             int /*delayMs*/) override { return NO_INIT; }
66 
setParameters(audio_io_handle_t,const String8 &,int)67     void setParameters(audio_io_handle_t /*ioHandle*/,
68                        const String8& /*keyValuePairs*/,
69                        int /*delayMs*/) override { }
getParameters(audio_io_handle_t,const String8 &)70     String8 getParameters(audio_io_handle_t /*ioHandle*/,
71                           const String8& /*keys*/) override { return String8(); }
setVoiceVolume(float,int)72     status_t setVoiceVolume(float /*volume*/, int /*delayMs*/) override { return NO_INIT; }
moveEffects(audio_session_t,audio_io_handle_t,audio_io_handle_t)73     status_t moveEffects(audio_session_t /*session*/,
74                          audio_io_handle_t /*srcOutput*/,
75                          audio_io_handle_t /*dstOutput*/) override { return NO_INIT; }
createAudioPatch(const struct audio_patch *,audio_patch_handle_t *,int)76     status_t createAudioPatch(const struct audio_patch* /*patch*/,
77                               audio_patch_handle_t* /*handle*/,
78                               int /*delayMs*/) override { return NO_INIT; }
releaseAudioPatch(audio_patch_handle_t,int)79     status_t releaseAudioPatch(audio_patch_handle_t /*handle*/,
80                                int /*delayMs*/) override { return NO_INIT; }
setAudioPortConfig(const struct audio_port_config *,int)81     status_t setAudioPortConfig(const struct audio_port_config* /*config*/,
82                                 int /*delayMs*/) override { return NO_INIT; }
onAudioPortListUpdate()83     void onAudioPortListUpdate() override { }
onAudioPatchListUpdate()84     void onAudioPatchListUpdate() override { }
onAudioVolumeGroupChanged(volume_group_t,int)85     void onAudioVolumeGroupChanged(volume_group_t /*group*/, int /*flags*/) override { }
newAudioUniqueId(audio_unique_id_use_t)86     audio_unique_id_t newAudioUniqueId(audio_unique_id_use_t /*use*/) override { return 0; }
onDynamicPolicyMixStateUpdate(String8,int32_t)87     void onDynamicPolicyMixStateUpdate(String8 /*regId*/, int32_t /*state*/) override { }
onRecordingConfigurationUpdate(int event __unused,const record_client_info_t * clientInfo __unused,const audio_config_base_t * clientConfig __unused,std::vector<effect_descriptor_t> clientEffects __unused,const audio_config_base_t * deviceConfig __unused,std::vector<effect_descriptor_t> effects __unused,audio_patch_handle_t patchHandle __unused,audio_source_t source __unused)88     void onRecordingConfigurationUpdate(int event __unused,
89                                         const record_client_info_t *clientInfo __unused,
90                                         const audio_config_base_t *clientConfig __unused,
91                                         std::vector<effect_descriptor_t> clientEffects __unused,
92                                         const audio_config_base_t *deviceConfig __unused,
93                                         std::vector<effect_descriptor_t> effects __unused,
94                                         audio_patch_handle_t patchHandle __unused,
95                                         audio_source_t source __unused) override { }
onRoutingUpdated()96     void onRoutingUpdated() override { }
onVolumeRangeInitRequest()97     void onVolumeRangeInitRequest() override { }
setEffectSuspended(int effectId __unused,audio_session_t sessionId __unused,bool suspended __unused)98     void setEffectSuspended(int effectId __unused,
99                             audio_session_t sessionId __unused,
100                             bool suspended __unused) {}
setSoundTriggerCaptureState(bool active __unused)101     void setSoundTriggerCaptureState(bool active __unused) override {};
getAudioPort(struct audio_port_v7 * port __unused)102     status_t getAudioPort(struct audio_port_v7 *port __unused) override {
103         return INVALID_OPERATION;
104     };
updateSecondaryOutputs(const TrackSecondaryOutputsMap & trackSecondaryOutputs __unused)105     status_t updateSecondaryOutputs(
106             const TrackSecondaryOutputsMap& trackSecondaryOutputs __unused) override {
107         return NO_INIT;
108     }
setDeviceConnectedState(const struct audio_port_v7 * port __unused,media::DeviceConnectedState state __unused)109     status_t setDeviceConnectedState(const struct audio_port_v7 *port __unused,
110                                      media::DeviceConnectedState state __unused) override {
111         return NO_INIT;
112     }
invalidateTracks(const std::vector<audio_port_handle_t> &)113     status_t invalidateTracks(const std::vector<audio_port_handle_t>& /*portIds*/) override {
114         return NO_INIT;
115     }
getAudioMixPort(const struct audio_port_v7 * devicePort __unused,struct audio_port_v7 * mixPort __unused)116     status_t getAudioMixPort(const struct audio_port_v7 *devicePort __unused,
117                              struct audio_port_v7 *mixPort __unused) override {
118         return INVALID_OPERATION;
119     }
120 
setTracksInternalMute(const std::vector<media::TrackInternalMuteInfo> &)121     status_t setTracksInternalMute(
122             const std::vector<media::TrackInternalMuteInfo>& /*tracksInternalMute*/) override {
123         return INVALID_OPERATION;
124     }
125 
getMmapPolicyInfos(media::audio::common::AudioMMapPolicyType,std::vector<media::audio::common::AudioMMapPolicyInfo> *)126     status_t getMmapPolicyInfos(
127             media::audio::common::AudioMMapPolicyType /*policyType*/,
128             std::vector<media::audio::common::AudioMMapPolicyInfo>* /*policyInfos*/) override {
129         return INVALID_OPERATION;
130     }
checkPermissionForInput(const AttributionSourceState &,const PermissionReqs &)131     error::BinderResult<bool> checkPermissionForInput(const AttributionSourceState& /* attr */,
132                                                               const PermissionReqs& /* req */) {
133         return true;
134     }
135 };
136 
137 } // namespace android
138