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

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

Issue 1777673002: AGSA-initiated weblite intents should be rewritten if Chrome can use weblite (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@2661
Patch Set: Created 4 years, 9 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/document/DocumentModeTest.java
diff --git a/chrome/android/javatests/src/org/chromium/chrome/browser/document/DocumentModeTest.java b/chrome/android/javatests/src/org/chromium/chrome/browser/document/DocumentModeTest.java
index 67b96e33a91f24adf4cd46f9facd135094e14f0e..1cee057730c1a79b075824466bb2db6a2657a040 100644
--- a/chrome/android/javatests/src/org/chromium/chrome/browser/document/DocumentModeTest.java
+++ b/chrome/android/javatests/src/org/chromium/chrome/browser/document/DocumentModeTest.java
@@ -10,6 +10,7 @@ import android.app.PendingIntent;
import android.content.Intent;
import android.net.Uri;
import android.os.Build;
+import android.os.Environment;
import android.test.FlakyTest;
import android.test.suitebuilder.annotation.MediumTest;
import android.text.TextUtils;
@@ -17,6 +18,7 @@ import android.view.View;
import org.chromium.base.ApplicationStatus;
import org.chromium.base.ThreadUtils;
+import org.chromium.base.test.util.CommandLineFlags;
import org.chromium.base.test.util.MinAndroidSdkLevel;
import org.chromium.base.test.util.UrlUtils;
import org.chromium.chrome.browser.ChromeActivity;
@@ -26,16 +28,19 @@ import org.chromium.chrome.browser.IntentHandler;
import org.chromium.chrome.browser.ShortcutHelper;
import org.chromium.chrome.browser.tab.Tab;
import org.chromium.chrome.browser.tabmodel.TabModel;
+import org.chromium.chrome.browser.tabmodel.TabModelSelector;
import org.chromium.chrome.browser.tabmodel.TabModelUtils;
import org.chromium.chrome.browser.tabmodel.document.DocumentTabModelSelector;
import org.chromium.chrome.browser.tabmodel.document.OffTheRecordDocumentTabModel;
import org.chromium.chrome.test.util.ActivityUtils;
import org.chromium.chrome.test.util.ApplicationTestUtils;
+import org.chromium.chrome.test.util.ChromeTabUtils;
import org.chromium.chrome.test.util.DisableInTabbedMode;
import org.chromium.content.browser.test.util.Criteria;
import org.chromium.content.browser.test.util.CriteriaHelper;
import org.chromium.content.browser.test.util.TouchCommon;
import org.chromium.content_public.browser.LoadUrlParams;
+import org.chromium.net.test.EmbeddedTestServer;
import java.lang.ref.WeakReference;
import java.util.List;
@@ -650,6 +655,53 @@ public class DocumentModeTest extends DocumentModeTestBase {
"about:blank", IntentHandler.getUrlFromIntent(lastIntent));
}
+ /**
+ * Tests that a Weblite url from an external app uses the lite_url param when Data Reduction
+ * Proxy previews are being used.
+ */
+ @MediumTest
+ @CommandLineFlags.Add({"enable-spdy-proxy-auth", "data-reduction-proxy-lo-fi=always-on",
+ "enable-data-reduction-proxy-lo-fi-preview"})
+ public void testLaunchWebLiteURL() throws Exception {
+ EmbeddedTestServer testServer;
+ testServer = EmbeddedTestServer.createAndStartFileServer(
+ getInstrumentation().getContext(), Environment.getExternalStorageDirectory());
+
+ String url = testServer.getURL("/chrome/test/data/android/about.html");
+ Runnable viewIntentRunnable = getViewIntentRunnable(false,
+ "http://googleweblight.com/?lite_url=" + url);
+
+ // Wait for the Activity to start up.
+ final DocumentActivity newActivity = ActivityUtils.waitForActivity(
+ getInstrumentation(), DocumentActivity.class, viewIntentRunnable);
+ ChromeTabUtils.waitForTabPageLoaded(newActivity.getActivityTab(), (String) null);
+
+ TabModelSelector selector = ChromeApplication.getDocumentTabModelSelector();
+ assertEquals(1, selector.getTotalTabCount());
+ assertEquals(url, selector.getModel(false).getTabAt(0).getUrl());
+
+ testServer.stopAndDestroyServer();
+ }
+
+ /**
+ * Tests that a Weblite url from an external app does not use the lite_url param when Data
+ * Reduction Proxy previews are not being used.
+ */
+ @MediumTest
+ public void testLaunchWebLiteURLNoPreviews() throws Exception {
+ String url = "http://googleweblight.com/?lite_url=chrome/test/data/android/about.html";
+ Runnable viewIntentRunnable = getViewIntentRunnable(false, url);
+
+ // Wait for the Activity to start up.
+ final DocumentActivity newActivity = ActivityUtils.waitForActivity(
+ getInstrumentation(), DocumentActivity.class, viewIntentRunnable);
+ ChromeTabUtils.waitForTabPageLoaded(newActivity.getActivityTab(), (String) null);
+
+ TabModelSelector selector = ChromeApplication.getDocumentTabModelSelector();
+ assertEquals(1, selector.getTotalTabCount());
+ assertEquals(url, selector.getModel(false).getTabAt(0).getUrl());
+ }
+
private Intent performNewWindowTest(String url, String title, boolean checkWindowOpenSuccess,
String openTitle, boolean waitLongerForOpenedPage) throws Exception {
launchViaLaunchDocumentInstance(false, url, title);

Powered by Google App Engine
This is Rietveld 408576698