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

Issue 639413002: [aw] Reuse WebContents PowerSaveBlocker in fullscreen. (Closed)

Created:
6 years, 2 months ago by Ignacio Solla
Modified:
6 years, 1 month ago
Reviewers:
michaelbai, no sievers
CC:
chromium-reviews, darin-cc_chromium.org, jam, android-webview-reviews_chromium.org, benm (inactive), qinmin
Base URL:
https://chromium.googlesource.com/chromium/src.git@testsForPowerSaver
Project:
chromium
Visibility:
Public.

Description

[aw] Transfer anchor views between container views. The WebView swaps container views when transitioning from/to fullscreen. This change ensures that anchor views are transferred across container views too. We also remove the PowerSaveBlocker attached to the ContentVideoView because as a result it is not longer needed. We now reuse the PowerSaveBlocker attached to the WebContents which is implemented as an anchor view. This has a number of advantages: 1. The PowerSaveBlocker now works correctly between transitions from/to fullscreen. 2. A PowerSaveBlocker is now also created for video elements contained inside a div (for these a ContentVideoView is not created when going fullscreen). This change depends on: https://codereview.chromium.org/639923003/ This change also adds comprehensive tests to verify the new behaviour. For this we need a longer video, so we replace the old one-frame test video. We also refactor the tests to remove flakiness and unnecessary complexity. BUG=398485 Committed: https://crrev.com/c698e079008a03048933818525310fb34908a10a Cr-Commit-Position: refs/heads/master@{#302094}

Patch Set 1 #

Patch Set 2 : Added tests #

Total comments: 7

Patch Set 3 : Rebase and address comments #

Patch Set 4 : Fix diffbase #

Patch Set 5 : Added ContentViewAndroidDelegateWrapper and corresponding tests #

Patch Set 6 : Rebase and added testViewAndroidCreatedWithCorrectDelegate #

Total comments: 13

Patch Set 7 : Rebase and some nits #

Patch Set 8 : Fix presubmit checks #

Patch Set 9 : Update AwContentsClientGetVideoLoadingProgressViewTest #

Total comments: 4

Patch Set 10 : Remove ReplaceableViewAndroidDelegate interface #

Patch Set 11 : Merge wrapper and delegate into one, and fix new presubmit warnings #

Patch Set 12 : Rebase #

Total comments: 8

Patch Set 13 : Nits #

Unified diffs Side-by-side diffs Delta from patch set Stats (+667 lines, -332 lines) Patch
M android_webview/android_webview_tests.gypi View 1 2 3 4 5 6 7 8 9 10 11 2 chunks +2 lines, -0 lines 0 comments Download
M android_webview/javatests/src/org/chromium/android_webview/test/AwContentsClientFullScreenTest.java View 1 2 3 4 6 chunks +193 lines, -48 lines 0 comments Download
M android_webview/javatests/src/org/chromium/android_webview/test/AwContentsClientGetVideoLoadingProgressViewTest.java View 1 2 3 4 5 6 7 8 4 chunks +9 lines, -15 lines 0 comments Download
M android_webview/javatests/src/org/chromium/android_webview/test/AwSettingsTest.java View 1 2 3 4 5 6 7 8 9 10 1 chunk +1 line, -2 lines 0 comments Download
M android_webview/javatests/src/org/chromium/android_webview/test/util/VideoTestUtil.java View 1 2 3 4 5 6 7 8 9 10 1 chunk +10 lines, -10 lines 0 comments Download
M android_webview/javatests/src/org/chromium/android_webview/test/util/VideoTestWebServer.java View 1 2 3 4 5 6 7 8 9 10 3 chunks +8 lines, -63 lines 0 comments Download
M android_webview/lib/main/aw_main_delegate.cc View 1 2 3 4 5 6 7 8 9 10 1 chunk +0 lines, -6 lines 0 comments Download
M android_webview/test/shell/assets/full_screen_video.js View 1 2 3 4 5 1 chunk +0 lines, -6 lines 0 comments Download
M android_webview/test/shell/assets/full_screen_video_inside_div_test.html View 1 3 1 chunk +7 lines, -6 lines 0 comments Download
M android_webview/test/shell/assets/full_screen_video_test.html View 1 2 3 4 5 6 7 8 1 chunk +5 lines, -3 lines 0 comments Download
A + android_webview/test/shell/assets/video.mp4 View 1 Binary file 0 comments Download
M content/browser/android/content_video_view.h View 2 chunks +0 lines, -14 lines 0 comments Download
M content/browser/android/content_video_view.cc View 3 7 chunks +0 lines, -35 lines 0 comments Download
M content/public/android/java/src/org/chromium/content/browser/ContentVideoView.java View 1 2 3 4 5 6 7 8 9 10 5 chunks +4 lines, -33 lines 0 comments Download
M content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java View 1 2 3 4 5 6 7 8 9 10 11 12 10 chunks +165 lines, -79 lines 0 comments Download
M content/public/android/javatests/src/org/chromium/content/browser/ContentViewCoreInputConnectionTest.java View 1 2 3 4 5 6 7 8 9 10 11 12 1 chunk +1 line, -0 lines 0 comments Download
A content/public/android/javatests/src/org/chromium/content/browser/ContentViewCoreViewAndroidDelegateTest.java View 1 2 3 4 5 6 7 8 9 10 11 12 1 chunk +223 lines, -0 lines 0 comments Download
M content/public/common/content_switches.h View 1 2 3 4 5 6 7 8 9 10 1 chunk +0 lines, -1 line 0 comments Download
M content/public/common/content_switches.cc View 1 2 3 4 5 6 7 8 9 10 1 chunk +0 lines, -4 lines 0 comments Download
M content/public/test/android/javatests/src/org/chromium/content/browser/test/util/DOMUtils.java View 1 2 3 4 3 chunks +39 lines, -7 lines 0 comments Download

