Bug 97532

Summary: [WK2][WTR] WTR bundle client loads binary data as text
Product: WebKit Reporter: Mikhail Pozdnyakov <mikhail.pozdnyakov>
Component: WebKit2Assignee: Mikhail Pozdnyakov <mikhail.pozdnyakov>
Status: RESOLVED FIXED    
Severity: Normal CC: benjamin, gyuyoung.kim, kenneth, rakuco, webkit.review.bot
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
patch
none
patch v2 none

Mikhail Pozdnyakov
Reported 2012-09-25 00:06:20 PDT
Currently InjectedBundlePage::decidePolicyForResponse always returns WKBundlePagePolicyActionUse even for Response MIME types that cannot be shown. This causes failing of http/tests/loading/text-content-type-with-binary-extension.html test, which checks that binary data is not loaded as text.
Attachments
patch (7.60 KB, patch)
2012-09-25 00:29 PDT, Mikhail Pozdnyakov
no flags
patch v2 (7.78 KB, patch)
2012-09-25 01:23 PDT, Mikhail Pozdnyakov
no flags
Mikhail Pozdnyakov
Comment 1 2012-09-25 00:29:29 PDT
Created attachment 165539 [details] patch WTR::InjectedBundlePage::decidePolicyForResponse now checks response MIME type and returns WKBundlePagePolicyActionPassThrough (skips for handling by UI process) if it cannot be shown.
Kenneth Rohde Christiansen
Comment 2 2012-09-25 00:43:36 PDT
Comment on attachment 165539 [details] patch View in context: https://bugs.webkit.org/attachment.cgi?id=165539&action=review > Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundlePage.cpp:419 > +// This function is here to keep consistency with WebKit::WebPageProxy::canShowMIMEType(). > +// Actually it does not need anything from page. > +bool WKBundlePageCanShowMIMEType(WKBundlePageRef, WKStringRef mimeTypeRef) Isn't that comment better in the changelog? I think so. Also could it potentially need something from page in the future?
Mikhail Pozdnyakov
Comment 3 2012-09-25 01:23:03 PDT
Created attachment 165551 [details] patch v2 Rebased. Took comments from Kenneth into consideration.
Mikhail Pozdnyakov
Comment 4 2012-09-25 01:27:38 PDT
> Also could it potentially need something from page in the future? Potentially maybe, but I don't think we will need it in WTR.
WebKit Review Bot
Comment 5 2012-09-25 02:19:38 PDT
Comment on attachment 165551 [details] patch v2 Clearing flags on attachment: 165551 Committed r129479: <http://trac.webkit.org/changeset/129479>
WebKit Review Bot
Comment 6 2012-09-25 02:19:42 PDT
All reviewed patches have been landed. Closing bug.
Raphael Kubo da Costa (:rakuco)
Comment 7 2012-09-25 07:16:44 PDT
Crash in fast/loader/reload-zero-byte-plugin.html on EFL being tracked in bug 97565.
Raphael Kubo da Costa (:rakuco)
Comment 8 2012-09-25 08:11:40 PDT
Could you also please check if the failure in http/tests/security/contentSecurityPolicy/object-src-url-allowed.html is related to this change?
Benjamin Poulain
Comment 9 2012-09-25 12:28:15 PDT
Comment on attachment 165551 [details] patch v2 View in context: https://bugs.webkit.org/attachment.cgi?id=165551&action=review > Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundlePage.cpp:420 > +bool WKBundlePageCanShowMIMEType(WKBundlePageRef, WKStringRef mimeTypeRef) > +{ > + using WebCore::MIMETypeRegistry; Why do your own thing instead of moving the code of WebPageProxy::canShowMIMEType() in a better place?? > Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundlePage.cpp:422 > + const WTF::String mimeType = toImpl(mimeTypeRef)->string(); This should be toWTFString. You should not prefix String with WTF::
Mikhail Pozdnyakov
Comment 10 2012-09-25 23:49:09 PDT
(In reply to comment #9) > (From update of attachment 165551 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=165551&action=review > > > Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundlePage.cpp:420 > > +bool WKBundlePageCanShowMIMEType(WKBundlePageRef, WKStringRef mimeTypeRef) > > +{ > > + using WebCore::MIMETypeRegistry; > > Why do your own thing instead of moving the code of WebPageProxy::canShowMIMEType() in a better place?? Actually this code can be shared even better :) please take a look at bug97547. > > > Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundlePage.cpp:422 > > + const WTF::String mimeType = toImpl(mimeTypeRef)->string(); > > This should be toWTFString. As far as I see toWTFString is declared in ./Tools/WebKitTestRunner/StringFunctions.h which is not part of WebKit source.
Benjamin Poulain
Comment 11 2012-09-26 11:29:04 PDT
> > Why do your own thing instead of moving the code of WebPageProxy::canShowMIMEType() in a better place?? > > Actually this code can be shared even better :) please take a look at bug97547. Good. It would have be nice doing that beforehand. > > > Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundlePage.cpp:422 > > > + const WTF::String mimeType = toImpl(mimeTypeRef)->string(); > > > > This should be toWTFString. > As far as I see toWTFString is declared in ./Tools/WebKitTestRunner/StringFunctions.h which is not part of WebKit source. No. See WKSharedAPICast.h
Mikhail Pozdnyakov
Comment 12 2012-09-26 13:34:51 PDT
(In reply to comment #11) > > No. > See WKSharedAPICast.h Oh, OK. Thanks for pointing this out. Strange that toWTFString is not used anywhere in Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundlePage.cpp, and I guess it should be fixed everywhere than..
Mikhail Pozdnyakov
Comment 13 2012-09-27 01:18:31 PDT
Strange that toWTFString is not used anywhere in Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundlePage.cpp, > and I guess it should be fixed everywhere than.. addressed in https://bugs.webkit.org/show_bug.cgi?id=97766
Note You need to log in before you can comment on or make changes to this bug.