diff options
author | powei@chromium.org <powei@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-06-27 19:31:48 +0000 |
---|---|---|
committer | powei@chromium.org <powei@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-06-27 19:31:48 +0000 |
commit | ec3b0785155d9967e7e115108b0030590b77e496 (patch) | |
tree | e51f93501cdcced5d4de9941c43638fee91961c7 | |
parent | 1c2bbf47bd5c796939967934f23862b2ef5a4814 (diff) | |
download | chromium_src-ec3b0785155d9967e7e115108b0030590b77e496.zip chromium_src-ec3b0785155d9967e7e115108b0030590b77e496.tar.gz chromium_src-ec3b0785155d9967e7e115108b0030590b77e496.tar.bz2 |
android: Add test for ContentViewCore readback
This test renders a blue screen and grabs a snapshot of the content. The
test checks that the pixel in the middle of the snapshot is blue.
BUG=372792
NOTRY=true
Review URL: https://codereview.chromium.org/358513002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@280381 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | build/android/findbugs_filter/findbugs_known_bugs.txt | 2 | ||||
-rw-r--r-- | content/public/android/javatests/src/org/chromium/content/browser/ContentViewReadbackTest.java | 124 |
2 files changed, 126 insertions, 0 deletions
diff --git a/build/android/findbugs_filter/findbugs_known_bugs.txt b/build/android/findbugs_filter/findbugs_known_bugs.txt index 35a6047..ed860ac 100644 --- a/build/android/findbugs_filter/findbugs_known_bugs.txt +++ b/build/android/findbugs_filter/findbugs_known_bugs.txt @@ -25,3 +25,5 @@ M V EI: org.chromium.content.browser.LoadUrlParams.getPostData() may expose inte M M LI: Incorrect lazy initialization of static field org.chromium.chrome.browser.sync.ProfileSyncService.sSyncSetupManager in org.chromium.chrome.browser.sync.ProfileSyncService.get(Context) At ProfileSyncService.java M V EI: org.chromium.android_webview.AwWebResourceResponse.getResponseHeaderNames() may expose internal representation by returning AwWebResourceResponse.mResponseHeaderNames At AwWebResourceResponse.java M V EI: org.chromium.android_webview.AwWebResourceResponse.getResponseHeaderValues() may expose internal representation by returning AwWebResourceResponse.mResponseHeaderValues At AwWebResourceResponse.java +M C NP: Null passed for nonnull parameter of ContentReadbackHandler$GetBitmapCallback.onFinishGetBitmap(boolean, Bitmap) in org.chromium.content.browser.ContentReadbackHandler.getCompositorBitmapAsync(WindowAndroid, ContentReadbackHandler$GetBitmapCallback) At ContentReadbackHandler.java +M C NP: Null passed for nonnull parameter of ContentReadbackHandler$GetBitmapCallback.onFinishGetBitmap(boolean, Bitmap) in org.chromium.content.browser.ContentReadbackHandler.getContentBitmapAsync(float, Rect, ContentViewCore, ContentReadbackHandler$GetBitmapCallback) At ContentReadbackHandler.java diff --git a/content/public/android/javatests/src/org/chromium/content/browser/ContentViewReadbackTest.java b/content/public/android/javatests/src/org/chromium/content/browser/ContentViewReadbackTest.java new file mode 100644 index 0000000..79049bf --- /dev/null +++ b/content/public/android/javatests/src/org/chromium/content/browser/ContentViewReadbackTest.java @@ -0,0 +1,124 @@ +// Copyright 2014 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +package org.chromium.content.browser; + +import static org.chromium.base.test.util.ScalableTimeout.scaleTimeout; + +import android.graphics.Bitmap; +import android.graphics.Color; +import android.graphics.Rect; +import android.os.SystemClock; +import android.test.suitebuilder.annotation.SmallTest; + +import junit.framework.AssertionFailedError; + +import org.chromium.base.ThreadUtils; +import org.chromium.base.test.util.Feature; +import org.chromium.base.test.util.UrlUtils; +import org.chromium.content.browser.ContentReadbackHandler.GetBitmapCallback; +import org.chromium.content.browser.test.util.Criteria; +import org.chromium.content.browser.test.util.CriteriaHelper; +import org.chromium.content_shell_apk.ContentShellTestBase; + +import java.util.concurrent.atomic.AtomicBoolean; +import java.util.concurrent.atomic.AtomicInteger; + +/** + * Tests that we can readback the contents of a ContentView. + */ +public class ContentViewReadbackTest extends ContentShellTestBase { + + private static final int COLOR_THRESHOLD = 8; + private static final long WAIT_FOR_READBACK_TIMEOUT = scaleTimeout(10000); + + @Override + protected void setUp() throws Exception { + super.setUp(); + launchContentShellWithUrl(UrlUtils.encodeHtmlDataUri( + "<html style=\"background: #00f;\"><head><style>body { height: 5000px; }</style>" + + "</head></html>")); + assertTrue("Page failed to load", waitForActiveShellToBeDoneLoading()); + } + + private static void assertEqualColor(int actual, int expected, int threshold) { + int deltaR = Math.abs(Color.red(actual) - Color.red(expected)); + int deltaG = Math.abs(Color.green(actual) - Color.green(expected)); + int deltaB = Math.abs(Color.blue(actual) - Color.blue(expected)); + if (deltaR > threshold || deltaG > threshold || deltaB > threshold) { + throw new AssertionFailedError( + "Color does not match; expected " + expected + ", got " + actual); + } + } + + private void assertWaitForYScroll(final int previousYScroll) throws InterruptedException { + assertTrue(CriteriaHelper.pollForCriteria(new Criteria() { + @Override + public boolean isSatisfied() { + return getContentViewCore().getNativeScrollYForTest() > previousYScroll; + } + })); + } + + private void assertWaitForReadback(final AtomicBoolean readbackDone) + throws InterruptedException { + assertTrue(CriteriaHelper.pollForCriteria(new Criteria() { + @Override + public boolean isSatisfied() { + return readbackDone.get(); + } + }, WAIT_FOR_READBACK_TIMEOUT, CriteriaHelper.DEFAULT_POLLING_INTERVAL)); + } + + /** + * Test to make sure the screenshots captured of the ContentView are not blank. + * + * @throws InterruptedException + */ + @SmallTest + @Feature({"Main"}) + public void testScreenshotIsNotBlank() throws Throwable { + final AtomicBoolean readbackDone = new AtomicBoolean(false); + final AtomicInteger color = new AtomicInteger(); + + // We wait on the fling to make sure that the compositor side has a layer available by the + // time we reach readback. + int previousYScroll = getContentViewCore().getNativeScrollYForTest(); + ThreadUtils.runOnUiThreadBlocking(new Runnable() { + @Override + public void run() { + getContentViewCore().flingForTest(SystemClock.uptimeMillis(), 0, 0, 0, -100); + } + }); + assertWaitForYScroll(previousYScroll); + + runTestOnUiThread(new Runnable() { + @Override + public void run() { + ContentReadbackHandler contentReadbackHandler = new ContentReadbackHandler() { + @Override + protected boolean readyForReadback() { + return true; + } + }; + + GetBitmapCallback callback = new GetBitmapCallback() { + @Override + public void onFinishGetBitmap(boolean success, Bitmap bitmap) { + // Verify a pixel in the center of the screenshot. + color.set(bitmap.getPixel(bitmap.getWidth() / 2, bitmap.getHeight() / 2)); + readbackDone.set(success); + } + }; + + contentReadbackHandler.initNativeContentReadbackHandler(); + contentReadbackHandler.getContentBitmapAsync(1.0f, new Rect(), getContentViewCore(), + callback); + } + }); + assertWaitForReadback(readbackDone); + + assertEqualColor(color.get(), Color.BLUE, COLOR_THRESHOLD); + } +} |