Converting ShortcutsLaunchTest gesture-stable
By converting to TAPL. Bug: 110103162 Test; TaplTests Change-Id: I788405f2e52cc0e29ebf69e58feda46b408e9eb9
This commit is contained in:
parent
b3fe661860
commit
ba8957b3c2
|
@ -296,11 +296,6 @@ public abstract class AbstractLauncherUiTest {
|
||||||
Process.myUserHandle()).get(0);
|
Process.myUserHandle()).get(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected LauncherActivityInfo getChromeApp() {
|
|
||||||
return LauncherAppsCompat.getInstance(mTargetContext)
|
|
||||||
.getActivityList("com.android.chrome", Process.myUserHandle()).get(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Broadcast receiver which blocks until the result is received.
|
* Broadcast receiver which blocks until the result is received.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -1,22 +1,20 @@
|
||||||
package com.android.launcher3.ui;
|
package com.android.launcher3.ui;
|
||||||
|
|
||||||
import static org.junit.Assert.assertNotNull;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
import android.content.pm.LauncherActivityInfo;
|
import android.content.pm.LauncherActivityInfo;
|
||||||
import android.graphics.Point;
|
|
||||||
import androidx.test.filters.LargeTest;
|
import androidx.test.filters.LargeTest;
|
||||||
import androidx.test.runner.AndroidJUnit4;
|
import androidx.test.runner.AndroidJUnit4;
|
||||||
import androidx.test.uiautomator.By;
|
import androidx.test.uiautomator.By;
|
||||||
import androidx.test.uiautomator.UiObject2;
|
|
||||||
import androidx.test.uiautomator.Until;
|
import androidx.test.uiautomator.Until;
|
||||||
import android.view.MotionEvent;
|
|
||||||
|
|
||||||
import com.android.launcher3.R;
|
import com.android.launcher3.Launcher;
|
||||||
import com.android.launcher3.util.Condition;
|
import com.android.launcher3.popup.ArrowPopup;
|
||||||
import com.android.launcher3.util.Wait;
|
import com.android.launcher3.tapl.AppIconMenu;
|
||||||
|
import com.android.launcher3.tapl.AppIconMenuItem;
|
||||||
|
import com.android.launcher3.views.OptionsPopupView;
|
||||||
|
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
|
||||||
|
@ -27,47 +25,33 @@ import org.junit.runner.RunWith;
|
||||||
@RunWith(AndroidJUnit4.class)
|
@RunWith(AndroidJUnit4.class)
|
||||||
public class ShortcutsLaunchTest extends AbstractLauncherUiTest {
|
public class ShortcutsLaunchTest extends AbstractLauncherUiTest {
|
||||||
|
|
||||||
@Test
|
private boolean isOptionsPopupVisible(Launcher launcher) {
|
||||||
@Ignore
|
final ArrowPopup popup = OptionsPopupView.getOptionsPopup(launcher);
|
||||||
public void testAppLauncher_portrait() throws Exception {
|
return popup != null && popup.isShown();
|
||||||
lockRotation(true);
|
|
||||||
performTest();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@Ignore
|
@PortraitLandscape
|
||||||
public void testAppLauncher_landscape() throws Exception {
|
public void testAppLauncher() throws Exception {
|
||||||
lockRotation(false);
|
|
||||||
performTest();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void performTest() throws Exception {
|
|
||||||
mActivityMonitor.startLauncher();
|
mActivityMonitor.startLauncher();
|
||||||
LauncherActivityInfo testApp = getSettingsApp();
|
final LauncherActivityInfo testApp = getSettingsApp();
|
||||||
|
|
||||||
// Open all apps and wait for load complete
|
final AppIconMenu menu = mLauncher.
|
||||||
final UiObject2 appsContainer = TestViewHelpers.openAllApps();
|
pressHome().
|
||||||
Wait.atMost(null, Condition.minChildCount(appsContainer, 2), DEFAULT_UI_TIMEOUT);
|
switchToAllApps().
|
||||||
|
getAppIcon(testApp.getLabel().toString()).
|
||||||
|
openMenu();
|
||||||
|
|
||||||
// Find settings app and verify shortcuts appear when long pressed
|
executeOnLauncher(
|
||||||
UiObject2 icon = scrollAndFind(appsContainer, By.text(testApp.getLabel().toString()));
|
launcher -> assertTrue("Launcher internal state didn't switch to Showing Menu",
|
||||||
// Press icon center until shortcuts appear
|
isOptionsPopupVisible(launcher)));
|
||||||
Point iconCenter = icon.getVisibleCenter();
|
|
||||||
TestViewHelpers.sendPointer(MotionEvent.ACTION_DOWN, iconCenter);
|
|
||||||
UiObject2 deepShortcutsContainer = TestViewHelpers.findViewById(
|
|
||||||
R.id.deep_shortcuts_container);
|
|
||||||
assertNotNull(deepShortcutsContainer);
|
|
||||||
TestViewHelpers.sendPointer(MotionEvent.ACTION_UP, iconCenter);
|
|
||||||
|
|
||||||
// Verify that launching a shortcut opens a page with the same text
|
final AppIconMenuItem menuItem = menu.getMenuItem(1);
|
||||||
assertTrue(deepShortcutsContainer.getChildCount() > 0);
|
final String itemName = menuItem.getText();
|
||||||
|
|
||||||
// Pick second children as it starts showing shortcuts.
|
menuItem.launch();
|
||||||
UiObject2 shortcut = deepShortcutsContainer.getChildren().get(1)
|
|
||||||
.findObject(TestViewHelpers.getSelectorForId(R.id.bubble_text));
|
|
||||||
shortcut.click();
|
|
||||||
assertTrue(mDevice.wait(Until.hasObject(By.pkg(
|
assertTrue(mDevice.wait(Until.hasObject(By.pkg(
|
||||||
testApp.getComponentName().getPackageName())
|
testApp.getComponentName().getPackageName())
|
||||||
.text(shortcut.getText())), DEFAULT_UI_TIMEOUT));
|
.text(itemName)), DEFAULT_UI_TIMEOUT));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
|
|
||||||
package com.android.launcher3.tapl;
|
package com.android.launcher3.tapl;
|
||||||
|
|
||||||
|
import android.graphics.Point;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import androidx.test.uiautomator.By;
|
import androidx.test.uiautomator.By;
|
||||||
|
@ -56,4 +57,15 @@ public final class AppIcon {
|
||||||
UiObject2 getIcon() {
|
UiObject2 getIcon() {
|
||||||
return mIcon;
|
return mIcon;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Long-clicks the icon to open its menu.
|
||||||
|
*/
|
||||||
|
public AppIconMenu openMenu() {
|
||||||
|
final Point iconCenter = mIcon.getVisibleCenter();
|
||||||
|
mLauncher.longTap(iconCenter.x, iconCenter.y);
|
||||||
|
final UiObject2 deepShortcutsContainer = mLauncher.waitForLauncherObject(
|
||||||
|
"deep_shortcuts_container");
|
||||||
|
return new AppIconMenu(mLauncher, deepShortcutsContainer);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
/*
|
||||||
|
* 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.launcher3.tapl;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
import androidx.test.uiautomator.UiObject2;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Context menu of an app icon.
|
||||||
|
*/
|
||||||
|
public class AppIconMenu {
|
||||||
|
private final LauncherInstrumentation mLauncher;
|
||||||
|
private final UiObject2 mDeepShortcutsContainer;
|
||||||
|
|
||||||
|
AppIconMenu(LauncherInstrumentation launcher,
|
||||||
|
UiObject2 deepShortcutsContainer) {
|
||||||
|
mLauncher = launcher;
|
||||||
|
mDeepShortcutsContainer = deepShortcutsContainer;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a menu item with a given number. Fails if it doesn't exist.
|
||||||
|
*/
|
||||||
|
public AppIconMenuItem getMenuItem(int itemNumber) {
|
||||||
|
assertTrue(mDeepShortcutsContainer.getChildCount() > itemNumber);
|
||||||
|
|
||||||
|
final UiObject2 shortcut = mLauncher.waitForObjectInContainer(
|
||||||
|
mDeepShortcutsContainer.getChildren().get(itemNumber), "bubble_text");
|
||||||
|
return new AppIconMenuItem(mLauncher, shortcut);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,52 @@
|
||||||
|
/*
|
||||||
|
* 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.launcher3.tapl;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
import androidx.test.uiautomator.UiObject2;
|
||||||
|
import androidx.test.uiautomator.Until;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Menu item in an app icon menu.
|
||||||
|
*/
|
||||||
|
public class AppIconMenuItem {
|
||||||
|
private final LauncherInstrumentation mLauncher;
|
||||||
|
final UiObject2 mShortcut;
|
||||||
|
|
||||||
|
AppIconMenuItem(LauncherInstrumentation launcher,
|
||||||
|
UiObject2 shortcut) {
|
||||||
|
mLauncher = launcher;
|
||||||
|
mShortcut = shortcut;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the visible text of the menu item.
|
||||||
|
*/
|
||||||
|
public String getText() {
|
||||||
|
return mShortcut.getText();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Launches the action for the menu item.
|
||||||
|
*/
|
||||||
|
public Background launch() {
|
||||||
|
assertTrue("Clicking a menu item didn't open a new window: " + mShortcut.getText(),
|
||||||
|
mShortcut.clickAndWait(Until.newWindow(), LauncherInstrumentation.WAIT_TIME_MS));
|
||||||
|
return new Background(mLauncher);
|
||||||
|
}
|
||||||
|
}
|
|
@ -28,6 +28,13 @@ import android.util.Log;
|
||||||
import android.view.Surface;
|
import android.view.Surface;
|
||||||
import android.view.accessibility.AccessibilityEvent;
|
import android.view.accessibility.AccessibilityEvent;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.test.uiautomator.By;
|
||||||
|
import androidx.test.uiautomator.BySelector;
|
||||||
|
import androidx.test.uiautomator.UiDevice;
|
||||||
|
import androidx.test.uiautomator.UiObject2;
|
||||||
|
import androidx.test.uiautomator.Until;
|
||||||
|
|
||||||
import com.android.launcher3.TestProtocol;
|
import com.android.launcher3.TestProtocol;
|
||||||
import com.android.quickstep.SwipeUpSetting;
|
import com.android.quickstep.SwipeUpSetting;
|
||||||
|
|
||||||
|
@ -36,13 +43,6 @@ import org.junit.Assert;
|
||||||
import java.lang.ref.WeakReference;
|
import java.lang.ref.WeakReference;
|
||||||
import java.util.concurrent.TimeoutException;
|
import java.util.concurrent.TimeoutException;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
import androidx.test.uiautomator.By;
|
|
||||||
import androidx.test.uiautomator.BySelector;
|
|
||||||
import androidx.test.uiautomator.UiDevice;
|
|
||||||
import androidx.test.uiautomator.UiObject2;
|
|
||||||
import androidx.test.uiautomator.Until;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The main tapl object. The only object that can be explicitly constructed by the using code. It
|
* The main tapl object. The only object that can be explicitly constructed by the using code. It
|
||||||
* produces all other objects.
|
* produces all other objects.
|
||||||
|
@ -394,6 +394,11 @@ public final class LauncherInstrumentation {
|
||||||
return mDevice;
|
return mDevice;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void longTap(int x, int y) {
|
||||||
|
mDevice.drag(x, y, x, y, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void swipe(int startX, int startY, int endX, int endY) {
|
void swipe(int startX, int startY, int endX, int endY) {
|
||||||
executeAndWaitForEvent(
|
executeAndWaitForEvent(
|
||||||
() -> mDevice.swipe(startX, startY, endX, endY, 60),
|
() -> mDevice.swipe(startX, startY, endX, endY, 60),
|
||||||
|
|
Loading…
Reference in New Issue