<p>Great!</p>
<p>What is the difference in handling the style attribute?</p>
<p>Also, can we convert existing tests to use testharness.js and submit them to W3C? That way, we can help other browser vendors implement it "correctly" when they do. (of course, this shouldn't block unprefixing the API)</p>

<p>- Ryosuke</p>
<div class="gmail_quote">On Jun 15, 2012 11:09 AM, "Adam Klein" <<a href="mailto:adamk@chromium.org">adamk@chromium.org</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
I was working closely with Olli Pettay when he was putting together<br>
the tests for Firefox, and we passed all of those (as of a couple<br>
months ago; our code hasn't changed since then). Just ran through our<br>
tests with Firefox Aurora and everything passed modulo differences in<br>
supported features (they don't support WebSQL or FileSystem API which<br>
we use in a few tests; there were some minor differences in handling<br>
of the style attribute, but nothing that looks likely to cause<br>
compatibility issues (whitespace)).<br>
<br>
I've uploaded a proposed patch at<br>
<a href="https://bugs.webkit.org/show_bug.cgi?id=89231" target="_blank">https://bugs.webkit.org/show_bug.cgi?id=89231</a> (wanted to give it a<br>
shot through the EWS bots). I've yet to implement a way to turn off<br>
the unprefixing for ports that aren't yet done, suggestions on how to<br>
do that most simply are appreciated.<br>
<br>
- Adam<br>
<br>
On Fri, Jun 15, 2012 at 10:48 AM, Ryosuke Niwa <<a href="mailto:rniwa@webkit.org">rniwa@webkit.org</a>> wrote:<br>
> Before unprefixing it, can we make sure we also pass Mozilla's tests and<br>
> vice versa? Mutation events was a huge mess partially because browsers<br>
> didn't interoperate. I'd like to make sure this API interoperates well from<br>
> day 1.<br>
><br>
> - Ryosuke<br>
><br>
> On Fri, Jun 15, 2012 at 10:31 AM, Adam Klein <<a href="mailto:adamk@chromium.org">adamk@chromium.org</a>> wrote:<br>
>><br>
>> An update: it appears that the GTK and EFL ports have added at least<br>
>> basic support for end-of-task delivery, in<br>
>> <a href="http://trac.webkit.org/changeset/108628" target="_blank">http://trac.webkit.org/changeset/108628</a> and<br>
>> <a href="http://trac.webkit.org/changeset/110568" target="_blank">http://trac.webkit.org/changeset/110568</a>. They now pass all<br>
>> MutationObserver tests. Do these tests pass in the actual browsers<br>
>> built from GTK and EFL, or only DRT?<br>
>><br>
>> On Fri, Jun 8, 2012 at 2:16 PM, Adam Klein <<a href="mailto:adamk@chromium.org">adamk@chromium.org</a>> wrote:<br>
>> > Hi webkit-dev,<br>
>> ><br>
>> > DOM MutationObservers (see meta bug<br>
>> > <a href="https://bugs.webkit.org/show_bug.cgi?id=68729" target="_blank">https://bugs.webkit.org/show_bug.cgi?id=68729</a>) have been shipping as<br>
>> > WebKitMutationObserver in Chromium since earlier this year. The<br>
>> > feature is fully specced as part of DOM4<br>
>> > (<a href="http://www.w3.org/TR/domcore/#mutation-observers" target="_blank">http://www.w3.org/TR/domcore/#mutation-observers</a>) and is implemented<br>
>> > in Firefox. Mozilla has also recently unprefixed their version of the<br>
>> > API (<a href="https://bugzilla.mozilla.org/show_bug.cgi?id=749920" target="_blank">https://bugzilla.mozilla.org/show_bug.cgi?id=749920</a>), and I'd<br>
>> > like to do the same (<a href="https://bugs.webkit.org/show_bug.cgi?id=85161" target="_blank">https://bugs.webkit.org/show_bug.cgi?id=85161</a>).<br>
>> ><br>
>> > The tricky part is that while the Chromium version is complete and<br>
>> > compatible with Firefox, there's one piece missing from all other<br>
>> > ports (<a href="https://bugs.webkit.org/show_bug.cgi?id=78290" target="_blank">https://bugs.webkit.org/show_bug.cgi?id=78290</a>). The short<br>
>> > version is that each port needs to be able to run some code<br>
>> > (delivering mutations) at the end of every task (see<br>
>> ><br>
>> > <a href="http://www.whatwg.org/specs/web-apps/current-work/multipage/webappapis.html#processing-model-2" target="_blank">http://www.whatwg.org/specs/web-apps/current-work/multipage/webappapis.html#processing-model-2</a>,<br>

>> > step 4 "Perform a microtask checkpoint"). Without this code, mutations<br>
>> > due to user input are not delivered in a timely fashion.<br>
>> ><br>
>> > It's easy for Chromium to do this because we have our own MessageLoop<br>
>> > abstraction wrapping the native event loops on various platforms, so<br>
>> > our definition of end-of-task is easy to define. But implementing this<br>
>> > properly is likely to be slightly different for every port.<br>
>> ><br>
>> > In the short term, my plan is to add the unprefixed version (in<br>
>> > addition to the prefixed) of MutationObserver when PLATFORM(CHROMIUM)<br>
>> > is enabled. But I'd like to help other ports implement this<br>
>> > appropriately, and provide the unprefixed version there too. Please<br>
>> > let me know how I can be of assistance.<br>
>> ><br>
>> > Let me know if you have questions or concerns,<br>
>> > Adam Klein<br>
>> _______________________________________________<br>
>> webkit-dev mailing list<br>
>> <a href="mailto:webkit-dev@lists.webkit.org">webkit-dev@lists.webkit.org</a><br>
>> <a href="http://lists.webkit.org/mailman/listinfo.cgi/webkit-dev" target="_blank">http://lists.webkit.org/mailman/listinfo.cgi/webkit-dev</a><br>
><br>
><br>
</blockquote></div>