blob: 6dcff3574fafdc9b725aebb4253d59aaa526dd65 [file] [log] [blame]
/*
* Copyright (C) 2018 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.server.hdmi;
import static com.google.common.truth.Truth.assertThat;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
import android.annotation.Nullable;
import android.hardware.hdmi.HdmiDeviceInfo;
import android.hardware.tv.cec.V1_0.SendMessageResult;
import android.media.AudioManager;
import android.os.Looper;
import android.os.test.TestLooper;
import androidx.test.InstrumentationRegistry;
import androidx.test.filters.SmallTest;
import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
/** Tests for {@link SystemAudioInitiationActionFromAvr} */
@SmallTest
@RunWith(JUnit4.class)
public class SystemAudioInitiationActionFromAvrTest {
private HdmiCecLocalDeviceAudioSystem mHdmiCecLocalDeviceAudioSystem;
private TestLooper mTestLooper = new TestLooper();
private boolean mShouldDispatchActiveSource;
private boolean mTvSystemAudioModeSupport;
private int mTryCountBeforeSucceed;
private HdmiDeviceInfo mDeviceInfoForTests;
private int mMsgRequestActiveSourceCount;
private int mMsgSetSystemAudioModeCount;
private int mQueryTvSystemAudioModeSupportCount;
private boolean mArcEnabled;
private boolean mIsPlaybackDevice;
private boolean mBroadcastActiveSource;
@Before
public void SetUp() {
mDeviceInfoForTests = new HdmiDeviceInfo(1001, 1234);
HdmiControlService hdmiControlService =
new HdmiControlService(InstrumentationRegistry.getTargetContext()) {
@Override
void sendCecCommand(
HdmiCecMessage command, @Nullable SendMessageCallback callback) {
switch (command.getOpcode()) {
case Constants.MESSAGE_REQUEST_ACTIVE_SOURCE:
mMsgRequestActiveSourceCount++;
if (mTryCountBeforeSucceed >= mMsgRequestActiveSourceCount
&& callback != null) {
callback.onSendCompleted(SendMessageResult.NACK);
break;
}
if (mShouldDispatchActiveSource) {
mHdmiCecLocalDeviceAudioSystem.dispatchMessage(
HdmiCecMessageBuilder.buildActiveSource(
Constants.ADDR_TV, 1002));
}
break;
case Constants.MESSAGE_SET_SYSTEM_AUDIO_MODE:
mMsgSetSystemAudioModeCount++;
if (mTryCountBeforeSucceed >= mMsgSetSystemAudioModeCount
&& callback != null) {
callback.onSendCompleted(SendMessageResult.NACK);
}
break;
case Constants.MESSAGE_INITIATE_ARC:
break;
default:
throw new IllegalArgumentException("Unexpected message");
}
}
@Override
AudioManager getAudioManager() {
return new AudioManager() {
@Override
public int setHdmiSystemAudioSupported(boolean on) {
return 0;
}
@Override
public int getStreamVolume(int streamType) {
return 0;
}
@Override
public boolean isStreamMute(int streamType) {
return false;
}
@Override
public int getStreamMaxVolume(int streamType) {
return 100;
}
@Override
public void adjustStreamVolume(
int streamType, int direction, int flags) {}
};
}
@Override
boolean isPowerStandby() {
return false;
}
@Override
boolean isAddressAllocated() {
return true;
}
@Override
void wakeUp() {}
@Override
int getPhysicalAddress() {
return 0;
}
@Override
boolean isPlaybackDevice() {
return mIsPlaybackDevice;
}
@Override
public void setAndBroadcastActiveSourceFromOneDeviceType(
int sourceAddress, int physicalAddress) {
mBroadcastActiveSource = true;
}
@Override
int pathToPortId(int path) {
return -1;
}
};
mHdmiCecLocalDeviceAudioSystem =
new HdmiCecLocalDeviceAudioSystem(hdmiControlService) {
@Override
void queryTvSystemAudioModeSupport(
TvSystemAudioModeSupportedCallback callback) {
mQueryTvSystemAudioModeSupportCount++;
if (callback != null) {
callback.onResult(mTvSystemAudioModeSupport);
}
}
@Override
HdmiDeviceInfo getDeviceInfo() {
return mDeviceInfoForTests;
}
@Override
void setArcStatus(boolean enabled) {
mArcEnabled = enabled;
}
};
mHdmiCecLocalDeviceAudioSystem.init();
Looper looper = mTestLooper.getLooper();
hdmiControlService.setIoLooper(looper);
}
@Test
public void testNoActiveSourceMessageReceived() {
resetTestVariables();
mShouldDispatchActiveSource = false;
assertThat(mHdmiCecLocalDeviceAudioSystem.getActiveSource().physicalAddress)
.isEqualTo(Constants.INVALID_PHYSICAL_ADDRESS);
mHdmiCecLocalDeviceAudioSystem.addAndStartAction(
new SystemAudioInitiationActionFromAvr(mHdmiCecLocalDeviceAudioSystem));
mTestLooper.dispatchAll();
assertThat(mMsgRequestActiveSourceCount).isEqualTo(1);
assertThat(mMsgSetSystemAudioModeCount).isEqualTo(0);
assertThat(mQueryTvSystemAudioModeSupportCount).isEqualTo(0);
assertFalse(mHdmiCecLocalDeviceAudioSystem.isSystemAudioActivated());
assertThat(mHdmiCecLocalDeviceAudioSystem.getActiveSource().physicalAddress)
.isEqualTo(Constants.INVALID_PHYSICAL_ADDRESS);
}
@Test
public void testTvNotSupport() {
resetTestVariables();
mShouldDispatchActiveSource = true;
mTvSystemAudioModeSupport = false;
mHdmiCecLocalDeviceAudioSystem.addAndStartAction(
new SystemAudioInitiationActionFromAvr(mHdmiCecLocalDeviceAudioSystem));
mTestLooper.dispatchAll();
assertThat(mMsgRequestActiveSourceCount).isEqualTo(1);
assertThat(mMsgSetSystemAudioModeCount).isEqualTo(0);
assertThat(mQueryTvSystemAudioModeSupportCount).isEqualTo(1);
assertFalse(mHdmiCecLocalDeviceAudioSystem.isSystemAudioActivated());
}
@Test
@Ignore("b/120845532")
public void testTvSupport() {
resetTestVariables();
mShouldDispatchActiveSource = true;
mTvSystemAudioModeSupport = true;
mHdmiCecLocalDeviceAudioSystem.addAndStartAction(
new SystemAudioInitiationActionFromAvr(mHdmiCecLocalDeviceAudioSystem));
mTestLooper.dispatchAll();
assertThat(mMsgRequestActiveSourceCount).isEqualTo(1);
assertThat(mMsgSetSystemAudioModeCount).isEqualTo(1);
assertThat(mQueryTvSystemAudioModeSupportCount).isEqualTo(1);
assertTrue(mHdmiCecLocalDeviceAudioSystem.isSystemAudioActivated());
assertThat(mHdmiCecLocalDeviceAudioSystem.getActiveSource().physicalAddress)
.isEqualTo(1002);
}
@Test
public void testKnownActiveSource() {
resetTestVariables();
mTvSystemAudioModeSupport = true;
mHdmiCecLocalDeviceAudioSystem.getActiveSource().physicalAddress = 1001;
mHdmiCecLocalDeviceAudioSystem.addAndStartAction(
new SystemAudioInitiationActionFromAvr(mHdmiCecLocalDeviceAudioSystem));
mTestLooper.dispatchAll();
assertThat(mMsgRequestActiveSourceCount).isEqualTo(0);
assertThat(mMsgSetSystemAudioModeCount).isEqualTo(1);
assertThat(mQueryTvSystemAudioModeSupportCount).isEqualTo(1);
assertTrue(mHdmiCecLocalDeviceAudioSystem.isSystemAudioActivated());
}
@Test
public void testRetry() {
resetTestVariables();
mTvSystemAudioModeSupport = true;
mShouldDispatchActiveSource = true;
mTryCountBeforeSucceed = 3;
assertThat(mTryCountBeforeSucceed)
.isAtMost(SystemAudioInitiationActionFromAvr.MAX_RETRY_COUNT);
assertThat(mHdmiCecLocalDeviceAudioSystem.getActiveSource().physicalAddress)
.isEqualTo(Constants.INVALID_PHYSICAL_ADDRESS);
mHdmiCecLocalDeviceAudioSystem.addAndStartAction(
new SystemAudioInitiationActionFromAvr(mHdmiCecLocalDeviceAudioSystem));
mTestLooper.dispatchAll();
assertThat(mMsgRequestActiveSourceCount).isEqualTo(4);
assertThat(mMsgSetSystemAudioModeCount).isEqualTo(4);
assertThat(mQueryTvSystemAudioModeSupportCount).isEqualTo(1);
assertTrue(mHdmiCecLocalDeviceAudioSystem.isSystemAudioActivated());
}
@Ignore("b/120845532")
@Test
public void testIsPlaybackDevice_cannotReceiveActiveSource() {
resetTestVariables();
mIsPlaybackDevice = true;
assertThat(mHdmiCecLocalDeviceAudioSystem.getActiveSource().physicalAddress)
.isEqualTo(Constants.INVALID_PHYSICAL_ADDRESS);
mHdmiCecLocalDeviceAudioSystem.addAndStartAction(
new SystemAudioInitiationActionFromAvr(mHdmiCecLocalDeviceAudioSystem));
mTestLooper.dispatchAll();
assertThat(mMsgRequestActiveSourceCount).isEqualTo(1);
assertThat(mBroadcastActiveSource).isTrue();
assertThat(mQueryTvSystemAudioModeSupportCount).isEqualTo(1);
assertThat(mMsgSetSystemAudioModeCount).isEqualTo(1);
assertThat(mHdmiCecLocalDeviceAudioSystem.isSystemAudioActivated()).isTrue();
}
private void resetTestVariables() {
mMsgRequestActiveSourceCount = 0;
mMsgSetSystemAudioModeCount = 0;
mQueryTvSystemAudioModeSupportCount = 0;
mTryCountBeforeSucceed = 0;
mIsPlaybackDevice = false;
mBroadcastActiveSource = false;
mHdmiCecLocalDeviceAudioSystem.getActiveSource().physicalAddress =
Constants.INVALID_PHYSICAL_ADDRESS;
}
}