Index: content/public/android/javatests/src/org/chromium/content/browser/JavaBridgeArrayTest.java |
diff --git a/content/public/android/javatests/src/org/chromium/content/browser/JavaBridgeArrayTest.java b/content/public/android/javatests/src/org/chromium/content/browser/JavaBridgeArrayTest.java |
index 2be60b5ab3f10993bf6138a40b49c7ca6996cc10..f4001b8fd00308071f22a2659bec0a26bc6c48df 100644 |
--- a/content/public/android/javatests/src/org/chromium/content/browser/JavaBridgeArrayTest.java |
+++ b/content/public/android/javatests/src/org/chromium/content/browser/JavaBridgeArrayTest.java |
@@ -6,7 +6,14 @@ package org.chromium.content.browser; |
import android.support.test.filters.SmallTest; |
+import org.junit.Assert; |
+import org.junit.Before; |
+import org.junit.Rule; |
+import org.junit.Test; |
+import org.junit.runner.RunWith; |
+ |
import org.chromium.base.annotations.SuppressFBWarnings; |
+import org.chromium.base.test.BaseJUnit4ClassRunner; |
import org.chromium.base.test.util.Feature; |
import org.chromium.content.browser.JavaBridgeTestCommon.Controller; |
@@ -20,7 +27,11 @@ import org.chromium.content.browser.JavaBridgeTestCommon.Controller; |
* FIXME: Consider making our implementation more compliant, if it will not |
* break backwards-compatibility. See b/4408210. |
*/ |
-public class JavaBridgeArrayTest extends JavaBridgeTestBase { |
+@RunWith(BaseJUnit4ClassRunner.class) |
+public class JavaBridgeArrayTest { |
+ @Rule |
+ public JavaBridgeActivityTestRule mActivityTestRule = new JavaBridgeActivityTestRule(); |
+ |
@SuppressFBWarnings("CHROMIUM_SYNCHRONIZED_METHOD") |
private static class TestObject extends Controller { |
private boolean mBooleanValue; |
@@ -88,128 +99,140 @@ public class JavaBridgeArrayTest extends JavaBridgeTestBase { |
private TestObject mTestObject; |
- @Override |
- protected void setUp() throws Exception { |
- super.setUp(); |
+ @Before |
+ public void setUp() throws Exception { |
mTestObject = new TestObject(); |
- injectObjectAndReload(mTestObject, "testObject"); |
+ mActivityTestRule.injectObjectAndReload(mTestObject, "testObject"); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testArrayLength() throws Throwable { |
- executeJavaScript("testObject.setIntArray([42, 43, 44]);"); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray([42, 43, 44]);"); |
int[] result = mTestObject.waitForIntArray(); |
- assertEquals(3, result.length); |
- assertEquals(42, result[0]); |
- assertEquals(43, result[1]); |
- assertEquals(44, result[2]); |
+ Assert.assertEquals(3, result.length); |
+ Assert.assertEquals(42, result[0]); |
+ Assert.assertEquals(43, result[1]); |
+ Assert.assertEquals(44, result[2]); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testPassNull() throws Throwable { |
- executeJavaScript("testObject.setIntArray(null);"); |
- assertNull(mTestObject.waitForIntArray()); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray(null);"); |
+ Assert.assertNull(mTestObject.waitForIntArray()); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testPassUndefined() throws Throwable { |
- executeJavaScript("testObject.setIntArray(undefined);"); |
- assertNull(mTestObject.waitForIntArray()); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray(undefined);"); |
+ Assert.assertNull(mTestObject.waitForIntArray()); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testPassEmptyArray() throws Throwable { |
- executeJavaScript("testObject.setIntArray([]);"); |
- assertEquals(0, mTestObject.waitForIntArray().length); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray([]);"); |
+ Assert.assertEquals(0, mTestObject.waitForIntArray().length); |
} |
// Note that this requires being able to pass a string from JavaScript to |
// Java. |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testPassArrayToStringMethod() throws Throwable { |
// LIVECONNECT_COMPLIANCE: Should call toString() on array. |
- executeJavaScript("testObject.setStringValue([42, 42, 42]);"); |
- assertEquals("undefined", mTestObject.waitForStringValue()); |
+ mActivityTestRule.executeJavaScript("testObject.setStringValue([42, 42, 42]);"); |
+ Assert.assertEquals("undefined", mTestObject.waitForStringValue()); |
} |
// Note that this requires being able to pass an integer from JavaScript to |
// Java. |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testPassArrayToNonStringNonArrayMethod() throws Throwable { |
// LIVECONNECT_COMPLIANCE: Should raise JavaScript exception. |
- executeJavaScript("testObject.setIntValue([42, 42, 42]);"); |
- assertEquals(0, mTestObject.waitForIntValue()); |
+ mActivityTestRule.executeJavaScript("testObject.setIntValue([42, 42, 42]);"); |
+ Assert.assertEquals(0, mTestObject.waitForIntValue()); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testPassNonArrayToArrayMethod() throws Throwable { |
// LIVECONNECT_COMPLIANCE: Should raise JavaScript exception. |
- executeJavaScript("testObject.setIntArray(42);"); |
- assertNull(mTestObject.waitForIntArray()); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray(42);"); |
+ Assert.assertNull(mTestObject.waitForIntArray()); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testObjectWithLengthProperty() throws Throwable { |
- executeJavaScript("testObject.setIntArray({length: 3, 1: 42});"); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray({length: 3, 1: 42});"); |
int[] result = mTestObject.waitForIntArray(); |
- assertEquals(3, result.length); |
- assertEquals(0, result[0]); |
- assertEquals(42, result[1]); |
- assertEquals(0, result[2]); |
+ Assert.assertEquals(3, result.length); |
+ Assert.assertEquals(0, result[0]); |
+ Assert.assertEquals(42, result[1]); |
+ Assert.assertEquals(0, result[2]); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testNonNumericLengthProperty() throws Throwable { |
// LIVECONNECT_COMPLIANCE: This should not count as an array, so we |
// should raise a JavaScript exception. |
- executeJavaScript("testObject.setIntArray({length: \"foo\"});"); |
- assertNull(mTestObject.waitForIntArray()); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray({length: \"foo\"});"); |
+ Assert.assertNull(mTestObject.waitForIntArray()); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testLengthOutOfBounds() throws Throwable { |
// LIVECONNECT_COMPLIANCE: This should not count as an array, so we |
// should raise a JavaScript exception. |
- executeJavaScript("testObject.setIntArray({length: -1});"); |
- assertNull(mTestObject.waitForIntArray()); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray({length: -1});"); |
+ Assert.assertNull(mTestObject.waitForIntArray()); |
// LIVECONNECT_COMPLIANCE: This should not count as an array, so we |
// should raise a JavaScript exception. |
long length = Integer.MAX_VALUE + 1L; |
- executeJavaScript("testObject.setIntArray({length: " + length + "});"); |
- assertNull(mTestObject.waitForIntArray()); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray({length: " + length + "});"); |
+ Assert.assertNull(mTestObject.waitForIntArray()); |
// LIVECONNECT_COMPLIANCE: This should not count as an array, so we |
// should raise a JavaScript exception. |
length = Integer.MAX_VALUE + 1L - Integer.MIN_VALUE + 1L; |
- executeJavaScript("testObject.setIntArray({length: " + length + "});"); |
- assertNull(mTestObject.waitForIntArray()); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray({length: " + length + "});"); |
+ Assert.assertNull(mTestObject.waitForIntArray()); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testSparseArray() throws Throwable { |
- executeJavaScript("var x = [42, 43]; x[3] = 45; testObject.setIntArray(x);"); |
+ mActivityTestRule.executeJavaScript( |
+ "var x = [42, 43]; x[3] = 45; testObject.setIntArray(x);"); |
int[] result = mTestObject.waitForIntArray(); |
- assertEquals(4, result.length); |
- assertEquals(42, result[0]); |
- assertEquals(43, result[1]); |
- assertEquals(0, result[2]); |
- assertEquals(45, result[3]); |
+ Assert.assertEquals(4, result.length); |
+ Assert.assertEquals(42, result[0]); |
+ Assert.assertEquals(43, result[1]); |
+ Assert.assertEquals(0, result[2]); |
+ Assert.assertEquals(45, result[3]); |
} |
// Note that this requires being able to pass a boolean from JavaScript to |
// Java. |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testMethodReturningArrayNotCalled() throws Throwable { |
@@ -217,39 +240,43 @@ public class JavaBridgeArrayTest extends JavaBridgeTestBase { |
// exception is raised. |
// LIVECONNECT_COMPLIANCE: Should call method and convert result to |
// JavaScript array. |
- executeJavaScript("testObject.setBooleanValue(undefined === testObject.arrayMethod())"); |
- assertTrue(mTestObject.waitForBooleanValue()); |
- assertFalse(mTestObject.wasArrayMethodCalled()); |
+ mActivityTestRule.executeJavaScript( |
+ "testObject.setBooleanValue(undefined === testObject.arrayMethod())"); |
+ Assert.assertTrue(mTestObject.waitForBooleanValue()); |
+ Assert.assertFalse(mTestObject.wasArrayMethodCalled()); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testMultiDimensionalArrayMethod() throws Throwable { |
// LIVECONNECT_COMPLIANCE: Should handle multi-dimensional arrays. |
- executeJavaScript("testObject.setIntIntArray([ [42, 43], [44, 45] ]);"); |
- assertNull(mTestObject.waitForIntIntArray()); |
+ mActivityTestRule.executeJavaScript("testObject.setIntIntArray([ [42, 43], [44, 45] ]);"); |
+ Assert.assertNull(mTestObject.waitForIntIntArray()); |
} |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testPassMultiDimensionalArray() throws Throwable { |
// LIVECONNECT_COMPLIANCE: Should handle multi-dimensional arrays. |
- executeJavaScript("testObject.setIntArray([ [42, 43], [44, 45] ]);"); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray([ [42, 43], [44, 45] ]);"); |
int[] result = mTestObject.waitForIntArray(); |
- assertEquals(2, result.length); |
- assertEquals(0, result[0]); |
- assertEquals(0, result[1]); |
+ Assert.assertEquals(2, result.length); |
+ Assert.assertEquals(0, result[0]); |
+ Assert.assertEquals(0, result[1]); |
} |
// Verify that ArrayBuffers are not converted into arrays when passed to Java. |
// The LiveConnect spec doesn't mention ArrayBuffers, so it doesn't seem to |
// be a compliance issue. |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testPassArrayBuffer() throws Throwable { |
- executeJavaScript("buffer = new ArrayBuffer(16);"); |
- executeJavaScript("testObject.setIntArray(buffer);"); |
- assertNull(mTestObject.waitForIntArray()); |
+ mActivityTestRule.executeJavaScript("buffer = new ArrayBuffer(16);"); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray(buffer);"); |
+ Assert.assertNull(mTestObject.waitForIntArray()); |
} |
// Verify that ArrayBufferViews are not converted into arrays when passed to Java. |
@@ -258,11 +285,12 @@ public class JavaBridgeArrayTest extends JavaBridgeTestBase { |
// Here, a DataView is used as an ArrayBufferView instance (since the latter is |
// an interface and can't be instantiated directly). See also JavaBridgeArrayCoercionTest |
// for typed arrays (that also subclass ArrayBufferView) tests. |
+ @Test |
@SmallTest |
@Feature({"AndroidWebView", "Android-JavaBridge"}) |
public void testPassDataView() throws Throwable { |
- executeJavaScript("buffer = new ArrayBuffer(16);"); |
- executeJavaScript("testObject.setIntArray(new DataView(buffer));"); |
- assertNull(mTestObject.waitForIntArray()); |
+ mActivityTestRule.executeJavaScript("buffer = new ArrayBuffer(16);"); |
+ mActivityTestRule.executeJavaScript("testObject.setIntArray(new DataView(buffer));"); |
+ Assert.assertNull(mTestObject.waitForIntArray()); |
} |
} |