Closed Bug 1471583 Opened Last year Closed Last year

Categories

(Core :: Layout, defect, P5)

defect

Tracking

()

RESOLVED FIXED
mozilla63
Tracking Status
firefox63 --- fixed

People

(Reporter: intermittent-bug-filer, Assigned: ccoroiu, NeedInfo)

References

(Blocks 1 open bug)

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: nobody → ccoroiu
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)
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)
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)
Depends on: 1419854
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)
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)
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
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)
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.
See Also: → 697230, 695765, 695763
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.
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.
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)
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!
Duplicate of this bug: 1419854
(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)
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?
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)
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)
(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.
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)
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.
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 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+
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
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)
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...
(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
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?
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)
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?
Flags: needinfo?(matt.woodrow) → needinfo?(aosmond)
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.
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)
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 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)
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.
That looks like it cares about whether the image was ever resolved, so probably could check for result != INCOMPLETE as well.
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 57 was pretty green on try :)
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 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)
See Also: → 1426587
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)
(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).
It looks fine on try, fwiw.
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)
(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)
(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)
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)
Attachment #9002202 - Flags: review?(tnikkel) → review+
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)
Flags: needinfo?(tnikkel)
Attachment #8997266 - Flags: review?(matt.woodrow)
Attachment #8997266 - Flags: review?(matt.woodrow) → review+
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]
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
https://hg.mozilla.org/mozilla-central/rev/5955f883a957
https://hg.mozilla.org/mozilla-central/rev/851b26405a34
Status: NEW → RESOLVED
Closed: Last year
Resolution: --- → FIXED
Target Milestone: --- → mozilla63
Flags: needinfo?(svoisen)
Whiteboard: [retriggered][stockwell disable-recommended] [stockwell needswork] → [retriggered][stockwell fixed:product]
You need to log in before you can comment on or make changes to this bug.