Closed
Bug 1471583
Opened 7 years ago
Closed 6 years ago
Intermittent /css/css-backgrounds/border-image-020.xht | Testing http://web-platform.test:8000/css/css-backgrounds/border-image-020.xht == http://web-platform.test:8000/css/reference/ref-filled-green-100px-square.xht
Categories
(Core :: Layout, defect, P5)
Core
Layout
Tracking
()
RESOLVED
FIXED
mozilla63
Tracking | Status | |
---|---|---|
firefox63 | --- | fixed |
People
(Reporter: intermittent-bug-filer, Assigned: ccoroiu)
References
Details
(Keywords: intermittent-failure, Whiteboard: [retriggered][stockwell fixed:product])
Attachments
(3 files, 3 obsolete files)
Filed by: ccoroiu [at] mozilla.com
https://treeherder.mozilla.org/logviewer.html#?job_id=185136318&repo=autoland
https://queue.taskcluster.net/v1/task/JQYn8rIbTMGnJdnBQZzSsg/runs/0/artifacts/public/logs/live_backing.log
https://hg.mozilla.org/mozilla-central/raw-file/tip/layout/tools/reftest/reftest-analyzer.xhtml#logurl=https://queue.taskcluster.net/v1/task/JQYn8rIbTMGnJdnBQZzSsg/runs/0/artifacts/public/logs/live_backing.log&only_show_unexpected=1
[task 2018-06-27T11:55:17.156Z] 11:55:17 INFO - TEST-START | /css/css-backgrounds/border-image-020.xht
[task 2018-06-27T11:55:17.163Z] 11:55:17 INFO - PID 5909 | 1530100517159 Marionette INFO Testing http://web-platform.test:8000/css/css-backgrounds/border-image-020.xht == http://web-platform.test:8000/css/reference/ref-filled-green-100px-square.xht
[task 2018-06-27T11:55:17.268Z] 11:55:17 INFO - PID 5909 | 1530100517264 Marionette DEBUG [4294967297] Waiting for page load of http://web-platform.test:8000/css/css-backgrounds/border-image-020.xht
[task 2018-06-27T11:55:17.270Z] 11:55:17 INFO - PID 5909 | ++DOMWINDOW == 96 (0xe3e98000) [pid = 6009] [serial = 96] [outer = 0xf7048380]
[task 2018-06-27T11:55:17.334Z] 11:55:17 INFO - PID 5909 | 1530100517333 Marionette DEBUG [4294967297] flushRendering false
[task 2018-06-27T11:55:17.342Z] 11:55:17 INFO - PID 5909 | 1530100517340 Marionette INFO Found 7296 pixels different, maximum difference per channel 255
[task 2018-06-27T11:55:17.402Z] 11:55:17 INFO - TEST-UNEXPECTED-FAIL | /css/css-backgrounds/border-image-020.xht | Testing http://web-platform.test:8000/css/css-backgrounds/border-image-020.xht == http://web-platform.test:8000/css/reference/ref-filled-green-100px-square.xht
[task 2018-06-27T11:55:17.403Z] 11:55:17 INFO - REFTEST IMAGE 1 (TEST): 
[task 2018-06-27T11:55:17.404Z] 11:55:17 INFO - REFTEST IMAGE 2 (REFERENCE): 
[task 2018-06-27T11:55:17.405Z] 11:55:17 INFO - TEST-INFO took 242ms
[task 2018-06-27T11:55:17.462Z] 11:55:17 INFO - PID 5909 | ###!!! [Parent][RunMessage] Error: Channel closing: too late to send/recv, messages will be lost
[task 2018-06-27T11:55:17.462Z] 11:55:17 INFO - PID 5909 | [Child 6009, Main Thread] WARNING: NS_ENSURE_TRUE(maybeContext) failed: file /builds/worker/workspace/build/src/xpcom/threads/nsThread.cpp, line 794
[task 2018-06-27T11:55:17.499Z] 11:55:17 INFO - PID 5909 | 1530100517487 Marionette INFO Stopped listening on port 2828
[task 2018-06-27T11:55:17.749Z] 11:55:17 INFO - PID 5909 | --DOCSHELL 0xe7c75c00 == 0 [pid = 6009] [id = {eda0c5fd-196f-4b78-b3fb-48209f484946}]
[task 2018-06-27T11:55:17.751Z] 11:55:17 INFO - PID 5909 | --DOMWINDOW == 95 (0xe248be00) [pid = 6009] [serial = 70] [outer = (nil)] [url = http://web-platform.test:8000/css/css-backgrounds/reference/background-size-028-ref.xht]
[task 2018-06-27T11:55:17.751Z] 11:55:17 INFO - PID 5909 | --DOMWINDOW == 94 (0xe2489a00) [pid = 6009] [serial = 69] [outer = (nil)] [url = http://web-platform.test:8000/css/css-backgrounds/background-size-027.html]
[task 2018-06-27T11:55:17.753Z] 11:55:17 INFO - PID 5909 | --DOMWINDOW == 93 (0xe2489400) [pid = 6009] [serial = 68] [outer = (nil)] [url = http://web-platform.test:8000/css/css-backgrounds/reference/background-size-027-ref.xht]
[task 2018-06-27T11:55:17.753Z] 11:55:17 INFO - PID 5909 | --DOMWINDOW == 92 (0xe248ae00) [pid = 6009] [serial = 67] [outer = (nil)] [url = http://web-platform.test:8000/css/css-backgrounds/background-size-026.html]
[task 2018-06-27T11:55:17.755Z] 11:55:17 INFO - PID 5909 | --DOMWINDOW == 91 (0xe248a400) [pid = 6009] [serial = 66] [outer = (nil)] [url = http://web-platform.test:8000/css/css-backgrounds/reference/background-size-026-ref.xht]
[task 2018-06-27T11:55:17.755Z] 11:55:17 INFO - PID 5909 | --DOMWINDOW == 90 (0xe3e9c200) [pid = 6009] [serial = 65] [outer = (nil)] [url = http://web-platform.test:8000/css/css-backgrounds/background-size-025.html]
[task 2018-06-27T11:55:17.757Z] 11:55:17 INFO - PID 5909 | --DOMWINDOW == 89 (0xf7071600) [pid = 6009] [serial = 64] [outer = (nil)] [url = http://web-platform.test:8000/css/css-backgrounds/reference/background-size-025-ref.xht]
[task 2018-06-27T11:55:17.760Z] 11:55:17 INFO - PID 5909 | --DOMWINDOW == 88 (0xeaabdc00) [pid = 6009] [serial = 63] [outer = (nil)] [url = http://web-platform.test:8000/css/css-backgrounds/background-size-021.html]
[task 2018-06-27T11:55:17.760Z] 11:55:17 INFO - PID 5909 | --DOMWINDOW == 87 (0xe3e9c400) [pid = 6009] [serial = 62] [outer = (nil)] [url = http://web-platform.test:8000/css/css-backgrounds/reference/background-size-021-ref.html]
Assignee | ||
Comment 1•7 years ago
|
||
Did some retriggers on the following range:
https://treeherder.mozilla.org/#/jobs?repo=autoland&selectedJob=185709589&filter-searchStr=Linux%20debug%20Web%20platform%20tests%20with%20e10s%20test-linux32%2Fdebug-web-platform-tests-reftests-e10s-1%20W-e10s(Wr1)&tochange=e922b59832f1be645761b4c67a479880bddb4b25&fromchange=378b43fe1658
And it seems that the failure started from here:
https://treeherder.mozilla.org/#/jobs?repo=autoland&revision=12a849d78301b32f4d800dfe50944fc6f4f810b4&filter-searchStr=Linux%20debug%20Web%20platform%20tests%20with%20e10s%20test-linux32%2Fdebug-web-platform-tests-reftests-e10s-1%20W-e10s(Wr1)&selectedJob=185716425
Bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1469000
:emilio, could your push be the culprit?
:jmaher could you please take a look?
Flags: needinfo?(jmaher)
Flags: needinfo?(emilio)
Whiteboard: [retriggered]
Assignee | ||
Updated•7 years ago
|
Assignee: nobody → ccoroiu
Comment 2•7 years ago
|
||
Seems somewhat unlikely. My patch deals with <img> invalidation, not any sort of border-image.
The testcase does have an <img>, but it's the only thing that actually gets painted correctly. Furthermore, the <img> in the test-case doesn't have any of the interesting attributes like sizes="", so it's actually not affected by my change.
So my patch is definitely not the root cause of this, though maybe it has uncovered an existing issue? I'm not sure. We do have a lot of other background/border related WPT tests intermittently failing though... :(
Flags: needinfo?(emilio)
Comment 3•7 years ago
|
||
I did more retriggers and unless there is something else going on, it does look like bug 1469000 is causing a lot of related regressions in wpt1 (including this bug).
with 50+ instances and no failures on many pushes prior, and then bug 1469000 lands and we have many failures, it is suspect:
https://treeherder.mozilla.org/#/jobs?repo=autoland&filter-searchStr=Linux%20debug%20Web%20platform%20tests%20with%20e10s%20test-linux32%2Fdebug-web-platform-tests-reftests-e10s-1%20W-e10s(Wr1)&fromchange=378b43fe1658&tochange=12a849d78301b32f4d800dfe50944fc6f4f810b4
Any issues that could be unrelated are:
* infra changes (stuff out of tree like aws machines we run on)
* builds - they are inconsistent and sometimes we clobber or don't
:emilio- it could be that these tests are being affected by other tests in the same browser session. Can you look into this or help us determine a path for correcting these failures?
Flags: needinfo?(jmaher) → needinfo?(emilio)
Comment 4•7 years ago
|
||
This condition was effectively removed in bug 1469000 because I didn't think it
was necessary at all. But looks like either it is (but I don't understand why),
or it's wallpapering something else...
Looks like this was introduced in bug 624647 and there's no comment related to
why it is relevant.
In any case it's harmless, as we'd overinvalidate when it's hit.
Joel, my patch removed this condition, which to this point still looks useless to me. But it's definitely hit in those tests (because the images are not constrained). Could you give this patch a few retriggers and tell me if this fixes the issue?
Flags: needinfo?(emilio) → needinfo?(jmaher)
Attachment #8988986 -
Flags: feedback?(jmaher)
Comment hidden (Intermittent Failures Robot) |
Comment 6•7 years ago
|
||
Comment on attachment 8988986 [details] [diff] [review]
Preserve the behavior of bailing out from GetSourceToDestTransform if any direction of the intrinsic size matches the destination rect.
Review of attachment 8988986 [details] [diff] [review]:
-----------------------------------------------------------------
this doesn't seem to make things much better:
https://treeherder.mozilla.org/#/jobs?repo=try&revision=9933e871c7790691bec49be4727f5743dfb04431
Attachment #8988986 -
Flags: feedback?(jmaher)
Updated•7 years ago
|
Flags: needinfo?(jmaher)
Comment 7•7 years ago
|
||
So I took a look at this, and this seems a problem with WPT's reftest harness I think.
I took a look with Pernosco and the last paint didn't have the image available yet as expected.
The relevant logic for WPT is testing/marionette/listener.js::reftestWait, and for reftests it is layout/tools/reftest/reftest-content.js.
There's something fishy since most CSS images don't block onload. I suspect IsMozAfterPaintPending, which is not just a getter[1] may have something to do with it, but not sure yet.
[1]: https://searchfox.org/mozilla-central/rev/1193ef6a61cb6e350460eb2e8468184d3cb0321d/layout/base/nsPresContext.cpp#146
I'll try to run the test under reftests and under WPT and see what's the difference that makes reftest.jsm wait properly.
Flags: needinfo?(emilio)
Comment 8•7 years ago
|
||
This sounds like the same underlying issue as what jgraham was hinting at in bug 1472434 comment 4, FWIW. (And bug 1381899 as well, possibly.)
See Also: → 1472434
Comment hidden (Intermittent Failures Robot) |
Comment 10•7 years ago
|
||
Ok, so I tracked this down in Pernosco, and the logic for waiting in WPT is sound (yay!).
There's a deeper issue though (nay! :/).
So what's going on is that the reftest harness goes through all this trouble of waiting for MozAfterPaint and such until there are no more paints left, but there may be image decodes left.
That's supposed to be handled by the updateLayerTree() call in[1], which ends up in [2], and passes the SYNC_DECODE_IMAGES flag around.
But that doesn't cause already-painted but not-yet-invalidated parts of the page to run. So the parts of the page without an invalidation won't go through that codepath and thus won't sync-decode. In particular, the border-image isn't invalidated yet by the time we get there, so no nsCSSBorderImageRenderer gets created, no image gets sync-decoded... etc.
I'm not quite sure how this is supposed to work. The obvious thing to do would be to do an invalidation of the whole page, but that may wallpaper bugs. We could try to return true for isMozAfterPaintPending if there are pending image decodes...
Matt, how does the later sound? Any other ideas?
I don't yet know where to look at whether there are pending image decoding tasks, but I'll figure that out.
[1]: https://searchfox.org/mozilla-central/rev/28daa2806c89684b3dfa4f0b551db1d099dda7c2/testing/marionette/listener.js#1675
[2]: https://searchfox.org/mozilla-central/rev/28daa2806c89684b3dfa4f0b551db1d099dda7c2/layout/base/nsLayoutUtils.cpp#3550
Flags: needinfo?(emilio) → needinfo?(matt.woodrow)
Comment 11•7 years ago
|
||
So, I talked with Andrew and he was fine with the proposed solution.
A bit more history on this... This is the exact problem that bug 697230 / bug 695765 were trying to solve, though we reverted that again at some other point... Bug 695763 is also relevant.
Comment 12•7 years ago
|
||
https://treeherder.mozilla.org/#/jobs?repo=try&revision=20cda5a47f876709f3326299e0e43cfc639d4482 is a very dumb attempt at this...
Not sure how it'll turn out just yet. It'd probably need a way to not expose DecodePool.h around, though maybe that's just fine.
Comment 13•7 years ago
|
||
Also, we probably need to also wait for image loads, ideally, I'd think, given I don't think there's anything that waits for any of the image loads...
Probably not too hard to do from the CSS image loader. Also it's way less likely to show up I'd guess given reftests are local. But still worth doing, probably in another bug, probably... I wonder why / when did we revert bug 697230.
Comment 14•7 years ago
|
||
Looks like it works, modulo other failures that are due to other patches on my queue. Joel, is there any chance you could give https://hg.mozilla.org/try/rev/fa8ed208b28047035de7b4dc8f36a402b673bae9 a try? Does it improve the situation here?
Flags: needinfo?(jmaher)
Comment 15•7 years ago
|
||
Well, the sooner I speak, the sooner the APZ tests and such start failing. Anyway, those are because I'm changing the existing isMozAfterPaintPending function, so I may have broken a few of those which rely on specific (pre-existing) semantics.
But hey, reftests seem green!
Comment 17•7 years ago
|
||
(In reply to Emilio Cobos Álvarez (:emilio) from comment #10)
> Ok, so I tracked this down in Pernosco, and the logic for waiting in WPT is
> sound (yay!).
>
> There's a deeper issue though (nay! :/).
>
> So what's going on is that the reftest harness goes through all this trouble
> of waiting for MozAfterPaint and such until there are no more paints left,
> but there may be image decodes left.
>
> That's supposed to be handled by the updateLayerTree() call in[1], which
> ends up in [2], and passes the SYNC_DECODE_IMAGES flag around.
>
> But that doesn't cause already-painted but not-yet-invalidated parts of the
> page to run. So the parts of the page without an invalidation won't go
> through that codepath and thus won't sync-decode. In particular, the
> border-image isn't invalidated yet by the time we get there, so no
> nsCSSBorderImageRenderer gets created, no image gets sync-decoded... etc.
>
> I'm not quite sure how this is supposed to work. The obvious thing to do
> would be to do an invalidation of the whole page, but that may wallpaper
> bugs. We could try to return true for isMozAfterPaintPending if there are
> pending image decodes...
>
> Matt, how does the later sound? Any other ideas?
>
> I don't yet know where to look at whether there are pending image decoding
> tasks, but I'll figure that out.
>
> [1]:
> https://searchfox.org/mozilla-central/rev/
> 28daa2806c89684b3dfa4f0b551db1d099dda7c2/testing/marionette/listener.js#1675
> [2]:
> https://searchfox.org/mozilla-central/rev/
> 28daa2806c89684b3dfa4f0b551db1d099dda7c2/layout/base/nsLayoutUtils.cpp#3550
What do you mean by the run bit of 'parts of the page to run'? Do you mean we don't call nsDisplayBorder::Paint?
The general idea is that that all paints during reftests are for the whole screen (full display list, full layerization, full update to the compositor), and then we only copy a subset of the pixels into the reftest <canvas> (based on the rectangle passed to DoDrawWindow).
I'd expect the un-decoded (and un-invalidated) nsDisplayBorder to be created, and put into a layer, and we should be checking if it is valid by calling nsDisplayBorder::ComputeInvalidationRegion.
I'd expect that to return an invalidation, since ShouldInvalidateToSyncDecodeImages() should be returning true if the display item wants to paint an image, but hasn't yet done so successfully (that is, the rendering of the display item will change once its image is decoded). We're in a sync decode paint, so that condition should be true, and we'd add the bounds of the border item to the invalid area for the layer, and then call nsDisplayBorder::Paint later on.
It's possible that the current drawWindow call is only copying pixels for other areas, and won't copy pixels for the newly drawn border-image, but the invalidation should also have triggered a new MozAfterPaint, so I'd expect another call to drawWindow to copy the remaining changed pixels.
Triggering whole screen invalidations definitely hides other bugs, the partial updates are a good way to test our invalidation code and a lot of tests have been written with this in mind.
Flags: needinfo?(matt.woodrow)
Comment 18•7 years ago
|
||
So Matt helped me out in explaining how this should all work.
What's going on is the following:
* In UpdateLayerTree(), which is supposed to sync-decode images, we end up skipping the whole paint because the display lists are identical.
* Display lists are _not_ supposed to be identical, and should get invalidated in:
https://searchfox.org/mozilla-central/rev/c579ce13ca7864c5df9711eda730ceb00501aed3/layout/painting/nsDisplayListInvalidation.h#203
if the image is not ready before.
* However mLastDrawResult is SUCCESS, because nsStyleImage::StartDecoding returns true, and thus frameReady is true:
https://searchfox.org/mozilla-central/rev/c579ce13ca7864c5df9711eda730ceb00501aed3/layout/painting/nsImageRenderer.cpp#126
(so we don't pick the NOT_READY path).
So at that point:
mImage->IsComplete() -> false
RasterImage::mHasBeenDecoded -> false
frameComplete -> true
The frame seems right though, inspecting StartDecoding(), the surface has the right pixels. The following is from the refresh driver tick _before_ the UpdateLayerTree call:
(pernosco) bt
#0 mozilla::image::RasterImage::RequestDecodeForSizeInternal (this=0x7f3d5aae22e0, aSize=..., aFlags=6) at /builds/worker/workspace/build/src/image/RasterImage.cpp:1183
#1 0x00007f3d5c6feba3 in mozilla::image::RasterImage::StartDecodingWithResult (this=<optimized out>, aFlags=<optimized out>) at /builds/worker/workspace/build/src/image/RasterImage.cpp:1137
#2 0x00007f3d5c705097 in imgRequestProxy::StartDecodingWithResult (this=0x5e05204fd100, aFlags=4) at /builds/worker/workspace/build/src/image/imgRequestProxy.cpp:592
#3 0x00007f3d5dcde582 in mozilla::nsImageRenderer::PrepareImage (this=this@entry=0x7fffdfebf960) at /builds/worker/workspace/build/src/layout/painting/nsImageRenderer.cpp:126
#4 0x00007f3d5dc950f4 in nsCSSBorderImageRenderer::CreateBorderImageRenderer
(pernosco) p result
$95 = {mSurface = {mDrawableRef = {mFrame = [(mozilla::image::imgFrame *) 0x3fde75847020], mRef = {mStorage = "\340\060\201u\336?\000\000\000\300\204u\336?\000\000\220\001\000\000=\177\000\000\001\"\256Z=\177\000", mIsSome = 1 '\001'}}, mProvider = [(mozilla::image::ISurfaceProvider *) 0x0], mHaveSurface = true}, mMatchType = mozilla::image::MatchType::EXACT, mSuggestedSize = {<mozilla::gfx::BaseSize<int, mozilla::gfx::IntSizeTyped<mozilla::gfx::UnknownUnits> >> = {{{width = 0, height = 0}, components = {0, 0}}}, <mozilla::gfx::UnknownUnits> = {<No data fields>}, <No data fields>}}
(pernosco) p result.mSurface.mDrawableRef.mFrame.mRawPtr->mRawSurface.mRawPtr
$69 = (mozilla::gfx::SourceSurfaceVolatileData *) 0x3fde758130e0
[..]
(pernosco) p (unsigned char*) $69->mVBuf.mRawPtr->mBuf
$83 = (unsigned char *) 0x3fde7584c000 ""
(pernosco) p $83[0]
$84 = 0 '\000'
(pernosco) p $83[1]
$85 = 128 '\200'
(pernosco) p $83[2]
$86 = 0 '\000'
(pernosco) p $83[3]
$87 = 255 '\377'
Yet the reftest screenshot doesn't show the green pixels at all! mLockedSurface.mRawData also looks fine.
Not sure what's up with that, whether the assumptions the display list code is doing about imagelib wrong, or the "identical display list" path via EndEmptyTransaction is wrong if we want to actually sync all our stuff over to the compositor?
Comment 19•7 years ago
|
||
Ok, so with a lot of help from Matt and Timothy I think I finally understand what's going on.
Timothy confirmed that the situation above is perfectly normal. Matt helped me move around all the FLB invalidation code and the compositor stuff.
I believe now that what's going on here is an invalidation bug. Basically, we're completely failing to invalidate display items that change as the new image becomes available.
Current understanding of what's going on:
* We paint the image but it's not decoded yet, so we store a NOT_READY in the display item geometry, but it has the correct size so we move on.
* We end up painting again, before the image decode notification arrives because, e.g., something inside changed. But now the image is decoded, so we paint and store SUCCESS in the image geometry. But we _don't_ invalidate the relevant area, so we never update the compositor.
* We try to take a screenshot for reftests since we're not aware of more paints pending, and normally we rely on the sync decode images invalidation stuff to mark the frames dirty:
https://searchfox.org/mozilla-central/rev/c579ce13ca7864c5df9711eda730ceb00501aed3/layout/painting/RetainedDisplayListBuilder.cpp#57
* But in this case the frame is not invalidated, because we already drew with SUCCESS so that code assumes it's up-to-date.
I need to get a better grasp at the order in which the invalidation stuff is called, but I suspect we need to store the last draw result in the display item itself and invalidate if it's different from the geometry's display item. Does that sound right to you Matt?
Flags: needinfo?(matt.woodrow)
Comment 20•7 years ago
|
||
That all makes sense so far, but what happens to the image decode notification that is in the event queue?
My expectation is that should run, invalidate the border frame, and we'd start returning true from isMozzAfterPaintPending again. Then reftests should continue to wait for the next paint, and that one should repaint the border properly.
Is there a race here where we temporarily report no paints pending and reftests packs up and goes home?
Flags: needinfo?(matt.woodrow)
Comment 21•7 years ago
|
||
(In reply to Matt Woodrow (:mattwoodrow) from comment #20)
> That all makes sense so far, but what happens to the image decode
> notification that is in the event queue?
>
> My expectation is that should run, invalidate the border frame, and we'd
> start returning true from isMozzAfterPaintPending again. Then reftests
> should continue to wait for the next paint, and that one should repaint the
> border properly.
>
> Is there a race here where we temporarily report no paints pending and
> reftests packs up and goes home?
That is exactly right, we don't wait for the decoding tasks to notify, thus the patch mentioned in comment 14.
After talking with tn, probably the easiest patch would be to stop recording a successful draw for now, then trying to remove the StartDecoding stuff (probably in another bug) since it's not really useful if the image has been painted before being ready already.
Afterwards trying to figure out a better way to deal with pending decode requests than sync-decoding would be really nice, we could probably start making async decoding the default for drawWindow and make the reftests explicitly opt-in.
In any case, that's followup work I'd say.
Comment 22•7 years ago
|
||
there are still many failures in the wr1 job on linux debug:
https://treeherder.mozilla.org/#/jobs?repo=try&revision=d84cd6c317236dfae6ffe4fb40b90f03c4f9cd53&filter-searchStr=reftest%20%20e10s%20wr1
but none of them are this specific test. Given that the fix is generic (at the layout level, not the test level), I am inclined to say this isn't helping a whole lot. Maybe there are other cases for the failures in -002, -017, -018, and -019 tests which would them mean that -020 is fixed.
Flags: needinfo?(jmaher)
Comment 23•7 years ago
|
||
Yeah, I would've expected not recording a successful draw here to fix it, but there are still background-image related failures in:
https://treeherder.mozilla.org/#/jobs?repo=try&revision=fcaff8fca519c7cde02f538c247f1dc2b35c6b94&selectedJob=187378519
I tried removing the StartDecoding call, which should also be green if the "mark frames without a successful draw dirty" stuff worked right, but that has even more orange:
https://treeherder.mozilla.org/#/jobs?repo=try&revision=2fb7804a951e08093ea80b372c4e3dd221f4d0f3&selectedJob=187378185
So more debugging awaits.
Comment 24•7 years ago
|
||
I've tried to unsuccessfully reproduce the same kind of failures locally under
rr with this patch applied, so that's a good sign.
This should fix the case where we don't invalidate from AttemptPartialUpdate
while trying to sync-decode.
This is a clear part of the problem, though not sure yet if it'll fix all the
issues we see in these tests. In any case I want to investigate those
separately.
Comment 25•7 years ago
|
||
Comment on attachment 8991293 [details]
Bug 1471583: Don't record a successful draw result if the image is not complete yet. r=tnikkel
Timothy Nikkel (:tnikkel) has approved the revision.
https://phabricator.services.mozilla.com/D2068
Attachment #8991293 -
Flags: review+
Comment 26•7 years ago
|
||
Pushed by emilio@crisal.io:
https://hg.mozilla.org/integration/mozilla-inbound/rev/9851707b13cb
Don't record a successful draw result if the image is not complete yet. r=tnikkel
Assignee | ||
Comment 27•7 years ago
|
||
Backed out changeset 9851707b13cb (bug 1471583) for Wr4 failures in multiple files e.g. css/CSS2/backgrounds/background-root-010.xht
Backout: https://hg.mozilla.org/integration/mozilla-inbound/rev/9235548deaff3dafab06626b8ebe909ee4bdca72
Failure push: https://treeherder.mozilla.org/#/jobs?repo=mozilla-inbound&revision=9851707b13cbcc41a970d677eab3a32d320e81dd
Failure log:https://treeherder.mozilla.org/logviewer.html#?job_id=187847624&repo=mozilla-inbound&lineNumber=5853
task 2018-07-12T14:51:15.840Z] 14:51:15 INFO - TEST-START | /css/CSS2/backgrounds/background-root-010.xht
[task 2018-07-12T14:51:15.848Z] 14:51:15 INFO - PID 1288 | 1531407075837 Marionette INFO Testing http://web-platform.test:8000/css/CSS2/backgrounds/background-root-010.xht == http://web-platform.test:8000/css/CSS2/backgrounds/background-root-010-ref.xht
[task 2018-07-12T14:51:15.848Z] 14:51:15 INFO - PID 1288 | 1531407075841 Marionette DEBUG [4294967297] Waiting for page load of http://web-platform.test:8000/css/CSS2/backgrounds/background-root-010-ref.xht
[task 2018-07-12T14:51:15.885Z] 14:51:15 INFO - PID 1288 | 1531407075874 Marionette DEBUG [4294967297] flushRendering false
[task 2018-07-12T14:51:15.887Z] 14:51:15 INFO - PID 1288 | 1531407075883 Marionette DEBUG [4294967297] Waiting for page load of http://web-platform.test:8000/css/CSS2/backgrounds/background-root-010.xht
[task 2018-07-12T14:51:15.915Z] 14:51:15 INFO - PID 1288 | 1531407075910 Marionette DEBUG [4294967297] flushRendering true
[task 2018-07-12T14:51:15.923Z] 14:51:15 INFO - PID 1288 | 1531407075918 Marionette INFO Found 3570 pixels different, maximum difference per channel 255
[task 2018-07-12T14:51:15.973Z] 14:51:15 INFO - TEST-UNEXPECTED-FAIL | /css/CSS2/backgrounds/background-root-010.xht | Testing http://web-platform.test:8000/css/CSS2/backgrounds/background-root-010.xht == http://web-platform.test:8000/css/CSS2/backgrounds/background-root-010-ref.xht
[task 2018-07-12T14:51:15.974Z] 14:51:15 INFO - REFTEST IMAGE 1 (TEST): 
[task 2018-07-12T14:51:15.977Z] 14:51:15 INFO - REFTEST IMAGE 2 (REFERENCE): 
[task 2018-07-12T14:51:15.977Z] 14:51:15 INFO - TEST-INFO took 114ms
[task 2018-07-12T14:51:15.999Z] 14:51:15 INFO - PID 1288 | 1531407075992 Marionette INFO Stopped listening on port 2828
[task 2018-07-12T14:51:16.467Z] 14:51:16 INFO - Browser exited with return code 0
[task 2018-07-12T14:51:16.470Z] 14:51:16 WARNING - u'runner_teardown': ()
[task 2018-07-12T14:51:16.486Z] 14:51:16 INFO - Setting up ssl
[task 2018-07-12T14:51:16.523Z] 14:51:16 INFO - certutil |
[task 2018-07-12T14:51:16.543Z] 14:51:16 INFO - certutil |
[task 2018-07-12T14:51:16.564Z] 14:51:16 INFO - certutil |
[task 2018-07-12T14:51:16.564Z] 14:51:16 INFO - Certificate Nickname Trust Attributes
[task 2018-07-12T14:51:16.565Z] 14:51:16 INFO - SSL,S/MIME,JAR/XPI
[task 2018-07-12T14:51:16.565Z] 14:51:16 INFO -
[task 2018-07-12T14:51:16.565Z] 14:51:16 INFO - web-platform-tests CT,,
[task 2018-07-12T14:51:16.565Z] 14:51:16 INFO -
[task 2018-07-12T14:51:16.613Z] 14:51:16 INFO - Application command: /builds/worker/workspace/build/application/firefox/firefox --marionette about:blank -profile /tmp/tmpK34RCy.mozrunner
Flags: needinfo?(emilio)
Comment hidden (Intermittent Failures Robot) |
Comment hidden (Intermittent Failures Robot) |
Comment 30•7 years ago
|
||
So I got a bit stuck debugging those... They repro rather easily with rr, and everything seems to happen as expected in a reftest I've been debugging today with my patch applied:
* The invalidation region is correct.
* We sync-decode and paint the images.
* The transactions arrive in the correct order to the parent process, and the child process waits before returning from updateLayerTree() via WaitOnTransactionProcessed.
So I'm a bit out of my depth here...
Comment hidden (Intermittent Failures Robot) |
(In reply to Emilio Cobos Álvarez (:emilio) from comment #30)
> So I got a bit stuck debugging those... They repro rather easily with rr,
> and everything seems to happen as expected in a reftest I've been debugging
> today with my patch applied:
https://pernos.co/debug/cttri8vVcetKzW28p212kA/index.html
Comment hidden (Intermittent Failures Robot) |
Comment hidden (Intermittent Failures Robot) |
Blocks: 1471553
Comment hidden (Intermittent Failures Robot) |
Comment 36•7 years ago
|
||
Update:
There have been 87 failures in the last week:
- linux64 /debug: 51
- linux32 / debug: 21
- linux64 / asan: 14
- linux64 / pgo: 1
Recent log file:
https://treeherder.mozilla.org/logviewer.html#?job_id=189423671&repo=mozilla-inbound&lineNumber=19835
Reftest analyzer:
https://hg.mozilla.org/mozilla-central/raw-file/tip/layout/tools/reftest/reftest-analyzer.xhtml#logurl=https://queue.taskcluster.net/v1/task/ZxVzNKOLTJydn7oFAnKFig/runs/0/artifacts/public/logs/live_backing.log&only_show_unexpected=1
Comment hidden (Intermittent Failures Robot) |
Comment hidden (Intermittent Failures Robot) |
Comment hidden (Intermittent Failures Robot) |
Comment 40•7 years ago
|
||
Emilio, there are 2 other bugs depending on this one that have [stockwell disable-recommended].
Is there something you can do to fix it or we should go ahead and disable?
Comment hidden (Intermittent Failures Robot) |
Comment hidden (Intermittent Failures Robot) |
Comment hidden (Intermittent Failures Robot) |
Comment 44•7 years ago
|
||
I got slightly stuck here, as in, not knowing where to look at.
Failures are easy to reproduce if you run the css backgrounds tests on rr chaos mode (or, see comment 32 for a pernosco recording, maybe talk to roc if you don't have access already). It's also easier to reproduce if you evict stuff from the image cache more often (with ChaosFeature::ImageCache) and with memory pressure notifications and such.
As far as my limited understanding of this goes, everything is happening as expected when https://phabricator.services.mozilla.com/D2068 is applied: UpdateLayerTree() ends up sync-decoding and drawing both images, the invalidation regions look fine (we invalidate the whole background / border area, etc...).
The OMTP code seems to be correctly buffering the messages and sending them before WaitOnTransactionProcessed...
Also, the fact that there are similar failures in WR in a couple other bugs make me really suspicious about the bug being in compositor / OMTP / FLB.
Matt, Timothy, is there any chance any of you could take a look (or know someone who could) to see if I've missed something? My next idea is just trying to switch off various bits (like OMTP, RDL, etc.) and do a bunch of retriggers to try to pinpoint something...
https://hg.mozilla.org/try/rev/311cdde6a7e8b39e61bb04a962ee224fad7b174b is a commit I've been using to repro this more easily, on top of the above phabricator revision. though it's not really required.
Flags: needinfo?(tnikkel)
Flags: needinfo?(matt.woodrow)
Comment hidden (Intermittent Failures Robot) |
Comment 46•7 years ago
|
||
https://treeherder.mozilla.org/#/jobs?repo=mozilla-inbound&filter-resultStatus=testfailed&filter-resultStatus=busted&filter-resultStatus=exception&filter-classifiedState=unclassified&selectedJob=191055902
https://treeherder.mozilla.org/logviewer.html#?job_id=191055902&repo=mozilla-inbound&lineNumber=13247
[task 2018-07-31T07:15:20.695Z] 07:15:20 INFO - TEST-UNEXPECTED-FAIL | /css/css-backgrounds/border-image-017.xht | Testing http://web-platform.test:8000/css/css-backgrounds/border-image-017.xht == http://web-platform.test:8000/css/reference/ref-filled-green-100px-square.xht
Comment hidden (Intermittent Failures Robot) |
Comment hidden (Intermittent Failures Robot) |
Comment 49•7 years ago
|
||
There were a few failures in the pernosco link in comment #32, but I looked at the last one, since it was the most visibly wrong (background-position-141.xht).
It looks like we get everything painted in the child process via a call to updateLayerTree which paints with the sync decode, and that sends the correct pixels to the compositor, and we notifiy the parent process that it can now snapshot.
Before the parent process can take the snapshot though, another paint happens in the child (from a vsync notification).
In this follow-up paint, we still think the image hasn't decoded (nsStyleImage::IsComplete returns false because we don't have the STATUS_FRAME_COMPLETE flag).
There's no sync decode flag this time (since it's a regular paint) so we just don't paint the blue image, and the red image underneath is now visible again. This layer update also gets sent to the compositor, and is received before the parent process requests a snapshot.
The parent process now requests the snapshot from the compositor, and gets the broken-didn't-sync-decode pixels from the vsync paint, and we fail the test.
When we do a sync decode, we probably need to also synchronously update the result of nsStyleImage::IsComplete, since it seems like the notification updating that is racing with the next paint (which is likely already in the event queue when the sync decode happens). I don't know the imglib notification code at all, so haven't tracked that bit down yet to confirm.
Andrew, does that sound possible?
Updated•7 years ago
|
Flags: needinfo?(matt.woodrow) → needinfo?(aosmond)
Comment 50•7 years ago
|
||
Roc pointed out that pernosco URLs let you link to specific moments in time, so attaching this:
https://pernos.co/debug/cttri8vVcetKzW28p212kA/index.html#{f:{m:[2820338,114869],t:[246,3013],f:{e:[2820338,114664],s:{a:88008786829312,b:218,o:587396678,f:'m',u:585790297}}}}
That's in the child process, main-thead when we're doing the extra paint (from vsync), and nsStyleImage::IsComplete returns false, even though we've previously painted the image fully with a sync decode.
I assume the notification to mark us as being decoded is probably in the event queue, should be fairly easy to track it down if anyone is interested.
Comment 51•7 years ago
|
||
I'd prefer to avoid sync notifying during painting. We removed it in bug 1311841. And I don't think we can notify when we are actually painting (as opposed to display list building) because then the invalidations that the observers do in response would be lost, right?
Instead, I propose a modification of Emilio's patch. If nsStyleImage::IsComplete is false then we don't record a successful draw but we still draw the image. (Emilio's patch doesn't draw the image if nsStyleImage::IsComplete is false.)
Flags: needinfo?(tnikkel)
Comment 52•7 years ago
|
||
This should handle all code that calls PrepareImage and records a ImgDrawResult I think.
I haven't tested it to check that it fixes the intermittent because I didn't get a setup that reproduced the intermittent.
Emilio could you push this to try or whatever to see if it works to fix the intermittent?
Attachment #8997266 -
Flags: feedback?(emilio)
Comment hidden (Intermittent Failures Robot) |
Comment 54•7 years ago
|
||
Comment on attachment 8997266 [details] [diff] [review]
draw the image but don't record success
Review of attachment 8997266 [details] [diff] [review]:
-----------------------------------------------------------------
I couldn't reproduce it locally anymore, yay!
Looks like this makes some CSS masking reftests permafail though:
https://treeherder.mozilla.org/#/jobs?repo=try&revision=54406cbbdeca407d74d26f72e0b534960235d532
I can try to take a look if you don't get to it sooner.
Attachment #8997266 -
Flags: feedback?(emilio)
Comment 55•7 years ago
|
||
Thanks.
I'm pretty sure those mask failures are because of this code
https://searchfox.org/mozilla-central/rev/3fdc491e118c5cdfbaf6e2d52f3466d2b27ad1de/layout/svg/nsSVGIntegrationUtils.cpp#582
Because we are using the ImgDrawResult for something other than just UpdateDrawResult; we are using it to determine if the image was drawn successfully and therefore how to draw the mask.
Not quite sure yet what to do. We really want to return two pieces of information: what to record in UpdateDrawResult and the actual ImgDrawResult, but that's really cumbersome.
Comment 56•7 years ago
|
||
That looks like it cares about whether the image was ever resolved, so probably could check for result != INCOMPLETE as well.
Comment 57•7 years ago
|
||
With attachment 8997266 [details] [diff] [review] there may be images that get drawn fully successfully but report INCOMPLETE status.
We could introduce another ImgDrawResult variant to represent that I suspect, but not sure it's worth the churn.
In any case the spec text that the comment under this condition is quoting is about non-resolvable images, and INCOMPLETE images are definitely resolvable.
Attachment #8988986 -
Attachment is obsolete: true
Flags: needinfo?(emilio)
Attachment #8997894 -
Flags: review?(dholbert)
Attachment #8997894 -
Flags: feedback?(tnikkel)
Comment 58•7 years ago
|
||
comment 57 was pretty green on try :)
Comment 59•7 years ago
|
||
Comment on attachment 8997894 [details] [diff] [review]
Allow also INCOMPLETE images to go through CreateAndPaintMaskSurface.
Review of attachment 8997894 [details] [diff] [review]:
-----------------------------------------------------------------
> Subject: [PATCH] Incomplete.
(Looks like this needs a commit message)
::: layout/svg/nsSVGIntegrationUtils.cpp
@@ +579,5 @@
> aSC, aMaskFrames, maskSurfaceMatrix,
> aOffsetToUserSpace);
>
> + if (aParams.imgParams.result != ImgDrawResult::SUCCESS &&
> + aParams.imgParams.result != ImgDrawResult::INCOMPLETE) {
Could you adjust the comment below this to make it clear why SUCCESS and INCOMPLETE are the specific two excluded values here? (I think those are the values that indicate that everything was successful and, at worst, we're blocked on decoding.)
It looks like the comment below is asking whether the mask resource is "resolvable or not"; I guess this is the "not resolvable" scenario, right? I'm not entirely sure why we'd only be checking for SUCCESS and INCOMPLETE to determine that... From the documentation for this enum[1], it seems like NOT_READY and perhaps even TEMPORARY_ERROR might be in the same 'resolvable' bucket as INCOMPLETE.
[1] https://dxr.mozilla.org/mozilla-central/rev/4e56a2f51ad739ca52046723448f3129a58f1666/image/ImgDrawResult.h#16-47
Attachment #8997894 -
Flags: review?(dholbert) → review-
Comment 60•7 years ago
|
||
Comment on attachment 8997894 [details] [diff] [review]
Allow also INCOMPLETE images to go through CreateAndPaintMaskSurface.
I'm fine with this, but in the case that we only have a partially decoded mask image do we want to draw the page using only a partially decoded mask image? It seems like this is a case where we want to either draw nothing or the full image (like background images).
Echoing dholbert, if we go this route then everything but BAD_IMAGE and BAD_ARGS should probably be treated the same way? I'm not too familiar with mask images though.
Attachment #8997894 -
Flags: feedback?(tnikkel)
Comment hidden (Intermittent Failures Robot) |
Comment hidden (Intermittent Failures Robot) |
Comment 63•6 years ago
|
||
Sorry, today I just went back to this because I got a patch backed out that introduced a test that happened to fail because of this bug.
WDYT about this Timothy?
Attachment #8997894 -
Attachment is obsolete: true
Attachment #9001975 -
Flags: review?(tnikkel)
Comment 64•6 years ago
|
||
(In reply to Emilio Cobos Álvarez (:emilio) from comment #63)
> Created attachment 9001975 [details] [diff] [review]
> With a way to distinguish INCOMPLETE from the 'drawed successfully but the
> image was not complete'
>
> Sorry, today I just went back to this because I got a patch backed out that
> introduced a test that happened to fail because of this bug.
>
> WDYT about this Timothy?
(This would apply on top of your other patch, and should probably be squashed into it).
Comment 65•6 years ago
|
||
It looks fine on try, fwiw.
Comment 66•6 years ago
|
||
Comment on attachment 9001975 [details] [diff] [review]
With a way to distinguish INCOMPLETE from the 'drawed successfully but the image was not complete'
Review of attachment 9001975 [details] [diff] [review]:
-----------------------------------------------------------------
There are about a half dozen other checks of equality with SUCCESS that I think also need to accept SUCCESS_NOT_COMPLETE. In nsDisplayListInvalidation.h, nsImageRenderer.h, nsDisplayList.cpp, nsCSSRendering.cpp, nsImageFrame.cpp, nsFloatManager.cpp, nsLayoutUtils.cpp, CanvasRenderingContext2D.cpp. The ones that happen in image/ should be fine because imagelib can't produce the SUCCESS_NOT_COMPLETE value.
::: image/ImgDrawResult.h
@@ +74,5 @@
> */
> inline ImgDrawResult
> operator&(const ImgDrawResult aLeft, const ImgDrawResult aRight)
> {
> if (MOZ_LIKELY(aLeft == ImgDrawResult::SUCCESS)) {
I think you need to check for SUCCESS_NOT_COMPLETE here too otherwise SUCCESS_NOT_COMPLETE & (some error) will be SUCCESS_NOT_COMPLETE.
Attachment #9001975 -
Flags: review?(tnikkel)
Comment 67•6 years ago
|
||
(In reply to Timothy Nikkel (:tnikkel) from comment #66)
> Comment on attachment 9001975 [details] [diff] [review]
> With a way to distinguish INCOMPLETE from the 'drawed successfully but the
> image was not complete'
>
> Review of attachment 9001975 [details] [diff] [review]:
> -----------------------------------------------------------------
So, just to ensure we're on the same page:
> nsDisplayListInvalidation.h
This one is the one that _explicitly_ doesn't need it, right? This is the whole point of this bug. If we treated this as a success result we'd end up not invalidating on sync-decode, which would end up causing the intermittents we're fixing.
> nsImageRenderer.h
This one I did audit, and mPrepareResult is not based on imagelib or anything else at all (which is kind of a weird usage of the result, btw). So shouldn't need to check it.
I can make an incomplete image store SUCCESS_NOT_COMPLETE instead of this 'treat as complete' we do for sync-decoding / frameComplete, then check it there and in nsCSSRendering, etc. But I don't think it's necessarily better than keeping this value's usage to the minimum, and the behavior should be the same.
> nsDisplayList.cpp
This one I agree it should be changed, I missed this while searching.
> nsCSSRendering.cpp
This one I also audited, and this assertion only changes the value that comes from PrepareImage (i.e. nsImageRenderer.h). So only needs tweak if we change nsImageRenderer as well.
> nsImageFrame.cpp
This one I didn't do because it looked just as a perf tweak, but I agree it can be checked, will do.
> nsFloatManager.cpp
This one I did audit as well, and DrawShapeImage can't generate SUCCESS_NOT_COMPLETE (since it's not the display list stuff it doesn't really matter, and it goes through nsLayoutUtils::DrawSingleImage which can't return the new value). I could change the check just for robustness if you think it's better, or change it so that it returns SUCCESS_NOT_COMPLETE for consistency with other Draw() stuff.
> nsLayoutUtils.cpp
Same, DrawImageInternal doesn't really / cannot really generate SUCCESS_NOT_COMPLETE. Again, doesn't hurt, but given those callers don't have an nsStyleImage handy I think it's clearer if they don't handle it.
> CanvasRenderingContext2D.cpp
That comes directly from imagelib, so shouldn't need to check it.
> The ones that happen in image/ should be fine
> because imagelib can't produce the SUCCESS_NOT_COMPLETE value.
Timothy, do you agree with the above? Should I just fix your comment below and change the checks in nsDisplayList.cpp nsImageFrame.cpp?
> ::: image/ImgDrawResult.h
> @@ +74,5 @@
> > */
> > inline ImgDrawResult
> > operator&(const ImgDrawResult aLeft, const ImgDrawResult aRight)
> > {
> > if (MOZ_LIKELY(aLeft == ImgDrawResult::SUCCESS)) {
>
> I think you need to check for SUCCESS_NOT_COMPLETE here too otherwise
> SUCCESS_NOT_COMPLETE & (some error) will be SUCCESS_NOT_COMPLETE.
True, will change. I guess I should really do it in an else clause, so that SUCCESS_NOT_COMPLETE & SUCCESS doesn't return SUCCESS.
Flags: needinfo?(tnikkel)
Comment 68•6 years ago
|
||
(In reply to Emilio Cobos Álvarez (:emilio) from comment #67)
<snip>
> Timothy, do you agree with the above? Should I just fix your comment below
> and change the checks in nsDisplayList.cpp nsImageFrame.cpp?
Ah yes, I think you are correct on all accounts. I just did a quick search and didn't put as much thought into it as you did. Thanks.
Flags: needinfo?(tnikkel)
Comment 69•6 years ago
|
||
The nsImageFrame caller doesn't need to handle the new value either, since it uses drawSingleImage directly.
Attachment #9001975 -
Attachment is obsolete: true
Attachment #9002202 -
Flags: review?(tnikkel)
Comment hidden (Intermittent Failures Robot) |
Updated•6 years ago
|
Attachment #9002202 -
Flags: review?(tnikkel) → review+
Comment 71•6 years ago
|
||
Timothy, can we land attachment 8997266 [details] [diff] [review]? I can stamp it, but maybe you want someone else to review it?
Flags: needinfo?(tnikkel)
Updated•6 years ago
|
Flags: needinfo?(tnikkel)
Attachment #8997266 -
Flags: review?(matt.woodrow)
Comment hidden (Intermittent Failures Robot) |
Updated•6 years ago
|
Attachment #8997266 -
Flags: review?(matt.woodrow) → review+
Comment 73•6 years ago
|
||
This bug has failed 42 times in the last 7 days. Failures occur on linux 32 and 64 platforms on asan and debug build types.
Log:
TEST-PASS | /css/css-backgrounds/border-image-019.xht | took 75ms
[task 2018-08-22T01:59:59.202Z] 01:59:59 INFO - TEST-START | /css/css-backgrounds/border-image-020.xht
[task 2018-08-22T01:59:59.203Z] 01:59:59 INFO - PID 6917 | 1534903199197 Marionette INFO Testing http://web-platform.test:8000/css/css-backgrounds/border-image-020.xht == http://web-platform.test:8000/css/reference/ref-filled-green-100px-square.xht
[task 2018-08-22T01:59:59.279Z] 01:59:59 INFO - PID 6917 | 1534903199271 Marionette INFO Found 7296 pixels different, maximum difference per channel 255
[task 2018-08-22T01:59:59.328Z] 01:59:59 INFO - TEST-UNEXPECTED-FAIL | /css/css-backgrounds/border-image-020.xht | Testing http://web-platform.test:8000/css/css-backgrounds/border-image-020.xht == http://web-platform.test:8000/css/reference/ref-filled-green-100px-square.xht
[task 2018-08-22T01:59:59.328Z] 01:59:59 INFO - REFTEST IMAGE 1 (TEST): 
[task 2018-08-22T01:59:59.329Z] 01:59:59 INFO - REFTEST IMAGE 2 (REFERENCE): 
[task 2018-08-22T01:59:59.330Z] 01:59:59 INFO - TEST-INFO took 123ms
[task 2018-08-22T01:59:59.367Z] 01:59:59 INFO - PID 6917 | ###!!! [Parent][RunMessage] Error: Channel closing: too late to send/recv, messages will be lost
[task 2018-08-22T01:59:59.395Z] 01:59:59 INFO - PID 6917 | 1534903199391 Marionette INFO Stopped listening on port 2828
[task 2018-08-22T02:00:00.694Z] 02:00:00 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:00.694Z] 02:00:00 INFO - PID 6917 | Suppressions used:
[task 2018-08-22T02:00:00.694Z] 02:00:00 INFO - PID 6917 | count bytes template
[task 2018-08-22T02:00:00.694Z] 02:00:00 INFO - PID 6917 | 620 19800 nsComponentManagerImpl
[task 2018-08-22T02:00:00.694Z] 02:00:00 INFO - PID 6917 | 2 416 mozJSComponentLoader::LoadModule
[task 2018-08-22T02:00:00.694Z] 02:00:00 INFO - PID 6917 | 2 288 libfontconfig.so
[task 2018-08-22T02:00:00.695Z] 02:00:00 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:00.864Z] 02:00:00 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:00.864Z] 02:00:00 INFO - PID 6917 | Suppressions used:
[task 2018-08-22T02:00:00.864Z] 02:00:00 INFO - PID 6917 | count bytes template
[task 2018-08-22T02:00:00.864Z] 02:00:00 INFO - PID 6917 | 620 19800 nsComponentManagerImpl
[task 2018-08-22T02:00:00.864Z] 02:00:00 INFO - PID 6917 | 2 416 mozJSComponentLoader::LoadModule
[task 2018-08-22T02:00:00.864Z] 02:00:00 INFO - PID 6917 | 611 17713 libfontconfig.so
[task 2018-08-22T02:00:00.864Z] 02:00:00 INFO - PID 6917 | 1 29 libglib-2.0.so
[task 2018-08-22T02:00:00.866Z] 02:00:00 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:00.930Z] 02:00:00 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:00.931Z] 02:00:00 INFO - PID 6917 | Suppressions used:
[task 2018-08-22T02:00:00.932Z] 02:00:00 INFO - PID 6917 | count bytes template
[task 2018-08-22T02:00:00.933Z] 02:00:00 INFO - PID 6917 | 620 19800 nsComponentManagerImpl
[task 2018-08-22T02:00:00.936Z] 02:00:00 INFO - PID 6917 | 2 416 mozJSComponentLoader::LoadModule
[task 2018-08-22T02:00:00.937Z] 02:00:00 INFO - PID 6917 | 611 17713 libfontconfig.so
[task 2018-08-22T02:00:00.938Z] 02:00:00 INFO - PID 6917 | 1 29 libglib-2.0.so
[task 2018-08-22T02:00:00.939Z] 02:00:00 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:01.283Z] 02:00:01 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:01.284Z] 02:00:01 INFO - PID 6917 | Suppressions used:
[task 2018-08-22T02:00:01.285Z] 02:00:01 INFO - PID 6917 | count bytes template
[task 2018-08-22T02:00:01.287Z] 02:00:01 INFO - PID 6917 | 620 19800 nsComponentManagerImpl
[task 2018-08-22T02:00:01.287Z] 02:00:01 INFO - PID 6917 | 2 416 mozJSComponentLoader::LoadModule
[task 2018-08-22T02:00:01.287Z] 02:00:01 INFO - PID 6917 | 611 17713 libfontconfig.so
[task 2018-08-22T02:00:01.287Z] 02:00:01 INFO - PID 6917 | 1 29 libglib-2.0.so
[task 2018-08-22T02:00:01.287Z] 02:00:01 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:02.461Z] 02:00:02 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:02.463Z] 02:00:02 INFO - PID 6917 | Suppressions used:
[task 2018-08-22T02:00:02.463Z] 02:00:02 INFO - PID 6917 | count bytes template
[task 2018-08-22T02:00:02.464Z] 02:00:02 INFO - PID 6917 | 626 19992 nsComponentManagerImpl
[task 2018-08-22T02:00:02.465Z] 02:00:02 INFO - PID 6917 | 38 7904 mozJSComponentLoader::LoadModule
[task 2018-08-22T02:00:02.466Z] 02:00:02 INFO - PID 6917 | 611 17509 libfontconfig.so
[task 2018-08-22T02:00:02.466Z] 02:00:02 INFO - PID 6917 | 8 352 _PR_Getfd
[task 2018-08-22T02:00:02.467Z] 02:00:02 INFO - PID 6917 | 1 29 libglib-2.0.so
[task 2018-08-22T02:00:02.467Z] 02:00:02 INFO - PID 6917 | -----------------------------------------------------
[task 2018-08-22T02:00:02.637Z] 02:00:02 INFO - Browser exited with return code 0
[task 2018-08-22T02:00:02.638Z] 02:00:02 WARNING - u'runner_teardown': ()
[task 2018-08-22T02:00:02.639Z] 02:00:02 INFO - INFO | runtests.py | ASan using symbolizer at /builds/worker/workspace/build/application/firefox/llvm-symbolizer
[task 2018-08-22T02:00:02.647Z] 02:00:02 INFO - STDOUT: Setting up LSAN
[task 2018-08-22T02:00:02.651Z] 02:00:02 INFO - LSan enabled.
[task 2018-08-22T02:00:02.651Z] 02:00:02 INFO - LSan using suppression file /builds/worker/workspace/build/tests/web-platform/prefs/lsan_suppressions.txt
[task 2018-08-22T02:00:02.651Z] 02:00:02 INFO - INFO | runtests.py | ASan running in default memory configuration
[task 2018-08-22T02:00:02.667Z] 02:00:02 INFO - Setting up ssl
[task 2018-08-22T02:00:02.716Z] 02:00:02 INFO - certutil |
[task 2018-08-22T02:00:02.772Z] 02:00:02 INFO - certutil |
[task 2018-08-22T02:00:02.813Z] 02:00:02 INFO - certutil |
[task 2018-08-22T02:00:02.813Z] 02:00:02 INFO - Certificate Nickname Trust Attributes
[task 2018-08-22T02:00:02.814Z] 02:00:02 INFO - SSL,S/MIME,JAR/XPI
[task 2018-08-22T02:00:02.814Z] 02:00:02 INFO -
[task 2018-08-22T02:00:02.814Z] 02:00:02 INFO - web-platform-tests CT,,
[task 2018-08-22T02:00:02.814Z] 02:00:02 INFO -
[task 2018-08-22T02:00:02.830Z] 02:00:02 INFO - Application command: /builds/worker/workspace/build/application/firefox/firefox --marionette about:blank -profile /tmp/tmprULjPS.mozrunner
[task 2018-08-22T02:00:02.847Z] 02:00:02 INFO - Starting runner
[task 2018-08-22T02:00:08.568Z] 02:00:08 INFO - PID 7324 | 1534903208556 Marionette INFO Listening on port 2828
[task 2018-08-22T02:00:09.227Z] 02:00:09 INFO - TEST-START | /css/css-backgrounds/border-image-5.html
svisen: Can you please take a look at this bug?
Flags: needinfo?(svoisen)
Whiteboard: [retriggered][stockwell disable-recommended] → [retriggered][stockwell disable-recommended] [stockwell needswork]
Comment 74•6 years ago
|
||
Pushed by tnikkel@gmail.com:
https://hg.mozilla.org/integration/mozilla-inbound/rev/5955f883a957
Don't record a successful image draw if the image isn't marked complete. r=mattwoodrow
https://hg.mozilla.org/integration/mozilla-inbound/rev/851b26405a34
Add a new ImgDrawResult variant to distinguish INCOMPLETE and 'fully drew an image which wasn't really complete'. r=tnikkel
Comment 75•6 years ago
|
||
bugherder |
https://hg.mozilla.org/mozilla-central/rev/5955f883a957
https://hg.mozilla.org/mozilla-central/rev/851b26405a34
Status: NEW → RESOLVED
Closed: 6 years ago
status-firefox63:
--- → fixed
Resolution: --- → FIXED
Target Milestone: --- → mozilla63
Updated•6 years ago
|
Flags: needinfo?(svoisen)
Comment hidden (Intermittent Failures Robot) |
Updated•6 years ago
|
Whiteboard: [retriggered][stockwell disable-recommended] [stockwell needswork] → [retriggered][stockwell fixed:product]
Comment hidden (Intermittent Failures Robot) |
Updated•5 years ago
|
Flags: needinfo?(aosmond)
You need to log in
before you can comment on or make changes to this bug.
Description
•