Bug 173166

Summary: CSS transitions added while page is not visible do not start when the page becomes visible
Product: WebKit Reporter: Chris Dumez <cdumez>
Component: CSSAssignee: Chris Dumez <cdumez>
Status: RESOLVED FIXED    
Severity: Normal CC: buildbot, commit-queue, csaavedra, darin, dino, dstockwell, hyatt, jonlee, simon.fraser, webkit-bug-importer, zalan
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
See Also: https://bugs.webkit.org/show_bug.cgi?id=173370
Bug Depends on: 173302    
Bug Blocks:    
Attachments:
Description Flags
WIP Patch
none
Patch
none
Patch none

Chris Dumez
Reported 2017-06-09 09:46:52 PDT
CSS transitions added while page is not visible do not start when the page becomes visible.
Attachments
WIP Patch (6.62 KB, patch)
2017-06-09 09:49 PDT, Chris Dumez
no flags
Patch (9.99 KB, patch)
2017-06-09 10:18 PDT, Chris Dumez
no flags
Patch (16.38 KB, patch)
2017-06-09 10:27 PDT, Chris Dumez
no flags
Chris Dumez
Comment 1 2017-06-09 09:47:27 PDT
Chris Dumez
Comment 2 2017-06-09 09:49:37 PDT
Created attachment 312444 [details] WIP Patch
Chris Dumez
Comment 3 2017-06-09 10:18:54 PDT
Darin Adler
Comment 4 2017-06-09 10:20:49 PDT
Comment on attachment 312449 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=312449&action=review > Source/WebCore/page/animation/ImplicitAnimation.h:58 > + void reset(const RenderStyle* to, CompositeAnimation*); Both arguments should be references rather than pointers. Unless CompositeAnimation* can be null?
Chris Dumez
Comment 5 2017-06-09 10:23:25 PDT
(In reply to Darin Adler from comment #4) > Comment on attachment 312449 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=312449&action=review > > > Source/WebCore/page/animation/ImplicitAnimation.h:58 > > + void reset(const RenderStyle* to, CompositeAnimation*); > > Both arguments should be references rather than pointers. Unless > CompositeAnimation* can be null? OK.
Chris Dumez
Comment 6 2017-06-09 10:27:01 PDT
Darin Adler
Comment 7 2017-06-09 10:28:38 PDT
Comment on attachment 312452 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=312452&action=review > Source/WebCore/page/animation/CompositeAnimation.cpp:176 > m_transitions.set(prop, WTFMove(implicitAnimation)); Not for this patch, I suppose, but a bit peculiar that this uses set rather than add.
Simon Fraser (smfr)
Comment 8 2017-06-09 10:43:18 PDT
Comment on attachment 312452 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=312452&action=review > Source/WebCore/page/animation/CompositeAnimation.cpp:173 > + if (m_suspended && implicitAnimation->hasStyle()) > + implicitAnimation->updatePlayState(AnimPlayStatePaused); I'm slightly concerned about doing this; pausing transitions is not a very well-tested code path (and historically has led to assertions in the state machine). But if tests don't assert, I don't object.
Chris Dumez
Comment 9 2017-06-09 10:44:36 PDT
(In reply to Simon Fraser (smfr) from comment #8) > Comment on attachment 312452 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=312452&action=review > > > Source/WebCore/page/animation/CompositeAnimation.cpp:173 > > + if (m_suspended && implicitAnimation->hasStyle()) > > + implicitAnimation->updatePlayState(AnimPlayStatePaused); > > I'm slightly concerned about doing this; pausing transitions is not a very > well-tested code path (and historically has led to assertions in the state > machine). But if tests don't assert, I don't object. Tests do not assert.
Chris Dumez
Comment 10 2017-06-09 10:49:36 PDT
(In reply to Chris Dumez from comment #9) > (In reply to Simon Fraser (smfr) from comment #8) > > Comment on attachment 312452 [details] > > Patch > > > > View in context: > > https://bugs.webkit.org/attachment.cgi?id=312452&action=review > > > > > Source/WebCore/page/animation/CompositeAnimation.cpp:173 > > > + if (m_suspended && implicitAnimation->hasStyle()) > > > + implicitAnimation->updatePlayState(AnimPlayStatePaused); > > > > I'm slightly concerned about doing this; pausing transitions is not a very > > well-tested code path (and historically has led to assertions in the state > > machine). But if tests don't assert, I don't object. > > Tests do not assert. And to be clear, this code path was already exercised when hiding a page that contains animated CSS transitions. I am now pausing such transitions in the same way when they are created while the page is hidden.
WebKit Commit Bot
Comment 11 2017-06-09 10:52:45 PDT
Comment on attachment 312452 [details] Patch Clearing flags on attachment: 312452 Committed r217997: <http://trac.webkit.org/changeset/217997>
WebKit Commit Bot
Comment 12 2017-06-09 10:52:48 PDT
All reviewed patches have been landed. Closing bug.
Claudio Saavedra
Comment 13 2017-06-14 06:06:31 PDT
(In reply to WebKit Commit Bot from comment #11) > Comment on attachment 312452 [details] > Patch > > Clearing flags on attachment: 312452 > > Committed r217997: <http://trac.webkit.org/changeset/217997> This patch is causing the following test to fail in several platforms: transitions/created-while-suspended.html [ Failure ] See for the failure: https://build.webkit.org/results/GTK%20Linux%2064-bit%20Release%20(Tests)/r218230%20(1716)/transitions/created-while-suspended-pretty-diff.html I suspect that the expectation just needs to be updated?
Darin Adler
Comment 14 2017-06-14 07:26:50 PDT
Seems possible that failure is what Chris fixed in bug 173302.
Claudio Saavedra
Comment 15 2017-06-14 07:42:27 PDT
(In reply to Darin Adler from comment #14) > Seems possible that failure is what Chris fixed in bug 173302. I tested the patch in that bug and the test output is the same, so it doesn't seem to be the case.
Chris Dumez
Comment 16 2017-06-14 08:38:03 PDT
(In reply to Claudio Saavedra from comment #13) > (In reply to WebKit Commit Bot from comment #11) > > Comment on attachment 312452 [details] > > Patch > > > > Clearing flags on attachment: 312452 > > > > Committed r217997: <http://trac.webkit.org/changeset/217997> > > This patch is causing the following test to fail in several platforms: > > transitions/created-while-suspended.html [ Failure ] > > See for the failure: > https://build.webkit.org/results/GTK%20Linux%2064-bit%20Release%20(Tests)/ > r218230%20(1716)/transitions/created-while-suspended-pretty-diff.html > > I suspect that the expectation just needs to be updated? This looks to me like a progression from my patch. Before my patch, the transition that was added while suspended would not actually be resumed when resuming animations. The test would still pass because it relies on internals.animationsAreSuspended() which claims animations were resumed. With my patch, you see an extra: #### Transition ended on element with id: box line after resuming the animations because the transition was *actually* resumed and the animation has time to finish because we wait 8 seconds after resuming the animations: setTimeout(function () { testRunner.notifyDone();}, 8000); So I think this test merely needs rebaselining. However, I think this test should be rewriting so it does not wait 8 seconds, this is way too slow. We can probably finish the test when the transition ends.
Chris Dumez
Comment 17 2017-06-14 08:40:57 PDT
(In reply to Chris Dumez from comment #16) > (In reply to Claudio Saavedra from comment #13) > > (In reply to WebKit Commit Bot from comment #11) > > > Comment on attachment 312452 [details] > > > Patch > > > > > > Clearing flags on attachment: 312452 > > > > > > Committed r217997: <http://trac.webkit.org/changeset/217997> > > > > This patch is causing the following test to fail in several platforms: > > > > transitions/created-while-suspended.html [ Failure ] > > > > See for the failure: > > https://build.webkit.org/results/GTK%20Linux%2064-bit%20Release%20(Tests)/ > > r218230%20(1716)/transitions/created-while-suspended-pretty-diff.html > > > > I suspect that the expectation just needs to be updated? > > This looks to me like a progression from my patch. Before my patch, the > transition that was added while suspended would not actually be resumed when > resuming animations. > The test would still pass because it relies on > internals.animationsAreSuspended() which claims animations were resumed. > > With my patch, you see an extra: > #### Transition ended on element with id: box > > line after resuming the animations because the transition was *actually* > resumed and the animation has time to finish because we wait 8 seconds after > resuming the animations: > setTimeout(function () { testRunner.notifyDone();}, 8000); > > So I think this test merely needs rebaselining. However, I think this test > should be rewriting so it does not wait 8 seconds, this is way too slow. We > can probably finish the test when the transition ends. Will find some time today to improve the test.
Chris Dumez
Comment 18 2017-06-14 09:52:24 PDT
(In reply to Chris Dumez from comment #17) > (In reply to Chris Dumez from comment #16) > > (In reply to Claudio Saavedra from comment #13) > > > (In reply to WebKit Commit Bot from comment #11) > > > > Comment on attachment 312452 [details] > > > > Patch > > > > > > > > Clearing flags on attachment: 312452 > > > > > > > > Committed r217997: <http://trac.webkit.org/changeset/217997> > > > > > > This patch is causing the following test to fail in several platforms: > > > > > > transitions/created-while-suspended.html [ Failure ] > > > > > > See for the failure: > > > https://build.webkit.org/results/GTK%20Linux%2064-bit%20Release%20(Tests)/ > > > r218230%20(1716)/transitions/created-while-suspended-pretty-diff.html > > > > > > I suspect that the expectation just needs to be updated? > > > > This looks to me like a progression from my patch. Before my patch, the > > transition that was added while suspended would not actually be resumed when > > resuming animations. > > The test would still pass because it relies on > > internals.animationsAreSuspended() which claims animations were resumed. > > > > With my patch, you see an extra: > > #### Transition ended on element with id: box > > > > line after resuming the animations because the transition was *actually* > > resumed and the animation has time to finish because we wait 8 seconds after > > resuming the animations: > > setTimeout(function () { testRunner.notifyDone();}, 8000); > > > > So I think this test merely needs rebaselining. However, I think this test > > should be rewriting so it does not wait 8 seconds, this is way too slow. We > > can probably finish the test when the transition ends. > > Will find some time today to improve the test. https://bugs.webkit.org/show_bug.cgi?id=173370
Note You need to log in before you can comment on or make changes to this bug.