Index: content/public/test/android/javatests/src/org/chromium/content/browser/test/util/DOMUtils.java |
diff --git a/content/public/test/android/javatests/src/org/chromium/content/browser/test/util/DOMUtils.java b/content/public/test/android/javatests/src/org/chromium/content/browser/test/util/DOMUtils.java |
index 84d84b66e473045dce2d27b8c1d2ca79620865da..46874fd4d2cb6a588400409d55a9ab1b52ccccfe 100644 |
--- a/content/public/test/android/javatests/src/org/chromium/content/browser/test/util/DOMUtils.java |
+++ b/content/public/test/android/javatests/src/org/chromium/content/browser/test/util/DOMUtils.java |
@@ -11,6 +11,7 @@ import android.util.JsonReader; |
import junit.framework.Assert; |
import org.chromium.content.browser.ContentViewCore; |
+import org.chromium.content_public.browser.WebContents; |
import java.io.IOException; |
import java.io.StringReader; |
@@ -24,22 +25,22 @@ public class DOMUtils { |
/** |
* Returns whether the video with given {@code nodeId} has ended. |
*/ |
- public static boolean hasVideoEnded(final ContentViewCore viewCore, final String nodeId) |
+ public static boolean hasVideoEnded(final WebContents webContents, final String nodeId) |
throws InterruptedException, TimeoutException { |
- return getNodeField("ended", viewCore, nodeId, Boolean.class); |
+ return getNodeField("ended", webContents, nodeId, Boolean.class); |
} |
/** |
* Wait until the end of the video with given {@code nodeId}. |
* @return Whether the video has ended. |
*/ |
- public static boolean waitForEndOfVideo(final ContentViewCore viewCore, final String nodeId) |
+ public static boolean waitForEndOfVideo(final WebContents webContents, final String nodeId) |
throws InterruptedException { |
return CriteriaHelper.pollForCriteria(new Criteria() { |
@Override |
public boolean isSatisfied() { |
try { |
- return DOMUtils.hasVideoEnded(viewCore, nodeId); |
+ return DOMUtils.hasVideoEnded(webContents, nodeId); |
} catch (InterruptedException e) { |
// Intentionally do nothing |
return false; |
@@ -54,19 +55,19 @@ public class DOMUtils { |
/** |
* Makes the document exit fullscreen. |
*/ |
- public static void exitFullscreen(final ContentViewCore viewCore) { |
+ public static void exitFullscreen(final WebContents webContents) { |
StringBuilder sb = new StringBuilder(); |
sb.append("(function() {"); |
sb.append(" if (document.webkitExitFullscreen) document.webkitExitFullscreen();"); |
sb.append("})();"); |
- JavaScriptUtils.executeJavaScript(viewCore, sb.toString()); |
+ JavaScriptUtils.executeJavaScript(webContents, sb.toString()); |
} |
/** |
* Returns the rect boundaries for a node by its id. |
*/ |
- public static Rect getNodeBounds(final ContentViewCore viewCore, String nodeId) |
+ public static Rect getNodeBounds(final WebContents webContents, String nodeId) |
throws InterruptedException, TimeoutException { |
StringBuilder sb = new StringBuilder(); |
sb.append("(function() {"); |
@@ -84,7 +85,7 @@ public class DOMUtils { |
sb.append("})();"); |
String jsonText = JavaScriptUtils.executeJavaScriptAndWaitForResult( |
- viewCore, sb.toString()); |
+ webContents, sb.toString()); |
Assert.assertFalse("Failed to retrieve bounds for " + nodeId, |
jsonText.trim().equalsIgnoreCase("null")); |
@@ -111,7 +112,7 @@ public class DOMUtils { |
/** |
* Focus a DOM node by its id. |
*/ |
- public static void focusNode(final ContentViewCore viewCore, String nodeId) |
+ public static void focusNode(final WebContents webContents, String nodeId) |
throws InterruptedException, TimeoutException { |
StringBuilder sb = new StringBuilder(); |
sb.append("(function() {"); |
@@ -119,7 +120,7 @@ public class DOMUtils { |
sb.append(" if (node) node.focus();"); |
sb.append("})();"); |
- JavaScriptUtils.executeJavaScriptAndWaitForResult(viewCore, sb.toString()); |
+ JavaScriptUtils.executeJavaScriptAndWaitForResult(webContents, sb.toString()); |
} |
/** |
@@ -147,38 +148,38 @@ public class DOMUtils { |
/** |
* Scrolls the view to ensure that the required DOM node is visible. |
*/ |
- public static void scrollNodeIntoView(ContentViewCore viewCore, String nodeId) |
+ public static void scrollNodeIntoView(WebContents webContents, String nodeId) |
throws InterruptedException, TimeoutException { |
- JavaScriptUtils.executeJavaScriptAndWaitForResult(viewCore, |
+ JavaScriptUtils.executeJavaScriptAndWaitForResult(webContents, |
"document.getElementById('" + nodeId + "').scrollIntoView()"); |
} |
/** |
* Returns the contents of the node by its id. |
*/ |
- public static String getNodeContents(ContentViewCore viewCore, String nodeId) |
+ public static String getNodeContents(WebContents webContents, String nodeId) |
throws InterruptedException, TimeoutException { |
- return getNodeField("textContent", viewCore, nodeId, String.class); |
+ return getNodeField("textContent", webContents, nodeId, String.class); |
} |
/** |
* Returns the value of the node by its id. |
*/ |
- public static String getNodeValue(final ContentViewCore viewCore, String nodeId) |
+ public static String getNodeValue(final WebContents webContents, String nodeId) |
throws InterruptedException, TimeoutException { |
- return getNodeField("value", viewCore, nodeId, String.class); |
+ return getNodeField("value", webContents, nodeId, String.class); |
} |
/** |
* Returns the string value of a field of the node by its id. |
*/ |
- public static String getNodeField(String fieldName, final ContentViewCore viewCore, |
+ public static String getNodeField(String fieldName, final WebContents webContents, |
String nodeId) |
throws InterruptedException, TimeoutException { |
- return getNodeField(fieldName, viewCore, nodeId, String.class); |
+ return getNodeField(fieldName, webContents, nodeId, String.class); |
} |
- private static <T> T getNodeField(String fieldName, final ContentViewCore viewCore, |
+ private static <T> T getNodeField(String fieldName, final WebContents webContents, |
String nodeId, Class<T> valueType) |
throws InterruptedException, TimeoutException { |
StringBuilder sb = new StringBuilder(); |
@@ -189,7 +190,7 @@ public class DOMUtils { |
sb.append("})();"); |
String jsonText = JavaScriptUtils.executeJavaScriptAndWaitForResult( |
- viewCore, sb.toString()); |
+ webContents, sb.toString()); |
Assert.assertFalse("Failed to retrieve contents for " + nodeId, |
jsonText.trim().equalsIgnoreCase("null")); |
@@ -224,14 +225,14 @@ public class DOMUtils { |
* Wait until a given node has non-zero bounds. |
* @return Whether the node started having non-zero bounds. |
*/ |
- public static boolean waitForNonZeroNodeBounds(final ContentViewCore viewCore, |
+ public static boolean waitForNonZeroNodeBounds(final WebContents webContents, |
final String nodeName) |
throws InterruptedException { |
return CriteriaHelper.pollForCriteria(new Criteria() { |
@Override |
public boolean isSatisfied() { |
try { |
- return !DOMUtils.getNodeBounds(viewCore, nodeName).isEmpty(); |
+ return !DOMUtils.getNodeBounds(webContents, nodeName).isEmpty(); |
} catch (InterruptedException e) { |
// Intentionally do nothing |
return false; |
@@ -248,7 +249,7 @@ public class DOMUtils { |
*/ |
private static int[] getClickTargetForNode(ContentViewCore viewCore, String nodeName) |
throws InterruptedException, TimeoutException { |
- Rect bounds = getNodeBounds(viewCore, nodeName); |
+ Rect bounds = getNodeBounds(viewCore.getWebContents(), nodeName); |
Assert.assertNotNull("Failed to get DOM element bounds of '" + nodeName + "'.", bounds); |
int clickX = (int) viewCore.getRenderCoordinates().fromLocalCssToPix(bounds.exactCenterX()); |