| /* |
| * Copyright 2020 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 android.hdmicec.cts.audio; |
| |
| import static com.google.common.truth.Truth.assertThat; |
| |
| import android.hdmicec.cts.HdmiCecClientWrapper; |
| import android.hdmicec.cts.HdmiCecConstants; |
| import android.hdmicec.cts.LogicalAddress; |
| import android.hdmicec.cts.RequiredPropertyRule; |
| import android.hdmicec.cts.RequiredFeatureRule; |
| |
| import com.android.tradefed.device.ITestDevice; |
| import com.android.tradefed.testtype.DeviceJUnit4ClassRunner; |
| import com.android.tradefed.testtype.junit4.BaseHostJUnit4Test; |
| |
| import org.junit.Rule; |
| import org.junit.rules.RuleChain; |
| import org.junit.runner.RunWith; |
| import org.junit.Test; |
| |
| import java.util.Scanner; |
| import java.util.concurrent.TimeUnit; |
| |
| @RunWith(DeviceJUnit4ClassRunner.class) |
| public final class HdmiCecRemoteControlPassThroughTest extends BaseHostJUnit4Test { |
| |
| /** The package name of the APK. */ |
| private static final String PACKAGE = "android.hdmicec.app"; |
| |
| /** The class name of the main activity in the APK. */ |
| private static final String CLASS = "HdmiCecKeyEventCapture"; |
| |
| /** The command to launch the main activity. */ |
| private static final String START_COMMAND = String.format( |
| "am start -W -a android.intent.action.MAIN -n %s/%s.%s", PACKAGE, PACKAGE, CLASS); |
| |
| /** The command to clear the main activity. */ |
| private static final String CLEAR_COMMAND = String.format("pm clear %s", PACKAGE); |
| |
| private static final int WAIT_TIME = 10; |
| |
| public HdmiCecClientWrapper hdmiCecClient = new HdmiCecClientWrapper(LogicalAddress.AUDIO_SYSTEM); |
| |
| @Rule |
| public RuleChain ruleChain = |
| RuleChain |
| .outerRule(new RequiredFeatureRule(this, LogicalAddress.HDMI_CEC_FEATURE)) |
| .around(new RequiredFeatureRule(this, LogicalAddress.LEANBACK_FEATURE)) |
| .around(RequiredPropertyRule.asCsvContainsValue( |
| this, |
| LogicalAddress.HDMI_DEVICE_TYPE_PROPERTY, |
| LogicalAddress.AUDIO_SYSTEM.getDeviceType())) |
| .around(hdmiCecClient); |
| |
| private void lookForLog(String expectedOut) throws Exception { |
| ITestDevice device = getDevice(); |
| TimeUnit.SECONDS.sleep(WAIT_TIME); |
| String logs = device.executeAdbCommand("logcat", "-v", "brief", "-d", CLASS + ":I", "*:S"); |
| // Search for string. |
| String testString = ""; |
| Scanner in = new Scanner(logs); |
| while (in.hasNextLine()) { |
| String line = in.nextLine(); |
| if(line.startsWith("I/" + CLASS)) { |
| testString = line.split(":")[1].trim(); |
| break; |
| } |
| } |
| device.executeAdbCommand("logcat", "-c"); |
| assertThat(testString).isEqualTo(expectedOut); |
| } |
| |
| /** |
| * Test 11.2.13-1 |
| * Tests that the device responds correctly to a <User Control Pressed> message followed |
| * immediately by a <User Control Released> message. |
| */ |
| @Test |
| public void cect_11_2_13_1_UserControlPressAndRelease() throws Exception { |
| ITestDevice device = getDevice(); |
| // Clear activity |
| device.executeShellCommand(CLEAR_COMMAND); |
| // Clear logcat. |
| device.executeAdbCommand("logcat", "-c"); |
| // Start the APK and wait for it to complete. |
| device.executeShellCommand(START_COMMAND); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_UP, false); |
| lookForLog("Short press KEYCODE_DPAD_UP"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_DOWN, false); |
| lookForLog("Short press KEYCODE_DPAD_DOWN"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_LEFT, false); |
| lookForLog("Short press KEYCODE_DPAD_LEFT"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_RIGHT, false); |
| lookForLog("Short press KEYCODE_DPAD_RIGHT"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_SELECT, false); |
| lookForLog("Short press KEYCODE_DPAD_CENTER"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_BACK, false); |
| lookForLog("Short press KEYCODE_BACK"); |
| } |
| |
| /** |
| * Test 11.2.13-2 |
| * Tests that the device responds correctly to a <User Control Pressed> message for press and |
| * hold operations. |
| */ |
| @Test |
| public void cect_11_2_13_2_UserControlPressAndHold() throws Exception { |
| ITestDevice device = getDevice(); |
| // Clear activity |
| device.executeShellCommand(CLEAR_COMMAND); |
| // Clear logcat. |
| device.executeAdbCommand("logcat", "-c"); |
| // Start the APK and wait for it to complete. |
| device.executeShellCommand(START_COMMAND); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_UP, true); |
| lookForLog("Long press KEYCODE_DPAD_UP"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_DOWN, true); |
| lookForLog("Long press KEYCODE_DPAD_DOWN"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_LEFT, true); |
| lookForLog("Long press KEYCODE_DPAD_LEFT"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_RIGHT, true); |
| lookForLog("Long press KEYCODE_DPAD_RIGHT"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_SELECT, true); |
| lookForLog("Long press KEYCODE_DPAD_CENTER"); |
| hdmiCecClient.sendUserControlPressAndRelease(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_BACK, true); |
| lookForLog("Long press KEYCODE_BACK"); |
| } |
| |
| /** |
| * Test 11.2.13-3 |
| * Tests that the device responds correctly to a <User Control Pressed> message for press and |
| * hold operations when no <User Control Released> is sent. |
| */ |
| @Test |
| public void cect_11_2_13_3_UserControlPressAndHoldWithNoRelease() throws Exception { |
| ITestDevice device = getDevice(); |
| // Clear activity |
| device.executeShellCommand(CLEAR_COMMAND); |
| // Clear logcat. |
| device.executeAdbCommand("logcat", "-c"); |
| // Start the APK and wait for it to complete. |
| device.executeShellCommand(START_COMMAND); |
| hdmiCecClient.sendUserControlPress(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_UP, true); |
| lookForLog("Long press KEYCODE_DPAD_UP"); |
| hdmiCecClient.sendUserControlPress(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_DOWN, true); |
| lookForLog("Long press KEYCODE_DPAD_DOWN"); |
| hdmiCecClient.sendUserControlPress(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_LEFT, true); |
| lookForLog("Long press KEYCODE_DPAD_LEFT"); |
| hdmiCecClient.sendUserControlPress(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_RIGHT, true); |
| lookForLog("Long press KEYCODE_DPAD_RIGHT"); |
| hdmiCecClient.sendUserControlPress(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_SELECT, true); |
| lookForLog("Long press KEYCODE_DPAD_CENTER"); |
| hdmiCecClient.sendUserControlPress(LogicalAddress.TV, LogicalAddress.AUDIO_SYSTEM, |
| HdmiCecConstants.CEC_CONTROL_BACK, true); |
| lookForLog("Long press KEYCODE_BACK"); |
| } |
| |
| /** |
| * Test 11.2.13-4 |
| * Tests that the device responds correctly to a <User Control Pressed> [firstKeycode] press |
| * and hold operation when interrupted by a <User Control Pressed> [secondKeycode] before a |
| * <User Control Released> [firstKeycode] is sent. |
| */ |
| @Test |
| public void cect_11_2_13_4_UserControlInterruptedPressAndHoldWithNoRelease() throws Exception { |
| ITestDevice device = getDevice(); |
| // Clear activity |
| device.executeShellCommand(CLEAR_COMMAND); |
| // Clear logcat. |
| device.executeAdbCommand("logcat", "-c"); |
| // Start the APK and wait for it to complete. |
| device.executeShellCommand(START_COMMAND); |
| hdmiCecClient.sendUserControlInterruptedPressAndHold(LogicalAddress.TV, |
| LogicalAddress.AUDIO_SYSTEM, HdmiCecConstants.CEC_CONTROL_UP, |
| HdmiCecConstants.CEC_CONTROL_BACK, true); |
| lookForLog("Long press KEYCODE_DPAD_UP"); |
| hdmiCecClient.sendUserControlInterruptedPressAndHold(LogicalAddress.TV, |
| LogicalAddress.AUDIO_SYSTEM, HdmiCecConstants.CEC_CONTROL_DOWN, |
| HdmiCecConstants.CEC_CONTROL_UP, true); |
| lookForLog("Long press KEYCODE_DPAD_DOWN"); |
| hdmiCecClient.sendUserControlInterruptedPressAndHold(LogicalAddress.TV, |
| LogicalAddress.AUDIO_SYSTEM, HdmiCecConstants.CEC_CONTROL_LEFT, |
| HdmiCecConstants.CEC_CONTROL_DOWN, true); |
| lookForLog("Long press KEYCODE_DPAD_LEFT"); |
| hdmiCecClient.sendUserControlInterruptedPressAndHold(LogicalAddress.TV, |
| LogicalAddress.AUDIO_SYSTEM, HdmiCecConstants.CEC_CONTROL_RIGHT, |
| HdmiCecConstants.CEC_CONTROL_LEFT, true); |
| lookForLog("Long press KEYCODE_DPAD_RIGHT"); |
| hdmiCecClient.sendUserControlInterruptedPressAndHold(LogicalAddress.TV, |
| LogicalAddress.AUDIO_SYSTEM, HdmiCecConstants.CEC_CONTROL_SELECT, |
| HdmiCecConstants.CEC_CONTROL_RIGHT, true); |
| lookForLog("Long press KEYCODE_DPAD_CENTER"); |
| hdmiCecClient.sendUserControlInterruptedPressAndHold(LogicalAddress.TV, |
| LogicalAddress.AUDIO_SYSTEM, HdmiCecConstants.CEC_CONTROL_BACK, |
| HdmiCecConstants.CEC_CONTROL_SELECT, true); |
| lookForLog("Long press KEYCODE_BACK"); |
| } |
| } |