Bug 177718

Summary: Add support for DOM aborting (https://dom.spec.whatwg.org/#aborting-ongoing-activities)
Product: WebKit Reporter: Sam Weinig <sam>
Component: New BugsAssignee: Sam Weinig <sam>
Status: RESOLVED FIXED    
Severity: Normal CC: buildbot, cdumez, darin, keith_miller, rniwa, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
URL: https://dom.spec.whatwg.org/#aborting-ongoing-activities
Attachments:
Description Flags
Patch
darin: review+, buildbot: commit-queue-
Archive of layout-test-results from ews100 for mac-elcapitan
none
Archive of layout-test-results from ews105 for mac-elcapitan-wk2
none
Archive of layout-test-results from ews114 for mac-elcapitan
none
Archive of layout-test-results from ews126 for ios-simulator-wk2 none

Sam Weinig
Reported 2017-10-01 08:57:29 PDT
Add support for AbortController / AbortSignal as a first step to supporting abort for fetch().
Attachments
Patch (62.83 KB, patch)
2017-10-01 12:28 PDT, Sam Weinig
darin: review+
buildbot: commit-queue-
Archive of layout-test-results from ews100 for mac-elcapitan (1.09 MB, application/zip)
2017-10-01 13:49 PDT, Build Bot
no flags
Archive of layout-test-results from ews105 for mac-elcapitan-wk2 (1.28 MB, application/zip)
2017-10-01 13:54 PDT, Build Bot
no flags
Archive of layout-test-results from ews114 for mac-elcapitan (1.92 MB, application/zip)
2017-10-01 14:02 PDT, Build Bot
no flags
Archive of layout-test-results from ews126 for ios-simulator-wk2 (1.09 MB, application/zip)
2017-10-01 14:15 PDT, Build Bot
no flags
Sam Weinig
Comment 1 2017-10-01 12:28:34 PDT
Darin Adler
Comment 2 2017-10-01 13:40:18 PDT
Comment on attachment 322325 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=322325&action=review Looks like the tests aren’t passing yet. > Source/WebCore/dom/AbortController.h:46 > + AbortController(ScriptExecutionContext&); I think explicit would be good. > Source/WebCore/dom/AbortSignal.cpp:53 > + // 1. If signalâs aborted flag is set, then return. Straighten the quotes perhaps? Not sure how we feel about UTF-8 in our sources. > Source/WebCore/dom/AbortSignal.h:37 > +class AbortSignal final : public RefCounted<AbortSignal>, public EventTargetWithInlineData, public ContextDestructionObserver { Can we derive privately from ContextDestructionObserver? > Source/WebCore/dom/AbortSignal.h:40 > + ~AbortSignal(); I think we can just leave this out and let it get generated. > Source/WebCore/dom/AbortSignal.h:47 > + using RefCounted<AbortSignal>::ref; > + using RefCounted<AbortSignal>::deref; Here inside the class you can write this without repeating the template argument: using RefCounted::ref; using RefCounted::deref; > Source/WebCore/dom/AbortSignal.h:50 > + AbortSignal(ScriptExecutionContext&); I suggest explicit here. > Source/WebCore/dom/AbortSignal.h:52 > + // EventTargetWithInlineData. Not personally a huge fan of comments citing which class we are implementing virtual function overrides for. > Source/WebCore/dom/AbortSignal.h:56 > + EventTargetInterface eventTargetInterface() const override { return AbortSignalEventTargetInterfaceType; } > + ScriptExecutionContext* scriptExecutionContext() const override { return ContextDestructionObserver::scriptExecutionContext(); } > + void refEventTarget() override { ref(); } > + void derefEventTarget() override { deref(); } I suggest final rather than override.
Build Bot
Comment 3 2017-10-01 13:49:50 PDT
Comment on attachment 322325 [details] Patch Attachment 322325 [details] did not pass mac-ews (mac): Output: http://webkit-queues.webkit.org/results/4716999 New failing tests: imported/w3c/web-platform-tests/fetch/api/abort/general.any.html imported/w3c/web-platform-tests/dom/interfaces.html js/dom/global-constructors-attributes-dedicated-worker.html imported/w3c/web-platform-tests/fetch/api/abort/general.any.worker.html
Build Bot
Comment 4 2017-10-01 13:49:51 PDT
Created attachment 322329 [details] Archive of layout-test-results from ews100 for mac-elcapitan The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: ews100 Port: mac-elcapitan Platform: Mac OS X 10.11.6
Build Bot
Comment 5 2017-10-01 13:54:19 PDT
Comment on attachment 322325 [details] Patch Attachment 322325 [details] did not pass mac-wk2-ews (mac-wk2): Output: http://webkit-queues.webkit.org/results/4717005 New failing tests: imported/w3c/web-platform-tests/fetch/api/abort/general.any.html imported/w3c/web-platform-tests/dom/interfaces.html imported/w3c/web-platform-tests/payment-request/interfaces.https.html js/dom/global-constructors-attributes-dedicated-worker.html imported/w3c/web-platform-tests/fetch/api/abort/general.any.worker.html
Build Bot
Comment 6 2017-10-01 13:54:20 PDT
Created attachment 322330 [details] Archive of layout-test-results from ews105 for mac-elcapitan-wk2 The attached test failures were seen while running run-webkit-tests on the mac-wk2-ews. Bot: ews105 Port: mac-elcapitan-wk2 Platform: Mac OS X 10.11.6
Build Bot
Comment 7 2017-10-01 14:02:21 PDT
Comment on attachment 322325 [details] Patch Attachment 322325 [details] did not pass mac-debug-ews (mac): Output: http://webkit-queues.webkit.org/results/4717011 New failing tests: imported/w3c/web-platform-tests/fetch/api/abort/general.any.html imported/w3c/web-platform-tests/fetch/api/abort/general.any.worker.html js/dom/global-constructors-attributes-dedicated-worker.html
Build Bot
Comment 8 2017-10-01 14:02:23 PDT
Created attachment 322332 [details] Archive of layout-test-results from ews114 for mac-elcapitan The attached test failures were seen while running run-webkit-tests on the mac-debug-ews. Bot: ews114 Port: mac-elcapitan Platform: Mac OS X 10.11.6
Sam Weinig
Comment 9 2017-10-01 14:07:36 PDT
(In reply to Darin Adler from comment #2) > Comment on attachment 322325 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=322325&action=review > > Looks like the tests aren’t passing yet. Yup, got more to rebase. > > > Source/WebCore/dom/AbortController.h:46 > > + AbortController(ScriptExecutionContext&); > > I think explicit would be good. Will change. > > > Source/WebCore/dom/AbortSignal.cpp:53 > > + // 1. If signalâs aborted flag is set, then return. > > Straighten the quotes perhaps? Not sure how we feel about UTF-8 in our > sources. I'm personally fine with it. I'm not sure what good reasons there are to limit our selves. > > > Source/WebCore/dom/AbortSignal.h:37 > > +class AbortSignal final : public RefCounted<AbortSignal>, public EventTargetWithInlineData, public ContextDestructionObserver { > > Can we derive privately from ContextDestructionObserver? Probably. Will find out. > > > Source/WebCore/dom/AbortSignal.h:40 > > + ~AbortSignal(); > > I think we can just leave this out and let it get generated. Yup. At one point I had a member I didn't want to #include the header of, but it's not there anymore. > > > Source/WebCore/dom/AbortSignal.h:47 > > + using RefCounted<AbortSignal>::ref; > > + using RefCounted<AbortSignal>::deref; > > Here inside the class you can write this without repeating the template > argument: > > using RefCounted::ref; > using RefCounted::deref; > Neat. > > Source/WebCore/dom/AbortSignal.h:50 > > + AbortSignal(ScriptExecutionContext&); > > I suggest explicit here. Will do. > > > Source/WebCore/dom/AbortSignal.h:52 > > + // EventTargetWithInlineData. > > Not personally a huge fan of comments citing which class we are implementing > virtual function overrides for. I'll remove it. I was cargo-culting my way through adding an EventTarget. > > > Source/WebCore/dom/AbortSignal.h:56 > > + EventTargetInterface eventTargetInterface() const override { return AbortSignalEventTargetInterfaceType; } > > + ScriptExecutionContext* scriptExecutionContext() const override { return ContextDestructionObserver::scriptExecutionContext(); } > > + void refEventTarget() override { ref(); } > > + void derefEventTarget() override { deref(); } > > I suggest final rather than override. Will do.
Build Bot
Comment 10 2017-10-01 14:15:09 PDT
Comment on attachment 322325 [details] Patch Attachment 322325 [details] did not pass ios-sim-ews (ios-simulator-wk2): Output: http://webkit-queues.webkit.org/results/4717035 New failing tests: imported/w3c/web-platform-tests/fetch/api/abort/general.any.html imported/w3c/web-platform-tests/fetch/api/abort/general.any.worker.html imported/w3c/web-platform-tests/payment-request/interfaces.https.html js/dom/global-constructors-attributes-dedicated-worker.html imported/w3c/web-platform-tests/dom/interfaces.html
Build Bot
Comment 11 2017-10-01 14:15:10 PDT
Created attachment 322333 [details] Archive of layout-test-results from ews126 for ios-simulator-wk2 The attached test failures were seen while running run-webkit-tests on the ios-sim-ews. Bot: ews126 Port: ios-simulator-wk2 Platform: Mac OS X 10.12.6
Sam Weinig
Comment 12 2017-10-01 15:33:00 PDT
Radar WebKit Bug Importer
Comment 13 2017-10-01 15:33:27 PDT
Sam Weinig
Comment 14 2017-10-01 18:36:20 PDT
Update TestExpectations for new flakey test that this triggered (the test itself is flakey when failing) with r222694.
Keith Miller
Comment 15 2017-10-06 10:34:26 PDT
Comment on attachment 322325 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=322325&action=review > Source/WebCore/DerivedSources.make:411 > + $(WebCore)/dom/AbortController.idl \ > + $(WebCore)/dom/AbortController.idl \ Was there a reason you added this idl twice? Can I remove the duplicate?
Sam Weinig
Comment 16 2017-10-06 15:17:07 PDT
(In reply to Keith Miller from comment #15) > Comment on attachment 322325 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=322325&action=review > > > Source/WebCore/DerivedSources.make:411 > > + $(WebCore)/dom/AbortController.idl \ > > + $(WebCore)/dom/AbortController.idl \ > > Was there a reason you added this idl twice? Can I remove the duplicate? It was a mistake. You can remove it!
Note You need to log in before you can comment on or make changes to this bug.