Bug 164609

Summary: event.composedPath() does not include window
Product: WebKit Reporter: Keanu Lee <webkit>
Component: DOMAssignee: Ryosuke Niwa <rniwa>
Status: RESOLVED FIXED    
Severity: Normal CC: buildbot, cdumez, commit-queue, dbates, esprehn+autocc, kangil.han, koivisto, rniwa, sam, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: Safari Technology Preview   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 148695    
Attachments:
Description Flags
Fixes the bug
none
Archive of layout-test-results from ews105 for mac-yosemite-wk2
none
Archive of layout-test-results from ews102 for mac-yosemite
none
Rebaselined the test
none
Fixes the bug
none
Patch for landing none

Keanu Lee
Reported 2016-11-10 12:41:23 PST
event.composedPath() should include the window object, as defined in the spec (https://dom.spec.whatwg.org/#dom-event-composedpath): http://jsbin.com/gebebag/edit?html,output
Attachments
Fixes the bug (20.20 KB, patch)
2016-11-11 16:50 PST, Ryosuke Niwa
no flags
Archive of layout-test-results from ews105 for mac-yosemite-wk2 (1.16 MB, application/zip)
2016-11-11 17:42 PST, Build Bot
no flags
Archive of layout-test-results from ews102 for mac-yosemite (929.39 KB, application/zip)
2016-11-11 18:02 PST, Build Bot
no flags
Rebaselined the test (20.48 KB, patch)
2016-11-11 18:06 PST, Ryosuke Niwa
no flags
Fixes the bug (20.48 KB, patch)
2016-11-11 18:38 PST, Ryosuke Niwa
no flags
Patch for landing (20.47 KB, patch)
2016-11-11 19:48 PST, Ryosuke Niwa
no flags
Radar WebKit Bug Importer
Comment 1 2016-11-10 16:48:52 PST
Ryosuke Niwa
Comment 2 2016-11-11 16:50:24 PST
Created attachment 294568 [details] Fixes the bug
Build Bot
Comment 3 2016-11-11 17:42:30 PST
Comment on attachment 294568 [details] Fixes the bug Attachment 294568 [details] did not pass mac-wk2-ews (mac-wk2): Output: http://webkit-queues.webkit.org/results/2500714 New failing tests: fast/shadow-dom/event-path-with-window.html
Build Bot
Comment 4 2016-11-11 17:42:35 PST
Created attachment 294572 [details] Archive of layout-test-results from ews105 for mac-yosemite-wk2 The attached test failures were seen while running run-webkit-tests on the mac-wk2-ews. Bot: ews105 Port: mac-yosemite-wk2 Platform: Mac OS X 10.10.5
Build Bot
Comment 5 2016-11-11 18:02:36 PST
Comment on attachment 294568 [details] Fixes the bug Attachment 294568 [details] did not pass mac-ews (mac): Output: http://webkit-queues.webkit.org/results/2500808 New failing tests: fast/shadow-dom/event-path-with-window.html
Build Bot
Comment 6 2016-11-11 18:02:40 PST
Created attachment 294573 [details] Archive of layout-test-results from ews102 for mac-yosemite The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: ews102 Port: mac-yosemite Platform: Mac OS X 10.10.5
Ryosuke Niwa
Comment 7 2016-11-11 18:06:14 PST
Created attachment 294574 [details] Rebaselined the test
Ryosuke Niwa
Comment 8 2016-11-11 18:38:10 PST
Created attachment 294579 [details] Fixes the bug
Antti Koivisto
Comment 9 2016-11-11 19:15:43 PST
Comment on attachment 294579 [details] Fixes the bug View in context: https://bugs.webkit.org/attachment.cgi?id=294579&action=review > Source/WebCore/dom/EventPath.cpp:176 > + if (!ambgiousContext.isMouseOrFocusEventContext()) > + continue; > + auto& context = downcast<MouseOrFocusEventContext>(ambgiousContext); is<MouseOrFocusEventContext>() pairs better with the cast than using a member test function. > Source/WebCore/dom/EventPath.cpp:221 > + if (context->isTouchEventContext()) { > + Node* currentRelatedNode = retargeter.currentNode(currentTarget); > + downcast<TouchEventContext>(*context).touchList(touchListType)->append(touch.cloneWithNewTarget(currentRelatedNode)); Same here with is<TouchEventContext>() > Source/WebCore/dom/EventPath.cpp:267 > + if (const DOMWindow* domWindow = const_cast<EventTarget&>(target).toDOMWindow()) { > + targetNode = domWindow->document(); > + ASSERT(targetNode); > + } else > + return path; I'd prefer this in early return style without else.
Ryosuke Niwa
Comment 10 2016-11-11 19:48:56 PST
Created attachment 294584 [details] Patch for landing
WebKit Commit Bot
Comment 11 2016-11-11 19:50:50 PST
Comment on attachment 294584 [details] Patch for landing Rejecting attachment 294584 [details] from commit-queue. Failed to run "['/Volumes/Data/EWS/WebKit/Tools/Scripts/webkit-patch', '--status-host=webkit-queues.webkit.org', '--bot-id=webkit-cq-01', 'validate-changelog', '--check-oops', '--non-interactive', 294584, '--port=mac']" exit_code: 1 cwd: /Volumes/Data/EWS/WebKit ChangeLog entry in LayoutTests/ChangeLog contains OOPS!. Full output: http://webkit-queues.webkit.org/results/2501394
Ryosuke Niwa
Comment 12 2016-11-11 20:00:25 PST
Comment on attachment 294584 [details] Patch for landing Will land with the right reviewer name after waiting for EWS.
Ryosuke Niwa
Comment 13 2016-11-11 21:06:33 PST
Note You need to log in before you can comment on or make changes to this bug.