Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3064)

Unified Diff: android_webview/javatests/src/org/chromium/android_webview/test/AwLayoutSizerTest.java

Issue 23478022: [android_webview] Fixes for wrap_content layouts. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: android_webview/javatests/src/org/chromium/android_webview/test/AwLayoutSizerTest.java
diff --git a/android_webview/javatests/src/org/chromium/android_webview/test/AwLayoutSizerTest.java b/android_webview/javatests/src/org/chromium/android_webview/test/AwLayoutSizerTest.java
index 88fd73387b1789e0c36cc0f832a6f40ee927dce2..e93c2fc842f4bc54a735d1a1e8e2241e83be2b32 100644
--- a/android_webview/javatests/src/org/chromium/android_webview/test/AwLayoutSizerTest.java
+++ b/android_webview/javatests/src/org/chromium/android_webview/test/AwLayoutSizerTest.java
@@ -10,6 +10,7 @@ import android.test.InstrumentationTestCase;
import android.test.suitebuilder.annotation.SmallTest;
import org.chromium.android_webview.AwLayoutSizer;
+import org.chromium.base.test.util.Feature;
public class AwLayoutSizerTest extends InstrumentationTestCase {
static class LayoutSizerDelegate implements AwLayoutSizer.Delegate {
@@ -17,6 +18,14 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
public boolean setMeasuredDimensionCalled;
public int measuredWidth;
public int measuredHeight;
+ public boolean fixedLayoutOverrideEnabled;
+ public int fixedLayoutOverrideWidth;
+ public int fixedLayoutOverrideHeight;
+ public boolean viewportDipSizeOverrideEnabled;
+ public int viewportDipSizeOverrideWidth;
+ public int viewportDipSizeOverrideHeight;
+ public int physicalBackingSizeWidth;
+ public int physicalBackingSizeHeight;
@Override
public void requestLayout() {
@@ -29,6 +38,26 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
this.measuredWidth = measuredWidth;
this.measuredHeight = measuredHeight;
}
+
+ @Override
+ public void setFixedLayoutOverride(boolean enable, int widthDip, int heightDip) {
+ fixedLayoutOverrideEnabled = enable;
+ fixedLayoutOverrideWidth = widthDip;
+ fixedLayoutOverrideHeight = heightDip;
+ }
+
+ @Override
+ public void setViewportDipSizeOverride(boolean enable, int widthDip, int heightDip) {
+ viewportDipSizeOverrideEnabled = enable;
+ viewportDipSizeOverrideWidth = widthDip;
+ viewportDipSizeOverrideHeight = heightDip;
+ }
+
+ @Override
+ public void setPhysicalBackingSize(int width, int height) {
+ physicalBackingSizeWidth = width;
+ physicalBackingSizeHeight = height;
+ }
}
private static final int FIRST_CONTENT_WIDTH = 101;
@@ -43,6 +72,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
private static final double INITIAL_PAGE_SCALE = 1.0;
private static final double DIP_SCALE = 1.0;
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testCanQueryContentSize() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -62,6 +93,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(contentHeight, delegate.measuredHeight & View.MEASURED_SIZE_MASK);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testContentSizeChangeRequestsLayout() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -76,6 +109,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(requestLayoutCallCount + 1, delegate.requestLayoutCallCount);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testContentSizeChangeDoesNotRequestLayoutIfMeasuredExcatly() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -92,6 +127,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(requestLayoutCallCount, delegate.requestLayoutCallCount);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testDuplicateContentSizeChangeDoesNotRequestLayout() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -108,6 +145,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(requestLayoutCallCount, delegate.requestLayoutCallCount);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testContentHeightGrowsTillAtMostSize() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -130,6 +169,46 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(AT_MOST_MEASURE_SIZE, delegate.measuredHeight & View.MEASURED_SIZE_MASK);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
+ public void testContentHeightShrinksAfterAtMostSize() {
+ AwLayoutSizer layoutSizer = new AwLayoutSizer();
+ LayoutSizerDelegate delegate = new LayoutSizerDelegate();
+ layoutSizer.setDelegate(delegate);
+ layoutSizer.setDIPScale(DIP_SCALE);
+
+ layoutSizer.onPageScaleChanged(INITIAL_PAGE_SCALE);
+ layoutSizer.onContentSizeChanged(SMALLER_CONTENT_SIZE, SMALLER_CONTENT_SIZE);
+ layoutSizer.onMeasure(
+ MeasureSpec.makeMeasureSpec(AT_MOST_MEASURE_SIZE, MeasureSpec.AT_MOST),
+ MeasureSpec.makeMeasureSpec(AT_MOST_MEASURE_SIZE, MeasureSpec.AT_MOST));
+ assertEquals(AT_MOST_MEASURE_SIZE, delegate.measuredWidth);
+ assertEquals(SMALLER_CONTENT_SIZE, delegate.measuredHeight);
+
+ layoutSizer.onContentSizeChanged(TOO_LARGE_CONTENT_SIZE, TOO_LARGE_CONTENT_SIZE);
+ layoutSizer.onMeasure(
+ MeasureSpec.makeMeasureSpec(AT_MOST_MEASURE_SIZE, MeasureSpec.AT_MOST),
+ MeasureSpec.makeMeasureSpec(AT_MOST_MEASURE_SIZE, MeasureSpec.AT_MOST));
+ assertEquals(AT_MOST_MEASURE_SIZE, delegate.measuredWidth & View.MEASURED_SIZE_MASK);
+ assertEquals(AT_MOST_MEASURE_SIZE, delegate.measuredHeight & View.MEASURED_SIZE_MASK);
+
+ int requestLayoutCallCount = delegate.requestLayoutCallCount;
+ layoutSizer.onContentSizeChanged(TOO_LARGE_CONTENT_SIZE, TOO_LARGE_CONTENT_SIZE + 1);
+ layoutSizer.onContentSizeChanged(TOO_LARGE_CONTENT_SIZE, TOO_LARGE_CONTENT_SIZE);
+ assertEquals(requestLayoutCallCount, delegate.requestLayoutCallCount);
+
+ requestLayoutCallCount = delegate.requestLayoutCallCount;
+ layoutSizer.onContentSizeChanged(SMALLER_CONTENT_SIZE, SMALLER_CONTENT_SIZE);
+ assertEquals(requestLayoutCallCount + 1, delegate.requestLayoutCallCount);
+ layoutSizer.onMeasure(
+ MeasureSpec.makeMeasureSpec(AT_MOST_MEASURE_SIZE, MeasureSpec.AT_MOST),
+ MeasureSpec.makeMeasureSpec(AT_MOST_MEASURE_SIZE, MeasureSpec.AT_MOST));
+ assertEquals(AT_MOST_MEASURE_SIZE, delegate.measuredWidth);
+ assertEquals(SMALLER_CONTENT_SIZE, delegate.measuredHeight);
+ }
+
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testScaleChangeRequestsLayout() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -147,6 +226,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(requestLayoutCallCount + 1, delegate.requestLayoutCallCount);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testDuplicateScaleChangeDoesNotRequestLayout() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -163,6 +244,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(requestLayoutCallCount, delegate.requestLayoutCallCount);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testScaleChangeGrowsTillAtMostSize() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -187,6 +270,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(AT_MOST_MEASURE_SIZE, delegate.measuredHeight & View.MEASURED_SIZE_MASK);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testFreezeAndUnfreezeDoesntCauseLayout() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -199,6 +284,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(requestLayoutCallCount, delegate.requestLayoutCallCount);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testFreezeInhibitsLayoutRequest() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -212,6 +299,8 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
assertEquals(requestLayoutCallCount, delegate.requestLayoutCallCount);
}
+ @SmallTest
+ @Feature({"AndroidWebView"})
public void testUnfreezeIssuesLayoutRequest() {
AwLayoutSizer layoutSizer = new AwLayoutSizer();
LayoutSizerDelegate delegate = new LayoutSizerDelegate();
@@ -226,4 +315,164 @@ public class AwLayoutSizerTest extends InstrumentationTestCase {
layoutSizer.unfreezeLayoutRequests();
assertEquals(requestLayoutCallCount + 1, delegate.requestLayoutCallCount);
}
+
+ @SmallTest
+ @Feature({"AndroidWebView"})
+ public void testViewportWithExactMeasureSpec() {
+ AwLayoutSizer layoutSizer = new AwLayoutSizer();
+ LayoutSizerDelegate delegate = new LayoutSizerDelegate();
+ layoutSizer.setDelegate(delegate);
+
+ final float dipScale = 2.0f;
+ final int measuredWidth = 800;
+ final int measuredHeight = 400;
+
+ layoutSizer.setDIPScale(dipScale);
+
+ layoutSizer.onContentSizeChanged(FIRST_CONTENT_WIDTH, FIRST_CONTENT_HEIGHT);
+ layoutSizer.onPageScaleChanged(INITIAL_PAGE_SCALE);
+ layoutSizer.onMeasure(MeasureSpec.makeMeasureSpec(measuredWidth, MeasureSpec.EXACTLY),
+ MeasureSpec.makeMeasureSpec(measuredHeight, MeasureSpec.EXACTLY));
+ assertEquals(measuredWidth, delegate.measuredWidth & View.MEASURED_SIZE_MASK);
+ assertEquals(measuredHeight, delegate.measuredHeight & View.MEASURED_SIZE_MASK);
+
+ layoutSizer.onSizeChanged(measuredWidth, measuredHeight, 0, 0);
+
+ assertEquals(false, delegate.fixedLayoutOverrideEnabled);
+ assertEquals(false, delegate.viewportDipSizeOverrideEnabled);
+ assertEquals(measuredWidth, delegate.physicalBackingSizeWidth);
+ assertEquals(measuredHeight, delegate.physicalBackingSizeHeight);
+
+ layoutSizer.onPageScaleChanged(2.0f);
+
+ assertEquals(false, delegate.fixedLayoutOverrideEnabled);
+ assertEquals(false, delegate.viewportDipSizeOverrideEnabled);
+ assertEquals(measuredWidth, delegate.physicalBackingSizeWidth);
+ assertEquals(measuredHeight, delegate.physicalBackingSizeHeight);
+ }
+
+ @SmallTest
+ @Feature({"AndroidWebView"})
+ public void testViewportDipSizeOverrideRounding() {
+ AwLayoutSizer layoutSizer = new AwLayoutSizer();
+ LayoutSizerDelegate delegate = new LayoutSizerDelegate();
+ layoutSizer.setDelegate(delegate);
+
+ final float dipScale = 0.666f;
+
+ int contentWidth = 9;
+ int contentHeight = 6;
+
+ layoutSizer.setDIPScale(dipScale);
+ layoutSizer.onContentSizeChanged(contentWidth, contentHeight);
+ layoutSizer.onPageScaleChanged(INITIAL_PAGE_SCALE);
+ layoutSizer.onMeasure(MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED),
+ MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
+
+ assertTrue(delegate.setMeasuredDimensionCalled);
+ int measuredWidth = delegate.measuredWidth & View.MEASURED_SIZE_MASK;
+ int measuredHeight = delegate.measuredHeight & View.MEASURED_SIZE_MASK;
+ assertFalse((int) Math.ceil(measuredWidth / dipScale) == contentWidth);
+ assertFalse((int) Math.ceil(measuredHeight / dipScale) == contentHeight);
+
+ layoutSizer.onSizeChanged(measuredWidth, measuredHeight, 0, 0);
+
+ assertEquals(true, delegate.viewportDipSizeOverrideEnabled);
+ assertEquals(contentWidth, delegate.viewportDipSizeOverrideWidth);
+ assertEquals(contentHeight, delegate.viewportDipSizeOverrideHeight);
+ }
+
+ @SmallTest
+ @Feature({"AndroidWebView"})
+ public void testViewportWithWrapContentMeasureSpec() {
+ AwLayoutSizer layoutSizer = new AwLayoutSizer();
+ LayoutSizerDelegate delegate = new LayoutSizerDelegate();
+ layoutSizer.setDelegate(delegate);
+
+ final float dipScale = 1.5f;
+ final int pageScale = 2;
+ final int dipAndPageScale = (int) (dipScale * pageScale);
+
+
+ int contentWidth = 800;
+ int contentHeight = 400;
+ int atMostWidth = contentWidth * dipAndPageScale;
+ int atMostHeight = contentHeight * dipAndPageScale;
+
+ layoutSizer.setDIPScale(dipScale);
+ layoutSizer.onContentSizeChanged(contentWidth, contentHeight);
+ layoutSizer.onPageScaleChanged(pageScale);
+ layoutSizer.onMeasure(MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED),
+ MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
+
+ assertTrue(delegate.setMeasuredDimensionCalled);
+ int measuredWidth = delegate.measuredWidth & View.MEASURED_SIZE_MASK;
+ int measuredHeight = delegate.measuredHeight & View.MEASURED_SIZE_MASK;
+
+ int sizeWidth = measuredWidth;
+ int sizeHeight = measuredHeight;
+ layoutSizer.onSizeChanged(sizeWidth, sizeHeight, 0, 0);
+
+ assertEquals(true, delegate.fixedLayoutOverrideEnabled);
+ assertEquals(contentWidth, delegate.fixedLayoutOverrideWidth);
+ assertEquals(AwLayoutSizer.FIXED_LAYOUT_HEIGHT, delegate.fixedLayoutOverrideHeight);
+ assertEquals(true, delegate.viewportDipSizeOverrideEnabled);
+ assertEquals(contentWidth, delegate.viewportDipSizeOverrideWidth);
+ assertEquals(contentHeight, delegate.viewportDipSizeOverrideHeight);
+ assertEquals(sizeWidth / pageScale, delegate.physicalBackingSizeWidth);
+ assertEquals(sizeHeight / pageScale, delegate.physicalBackingSizeHeight);
+
+ sizeWidth = measuredWidth * 2;
+ sizeHeight = measuredHeight * 2;
+ layoutSizer.onSizeChanged(sizeWidth, sizeHeight, 0, 0);
+
+ assertEquals(true, delegate.fixedLayoutOverrideEnabled);
+ assertEquals(sizeWidth / dipAndPageScale, delegate.fixedLayoutOverrideWidth);
+ assertEquals(AwLayoutSizer.FIXED_LAYOUT_HEIGHT, delegate.fixedLayoutOverrideHeight);
+ assertEquals(true, delegate.viewportDipSizeOverrideEnabled);
+ assertEquals(sizeWidth / pageScale, delegate.physicalBackingSizeWidth);
+ assertEquals(sizeHeight / pageScale, delegate.physicalBackingSizeHeight);
+
+ sizeWidth = measuredWidth / 2;
+ sizeHeight = measuredHeight / 2;
+ layoutSizer.onSizeChanged(sizeWidth, sizeHeight, 0, 0);
+
+ assertEquals(true, delegate.fixedLayoutOverrideEnabled);
+ assertEquals(sizeWidth / dipAndPageScale, delegate.fixedLayoutOverrideWidth);
+ assertEquals(AwLayoutSizer.FIXED_LAYOUT_HEIGHT, delegate.fixedLayoutOverrideHeight);
+ assertEquals(true, delegate.viewportDipSizeOverrideEnabled);
+ assertEquals(sizeWidth / pageScale, delegate.physicalBackingSizeWidth);
+ assertEquals(sizeHeight / pageScale, delegate.physicalBackingSizeHeight);
+ }
+
+ @SmallTest
+ @Feature({"AndroidWebView"})
+ public void testFixedLayoutViewportGoesBackToZeroWithWrapContentMeasureSpec() {
+ AwLayoutSizer layoutSizer = new AwLayoutSizer();
+ LayoutSizerDelegate delegate = new LayoutSizerDelegate();
+ layoutSizer.setDelegate(delegate);
+ layoutSizer.setDIPScale(DIP_SCALE);
+
+ layoutSizer.onContentSizeChanged(FIRST_CONTENT_WIDTH, FIRST_CONTENT_HEIGHT);
+ layoutSizer.onPageScaleChanged(INITIAL_PAGE_SCALE);
+ layoutSizer.onMeasure(MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED),
+ MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
+ layoutSizer.onSizeChanged((int) (FIRST_CONTENT_WIDTH * DIP_SCALE),
+ (int) (FIRST_CONTENT_HEIGHT * DIP_SCALE), 0, 0);
+
+ assertEquals(true, delegate.fixedLayoutOverrideEnabled);
+ assertEquals(AwLayoutSizer.FIXED_LAYOUT_HEIGHT, delegate.fixedLayoutOverrideHeight);
+
+ layoutSizer.onContentSizeChanged(FIRST_CONTENT_WIDTH, AwLayoutSizer.FIXED_LAYOUT_HEIGHT);
+ layoutSizer.onSizeChanged((int) (FIRST_CONTENT_WIDTH * DIP_SCALE),
+ (int) (FIRST_CONTENT_HEIGHT * DIP_SCALE), 0, 0);
+ assertEquals(true, delegate.fixedLayoutOverrideEnabled);
+ assertEquals(0, delegate.fixedLayoutOverrideHeight);
+
+ layoutSizer.onContentSizeChanged(FIRST_CONTENT_WIDTH, 0);
+ layoutSizer.onSizeChanged((int) (FIRST_CONTENT_WIDTH * DIP_SCALE),
+ (int) (FIRST_CONTENT_HEIGHT * DIP_SCALE), 0, 0);
+ assertEquals(true, delegate.fixedLayoutOverrideEnabled);
+ assertEquals(0, delegate.fixedLayoutOverrideHeight);
+ }
}

Powered by Google App Engine
This is Rietveld 408576698