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

Unified Diff: chrome/android/javatests/src/org/chromium/chrome/browser/UrlSchemeTest.java

Issue 2831823003: Convert ChromeActivityTestCaseBase direct children to JUnit4 (Closed)
Patch Set: rebase and convert newly added test Created 3 years, 8 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: chrome/android/javatests/src/org/chromium/chrome/browser/UrlSchemeTest.java
diff --git a/chrome/android/javatests/src/org/chromium/chrome/browser/UrlSchemeTest.java b/chrome/android/javatests/src/org/chromium/chrome/browser/UrlSchemeTest.java
index 87fa65da1556886b69bf7240c2102a1af5c05b45..3f475eeaed6372cd53e906b5b8bc70649486d123 100644
--- a/chrome/android/javatests/src/org/chromium/chrome/browser/UrlSchemeTest.java
+++ b/chrome/android/javatests/src/org/chromium/chrome/browser/UrlSchemeTest.java
@@ -7,14 +7,24 @@ package org.chromium.chrome.browser;
import android.content.Context;
import android.net.Uri;
import android.os.Environment;
+import android.support.test.InstrumentationRegistry;
import android.support.test.filters.MediumTest;
+import org.junit.After;
+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.ThreadUtils;
+import org.chromium.base.test.util.CommandLineFlags;
import org.chromium.base.test.util.Feature;
import org.chromium.base.test.util.RetryOnFailure;
import org.chromium.base.test.util.TestFileUtil;
import org.chromium.base.test.util.UrlUtils;
-import org.chromium.chrome.test.ChromeActivityTestCaseBase;
+import org.chromium.chrome.test.ChromeActivityTestRule;
+import org.chromium.chrome.test.ChromeJUnit4ClassRunner;
import org.chromium.chrome.test.TestContentProvider;
import org.chromium.content.browser.test.util.Criteria;
import org.chromium.content.browser.test.util.CriteriaHelper;
@@ -26,30 +36,35 @@ import java.io.InputStream;
import java.util.concurrent.Callable;
/** Test suite for different Android URL schemes. */
+@RunWith(ChromeJUnit4ClassRunner.class)
@RetryOnFailure
-public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
+@CommandLineFlags.Add({ChromeSwitches.DISABLE_FIRST_RUN_EXPERIENCE,
+ ChromeActivityTestRule.DISABLE_NETWORK_PREDICTION_FLAG})
+public class UrlSchemeTest {
+ @Rule
+ public ChromeActivityTestRule<ChromeActivity> mActivityTestRule =
+ new ChromeActivityTestRule<>(ChromeActivity.class);
+
private static final String SIMPLE_SRC = "simple.html";
private static final String SIMPLE_IMAGE = "google.png";
private EmbeddedTestServer mTestServer;
- public UrlSchemeTest() {
- super(ChromeActivity.class);
- }
-
- @Override
+ @Before
public void setUp() throws Exception {
- super.setUp();
- TestContentProvider.resetResourceRequestCounts(getInstrumentation().getTargetContext());
- TestContentProvider.setDataFilePath(getInstrumentation().getTargetContext(),
+ mActivityTestRule.startMainActivityFromLauncher();
+ TestContentProvider.resetResourceRequestCounts(
+ InstrumentationRegistry.getInstrumentation().getTargetContext());
+ TestContentProvider.setDataFilePath(
+ InstrumentationRegistry.getInstrumentation().getTargetContext(),
UrlUtils.getTestFilePath(""));
- mTestServer = EmbeddedTestServer.createAndStartServer(getInstrumentation().getContext());
+ mTestServer = EmbeddedTestServer.createAndStartServer(
+ InstrumentationRegistry.getInstrumentation().getContext());
}
- @Override
- protected void tearDown() throws Exception {
+ @After
+ public void tearDown() throws Exception {
mTestServer.stopAndDestroyServer();
- super.tearDown();
}
/**
@@ -57,6 +72,7 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
* This is to make sure that attempts to access the content provider
* will be detected.
*/
+ @Test
@MediumTest
@Feature({"Navigation"})
public void testContentProviderResourceRequestCount() throws IOException {
@@ -64,11 +80,11 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
ensureResourceRequestCountInContentProvider(resource, 0);
// Make a request to the content provider.
Uri uri = Uri.parse(createContentUrl(resource));
- Context context = getInstrumentation().getContext();
+ Context context = InstrumentationRegistry.getInstrumentation().getContext();
InputStream inputStream = null;
try {
inputStream = context.getContentResolver().openInputStream(uri);
- assertNotNull(inputStream);
+ Assert.assertNotNull(inputStream);
} finally {
if (inputStream != null) inputStream.close();
}
@@ -78,11 +94,12 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
/**
* Make sure content URL access works.
*/
+ @Test
@MediumTest
@Feature({"Navigation"})
public void testContentUrlAccess() throws InterruptedException {
String resource = SIMPLE_SRC;
- loadUrl(createContentUrl(resource));
+ mActivityTestRule.loadUrl(createContentUrl(resource));
ensureResourceRequestCountInContentProviderNotLessThan(resource, 1);
}
@@ -90,6 +107,7 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
* Make sure a Content url *CANNOT* access the contents of an iframe that is loaded as a
* content URL.
*/
+ @Test
@MediumTest
@Feature({"Navigation"})
public void testContentUrlIframeAccessFromContentUrl() throws Throwable {
@@ -104,24 +122,25 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
+ " document.title = 'fail';"
+ "}";
- loadUrl(createContentUrl(resource));
+ mActivityTestRule.loadUrl(createContentUrl(resource));
// Make sure iframe is really loaded by verifying the title
CriteriaHelper.pollUiThread(new Criteria() {
@Override
public boolean isSatisfied() {
- return getActivity().getActivityTab().getTitle().equals("iframe loaded");
+ return mActivityTestRule.getActivity().getActivityTab().getTitle().equals(
+ "iframe loaded");
}
});
// Make sure that content provider was asked to provide the content.
ensureResourceRequestCountInContentProviderNotLessThan(iframe, 1);
- runJavaScriptCodeInCurrentTab(script);
+ mActivityTestRule.runJavaScriptCodeInCurrentTab(script);
// Make sure content access failed by verifying that title is set to fail.
CriteriaHelper.pollUiThread(new Criteria() {
@Override
public boolean isSatisfied() {
- return getActivity().getActivityTab().getTitle().equals("fail");
+ return mActivityTestRule.getActivity().getActivityTab().getTitle().equals("fail");
}
});
}
@@ -129,6 +148,7 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
/**
* Test that a content URL is *ALLOWED* to access an image provided by a content URL.
*/
+ @Test
@MediumTest
@Feature({"Navigation"})
public void testContentUrlImageFromContentUrl() throws Throwable {
@@ -138,6 +158,7 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
/**
* Test that a HTTP URL is *NOT ALLOWED* to access an image provided by a content URL.
*/
+ @Test
@MediumTest
@Feature({"Navigation"})
public void testContentUrlImageFromHttpUrl() throws Throwable {
@@ -154,13 +175,14 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
+ " img.onload = function() { document.title = 'success' };"
+ " img.src = '" + createContentUrl(resource) + "';"
+ " document.body.appendChild(img);";
- loadUrl(url);
- runJavaScriptCodeInCurrentTab(script);
+ mActivityTestRule.loadUrl(url);
+ mActivityTestRule.runJavaScriptCodeInCurrentTab(script);
CriteriaHelper.pollUiThread(new Criteria() {
@Override
public boolean isSatisfied() {
- return getActivity().getActivityTab().getTitle().equals(expectedTitle);
+ return mActivityTestRule.getActivity().getActivityTab().getTitle().equals(
+ expectedTitle);
}
});
ensureResourceRequestCountInContentProviderNotLessThan(resource, expectedLoadCount);
@@ -169,18 +191,20 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
/**
* Test that a content URL is not allowed within a data URL.
*/
+ @Test
@MediumTest
@Feature({"Navigation"})
public void testContentUrlFromData() throws InterruptedException {
final String target = SIMPLE_IMAGE;
- loadUrl(UrlUtils.encodeHtmlDataUri(
- "<img src=\"" + createContentUrl(target) + "\">"));
+ mActivityTestRule.loadUrl(
+ UrlUtils.encodeHtmlDataUri("<img src=\"" + createContentUrl(target) + "\">"));
ensureResourceRequestCountInContentProvider(target, 0);
}
/**
* Test that a content URL is not allowed within a local file.
*/
+ @Test
@MediumTest
@Feature({"Navigation"})
public void testContentUrlFromFile() throws InterruptedException, IOException {
@@ -189,7 +213,7 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
try {
TestFileUtil.createNewHtmlFile(
file, target, "<img src=\"" + createContentUrl(target) + "\">");
- loadUrl("file:///" + file.getAbsolutePath());
+ mActivityTestRule.loadUrl("file:///" + file.getAbsolutePath());
ensureResourceRequestCountInContentProvider(target, 0);
} finally {
TestFileUtil.deleteFile(file);
@@ -200,7 +224,7 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
return ThreadUtils.runOnUiThreadBlockingNoException(new Callable<String>() {
@Override
public String call() throws Exception {
- return getActivity().getActivityTab().getTitle();
+ return mActivityTestRule.getActivity().getActivityTab().getTitle();
}
});
}
@@ -208,6 +232,7 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
/**
* Test that the browser can be navigated to a file URL.
*/
+ @Test
@MediumTest
@Feature({"Navigation"})
public void testFileUrlNavigation() throws InterruptedException, IOException {
@@ -216,8 +241,8 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
try {
TestFileUtil.createNewHtmlFile(file, "File", null);
- loadUrl("file://" + file.getAbsolutePath());
- assertEquals("File", getTitleOnUiThread());
+ mActivityTestRule.loadUrl("file://" + file.getAbsolutePath());
+ Assert.assertEquals("File", getTitleOnUiThread());
} finally {
TestFileUtil.deleteFile(file);
}
@@ -229,9 +254,9 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
* @param expectedCount Expected resource requests count
*/
private void ensureResourceRequestCountInContentProvider(String resource, int expectedCount) {
- Context context = getInstrumentation().getTargetContext();
+ Context context = InstrumentationRegistry.getInstrumentation().getTargetContext();
int actualCount = TestContentProvider.getResourceRequestCount(context, resource);
- assertEquals(expectedCount, actualCount);
+ Assert.assertEquals(expectedCount, actualCount);
}
/**
@@ -241,18 +266,13 @@ public class UrlSchemeTest extends ChromeActivityTestCaseBase<ChromeActivity> {
*/
private void ensureResourceRequestCountInContentProviderNotLessThan(
String resource, int expectedMinimalCount) {
- Context context = getInstrumentation().getTargetContext();
+ Context context = InstrumentationRegistry.getInstrumentation().getTargetContext();
int actualCount = TestContentProvider.getResourceRequestCount(context, resource);
- assertTrue("Minimal expected: " + expectedMinimalCount + ", actual: " + actualCount,
+ Assert.assertTrue("Minimal expected: " + expectedMinimalCount + ", actual: " + actualCount,
actualCount >= expectedMinimalCount);
}
private String createContentUrl(final String target) {
return TestContentProvider.createContentUrl(target);
}
-
- @Override
- public void startMainActivity() throws InterruptedException {
- startMainActivityFromLauncher();
- }
}

Powered by Google App Engine
This is Rietveld 408576698