Bug 126214 - Merge PageVisibilityState & ViewState::IsVisible in WebKit2
Summary: Merge PageVisibilityState & ViewState::IsVisible in WebKit2
Status: RESOLVED FIXED
Alias: None
Product: WebKit
Classification: Unclassified
Component: WebKit2 (show other bugs)
Version: 528+ (Nightly build)
Hardware: Unspecified Unspecified
: P2 Normal
Assignee: Gavin Barraclough
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2013-12-24 08:34 PST by Gavin Barraclough
Modified: 2013-12-27 11:42 PST (History)
9 users (show)

See Also:


Attachments
Fixed? (41.48 KB, patch)
2013-12-25 14:13 PST, Gavin Barraclough
eflews.bot: commit-queue-
Details | Formatted Diff | Diff
style, efl fixes (42.22 KB, patch)
2013-12-25 14:30 PST, Gavin Barraclough
eflews.bot: commit-queue-
Details | Formatted Diff | Diff
efl build fix take 2 (42.71 KB, patch)
2013-12-25 15:43 PST, Gavin Barraclough
no flags Details | Formatted Diff | Diff
Stupid autocorrect :-( ... s/pretender/prerender/ in Changelog (42.71 KB, patch)
2013-12-25 21:57 PST, Gavin Barraclough
ap: review+
Details | Formatted Diff | Diff

Note You need to log in before you can comment on or make changes to this bug.
Description Gavin Barraclough 2013-12-24 08:34:52 PST
WebKit2 redundantly tracks the visibility of the view through two mechanisms - the visibility state, and the view state. Remove visibility state from the WebKit2 layer. The visibility state also tracks the 'pretender' state - so split this out and handle it separately (a change we should make in WebCore, too).

Removing the redundancy also removes the ability from the API to set a fake visibility state (IsVisible tracks the actual visibility of the view). Through private API (WKPageSetVisibilityState) a client could previously request the view be reported as hidden/visible, but this didn't really work - the override was not enforced and the API may reset the state at an arbitrary point. The mechanism is only used by testing code, which instead should actually update the view visibility (this tests more of the actual visibility mechanisms used by the browser). The one aspect of the API relied on by existing clients is the ability to initialize a hidden view as prerender -continue to support this specific functionality via WKPageSetVisibilityState, to maintain backwards compatibility.
Comment 1 Gavin Barraclough 2013-12-25 14:13:22 PST
Created attachment 220000 [details]
Fixed?
Comment 2 WebKit Commit Bot 2013-12-25 14:15:09 PST
Attachment 220000 [details] did not pass style-queue:

Failed to run "['Tools/Scripts/check-webkit-style', '--diff-files', u'LayoutTests/ChangeLog', u'LayoutTests/fast/events/page-visibility-transition-test-expected.txt', u'LayoutTests/fast/events/page-visibility-transition-test.html', u'Source/WebCore/ChangeLog', u'Source/WebCore/page/Page.cpp', u'Source/WebKit2/ChangeLog', u'Source/WebKit2/UIProcess/API/C/WKPage.cpp', u'Source/WebKit2/UIProcess/WebPageProxy.cpp', u'Source/WebKit2/UIProcess/WebPageProxy.h', u'Source/WebKit2/WebProcess/WebPage/WebPage.cpp', u'Source/WebKit2/WebProcess/WebPage/WebPage.h', u'Source/WebKit2/WebProcess/WebPage/WebPage.messages.in', u'Tools/ChangeLog', u'Tools/TestWebKitAPI/TestWebKitAPI.xcodeproj/project.pbxproj', u'Tools/TestWebKitAPI/Tests/WebKit2/PageVisibilityState.cpp', u'Tools/TestWebKitAPI/Tests/mac/PageVisibilityStateWithWindowChanges.mm', u'Tools/WebKitTestRunner/TestController.cpp', u'Tools/WebKitTestRunner/TestController.h', u'Tools/WebKitTestRunner/efl/TestControllerEfl.cpp', u'Tools/WebKitTestRunner/gtk/TestControllerGtk.cpp', u'Tools/WebKitTestRunner/mac/TestControllerMac.mm', '--commit-queue']" exit_code: 1
ERROR: Tools/WebKitTestRunner/TestController.h:167:  The parameter name "hidden" adds no information, so it should be removed.  [readability/parameter_name] [5]
Total errors found: 1 in 18 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 3 EFL EWS Bot 2013-12-25 14:21:41 PST
Comment on attachment 220000 [details]
Fixed?

Attachment 220000 [details] did not pass efl-wk2-ews (efl-wk2):
Output: http://webkit-queues.appspot.com/results/5033067089494016
Comment 4 Gavin Barraclough 2013-12-25 14:30:26 PST
Created attachment 220002 [details]
style, efl fixes
Comment 5 EFL EWS Bot 2013-12-25 14:45:59 PST
Comment on attachment 220002 [details]
style, efl fixes

Attachment 220002 [details] did not pass efl-wk2-ews (efl-wk2):
Output: http://webkit-queues.appspot.com/results/6107173985714176
Comment 6 Gavin Barraclough 2013-12-25 15:43:19 PST
Created attachment 220008 [details]
efl build fix take 2
Comment 7 Gavin Barraclough 2013-12-25 21:57:08 PST
Created attachment 220022 [details]
Stupid autocorrect :-( ... s/pretender/prerender/ in Changelog
Comment 8 Alexey Proskuryakov 2013-12-27 00:48:22 PST
Comment on attachment 220022 [details]
Stupid autocorrect :-( ... s/pretender/prerender/ in Changelog

View in context: https://bugs.webkit.org/attachment.cgi?id=220022&action=review

> Source/WebCore/ChangeLog:20
> +        by the browser). The one aspect of the API relied on by existing clients is the ability to
> +        initialize a hidden view as prerender -continue to support this specific functionality via

Seems like there should be a space in "-continue".

> Source/WebCore/ChangeLog:23
> +
> +

Extra blank line.

> Source/WebCore/ChangeLog:24
> +        WebCore - chnages the the API tests exposed a bug, a view should only ever come out of the

chnages, the the

> Source/WebKit2/ChangeLog:20
> +        initialize a hidden view as prerender -continue to support this specific functionality via

-continue

> Source/WebKit2/ChangeLog:23
> +
> +

Extra blank line.

> Tools/ChangeLog:23
> +        initialize a hidden view as prerender -continue to support this specific functionality via
> +        WKPageSetVisibilityState, to maintain backwards compatibility.
> +
> +

...

Does this really need to be repeated in every ChangeLog? I usually put extra info into a project that had the most changes - they are all combined for commit message anyway.

> Tools/WebKitTestRunner/mac/TestControllerMac.mm:90
> +        [window makeKeyAndOrderFront:nil];

Hopefully it's not forced back on screen, so nothing visually blinks and prevents using the computer while tests are running?

> Tools/WebKitTestRunner/mac/TestControllerMac.mm:91
> +        [NSApp activateIgnoringOtherApps:YES];

Why is this needed? A comment would probably be of use.
Comment 9 Gavin Barraclough 2013-12-27 11:40:46 PST
(In reply to comment #8)
> > Tools/WebKitTestRunner/mac/TestControllerMac.mm:90
> > +        [window makeKeyAndOrderFront:nil];
> 
> Hopefully it's not forced back on screen, so nothing visually blinks and prevents using the computer while tests are running?

No,from my testing the window is not actually forced onscreen.

> > Tools/WebKitTestRunner/mac/TestControllerMac.mm:91
> > +        [NSApp activateIgnoringOtherApps:YES];
> 
> Why is this needed? A comment would probably be of use.

You're right, looks like this was overkill - removed.

Thanks Alexey!
Comment 10 Gavin Barraclough 2013-12-27 11:42:34 PST
Committed revision 161105.