Bug 26655

Summary: ResourceHandle infrastructure is needed to support loading out of an appcache
Product: WebKit Reporter: Michael Nordman <michaeln>
Component: WebCore Misc.Assignee: Michael Nordman <michaeln>
Status: RESOLVED WONTFIX    
Severity: Normal CC: andersca, ap, eric
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: PC   
OS: OS X 10.5   
Attachments:
Description Flags
Interceptor (rev1)
none
Interceptor (rev2)
none
Interceptor (rev2) none

Michael Nordman
Reported 2009-06-23 12:46:38 PDT
This bug was split off of https://bugs.webkit.org/show_bug.cgi?id=25436. Please see the discussion there about the reason for this. Preliminary patch forth coming.
Attachments
Interceptor (rev1) (43.87 KB, patch)
2009-06-23 14:32 PDT, Michael Nordman
no flags
Interceptor (rev2) (69.26 KB, patch)
2009-06-24 15:16 PDT, Michael Nordman
no flags
Interceptor (rev2) (133.50 KB, patch)
2009-07-01 09:49 PDT, Michael Nordman
no flags
Michael Nordman
Comment 1 2009-06-23 14:32:49 PDT
Created attachment 31738 [details] Interceptor (rev1) Looking for some preliminary feedback on this new piece of webcore resource handle infrastructure. These changes allow an 'interceptor' to hijack ResourceHandle requests and to provide response data instead of actually going to the network. The approach taken in this preliminary patch ripples into the platform specific resourcehandleXXX.cpp files more than i would like. Its doable, just very platform specific. Another approach would be to introduce a new ResourceHandle class into the hierarchy that 'wraps' the existing class. Something like... * rename existing ResourceHandle.h cpp --> PlatformResourceHandle.h cpp * introduce new ResourceHandle.h cpp with same interface as existing class, but have it use ResourceHandleInterceptorHost and PlatformResourceHandle for everything under the covers. I'm preparing another patch with that hoist usage of the ResourceHandleInterceptorHost into a new wrapper class as described above.
Michael Nordman
Comment 2 2009-06-24 15:16:30 PDT
Created attachment 31813 [details] Interceptor (rev2) Uploaded another stab it using the "other approach"... the wrapper class * renamed existing ResourceHandle.h cpp --> PlatformResourceHandle.h cpp * introduced new ResourceHandle.h cpp with same interface as existing class, but have it use the PlatformResourceHandle for everything * bake ResourceHandleInterceptor usage into the new class The good thing about this approach is that it only calls for entirely mechanical changes to the existing platorm specific ResourceHandle impls... simple class name changes. Still just looking for preliminary comments right now. An obvious thing thats needed are test cases. Incidentally, chrome has the moral equivalent, URLRequest::Interceptor, in place for this already... http://codereview.chromium.org/67019... including a decent set of test cases. I'll be looking to implement similar tests for this ResourceHandle Intercepor stuff.
Eric Seidel (no email)
Comment 3 2009-06-30 03:19:25 PDT
Comment on attachment 31738 [details] Interceptor (rev1) It appears that this patch should have been obsoleted.
Eric Seidel (no email)
Comment 4 2009-06-30 03:20:22 PDT
Comment on attachment 31813 [details] Interceptor (rev2) This patch needs ChangeLogs to explain what your doing. http://webkit.org/coding/contributing.html
Michael Nordman
Comment 5 2009-06-30 16:08:56 PDT
I've unobsoleted the initial patch. Patch rev1 and rev2 represent different approaches. I'm looking for preliminary comments including which of these approaches looks more promising. There's no change log entry yet, just looking for initial comments right now. Please see the discussion in https://bugs.webkit.org/show_bug.cgi?id=25436 for the explanation.
Michael Nordman
Comment 6 2009-06-30 19:34:32 PDT
I've been pushing on the second approach (rev2) since initially uploading since that's the direction that Alexey and I had discussed taking. Here's an update... * rev2 as uploaded builds and runs in chrome as is (with simple mechanical changes to chrome platform specific files to deal with the rename to PlatformResourceHandle) * moved this over to a mac webkit client * did the obvious class name change work in ResourceHandleMac.mm * did the less obvious class name change work in FormDataStreamMac.h .mm * addressed some some gcc vs msvc issues to get things to compile * fleshed out the PLATFORM(MAC) parts of ResourceHandle.h .cpp to make the linker happy * build and runs and passes unit tests (modulo few items that i think were also failing prior to patching anything in) I still don't have good automated tests for this, but manual testing (using the TestInterceptor class in the patch) is looking good. The 'intercept_main', 'intercept_response', 'intercept_redirect', 'intercept_error', and 'restart_wo_interception' cases are working for me. Cheers
Michael Nordman
Comment 7 2009-07-01 09:49:40 PDT
Created attachment 32128 [details] Interceptor (rev2) Here's an updated patch that working for me on Safari/mac.
Eric Seidel (no email)
Comment 8 2009-07-15 16:15:12 PDT
133k is too large for me to review. But maybe you've been working with a reviewer who can understand this huge patch?
Michael Nordman
Comment 9 2009-07-15 16:34:33 PDT
This is patch is really here more for proof-of-concept purposes, I'm not looking to submit anything like this at this time. Appropriate folks are taking a look.
David Levin
Comment 10 2009-07-16 10:53:49 PDT
Comment on attachment 32128 [details] Interceptor (rev2) Clearing r? to move this out of the review queue since Michael Nordman stated "This is patch is really here more for proof-of-concept purposes, I'm not looking to submit anything like this at this time."
David Levin
Comment 11 2009-07-16 10:54:18 PDT
Comment on attachment 31738 [details] Interceptor (rev1) Clearing r? to move this out of the review queue since Michael Nordman stated "This is patch is really here more for proof-of-concept purposes, I'm not looking to submit anything like this at this time."
Michael Nordman
Comment 12 2009-07-29 16:18:40 PDT
Closing... The webkit team has other plans in mind. We'll have to wait and see what that looks like. In the meantime, the chrome team is going to build its own appcache system as what webcore currently has to offer just plain don't work for us.
Note You need to log in before you can comment on or make changes to this bug.