aboutsummaryrefslogtreecommitdiff
path: root/eclipse/plugins/com.android.ide.eclipse.tests/unittests/com/android/ide/common/layout/RelativeLayoutRuleTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'eclipse/plugins/com.android.ide.eclipse.tests/unittests/com/android/ide/common/layout/RelativeLayoutRuleTest.java')
-rw-r--r--eclipse/plugins/com.android.ide.eclipse.tests/unittests/com/android/ide/common/layout/RelativeLayoutRuleTest.java167
1 files changed, 167 insertions, 0 deletions
diff --git a/eclipse/plugins/com.android.ide.eclipse.tests/unittests/com/android/ide/common/layout/RelativeLayoutRuleTest.java b/eclipse/plugins/com.android.ide.eclipse.tests/unittests/com/android/ide/common/layout/RelativeLayoutRuleTest.java
new file mode 100644
index 000000000..f9747f39d
--- /dev/null
+++ b/eclipse/plugins/com.android.ide.eclipse.tests/unittests/com/android/ide/common/layout/RelativeLayoutRuleTest.java
@@ -0,0 +1,167 @@
+/*
+ * Copyright (C) 2010 The Android Open Source Project
+ *
+ * Licensed under the Eclipse Public License, Version 1.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.eclipse.org/org/documents/epl-v10.php
+ *
+ * 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.ide.common.layout;
+
+
+import static com.android.SdkConstants.ANDROID_URI;
+
+import com.android.ide.common.api.INode;
+import com.android.ide.common.api.Point;
+import com.android.ide.common.api.Rect;
+
+/** Test the {@link RelativeLayoutRule} */
+public class RelativeLayoutRuleTest extends LayoutTestBase {
+ // Utility for other tests
+ protected INode dragInto(Rect dragBounds, Point dragPoint, Point secondDragPoint,
+ int insertIndex, int currentIndex, String... graphicsFragments) {
+ INode layout = TestNode.create("android.widget.RelativeLayout").id("@+id/RelativeLayout01")
+ .bounds(new Rect(0, 0, 240, 480)).add(
+ // Add centered button as the anchor
+ TestNode.create("android.widget.Button").id("@+id/Centered").bounds(
+ new Rect(70, 200, 100, 80)).set(ANDROID_URI,
+ "layout_centerInParent", "true"),
+ // Add a second button anchored to it
+ TestNode.create("android.widget.Button").id("@+id/Below").bounds(
+ new Rect(70, 280, 100, 80)).set(ANDROID_URI, "layout_below",
+ "@+id/Centered").set(ANDROID_URI, "layout_alignLeft",
+ "@+id/Centered"));
+
+ return super.dragInto(new RelativeLayoutRule(), layout, dragBounds, dragPoint,
+ secondDragPoint, insertIndex, currentIndex, graphicsFragments);
+ }
+
+ protected INode dragInto(Rect dragBounds, Point dragPoint, Point secondDragPoint,
+ int insertIndex, int currentIndex, String[] extraFragments,
+ String... graphicsFragments) {
+
+ // When we switch to JDK6, use Arrays#copyOf instead
+ String[] combined = new String[extraFragments.length + graphicsFragments.length];
+ System.arraycopy(graphicsFragments, 0, combined, 0, graphicsFragments.length);
+ System.arraycopy(extraFragments, 0, combined, graphicsFragments.length,
+ extraFragments.length);
+
+ return dragInto(dragBounds, dragPoint, secondDragPoint, insertIndex,
+ currentIndex, combined);
+ }
+
+ /* This needs to be updated for the new interaction
+ public void testDropTopEdge() {
+ // If we drag right into the button itself, not a valid drop position
+ INode inserted = dragInto(
+ new Rect(0, 0, 105, 80), new Point(30, -10), null, 2, -1,
+ // Bounds rectangle
+ "useStyle(DROP_RECIPIENT), drawRect(Rect[0,0,240,480])",
+
+ // Preview line + drop zone rectangle along the top
+ "useStyle(DROP_ZONE), drawRect(Rect[0,-10,240,20])",
+ "useStyle(DROP_ZONE_ACTIVE), fillRect(Rect[0,-10,240,20])",
+ "useStyle(DROP_PREVIEW), drawLine(0,0,240,0)",
+
+ // Tip
+ "useStyle(HELP), drawBoxedStrings(5,15,[alignParentTop])",
+
+ // Drop preview
+ "useStyle(DROP_PREVIEW), drawRect(Rect[0,0,105,80])");
+
+ assertEquals("true", inserted.getStringAttr(ANDROID_URI,
+ "layout_alignParentTop"));
+ }
+
+ public void testDropZones() {
+ List<Pair<Point,String[]>> zones = new ArrayList<Pair<Point,String[]>>();
+
+ zones.add(Pair.of(new Point(51+10, 181+10),
+ new String[] {"above=@+id/Centered", "toLeftOf=@+id/Centered"}));
+ zones.add(Pair.of(new Point(71+10, 181+10),
+ new String[] {"above=@+id/Centered", "alignLeft=@+id/Centered"}));
+ zones.add(Pair.of(new Point(104+10, 181+10),
+ new String[] {"above=@+id/Centered", "alignRight=@+id/Centered"}));
+ zones.add(Pair.of(new Point(137+10, 181+10),
+ new String[] {"above=@+id/Centered", "alignRight=@+id/Centered"}));
+ zones.add(Pair.of(new Point(170+10, 181+10),
+ new String[] {"above=@+id/Centered", "toRightOf=@+id/Centered"}));
+ zones.add(Pair.of(new Point(51+10, 279+10),
+ new String[] {"below=@+id/Centered", "toLeftOf=@+id/Centered"}));
+ zones.add(Pair.of(new Point(71+10, 279+10),
+ new String[] {"below=@+id/Centered", "alignLeft=@+id/Centered"}));
+ zones.add(Pair.of(new Point(104+10, 279+10),
+ new String[] {"below=@+id/Centered", "alignLeft=@+id/Centered"}));
+ zones.add(Pair.of(new Point(137+10, 279+10),
+ new String[] {"below=@+id/Centered", "alignRight=@+id/Centered"}));
+ zones.add(Pair.of(new Point(170+10, 279+10),
+ new String[] {"below=@+id/Centered", "toRightOf=@+id/Centered"}));
+ zones.add(Pair.of(new Point(51+10, 201+10),
+ new String[] {"toLeftOf=@+id/Centered", "alignTop=@+id/Centered"}));
+ zones.add(Pair.of(new Point(51+10, 227+10),
+ new String[] {"toLeftOf=@+id/Centered", "alignTop=@+id/Centered"}));
+ zones.add(Pair.of(new Point(170+10, 201+10),
+ new String[] {"toRightOf=@+id/Centered", "alignTop=@+id/Centered"}));
+ zones.add(Pair.of(new Point(51+10, 253+10),
+ new String[] {"toLeftOf=@+id/Centered", "alignBottom=@+id/Centered"}));
+ zones.add(Pair.of(new Point(170+10, 227+10),
+ new String[] {"toRightOf=@+id/Centered", "alignTop=@+id/Centered",
+ "alignBottom=@+id/Centered"}));
+ zones.add(Pair.of(new Point(170+10, 253+10),
+ new String[] {"toRightOf=@+id/Centered", "alignBottom=@+id/Centered"}));
+
+ for (Pair<Point,String[]> zonePair : zones) {
+ Point dropPoint = zonePair.getFirst();
+ String[] attachments = zonePair.getSecond();
+ // If we drag right into the button itself, not a valid drop position
+
+ INode inserted = dragInto(
+ new Rect(0, 0, 105, 80), new Point(120, 240), dropPoint, 1, -1,
+ attachments,
+
+ // Bounds rectangle
+ "useStyle(DROP_RECIPIENT), drawRect(Rect[0,0,240,480])",
+
+ // Drop zones
+ "useStyle(DROP_ZONE), "
+ + "drawRect(Rect[51,181,20,20]), drawRect(Rect[71,181,33,20]), "
+ + "drawRect(Rect[104,181,33,20]), drawRect(Rect[137,181,33,20]), "
+ + "drawRect(Rect[170,181,20,20]), drawRect(Rect[51,279,20,20]), "
+ + "drawRect(Rect[71,279,33,20]), drawRect(Rect[104,279,33,20]), "
+ + "drawRect(Rect[137,279,33,20]), drawRect(Rect[170,279,20,20]), "
+ + "drawRect(Rect[51,201,20,26]), drawRect(Rect[51,227,20,26]), "
+ + "drawRect(Rect[51,253,20,26]), drawRect(Rect[170,201,20,26]), "
+ + "drawRect(Rect[170,227,20,26]), drawRect(Rect[170,253,20,26])");
+
+ for (String attachment : attachments) {
+ String[] elements = attachment.split("=");
+ String name = "layout_" + elements[0];
+ String value = elements[1];
+ assertEquals(value, inserted.getStringAttr(ANDROID_URI, name));
+ }
+ }
+ }
+
+
+ public void testDragInvalid() {
+ // If we drag right into the button itself, not a valid drop position
+ dragInto(new Rect(70, 200, 100, 80), new Point(120, 240), new Point(120, 240), -1, 0,
+ // Bounds rectangle
+ "useStyle(DROP_RECIPIENT), drawRect(Rect[0,0,240,480])",
+
+ // Invalid marker
+ "useStyle(INVALID), fillRect(Rect[70,200,100,80]), drawLine(70,200,170,280), "
+ + "drawLine(70,280,170,200)");
+ }
+
+ // TODO: Test error (dragging on ancestor)
+ */
+}