mirror of
https://github.com/LawnchairLauncher/lawnchair.git
synced 2026-02-20 19:38:21 +00:00
Merge "Adding test to make sure the icons seen when unfolded are the same when folded" into tm-qpr-dev am: b57479c189
Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Launcher3/+/21120301 Change-Id: I6b533a97afe291c4211983705e5c8e4caed8bfa5 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
@@ -0,0 +1,52 @@
|
||||
/*
|
||||
* Copyright (C) 2023 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.celllayout;
|
||||
|
||||
import android.view.View;
|
||||
|
||||
import com.android.launcher3.CellLayout;
|
||||
import com.android.launcher3.Launcher;
|
||||
import com.android.launcher3.views.DoubleShadowBubbleTextView;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
public class CellLayoutTestUtils {
|
||||
|
||||
public static ArrayList<CellLayoutBoard> workspaceToBoards(Launcher launcher) {
|
||||
ArrayList<CellLayoutBoard> boards = new ArrayList<>();
|
||||
int widgetCount = 0;
|
||||
for (CellLayout cellLayout : launcher.getWorkspace().mWorkspaceScreens) {
|
||||
CellLayoutBoard board = new CellLayoutBoard();
|
||||
int count = cellLayout.getShortcutsAndWidgets().getChildCount();
|
||||
for (int i = 0; i < count; i++) {
|
||||
View callView = cellLayout.getShortcutsAndWidgets().getChildAt(i);
|
||||
CellLayoutLayoutParams params =
|
||||
(CellLayoutLayoutParams) callView.getLayoutParams();
|
||||
// is icon
|
||||
if (callView instanceof DoubleShadowBubbleTextView) {
|
||||
board.addIcon(params.getCellX(), params.getCellY());
|
||||
} else {
|
||||
// is widget
|
||||
board.addWidget(params.getCellX(), params.getCellY(), params.cellHSpan,
|
||||
params.cellVSpan, (char) ('A' + widgetCount));
|
||||
widgetCount++;
|
||||
}
|
||||
}
|
||||
boards.add(board);
|
||||
}
|
||||
return boards;
|
||||
}
|
||||
}
|
||||
@@ -20,12 +20,10 @@ import static org.junit.Assert.assertTrue;
|
||||
|
||||
import android.graphics.Point;
|
||||
import android.util.Log;
|
||||
import android.view.View;
|
||||
|
||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||
import androidx.test.filters.SmallTest;
|
||||
|
||||
import com.android.launcher3.CellLayout;
|
||||
import com.android.launcher3.InvariantDeviceProfile;
|
||||
import com.android.launcher3.celllayout.testcases.FullReorderCase;
|
||||
import com.android.launcher3.celllayout.testcases.MoveOutReorderCase;
|
||||
@@ -38,7 +36,6 @@ import com.android.launcher3.tapl.WidgetResizeFrame;
|
||||
import com.android.launcher3.ui.AbstractLauncherUiTest;
|
||||
import com.android.launcher3.ui.TaplTestsLauncher3;
|
||||
import com.android.launcher3.util.rule.ShellCommandRule;
|
||||
import com.android.launcher3.views.DoubleShadowBubbleTextView;
|
||||
|
||||
import org.junit.Assume;
|
||||
import org.junit.Before;
|
||||
@@ -105,30 +102,7 @@ public class ReorderWidgets extends AbstractLauncherUiTest {
|
||||
}
|
||||
|
||||
private ArrayList<CellLayoutBoard> workspaceToBoards() {
|
||||
return getFromLauncher(l -> {
|
||||
ArrayList<CellLayoutBoard> boards = new ArrayList<>();
|
||||
int widgetCount = 0;
|
||||
for (CellLayout cellLayout : l.getWorkspace().mWorkspaceScreens) {
|
||||
CellLayoutBoard board = new CellLayoutBoard();
|
||||
int count = cellLayout.getShortcutsAndWidgets().getChildCount();
|
||||
for (int i = 0; i < count; i++) {
|
||||
View callView = cellLayout.getShortcutsAndWidgets().getChildAt(i);
|
||||
CellLayoutLayoutParams params =
|
||||
(CellLayoutLayoutParams) callView.getLayoutParams();
|
||||
// is icon
|
||||
if (callView instanceof DoubleShadowBubbleTextView) {
|
||||
board.addIcon(params.getCellX(), params.getCellY());
|
||||
} else {
|
||||
// is widget
|
||||
board.addWidget(params.getCellX(), params.getCellY(), params.cellHSpan,
|
||||
params.cellVSpan, (char) ('A' + widgetCount));
|
||||
widgetCount++;
|
||||
}
|
||||
}
|
||||
boards.add(board);
|
||||
}
|
||||
return boards;
|
||||
});
|
||||
return getFromLauncher(CellLayoutTestUtils::workspaceToBoards);
|
||||
}
|
||||
|
||||
private void runTestCase(ReorderTestCase testCase)
|
||||
|
||||
@@ -28,13 +28,14 @@ public class ReorderTestCase {
|
||||
public Point moveMainTo;
|
||||
public List<List<CellLayoutBoard>> mEnd;
|
||||
|
||||
ReorderTestCase(List<CellLayoutBoard> start, Point moveMainTo, List<CellLayoutBoard> ... end) {
|
||||
public ReorderTestCase(List<CellLayoutBoard> start, Point moveMainTo,
|
||||
List<CellLayoutBoard>... end) {
|
||||
mStart = start;
|
||||
this.moveMainTo = moveMainTo;
|
||||
mEnd = Arrays.asList(end);
|
||||
}
|
||||
|
||||
ReorderTestCase(String start, Point moveMainTo, String ... end) {
|
||||
public ReorderTestCase(String start, Point moveMainTo, String ... end) {
|
||||
mStart = CellLayoutBoard.boardListFromString(start);
|
||||
this.moveMainTo = moveMainTo;
|
||||
mEnd = Arrays
|
||||
|
||||
Reference in New Issue
Block a user