Messages

Total messages: 42 (4 generated)
Ignacio Solla
jam@chromium.org: Please review changes in content/ miguelg@chromium.org: Please review changes in ui/android michaelbai@chromium.org: Please review ...
6 years, 2 months ago (2014-10-10 14:39:26 UTC) #2
Ignacio Solla
On 2014/10/10 14:39:26, Ignacio Solla wrote: > mailto:jam@chromium.org: Please review changes in content/ > > ...
6 years, 2 months ago (2014-10-10 15:21:56 UTC) #3
Ignacio Solla
https://codereview.chromium.org/639413002/diff/20001/android_webview/javatests/src/org/chromium/android_webview/test/AwContentsClientGetVideoLoadingProgressViewTest.java File android_webview/javatests/src/org/chromium/android_webview/test/AwContentsClientGetVideoLoadingProgressViewTest.java (left): https://codereview.chromium.org/639413002/diff/20001/android_webview/javatests/src/org/chromium/android_webview/test/AwContentsClientGetVideoLoadingProgressViewTest.java#oldcode78 android_webview/javatests/src/org/chromium/android_webview/test/AwContentsClientGetVideoLoadingProgressViewTest.java:78: if (webServer != null) webServer.getTestWebServer().shutdown(); Note to myself: add ...
6 years, 2 months ago (2014-10-10 18:14:04 UTC) #4
Ignacio Solla
On 2014/10/10 14:39:26, Ignacio Solla wrote: > mailto:jam@chromium.org: Please review changes in content/ > > ...
6 years, 2 months ago (2014-10-11 09:58:39 UTC) #6
no sievers
looks fine as long as michaelbai is happy https://codereview.chromium.org/639413002/diff/20001/content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java File content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java (right): https://codereview.chromium.org/639413002/diff/20001/content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java#newcode514 content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java:514: public ...
6 years, 2 months ago (2014-10-14 21:51:34 UTC) #7
Ignacio Solla
https://codereview.chromium.org/639413002/diff/20001/content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java File content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java (right): https://codereview.chromium.org/639413002/diff/20001/content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java#newcode514 content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java:514: public void anchorAnchorView(View anchorView) { On 2014/10/14 21:51:34, sievers ...
6 years, 2 months ago (2014-10-15 11:43:27 UTC) #8
michaelbai
Could you explain why don't you create new PowerSaveBlocker when it needed, instead of reusing ...
6 years, 2 months ago (2014-10-15 18:03:27 UTC) #9
Ignacio Solla
On 2014/10/15 18:03:27, michaelbai wrote: > Could you explain why don't you create new PowerSaveBlocker ...
6 years, 2 months ago (2014-10-15 18:26:13 UTC) #10
michaelbai
On 2014/10/15 18:26:13, Ignacio Solla wrote: > On 2014/10/15 18:03:27, michaelbai wrote: > > Could ...
6 years, 2 months ago (2014-10-15 18:38:33 UTC) #11
Ignacio Solla
On 2014/10/15 18:38:33, michaelbai wrote: > On 2014/10/15 18:26:13, Ignacio Solla wrote: > > On ...
6 years, 2 months ago (2014-10-15 18:51:16 UTC) #12
Ignacio Solla
On 2014/10/15 18:51:16, Ignacio Solla wrote: > On 2014/10/15 18:38:33, michaelbai wrote: > > On ...
6 years, 2 months ago (2014-10-15 18:54:54 UTC) #13
michaelbai
On 2014/10/15 18:51:16, Ignacio Solla wrote: > On 2014/10/15 18:38:33, michaelbai wrote: > > On ...
6 years, 2 months ago (2014-10-15 18:55:08 UTC) #14
Ignacio Solla
On 2014/10/15 18:55:08, michaelbai wrote: > On 2014/10/15 18:51:16, Ignacio Solla wrote: > > On ...
6 years, 2 months ago (2014-10-15 18:57:23 UTC) #15
michaelbai
On 2014/10/15 18:57:23, Ignacio Solla wrote: > On 2014/10/15 18:55:08, michaelbai wrote: > > On ...
6 years, 2 months ago (2014-10-15 19:08:57 UTC) #16
Ignacio Solla
On 2014/10/15 19:08:57, michaelbai wrote: > On 2014/10/15 18:57:23, Ignacio Solla wrote: > > On ...
6 years, 2 months ago (2014-10-15 19:19:26 UTC) #17
michaelbai
On 2014/10/15 19:19:26, Ignacio Solla wrote: > On 2014/10/15 19:08:57, michaelbai wrote: > > On ...
6 years, 2 months ago (2014-10-15 21:07:11 UTC) #18
Ignacio Solla
On 2014/10/15 21:07:11, michaelbai wrote: > On 2014/10/15 19:19:26, Ignacio Solla wrote: > > On ...
6 years, 2 months ago (2014-10-16 09:44:36 UTC) #19
michaelbai
On 2014/10/16 09:44:36, Ignacio Solla wrote: > On 2014/10/15 21:07:11, michaelbai wrote: > > On ...
6 years, 2 months ago (2014-10-16 14:44:13 UTC) #20
Ignacio Solla
On 2014/10/16 14:44:13, michaelbai wrote: > On 2014/10/16 09:44:36, Ignacio Solla wrote: > > On ...
6 years, 2 months ago (2014-10-17 14:01:32 UTC) #21
michaelbai
https://codereview.chromium.org/639413002/diff/280001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java File content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java (right): https://codereview.chromium.org/639413002/diff/280001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java#newcode33 content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java:33: interface ContentViewAndroidDelegate extends ViewAndroidDelegate { Maybe SwappableViewAndroidDelegate? https://codereview.chromium.org/639413002/diff/280001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java#newcode34 content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java:34: ...
6 years, 2 months ago (2014-10-17 17:30:56 UTC) #23
Ignacio Solla
https://codereview.chromium.org/639413002/diff/280001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java File content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java (right): https://codereview.chromium.org/639413002/diff/280001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java#newcode33 content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java:33: interface ContentViewAndroidDelegate extends ViewAndroidDelegate { On 2014/10/17 17:30:55, michaelbai ...
6 years, 2 months ago (2014-10-20 11:41:03 UTC) #24
michaelbai
https://codereview.chromium.org/639413002/diff/280001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java File content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java (right): https://codereview.chromium.org/639413002/diff/280001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java#newcode58 content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java:58: List<View> mAnchorViews; On 2014/10/20 11:41:02, Ignacio Solla wrote: > ...
6 years, 2 months ago (2014-10-20 17:19:50 UTC) #25
Ignacio Solla
On 2014/10/20 17:19:50, michaelbai wrote: > https://codereview.chromium.org/639413002/diff/280001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java > File > content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java > (right): > > ...
6 years, 2 months ago (2014-10-20 17:47:56 UTC) #26
michaelbai
On 2014/10/20 17:47:56, Ignacio Solla wrote: > On 2014/10/20 17:19:50, michaelbai wrote: > > > ...
6 years, 2 months ago (2014-10-20 18:05:00 UTC) #27
Ignacio Solla
On 2014/10/20 18:05:00, michaelbai wrote: > On 2014/10/20 17:47:56, Ignacio Solla wrote: > > On ...
6 years, 2 months ago (2014-10-20 18:22:37 UTC) #28
michaelbai
On 2014/10/20 18:22:37, Ignacio Solla wrote: > On 2014/10/20 18:05:00, michaelbai wrote: > > On ...
6 years, 2 months ago (2014-10-20 18:50:08 UTC) #29
michaelbai
android_webview LGTM
6 years, 2 months ago (2014-10-20 18:50:25 UTC) #30
Ignacio Solla
On 2014/10/20 18:50:08, michaelbai wrote: > On 2014/10/20 18:22:37, Ignacio Solla wrote: > > On ...
6 years, 2 months ago (2014-10-21 10:20:29 UTC) #31
no sievers
https://codereview.chromium.org/639413002/diff/340001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java File content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java (right): https://codereview.chromium.org/639413002/diff/340001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java#newcode17 content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java:17: * Wrapper around a {@link ReplaceableViewAndroidDelegate} that transfers anchor ...
6 years, 2 months ago (2014-10-22 20:10:17 UTC) #32
Ignacio Solla
https://codereview.chromium.org/639413002/diff/340001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java File content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java (right): https://codereview.chromium.org/639413002/diff/340001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java#newcode17 content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java:17: * Wrapper around a {@link ReplaceableViewAndroidDelegate} that transfers anchor ...
6 years, 1 month ago (2014-10-27 12:10:52 UTC) #33
Ignacio Solla
On 2014/10/27 12:10:52, Ignacio Solla wrote: > https://codereview.chromium.org/639413002/diff/340001/content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java > File > content/public/android/java/src/org/chromium/content/browser/ContentViewAndroidDelegateWrapper.java > (right): > ...
6 years, 1 month ago (2014-10-27 13:16:01 UTC) #34
no sievers
In this case I'd find the code much easier to follow if it was encapsulated ...
6 years, 1 month ago (2014-10-27 21:37:03 UTC) #35
Ignacio Solla
On 2014/10/27 21:37:03, sievers wrote: > In this case I'd find the code much easier ...
6 years, 1 month ago (2014-10-28 10:52:10 UTC) #36
no sievers
lgtm https://codereview.chromium.org/639413002/diff/400001/content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java File content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java (right): https://codereview.chromium.org/639413002/diff/400001/content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java#newcode158 content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java:158: private class Position { nit: You can use ...
6 years, 1 month ago (2014-10-28 18:34:14 UTC) #37
Ignacio Solla
https://codereview.chromium.org/639413002/diff/400001/content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java File content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java (right): https://codereview.chromium.org/639413002/diff/400001/content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java#newcode158 content/public/android/java/src/org/chromium/content/browser/ContentViewCore.java:158: private class Position { On 2014/10/28 18:34:13, sievers wrote: ...
6 years, 1 month ago (2014-10-30 16:01:39 UTC) #38
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/patch-status/639413002/420001
6 years, 1 month ago (2014-10-30 16:03:03 UTC) #40
commit-bot: I haz the power
Committed patchset #13 (id:420001)
6 years, 1 month ago (2014-10-30 16:52:34 UTC) #41
commit-bot: I haz the power
6 years, 1 month ago (2014-10-30 16:53:19 UTC) #42
Message was sent while issue was closed.
Patchset 13 (id:??) landed as
https://crrev.com/c698e079008a03048933818525310fb34908a10a
Cr-Commit-Position: refs/heads/master@{#302094}

Powered by Google App Engine
This is Rietveld 408576698