Index: chrome/android/javatests/src/org/chromium/chrome/browser/vr_shell/VrShellNavigationTest.java |
diff --git a/chrome/android/javatests/src/org/chromium/chrome/browser/vr_shell/VrShellNavigationTest.java b/chrome/android/javatests/src/org/chromium/chrome/browser/vr_shell/VrShellNavigationTest.java |
new file mode 100644 |
index 0000000000000000000000000000000000000000..02c0f5d4b183901957811e255de5affc80323568 |
--- /dev/null |
+++ b/chrome/android/javatests/src/org/chromium/chrome/browser/vr_shell/VrShellNavigationTest.java |
@@ -0,0 +1,265 @@ |
+// Copyright 2017 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.chrome.browser.vr_shell; |
+ |
+import static org.chromium.chrome.browser.vr_shell.VrUtils.POLL_TIMEOUT_LONG_MS; |
+import static org.chromium.chrome.browser.vr_shell.VrUtils.POLL_TIMEOUT_SHORT_MS; |
+import static org.chromium.chrome.test.util.ChromeRestriction.RESTRICTION_TYPE_VIEWER_DAYDREAM; |
+ |
+import android.support.test.filters.MediumTest; |
+ |
+import org.chromium.base.ThreadUtils; |
+import org.chromium.base.test.util.CommandLineFlags; |
+import org.chromium.base.test.util.Restriction; |
+import org.chromium.chrome.test.util.ChromeTabUtils; |
+import org.chromium.content.browser.test.util.DOMUtils; |
+ |
+import java.util.concurrent.CountDownLatch; |
+import java.util.concurrent.TimeUnit; |
+import java.util.concurrent.TimeoutException; |
+ |
+/** |
+ * End-to-end tests for testing navigation transitions (e.g. link clicking) in VR Browser mode, aka |
+ * "VR Shell". This may require interacting with WebVR in addition to the VR browser, so inherit |
+ * from VrTestBase for the WebVR test framework. |
+ */ |
+@CommandLineFlags.Add("enable-features=VrShell") |
bsheedy
2017/05/01 21:48:17
FYI, I think the enabling of VR Shell won't automa
tiborg
2017/05/01 23:09:46
Done.
|
+public class VrShellNavigationTest extends VrTestBase { |
+ private static final String TEST_PAGE_2D_URL = |
+ VrTestBase.getHtmlTestFile("test_navigation_2d_page"); |
+ private static final String TEST_PAGE_WEBVR_URL = |
+ VrTestBase.getHtmlTestFile("test_navigation_webvr_page"); |
+ |
+ private enum Page { PAGE_2D, PAGE_WEBVR } |
+ |
+ private enum PresentationMode { NON_PRESENTING, PRESENTING } |
+ |
+ private enum FullscreenMode { NON_FULLSCREENED, FULLSCREENED } |
+ |
+ private void navigateTo(Page to) throws InterruptedException { |
+ // Trigger navigation to new page. |
+ String testPageUrl; |
+ switch (to) { |
+ case PAGE_2D: |
+ testPageUrl = TEST_PAGE_2D_URL + "?id=0"; |
+ break; |
+ case PAGE_WEBVR: |
+ testPageUrl = TEST_PAGE_WEBVR_URL + "?id=0"; |
+ break; |
+ default: |
+ throw new UnsupportedOperationException(); |
+ } |
+ runJavaScriptOrFail("window.location.href = '" + testPageUrl + "';", POLL_TIMEOUT_SHORT_MS, |
bsheedy
2017/05/01 21:48:16
Was there an issue using loadUrl() for this? It se
tiborg
2017/05/01 23:09:45
I was not sure how many steps of the transition lo
bsheedy
2017/05/01 23:36:31
Makes sense, although I'd add a comment explaining
tiborg
2017/05/02 14:15:02
Done.
|
+ mWebContents); |
+ // Wait until new page is loaded. |
+ final CountDownLatch pageLoadedLatch = new CountDownLatch(1); |
+ ChromeTabUtils.waitForTabPageLoaded(getActivity().getActivityTab(), new Runnable() { |
+ @Override |
+ public void run() { |
+ ThreadUtils.runOnUiThreadBlocking(new Runnable() { |
+ @Override |
+ public void run() { |
+ pageLoadedLatch.countDown(); |
+ } |
+ }); |
+ } |
+ }, POLL_TIMEOUT_LONG_MS); |
+ assertTrue( |
+ "Page loaded", pageLoadedLatch.await(POLL_TIMEOUT_LONG_MS, TimeUnit.MILLISECONDS)); |
+ } |
+ |
+ private void goFullscreened() throws InterruptedException, TimeoutException { |
bsheedy
2017/05/01 21:48:16
nit: goFullscreened sounds a little odd to me - ma
tiborg
2017/05/01 23:09:45
Done.
|
+ DOMUtils.clickNode(getActivity().getActivityTab().getContentViewCore(), "fullscreen"); |
bsheedy
2017/05/01 21:48:16
I would suggest changing goFullscreened() to goFul
tiborg
2017/05/01 23:09:46
Done.
|
+ waitOnJavaScriptStep(mWebContents); |
+ assertTrue(DOMUtils.isFullscreen( |
+ getActivity().getActivityTab().getContentViewCore().getWebContents())); |
+ } |
+ |
+ private void present() throws InterruptedException, TimeoutException { |
bsheedy
2017/05/01 21:48:16
There's already a function to do this in VrTestBas
tiborg
2017/05/01 23:09:45
I considered changing enterVrTap. However, then We
|
+ DOMUtils.clickNode(getActivity().getActivityTab().getContentViewCore(), "webgl-canvas"); |
bsheedy
2017/05/01 21:48:16
Same comment as above - pass in a CVC and use that
tiborg
2017/05/01 23:09:46
Done.
|
+ waitOnJavaScriptStep(mWebContents); |
+ assertTrue(VrShellDelegate.getVrShellForTesting().getWebVrModeEnabled()); |
+ } |
+ |
+ private void assertState(Page page, PresentationMode presentationMode, |
+ FullscreenMode fullscreenMode) throws InterruptedException, TimeoutException { |
+ String url; |
+ switch (page) { |
+ case PAGE_2D: |
+ url = TEST_PAGE_2D_URL + "?id=0"; |
+ break; |
+ case PAGE_WEBVR: |
+ url = TEST_PAGE_WEBVR_URL + "?id=0"; |
+ break; |
+ default: |
+ throw new UnsupportedOperationException(); |
+ } |
+ assertTrue("Browser is in VR", VrShellDelegate.isInVr()); |
+ assertEquals( |
+ "Browser is on correct web site", url, getActivity().getActivityTab().getUrl()); |
bsheedy
2017/05/01 21:48:17
Consider making assertState take a WebContents obj
tiborg
2017/05/01 23:09:45
Done.
|
+ assertEquals("Browser is in VR Presentation Mode", |
+ presentationMode == PresentationMode.PRESENTING, |
+ VrShellDelegate.getVrShellForTesting().getWebVrModeEnabled()); |
+ assertEquals("Browser is in fullscreen", fullscreenMode == FullscreenMode.FULLSCREENED, |
+ DOMUtils.isFullscreen( |
+ getActivity().getActivityTab().getContentViewCore().getWebContents())); |
+ } |
+ |
+ @Override |
+ public int loadUrl(String url, long secondsToWait) |
bsheedy
2017/05/01 21:48:16
I think the base loadUrl blocks until the page is
tiborg
2017/05/01 23:09:46
I'm not sure if loadUrl waits until all resources
bsheedy
2017/05/01 23:36:31
In that case, I'll consider moving this into VrTes
tiborg
2017/05/02 14:15:02
Sounds good.
|
+ throws IllegalArgumentException, InterruptedException { |
+ int result = super.loadUrl(url, secondsToWait); |
+ waitOnJavaScriptStep(mWebContents); |
+ return result; |
+ } |
+ |
+ @Override |
+ protected void setUp() throws Exception { |
+ super.setUp(); |
+ VrUtils.forceEnterVr(); |
+ VrUtils.waitForVrSupported(POLL_TIMEOUT_LONG_MS); |
+ assertTrue(VrShellDelegate.isInVr()); |
bsheedy
2017/05/01 21:48:16
nit: This assert doesn't really do anything since
tiborg
2017/05/01 23:09:46
Done.
|
+ } |
+ |
+ @Override |
+ public void startMainActivity() throws InterruptedException { |
bsheedy
2017/05/01 21:48:17
Unnecessary override since VrTestBase's startMainA
tiborg
2017/05/01 23:09:45
Done.
|
+ startMainActivityOnBlankPage(); |
+ } |
+ |
+ @Restriction(RESTRICTION_TYPE_VIEWER_DAYDREAM) |
bsheedy
2017/05/01 21:48:16
Since every test here seems to have the same restr
tiborg
2017/05/01 23:09:46
Done.
|
+ @MediumTest |
+ public void test2dTo2d() throws InterruptedException, TimeoutException { |
bsheedy
2017/05/01 21:48:17
I think test cases are supposed to have comments b
tiborg
2017/05/01 23:09:45
Done.
|
+ // Arrange. |
bsheedy
2017/05/01 21:48:17
nit: The arrange/act/assert comments seem unnecess
tiborg
2017/05/01 23:09:45
Done.
|
+ loadUrl(TEST_PAGE_2D_URL, PAGE_LOAD_TIMEOUT_S); |
+ |
+ // Act. |
+ navigateTo(Page.PAGE_2D); |
+ |
+ // Assert. |
+ assertState(Page.PAGE_2D, PresentationMode.NON_PRESENTING, FullscreenMode.NON_FULLSCREENED); |
+ } |
+ |
+ @Restriction(RESTRICTION_TYPE_VIEWER_DAYDREAM) |
+ @MediumTest |
+ public void test2dToWebVr() |
+ throws IllegalArgumentException, InterruptedException, TimeoutException { |
+ // Arrange. |
+ loadUrl(TEST_PAGE_2D_URL, PAGE_LOAD_TIMEOUT_S); |
+ |
+ // Act. |
+ navigateTo(Page.PAGE_WEBVR); |
+ |
+ // Assert. |
+ assertState( |
+ Page.PAGE_WEBVR, PresentationMode.NON_PRESENTING, FullscreenMode.NON_FULLSCREENED); |
+ } |
+ |
+ @Restriction(RESTRICTION_TYPE_VIEWER_DAYDREAM) |
+ @MediumTest |
+ public void test2dFullscreenToWebVr() |
+ throws IllegalArgumentException, InterruptedException, TimeoutException { |
+ // Arrange. |
+ loadUrl(TEST_PAGE_2D_URL, PAGE_LOAD_TIMEOUT_S); |
+ goFullscreened(); |
+ |
+ // Act. |
+ navigateTo(Page.PAGE_WEBVR); |
+ |
+ // Assert. |
+ assertState( |
+ Page.PAGE_WEBVR, PresentationMode.NON_PRESENTING, FullscreenMode.NON_FULLSCREENED); |
+ } |
+ |
+ @Restriction(RESTRICTION_TYPE_VIEWER_DAYDREAM) |
+ @MediumTest |
+ public void testWebVrTo2d() |
+ throws IllegalArgumentException, InterruptedException, TimeoutException { |
+ // Arrange. |
+ loadUrl(TEST_PAGE_WEBVR_URL, PAGE_LOAD_TIMEOUT_S); |
+ |
+ // Act. |
+ navigateTo(Page.PAGE_2D); |
+ |
+ // Assert. |
+ assertState(Page.PAGE_2D, PresentationMode.NON_PRESENTING, FullscreenMode.NON_FULLSCREENED); |
+ } |
+ |
+ @Restriction(RESTRICTION_TYPE_VIEWER_DAYDREAM) |
+ @MediumTest |
+ public void testWebVrToWebVr() |
+ throws IllegalArgumentException, InterruptedException, TimeoutException { |
+ // Arrange. |
+ loadUrl(TEST_PAGE_WEBVR_URL, PAGE_LOAD_TIMEOUT_S); |
+ |
+ // Act. |
+ navigateTo(Page.PAGE_WEBVR); |
+ |
+ // Assert. |
+ assertState( |
+ Page.PAGE_WEBVR, PresentationMode.NON_PRESENTING, FullscreenMode.NON_FULLSCREENED); |
+ } |
+ |
+ @Restriction(RESTRICTION_TYPE_VIEWER_DAYDREAM) |
+ @MediumTest |
+ public void testWebVrPresentingTo2d() |
+ throws IllegalArgumentException, InterruptedException, TimeoutException { |
+ // Arrange. |
+ loadUrl(TEST_PAGE_WEBVR_URL, PAGE_LOAD_TIMEOUT_S); |
+ present(); |
+ |
+ // Act. |
+ navigateTo(Page.PAGE_2D); |
+ |
+ // Assert. |
+ assertState(Page.PAGE_2D, PresentationMode.NON_PRESENTING, FullscreenMode.NON_FULLSCREENED); |
+ } |
+ |
+ @Restriction(RESTRICTION_TYPE_VIEWER_DAYDREAM) |
+ @MediumTest |
+ public void testWebVrPresentingToWebVr() |
+ throws IllegalArgumentException, InterruptedException, TimeoutException { |
+ // Arrange. |
+ loadUrl(TEST_PAGE_WEBVR_URL, PAGE_LOAD_TIMEOUT_S); |
+ present(); |
+ |
+ // Act. |
+ navigateTo(Page.PAGE_WEBVR); |
+ |
+ // Assert. |
+ assertState( |
+ Page.PAGE_WEBVR, PresentationMode.NON_PRESENTING, FullscreenMode.NON_FULLSCREENED); |
+ } |
+ |
+ @Restriction(RESTRICTION_TYPE_VIEWER_DAYDREAM) |
+ @MediumTest |
+ public void testWebVrFullscreenTo2d() |
+ throws IllegalArgumentException, InterruptedException, TimeoutException { |
+ // Arrange. |
+ loadUrl(TEST_PAGE_WEBVR_URL, PAGE_LOAD_TIMEOUT_S); |
+ goFullscreened(); |
+ |
+ // Act. |
+ navigateTo(Page.PAGE_2D); |
+ |
+ // Assert. |
+ assertState(Page.PAGE_2D, PresentationMode.NON_PRESENTING, FullscreenMode.NON_FULLSCREENED); |
+ } |
+ |
+ @Restriction(RESTRICTION_TYPE_VIEWER_DAYDREAM) |
+ @MediumTest |
+ public void testWebVrFullscreenToWebVr() |
+ throws IllegalArgumentException, InterruptedException, TimeoutException { |
+ // Arrange. |
+ loadUrl(TEST_PAGE_WEBVR_URL, PAGE_LOAD_TIMEOUT_S); |
+ goFullscreened(); |
+ |
+ // Act. |
+ navigateTo(Page.PAGE_WEBVR); |
+ |
+ // Assert. |
+ assertState( |
+ Page.PAGE_WEBVR, PresentationMode.NON_PRESENTING, FullscreenMode.NON_FULLSCREENED); |
+ } |
+} |