Index: content/public/android/javatests/src/org/chromium/content/browser/ContentViewLocationTest.java |
diff --git a/content/public/android/javatests/src/org/chromium/content/browser/ContentViewLocationTest.java b/content/public/android/javatests/src/org/chromium/content/browser/ContentViewLocationTest.java |
deleted file mode 100644 |
index 3e6b3f7ac431abe36e1809242a5b907ffae3c162..0000000000000000000000000000000000000000 |
--- a/content/public/android/javatests/src/org/chromium/content/browser/ContentViewLocationTest.java |
+++ /dev/null |
@@ -1,173 +0,0 @@ |
-// Copyright 2013 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 android.test.suitebuilder.annotation.MediumTest; |
- |
-import org.chromium.base.test.util.Feature; |
-import org.chromium.content.browser.test.util.Criteria; |
-import org.chromium.content.browser.test.util.CriteriaHelper; |
-import org.chromium.content.browser.test.util.MockLocationProvider; |
-import org.chromium.content.browser.test.util.TestCallbackHelperContainer; |
-import org.chromium.content_shell_apk.ContentShellTestBase; |
- |
-/** |
- * Test suite for ensureing that Geolocation interacts as expected |
- * with ContentView APIs - e.g. that it's started and stopped as the |
- * ContentView is hidden or shown. |
- */ |
-public class ContentViewLocationTest extends ContentShellTestBase { |
- |
- private TestCallbackHelperContainer mTestCallbackHelperContainer; |
- private TestCallbackHelperContainer.OnEvaluateJavaScriptResultHelper mJavascriptHelper; |
- private MockLocationProvider mMockLocationProvider; |
- |
- private void hideContentViewOnUiThread() { |
- getInstrumentation().runOnMainSync(new Runnable() { |
- @Override |
- public void run() { |
- getContentView().onHide(); |
- } |
- }); |
- } |
- |
- private void showContentViewOnUiThread() { |
- getInstrumentation().runOnMainSync(new Runnable() { |
- @Override |
- public void run() { |
- getContentView().onShow(); |
- } |
- }); |
- } |
- |
- private void pollForPositionCallback() throws Throwable { |
- mJavascriptHelper.evaluateJavaScript(getContentViewCore(), |
- "positionCount = 0"); |
- mJavascriptHelper.waitUntilHasValue(); |
- assertEquals(0, Integer.parseInt(mJavascriptHelper.getJsonResultAndClear())); |
- |
- assertTrue(CriteriaHelper.pollForCriteria(new Criteria() { |
- @Override |
- public boolean isSatisfied() { |
- mJavascriptHelper.evaluateJavaScript(getContentViewCore(), "positionCount"); |
- try { |
- mJavascriptHelper.waitUntilHasValue(); |
- } catch (Exception e) { |
- fail(); |
- } |
- return Integer.parseInt(mJavascriptHelper.getJsonResultAndClear()) > 0; |
- } |
- })); |
- } |
- |
- private void startGeolocationWatchPosition() throws Throwable { |
- mJavascriptHelper.evaluateJavaScript(getContentViewCore(), |
- "initiate_watchPosition();"); |
- mJavascriptHelper.waitUntilHasValue(); |
- } |
- |
- private void ensureGeolocationRunning(final boolean running) throws Exception { |
- assertTrue(CriteriaHelper.pollForCriteria(new Criteria() { |
- @Override |
- public boolean isSatisfied() { |
- return mMockLocationProvider.isRunning() == running; |
- } |
- })); |
- } |
- |
- @Override |
- protected void setUp() throws Exception { |
- super.setUp(); |
- |
- mMockLocationProvider = new MockLocationProvider(); |
- LocationProviderFactory.setLocationProviderImpl(mMockLocationProvider); |
- |
- try { |
- startActivityWithTestUrl("content/geolocation.html"); |
- } catch (Throwable t) { |
- fail(); |
- } |
- |
- mTestCallbackHelperContainer = new TestCallbackHelperContainer(getContentView()); |
- mJavascriptHelper = mTestCallbackHelperContainer.getOnEvaluateJavaScriptResultHelper(); |
- |
- ensureGeolocationRunning(false); |
- } |
- |
- @Override |
- protected void tearDown() throws Exception { |
- mMockLocationProvider.stopUpdates(); |
- super.tearDown(); |
- } |
- |
- @MediumTest |
- @Feature({"Location"}) |
- public void testWatchHideShowStop() throws Throwable { |
- |
- startGeolocationWatchPosition(); |
- pollForPositionCallback(); |
- ensureGeolocationRunning(true); |
- |
- // Now hide the ContentView and ensure that geolocation stops. |
- hideContentViewOnUiThread(); |
- ensureGeolocationRunning(false); |
- |
- mJavascriptHelper.evaluateJavaScript(getContentViewCore(), |
- "positionCount = 0"); |
- mJavascriptHelper.waitUntilHasValue(); |
- |
- // Show the ContentView again and ensure that geolocation starts again. |
- showContentViewOnUiThread(); |
- pollForPositionCallback(); |
- ensureGeolocationRunning(true); |
- |
- // Navigate away and ensure that geolocation stops. |
- loadUrl(getContentView(), mTestCallbackHelperContainer, new LoadUrlParams("about:blank")); |
- ensureGeolocationRunning(false); |
- } |
- |
- @MediumTest |
- @Feature({"Location"}) |
- public void testHideWatchResume() throws Throwable { |
- hideContentViewOnUiThread(); |
- startGeolocationWatchPosition(); |
- ensureGeolocationRunning(false); |
- |
- showContentViewOnUiThread(); |
- pollForPositionCallback(); |
- ensureGeolocationRunning(true); |
- } |
- |
- @MediumTest |
- @Feature({"Location"}) |
- public void testWatchHideNewWatchShow() throws Throwable { |
- startGeolocationWatchPosition(); |
- pollForPositionCallback(); |
- ensureGeolocationRunning(true); |
- |
- hideContentViewOnUiThread(); |
- |
- // Make sure that when starting a new watch while paused we still don't |
- // start up geolocation until we show the content view again. |
- startGeolocationWatchPosition(); |
- ensureGeolocationRunning(false); |
- |
- showContentViewOnUiThread(); |
- pollForPositionCallback(); |
- ensureGeolocationRunning(true); |
- } |
- |
- @MediumTest |
- @Feature({"Location"}) |
- public void testHideWatchStopShow() throws Throwable { |
- hideContentViewOnUiThread(); |
- startGeolocationWatchPosition(); |
- ensureGeolocationRunning(false); |
- |
- loadUrl(getContentView(), mTestCallbackHelperContainer, new LoadUrlParams("about:blank")); |
- showContentViewOnUiThread(); |
- ensureGeolocationRunning(false); |
- } |
-} |