Closed Bug 1412179 Opened 3 years ago Closed 1 year ago

webrender: implement fieldsets with non-empty legends

Categories

(Core :: Graphics: WebRender, enhancement, P3)

enhancement

Tracking

()

RESOLVED FIXED
mozilla68
Tracking Status
firefox57 --- unaffected
firefox58 --- unaffected
firefox68 --- fixed

People

(Reporter: Gankra, Assigned: Gankra, Mentored)

References

(Blocks 1 open bug)

Details

(Whiteboard: [wr-reserve] [gfx-noted])

Attachments

(2 files, 5 obsolete files)

This was left out in initial conversion as it required upstream support. We now have ClipMode::ClipOut which provides that support.

Someone just needs to add the appropriate push/pop clip commands in nsDisplayFieldSetBorder::CreateWebRenderCommands (it's mostly already set up with a comment).

Good bug starter bug, happy to mentor. (do we have a tag for that?)
Mentor: a.beingessner
Whiteboard: [gfx-noted]
If I could get some help on this then I would love to try and fix this!

I assume the comment Alexis refers to is https://dxr.mozilla.org/mozilla-central/source/layout/forms/nsFieldSetFrame.cpp?q=nsDisplayFieldSetBorder%3A%3ACreateWebRenderCommands&redirect_type=direct#174 ?
Yes, exactly. So looking a bit closer, there's two things to do here:

1. Add API support for generating a ClipOut
2. Use that API to Push/PopClip in the code you linked.

I expect (1) will involve making a version of ToComplexClipRegion ( http://searchfox.org/mozilla-central/source/gfx/webrender_bindings/WebRenderTypes.h#330 ) that takes a (non-rounded) Rect and a ClipMode. (It might end up trivial enough that you should just skip making a function and do the work directly in CreateWebRenderCommands)


I think (2) should look like (very-pseudocode):

region = ToComplexClipRegion(legendRect, ClipOut)
aBuiler->PushClip(aBuilder->DefineClip(region))

...

result = CreateWebRenderCommandsForBorder(..)
if (pushedClip) { aBuilder->PopClip() }
return result

Somewhere in there you should also use the aSc.ToRelativeLayoutRect to get the units right. This should be a decent example:

http://searchfox.org/mozilla-central/source/layout/generic/TextDrawTarget.h#61-75
Thanks for the details!

Unfortunately I will not be able to do anything tonight, but I'll sit down and work with this tomorrow. If I encounter any problems I'll let you know!
Whiteboard: [gfx-noted] → [gfx-noted][wr-reserve-candidate]
Whiteboard: [gfx-noted][wr-reserve-candidate] → [wr-mvp] [triage] [gfx-noted] [wr-reserve-candidate]
Whiteboard: [wr-mvp] [triage] [gfx-noted] [wr-reserve-candidate] → [wr-reserve] [gfx-noted]
I started working on an implementation today and decided to divide it up like you did with (1) and (2) (if the function becomes very small I'll just manually inline it). 

I wanted to ask about the non-rounded Rect. I wasn't sure which one to use that work with the nsRect class from "nsDisplayFieldSetBorder::CreateWebRenderCommands". Am I right in assuming that RectTyped will work (http://searchfox.org/mozilla-central/source/gfx/2d/Rect.h#229) and is it then appropriate to use gfxRect from http://searchfox.org/mozilla-central/source/gfx/thebes/gfxRect.h#12 ?
Flags: needinfo?(a.beingessner)
Looking again, it looks like ToComplexClipRegion is now dead code, having been replaced by ToComplexClipRegions. This suggests to me you should just skip to doing it inline, based on the body of ToComplexClipRegions.
Flags: needinfo?(a.beingessner)
I mimicked the ToComplexClipRegions without the radii (I assume that it shouldn't be there). DefineClip didn't need the ComplexClipRegion, can I just pass it in directly to aBuilder.DefineClip like in the code snippet? Do I need to manually define the ClipMode::ClipOut somewhere because now I only throw the layoutRect into the DefineClip

```
  bool pushedClip{false};

  if (nsIFrame* legend = frame->GetLegend()) {
    rect = frame->VisualBorderRectRelativeToSelf() + offset;
    nsRect legendRect = legend->GetNormalRect() + offset;

    if (!legendRect.IsEmpty()) {
      auto appUnitsPerDevPixel = frame->PresContext()->AppUnitsPerDevPixel();
      wr::ComplexClipRegion region;
      auto layoutRect = LayoutDeviceRect::FromAppUnits(legendRect, appUnitsPerDevPixel);

      aBuilder.PushClip(aBuilder.DefineClip(Nothing(), Nothing(), aSc.ToRelativeLayoutRect(layoutRect)));
      pushedClip = true;
    }

  } else {
    rect = nsRect(offset, frame->GetRect().Size());
  }
```

The full change is in the patch
Attached patch my.patch (obsolete) — Splinter Review
Ah, so the issue is that when we added the ClipOut API to webrender, we only put it on ComplexClipRegions, because we didn't want to bloat the much more common clip-rect. So you need to set the mode on the region, properly initialize it, and pass that in too.
Attached patch my.patch (obsolete) — Splinter Review
Attachment #8925116 - Attachment is obsolete: true
I updated the patch and am now creating an Array with a single ComplexClipRegion that I pass into the DefineClip function. With the previous patch I thought I had to pass the ComplexClipRegion as the rect (third parameter). Perhaps I should have taken a second to read exactly what the fourth parameter was '-.-
Assignee: nobody → anting004
Status: NEW → ASSIGNED
Priority: P3 → P1
It seems I did not add any flags to my updated patch, woops.

Could you look at the patch Alexis?
Flags: needinfo?(a.beingessner)
Whoops, yeah sorry didn't see you updated this!

Patch looks like what I was imagining. The style is a bit different from what I'm used to in our codebase. 

mstange, can you advise on style?
Flags: needinfo?(a.beingessner) → needinfo?(mstange)
Comment on attachment 8925848 [details] [diff] [review]
my.patch

Review of attachment 8925848 [details] [diff] [review]:
-----------------------------------------------------------------

Yes, I have some style comments. The code itself looks good!

::: layout/forms/nsFieldSetFrame.cpp
@@ +167,4 @@
>    auto frame = static_cast<nsFieldSetFrame*>(mFrame);
>    auto offset = ToReferenceFrame();
>    nsRect rect;
> +  bool pushedClip{false};

This syntax is rarely used in our code, usually only when initializing struct fields. So I'd recommend making this "bool pushedClip = false;" instead, so that it looks less out of place.

@@ +178,5 @@
> +      auto layoutRect = LayoutDeviceRect::FromAppUnits(legendRect, appUnitsPerDevPixel);
> +      wr::ComplexClipRegion region;
> +      region.rect = aSc.ToRelativeLayoutRect(layoutRect);
> +      region.mode = wr::ClipMode::ClipOut;
> +      nsTArray<mozilla::wr::ComplexClipRegion> array{region};

whoa, I didn't know we had a way to add a value into an nsTArray during construction!

@@ +179,5 @@
> +      wr::ComplexClipRegion region;
> +      region.rect = aSc.ToRelativeLayoutRect(layoutRect);
> +      region.mode = wr::ClipMode::ClipOut;
> +      nsTArray<mozilla::wr::ComplexClipRegion> array{region};
> +      auto clip = aBuilder.DefineClip(Nothing(), Nothing(), region.rect, &array);

Let's make this "wr::ClipId" instead of "auto" to be consistent with the other users of DefineClip.

@@ +188,5 @@
>    } else {
>      rect = nsRect(offset, frame->GetRect().Size());
>    }
>  
> +  auto result = nsCSSRendering::CreateWebRenderCommandsForBorder(this,

And please make this auto a bool instead. Same number of characters and clearer.

@@ +196,5 @@
> +                                                                 aResources,
> +                                                                 aSc,
> +                                                                 aManager,
> +                                                                 aDisplayListBuilder);
> +  if (pushedClip) { aBuilder.PopClip(); }

Final style comment: Please add line breaks.

if (pushedClip) {
  aBuilder.PopClip();
}
Attached patch my.patch (obsolete) — Splinter Review
Style fixes
Attachment #8925848 - Attachment is obsolete: true
Flags: needinfo?(a.beingessner)
Comment on attachment 8930831 [details] [diff] [review]
my.patch

Review of attachment 8930831 [details] [diff] [review]:
-----------------------------------------------------------------

perfect!
Attachment #8930831 - Flags: review+
Flags: needinfo?(a.beingessner)
Keywords: checkin-needed
It's probably worth adding a reftest to exercise this case (in a follow-up bug maybe) since our existing reftest suite doesn't seem to cover this.
I will be without a laptop for the next week or so. My suggestion is to, as @kats says, put the reftest in a follow-up bug. Or someone else will have to work on this bug to complete it in a timely manner.
From irc discussion, this was a misunderstanding. Because this is replacing a fallback with a proper WR implementation, it should be fine.
Yeah, my mistake. I can land this patch for you - in the future please make sure to also include the bug number in the commit message ("Bug XXXXX - commit message. r=reviewer" is the usual format).
Pushed by kgupta@mozilla.com:
https://hg.mozilla.org/integration/mozilla-inbound/rev/0df37c7600d1
Implement fieldsets with non-empty legends. r=Gankro
Keywords: checkin-needed
Henrik (or Alexis) please update the patch to correct the build bustage. Thanks!

I'd do it but since this is a mentored bug you guys might as well get the full Gecko-hacking experience :)
Flags: needinfo?(bugmail) → needinfo?(anting004)
I'll happily fix it if Henrik's fine with it (since they can't work on it for a week)
I'll have a hard time fixing it for same reason as i mentioned before so please do fix it Alexis
Flags: needinfo?(anting004)
Deprioritized to P3 during triage - moving to Reserve Backlog.
Assignee: anting004 → nobody
Status: ASSIGNED → NEW
Priority: P1 → P3
Flags: needinfo?(mstange)
We'll fallback so this issue isn't related to correctness.
Priority: P1 → P3
Assignee: nobody → a.beingessner
MozReview-Commit-ID: 1QqgRcSN1K3
note to sheriffs: there's multiple commits on phabricator but I only see the first in bugzilla?
Keywords: checkin-needed
Pushed by ebalazs@mozilla.com:
https://hg.mozilla.org/integration/autoland/rev/69faa23050d9
Implement non-empty legends for wr. r=jrmuizel
Keywords: checkin-needed
Comment on attachment 9003784 [details]
Bug 1412179 - Implement non-empty legends for wr. r=jrmuizel

Jeff Muizelaar [:jrmuizel] has approved the revision.
Attachment #9003784 - Flags: review+
Backout by ebalazs@mozilla.com:
https://hg.mozilla.org/integration/autoland/rev/902644464343
Backed out changeset 69faa23050d9 for landing without first patch
https://phabricator.services.mozilla.com/p/Gankro/ mentions only one patch for this bug. Are the other patches on phabricator? Is https://phabricator.services.mozilla.com/D4010 the other patch? It changed bug numbers.
Flags: needinfo?(a.beingessner)
This should be ready to go, but I don't think we need to block the release on it.
Blocks: stage-wr-next
No longer blocks: stage-wr-trains
Alexis, please upload the patch again with arc diff so proper author information (your name and email) are included.
Depends on D4963
Attachment #8930831 - Attachment is obsolete: true
Flags: needinfo?(a.beingessner)
Attachment #9003784 - Attachment is obsolete: true
Comment on attachment 9006321 [details]
Bug 1412179 - Implement non-empty legends for wr

Jeff Muizelaar [:jrmuizel] has approved the revision.
Attachment #9006321 - Flags: review+
Comment on attachment 9006322 [details]
Bug 1412179 - defuzz tests that no longer fallback

Jeff Muizelaar [:jrmuizel] has approved the revision.
Attachment #9006322 - Flags: review+
Keywords: checkin-needed
Hi. I've tried to land this 2 times, lando returns: 

This diff does not have the proper author information uploaded to Phabricator. This can happen if the diff was created using the web UI, or a non standard client. The author should re-upload the diff to Phabricator using the "arc diff" command. 

Importing the patches returns this: 

https://irccloud.mozilla.com/file/2Kl01K6B/image.png

Removing checkin-needed, please take a look at this.
Flags: needinfo?(aryx.bugmail)
Keywords: checkin-needed
Flags: needinfo?(a.beingessner)
fyi, nika ^
Flags: needinfo?(a.beingessner) → needinfo?(nika)
Gankro: update phlay to the latest version and try repushing the patch. This is a bug with the old version.
Flags: needinfo?(nika)
Attachment #9006321 - Attachment description: Bug 1412179 - Implement non-empty legends for wr. r=jrmuizel → Bug 1412179 - Implement non-empty legends for wr
Attachment #9006322 - Attachment description: Bug 1412179 - defuzz tests that no longer fallback. r=jrmuizel → Bug 1412179 - defuzz tests that no longer fallback
*sobbing* please work phabricator
Keywords: checkin-needed
Pushed by dluca@mozilla.com:
https://hg.mozilla.org/integration/autoland/rev/f22f3ce35811
Implement non-empty legends for wr r=jrmuizel
Keywords: checkin-needed
Pushed by archaeopteryx@coole-files.de:
https://hg.mozilla.org/integration/autoland/rev/29b47a085757
defuzz tests that no longer fallback. r=jrmuizel CLOSED TREE
Wait I'm confused, you pushed only one patch, and then archaeopteryx pushed the expectation changes, but I got backed out for not having the expectation change?
Flags: needinfo?(a.beingessner) → needinfo?(dluca)
After both patches landed, there was failure for layout/reftests/box-shadow/fieldset.html:

https://treeherder.mozilla.org/#/jobs?repo=autoland&resultStatus=testfailed,busted,exception&tochange=7102989560f2a6155025e4f083cc41427516c2b8&fromchange=56a508217ab7e7c28e1e5622f8dd31caa98a8706&searchStr=reftest&selectedJob=198931299

REFTEST TEST-UNEXPECTED-FAIL | file:///builds/worker/workspace/build/tests/reftest/tests/layout/reftests/box-shadow/fieldset.html == file:///builds/worker/workspace/build/tests/reftest/tests/layout/reftests/box-shadow/fieldset-ref.html | image comparison, max difference: 246, number of differing pixels: 42

Your patch in phabricator https://phabricator.services.mozilla.com/D4964 looks like the change which landed for that file: https://hg.mozilla.org/integration/autoland/rev/29b47a0857574c7164d03ec56c27d5c3e51f412a

The expectation for the sticky-legend one had already been changed before to the new value: https://hg.mozilla.org/integration/autoland/rev/e4f3b85bc61b / bug 1488403

Part 1 has a merge conflict now, please update it. Set potential needinfos on me, my work interval is more frequent (but shorter) compared to the sheriffs. Let's get this landed.
Flags: needinfo?(dluca)
Flags: needinfo?(aryx.bugmail)
Attachment #9006322 - Attachment is obsolete: true
Keywords: checkin-needed

Pushed by ncsoregi@mozilla.com:
https://hg.mozilla.org/integration/autoland/rev/fd5cb917b6eb
implement fieldsets with nonempty legends. r=kats

Keywords: checkin-needed

Backed out changeset fd5cb917b6eb (bug 1412179) for Wr failures at /html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-vertical.html

Backout: https://hg.mozilla.org/integration/autoland/rev/bcf9b5a72198cb74f6fc063234652583201e4c3e

Failure push: https://treeherder.mozilla.org/#/jobs?repo=autoland&selectedJob=240112129&revision=fd5cb917b6eb7623ee6de94d5105ac4e23c38371

Failure log: https://treeherder.mozilla.org/logviewer.html#/jobs?job_id=240114849&repo=autoland&lineNumber=44081

task 2019-04-13T07:52:27.639Z] 07:52:27 INFO - TEST-START | /html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-vertical.html
[task 2019-04-13T07:52:27.646Z] 07:52:27 INFO - PID 17262 | 1555141947639 Marionette INFO Testing http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-vertical.html == http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-vertical-ref.html
[task 2019-04-13T07:52:27.662Z] 07:52:27 INFO - PID 17262 | JavaScript error: resource:///modules/sessionstore/SessionStore.jsm, line 2383: TypeError: tabbrowser.getTabForBrowser is not a function
[task 2019-04-13T07:52:27.662Z] 07:52:27 INFO - PID 17262 | ++DOMWINDOW == 49 (0x7f95d8af7400) [pid = 17403] [serial = 49] [outer = 0x7f95dbfcbd40]
[task 2019-04-13T07:52:28.032Z] 07:52:28 INFO - PID 17262 | JavaScript error: resource:///modules/sessionstore/SessionStore.jsm, line 2383: TypeError: tabbrowser.getTabForBrowser is not a function
[task 2019-04-13T07:52:28.039Z] 07:52:28 INFO - PID 17262 | ++DOMWINDOW == 50 (0x7f95d8af4000) [pid = 17403] [serial = 50] [outer = 0x7f95dbfcbd40]
[task 2019-04-13T07:52:28.282Z] 07:52:28 INFO - PID 17262 | 1555141948276 Marionette INFO No differences allowed
[task 2019-04-13T07:52:28.388Z] 07:52:28 INFO - TEST-UNEXPECTED-PASS | /html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-vertical.html | Testing http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-vertical.html == http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-vertical-ref.html
[task 2019-04-13T07:52:28.388Z] 07:52:28 INFO - REFTEST IMAGE 1 (TEST): 
[task 2019-04-13T07:52:28.389Z] 07:52:28 INFO - REFTEST IMAGE 2 (REFERENCE): 
[task 2019-04-13T07:52:28.392Z] 07:52:28 INFO - TEST-INFO expected FAIL | took 712ms
[task 2019-04-13T07:52:28.392Z] 07:52:28 INFO - PID 17262 | [Parent 17262, Compositor] WARNING: Possibly dropping task posted to updater thread: file /builds/worker/workspace/build/src/gfx/layers/apz/src/APZUpdater.cpp, line 424
[task 2019-04-13T07:52:28.711Z] 07:52:28 INFO - PID 17262 | 1555141948706 Marionette INFO Stopped listening on port 2828
[task 2019-04-13T07:52:29.097Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 49 (0x7f95dbfcbd40) [pid = 17403] [serial = 1] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-vertical.html]
[task 2019-04-13T07:52:29.099Z] 07:52:29 INFO - PID 17262 | --DOCSHELL 0x7f95daba6800 == 0 [pid = 17403] [id = {b37e6bd2-67e9-4ddf-9398-4248101da57b}] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-vertical.html]
[task 2019-04-13T07:52:29.175Z] 07:52:29 INFO - PID 17262 | [Parent 17262, Compositor] WARNING: Possibly dropping task posted to updater thread: file /builds/worker/workspace/build/src/gfx/layers/apz/src/APZUpdater.cpp, line 424
[task 2019-04-13T07:52:29.232Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 48 (0x7f95d8aef800) [pid = 17403] [serial = 29] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ul-type-unsupported-lower-alpha.html]
[task 2019-04-13T07:52:29.236Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 47 (0x7f95d8af1400) [pid = 17403] [serial = 30] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ul-type-unsupported-lower-roman.html]
[task 2019-04-13T07:52:29.237Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 46 (0x7f95d8c3c800) [pid = 17403] [serial = 20] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ol-type-unsupported-square.html]
[task 2019-04-13T07:52:29.237Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 45 (0x7f95dab2b800) [pid = 17403] [serial = 7] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/li-type-unsupported-upper-alpha.html]
[task 2019-04-13T07:52:29.246Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 44 (0x7f95d8af9c00) [pid = 17403] [serial = 35] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-border-gap-position-relative-ref.html]
[task 2019-04-13T07:52:29.246Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 43 (0x7f95d8afcc00) [pid = 17403] [serial = 37] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-containing-block-ref.html]
[task 2019-04-13T07:52:29.247Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 42 (0x7f95d8c3b000) [pid = 17403] [serial = 19] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ol-type-unsupported-round.html]
[task 2019-04-13T07:52:29.247Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 41 (0x7f95d8c38000) [pid = 17403] [serial = 17] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ol-type-unsupported-lower-roman.html]
[task 2019-04-13T07:52:29.247Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 40 (0x7f95dab33800) [pid = 17403] [serial = 10] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ol-type-supported-xhtml.xhtml]
[task 2019-04-13T07:52:29.248Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 39 (0x7f95dab33400) [pid = 17403] [serial = 9] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ol-type-supported-ref.html]
[task 2019-04-13T07:52:29.248Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 38 (0x7f95d8c43c00) [pid = 17403] [serial = 26] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ul-type-unsupported-ref.html]
[task 2019-04-13T07:52:29.249Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 37 (0x7f95d8c36800) [pid = 17403] [serial = 16] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ol-type-unsupported-lower-alpha.html]
[task 2019-04-13T07:52:29.249Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 36 (0x7f95d8c44c00) [pid = 17403] [serial = 27] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ul-type-unsupported-decimal.html]
[task 2019-04-13T07:52:29.249Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 35 (0x7f95dad92c00) [pid = 17403] [serial = 13] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ol-type-unsupported-circle.html]
[task 2019-04-13T07:52:29.249Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 34 (0x7f95d8c42400) [pid = 17403] [serial = 25] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ul-type-supported.html]
[task 2019-04-13T07:52:29.250Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 33 (0x7f95dab34800) [pid = 17403] [serial = 28] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ul-type-unsupported-invalid.html]
[task 2019-04-13T07:52:29.253Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 32 (0x7f95d8af2c00) [pid = 17403] [serial = 31] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ul-type-unsupported-upper-alpha.html]
[task 2019-04-13T07:52:29.253Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 31 (0x7f95d8af6000) [pid = 17403] [serial = 33] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/no-red-ref.html]
[task 2019-04-13T07:52:29.253Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 30 (0x7f95dab2d000) [pid = 17403] [serial = 8] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/li-type-unsupported-upper-roman.html]
[task 2019-04-13T07:52:29.254Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 29 (0x7f95dab36400) [pid = 17403] [serial = 11] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/lists/ol-type-supported.html]
[task 2019-04-13T07:52:29.254Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 28 (0x7f95d8afb400) [pid = 17403] [serial = 36] [outer = (nil)] [url = http://web-platform.test:8000/html/rendering/non-replaced-elements/the-fieldset-and-legend-elements/fieldset-border-gap-position-relative.html]
[task 2019-04-13T07:52:29.255Z] 07:52:29 INFO - PID 17262 | --DOMWINDOW == 27 (0x7f95da784000) [pid = 17403] [serial = 3] [outer = (nil)] [url = about:blank]

Flags: needinfo?(a.beingessner)

one unexpected pass, and one fuzzy-if(webrender, 8, 9), which seems totally fine to land. Nice!

Flags: needinfo?(a.beingessner)
Keywords: checkin-needed

Pushed by ccoroiu@mozilla.com:
https://hg.mozilla.org/integration/autoland/rev/693535165c9f
implement fieldsets with nonempty legends. r=kats

Keywords: checkin-needed
Status: NEW → RESOLVED
Closed: 1 year ago
Resolution: --- → FIXED
Target Milestone: --- → mozilla68
Regressions: 1546018
You need to log in before you can comment on or make changes to this bug.