Bug 150898

Summary: [WK2] Extract networking code out of NetworkResourceLoader class to improve reusability
Product: WebKit Reporter: Chris Dumez <cdumez>
Component: WebKit2Assignee: Chris Dumez <cdumez>
Status: RESOLVED FIXED    
Severity: Normal CC: achristensen, andersca, commit-queue, koivisto, ryanhaddad
Priority: P2    
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on: 150937    
Bug Blocks: 150856    
Attachments:
Description Flags
WIP Patch
none
WIP Patch
none
WIP Patch
none
Patch
none
Patch
none
Patch none

Chris Dumez
Reported 2015-11-04 10:40:46 PST
Extract networking code out of NetworkResourceLoader class to improve reusability (will be used for speculative revalidation) and simplify the NetworkResourceLoader.
Attachments
WIP Patch (73.15 KB, patch)
2015-11-04 10:59 PST, Chris Dumez
no flags
WIP Patch (72.42 KB, patch)
2015-11-04 11:01 PST, Chris Dumez
no flags
WIP Patch (72.80 KB, patch)
2015-11-04 11:08 PST, Chris Dumez
no flags
Patch (75.13 KB, patch)
2015-11-04 11:24 PST, Chris Dumez
no flags
Patch (74.92 KB, patch)
2015-11-04 13:50 PST, Chris Dumez
no flags
Patch (2.17 KB, patch)
2015-11-04 16:41 PST, Chris Dumez
no flags
Chris Dumez
Comment 1 2015-11-04 10:59:53 PST
Created attachment 264799 [details] WIP Patch
Chris Dumez
Comment 2 2015-11-04 11:01:54 PST
Created attachment 264800 [details] WIP Patch
Chris Dumez
Comment 3 2015-11-04 11:08:43 PST
Created attachment 264801 [details] WIP Patch
Chris Dumez
Comment 4 2015-11-04 11:24:20 PST
Alex Christensen
Comment 5 2015-11-04 12:33:34 PST
Comment on attachment 264802 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=264802&action=review r=me with a few comments: > Source/WebKit2/ChangeLog:9 > + reusability (will be used for speculative revalidation) and simplify The speculative revalidator will be a NetworkLoadClient, right? > Source/WebKit2/NetworkProcess/NetworkConnectionToWebProcess.cpp:209 > - loader->handle()->continueDidReceiveResponse(); > + loader->networkLoad()->handle()->continueDidReceiveResponse(); I guess the assumption that the loader has a networkLoad and the networkLoad has a handle is just as good as the old assumption that the we have a loader with a handle. > Source/WebKit2/NetworkProcess/NetworkLoadParameters.cpp:44 > +NetworkLoadParameters::NetworkLoadParameters() > + : webPageID(0) > + , webFrameID(0) > + , sessionID(SessionID::emptySessionID()) > + , contentSniffingPolicy(SniffContent) > + , allowStoredCredentials(DoNotAllowStoredCredentials) > + , clientCredentialPolicy(DoNotAskClientForAnyCredentials) > + , shouldClearReferrerOnHTTPSToHTTPRedirect(true) > + , defersLoading(false) > + , needsCertificateInfo(false) If this constructor is needed, you should have webPageID { 0 }; etc. in the header instead of here. > Source/WebKit2/NetworkProcess/NetworkResourceLoader.cpp:163 > +static NetworkLoadParameters constructNetworkLoadParameters(const NetworkResourceLoadParameters& parameters, const Optional<ResourceRequest>& updatedRequest) This should be an actual constructor.
Chris Dumez
Comment 6 2015-11-04 13:02:43 PST
Comment on attachment 264802 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=264802&action=review >> Source/WebKit2/ChangeLog:9 >> + reusability (will be used for speculative revalidation) and simplify > > The speculative revalidator will be a NetworkLoadClient, right? Yes. >> Source/WebKit2/NetworkProcess/NetworkConnectionToWebProcess.cpp:209 >> + loader->networkLoad()->handle()->continueDidReceiveResponse(); > > I guess the assumption that the loader has a networkLoad and the networkLoad has a handle is just as good as the old assumption that the we have a loader with a handle. That's right. handle() could probably return a reference now though. I'll see if I can make this change. >> Source/WebKit2/NetworkProcess/NetworkLoadParameters.cpp:44 >> + , needsCertificateInfo(false) > > If this constructor is needed, you should have webPageID { 0 }; etc. in the header instead of here. Right, I'll move the initializations inline. >> Source/WebKit2/NetworkProcess/NetworkResourceLoader.cpp:163 >> +static NetworkLoadParameters constructNetworkLoadParameters(const NetworkResourceLoadParameters& parameters, const Optional<ResourceRequest>& updatedRequest) > > This should be an actual constructor. You mean have a NetworkLoadParameters constructor that takes a NetworkResourceLoadParameters in argument?
Alex Christensen
Comment 7 2015-11-04 13:03:32 PST
(In reply to comment #6) > >> Source/WebKit2/NetworkProcess/NetworkResourceLoader.cpp:163 > >> +static NetworkLoadParameters constructNetworkLoadParameters(const NetworkResourceLoadParameters& parameters, const Optional<ResourceRequest>& updatedRequest) > > > > This should be an actual constructor. > > You mean have a NetworkLoadParameters constructor that takes a > NetworkResourceLoadParameters in argument? Yes.
Chris Dumez
Comment 8 2015-11-04 13:50:41 PST
WebKit Commit Bot
Comment 9 2015-11-04 14:40:09 PST
Comment on attachment 264808 [details] Patch Clearing flags on attachment: 264808 Committed r192038: <http://trac.webkit.org/changeset/192038>
WebKit Commit Bot
Comment 10 2015-11-04 14:40:14 PST
All reviewed patches have been landed. Closing bug.
Chris Dumez
Comment 12 2015-11-04 16:28:27 PST
(In reply to comment #11) > This change seems to have caused some new crashes: > > Crashlog > <https://build.webkit.org/results/Apple%20Yosemite%20Debug%20WK2%20(Tests)/ > r192038%20(8097)/fast/inspector-support/matchedrules-crash-log.txt> > > Run: > <https://build.webkit.org/builders/ > Apple%20Yosemite%20Debug%20WK2%20%28Tests%29/builds/8097> It looks like the SandBoxExtension has a non-zero useCount when it is destroyed and therefore hits an assertion. I am trying to figure out how this is possible. NetworkResourceLoader::cleanup() is called and it should revoke the sandbox extension.
Chris Dumez
Comment 13 2015-11-04 16:41:21 PST
Chris Dumez
Comment 14 2015-11-04 16:42:36 PST
Comment on attachment 264808 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=264808&action=review > Source/WebKit2/NetworkProcess/NetworkResourceLoader.cpp:-211 > - return; We used to return early after calling setDefersLoading() on the handle here and I stopped doing this by mistake after my change.
Chris Dumez
Comment 15 2015-11-04 16:55:18 PST
Comment on attachment 264826 [details] Patch Clearing flags on attachment: 264826 Committed r192044: <http://trac.webkit.org/changeset/192044>
Chris Dumez
Comment 16 2015-11-04 16:55:23 PST
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.