Closed Bug 749455 Opened 12 years ago Closed 12 years ago

Click to play brings up missing plugins warning

Categories

(Core Graveyard :: Plug-ins, defect)

15 Branch
x86
Windows 7
defect
Not set
normal

Tracking

(Not tracked)

RESOLVED FIXED
mozilla16

People

(Reporter: mp3geek, Assigned: keeler)

References

Details

Attachments

(1 file, 5 obsolete files)

User Agent: Mozilla/5.0 (Windows NT 6.1; rv:15.0) Gecko/20120424 Firefox/15.0a1
Build ID: 20120424175522

Steps to reproduce:

enable click to play
Visit this site, 
http://arstechnica.com/business/news/2012/04/vmware-confirms-source-code-leak-lulzsec-affiliated-hacker-claims-credit.ars



Actual results:

Yellow bar (missing plugin) comes up


Expected results:

No missing plugins bar should show
confirming with Mozilla/5.0 (Windows NT 6.1; rv:15.0) Gecko/20120427 Firefox/15.0a1 SeaMonkey/2.12a1
Status: UNCONFIRMED → NEW
Component: Untriaged → Plug-ins
Ever confirmed: true
Product: Firefox → Core
QA Contact: untriaged → plugins
Attached patch fix + testcase (obsolete) — Splinter Review
nsObjectLoadingContent::OnStartRequest was perhaps being a bit too strict in deciding when to use mContentType to load a plugin (rather than the type of file indicated in the http response).

The larger problem is that embed/object tags can lie about their content. That is, they can say they're "application/x-shockwave-flash" but serve up a "text/html" file. When this happens, should this be an error? Should there be a notification?
Assignee: nobody → dkeeler
Status: NEW → ASSIGNED
Attachment #619219 - Flags: review?(joshmoz)
Comment on attachment 619219 [details] [diff] [review]
fix + testcase

Canceling r? b/c there might be a more general way to fix these kinds of bugs.
Attachment #619219 - Flags: review?(joshmoz)
Attached patch patch + test (obsolete) — Splinter Review
Ok, I take that back. I think this is the best fix.
Re-uploaded for a rebase, and requesting a review for real this time.
Attachment #619219 - Attachment is obsolete: true
Attachment #622485 - Flags: review?(joshmoz)
Attached patch patch + test (obsolete) — Splinter Review
Meant x-test instead of flash in the test.
Sorry for the bugspam.
Attachment #622485 - Attachment is obsolete: true
Attachment #622485 - Flags: review?(joshmoz)
Attachment #622536 - Flags: review?(joshmoz)
Comment on attachment 622536 [details] [diff] [review]
patch + test

Review of attachment 622536 [details] [diff] [review]:
-----------------------------------------------------------------

::: content/base/src/nsObjectLoadingContent.cpp
@@ +803,5 @@
>    // We want to use the channel type unless one of the following is true:
>    //
>    // 1) The channel type is application/octet-stream and we have a
>    //    type hint and the type hint is not a document type.
>    // 2) Our type hint is a type that we support with a plugin.

These comments need updating. I don't think they accurately reflect the modified form of this condition.

@@ +815,5 @@
>        // because otherwise the default plug-in's catch-all behavior would
>        // confuse things.
> +      ((NS_SUCCEEDED(pluginState) || 
> +        pluginState ==  NS_ERROR_PLUGIN_CLICKTOPLAY) &&
> +       (caps & eSupportPlugins))) {

This 'if' statement is a disaster. The logic is enough to make it hard to read, plus there is a comment in the middle of it now.

I don't want to make this worse. Please find a cleaner way to handle this logic instead of just piling on.
Attachment #622536 - Flags: review?(joshmoz) → review-
Attached patch patch v2 + test (obsolete) — Splinter Review
Re-wrote comment and if statement per Josh's comments. Asking for review again.
Attachment #622536 - Attachment is obsolete: true
Attachment #622770 - Flags: review?(joshmoz)
Comment on attachment 622770 [details] [diff] [review]
patch v2 + test

Review of attachment 622770 [details] [diff] [review]:
-----------------------------------------------------------------

LGTM. However, looking at this method raises a higher-level question: do we really want to let a stream load continue for a click-to-play plugin? Will it cancel the stream at some later point or are we just letting it load while the plugin is in the click-to-play state?
Attachment #622770 - Flags: review?(joshmoz) → review+
(In reply to Josh Aas (Mozilla Corporation) from comment #8)

> LGTM. However, looking at this method raises a higher-level question: do we
> really want to let a stream load continue for a click-to-play plugin? Will
> it cancel the stream at some later point or are we just letting it load
> while the plugin is in the click-to-play state?

If you don't know the answer to this, or the behavior isn't what we want, can you file a bug on this?
This doesn't actually continue the stream for click-to-play plugins - it's just how we determine what (mime) type it is. Given that type, we use it in GetTypeOfContent. If the plugin happens to be click-to-play, GetTypeOfContent returns eType_Null, and the plugin doesn't load. The important part is, when we look up why the type is eType_Null, we know what mime type the content should be, and we make the right decision regarding click-to-play vs. missing plugin.
https://hg.mozilla.org/integration/mozilla-inbound/rev/449229be3db1
Flags: in-testsuite+
Keywords: checkin-needed
Target Milestone: --- → mozilla15
Backed out due to OS X reftest failures.
https://hg.mozilla.org/integration/mozilla-inbound/rev/eadef7d76892

https://tbpl.mozilla.org/php/getParsedLog.php?id=11741654&tree=Mozilla-Inbound
REFTEST TEST-START | http://localhost:4444/1337040818439/327/type-overridden-by-server-ref.html | 5024 / 7610 (66%)
REFTEST TEST-UNEXPECTED-FAIL | file:///Users/cltbld/talos-slave/test/build/reftest/tests/layout/reftests/object/type-overridden-by-server.html | image comparison (==)
REFTEST   IMAGE 1 (TEST): 
REFTEST   IMAGE 2 (REFERENCE): 
REFTEST number of differing pixels: 448 max difference: 255
Target Milestone: mozilla15 → ---
Attached patch patch v3 + test (obsolete) — Splinter Review
On OSX, a quicktime plugin was saying it could handle image types, and so the channel type got overridden (which it shouldn't have). Fixed this by specifically denying image types when checking for plugin support. Asking for review again to make sure this is what we want to do.
Attachment #622770 - Attachment is obsolete: true
Attachment #625188 - Flags: review?(joshmoz)
Comment on attachment 625188 [details] [diff] [review]
patch v3 + test

Review of attachment 625188 [details] [diff] [review]:
-----------------------------------------------------------------

::: content/base/src/nsObjectLoadingContent.cpp
@@ +821,5 @@
> +                          pluginState == NS_ERROR_PLUGIN_CLICKTOPLAY);
> +  PRUint32 caps = GetCapabilities();
> +  bool caseTwo = (pluginSupported && 
> +                  (caps & eSupportPlugins) &&
> +                  typeOfContent != eType_Image);

The idea behind case two seems to be that if we're in a position to possibly load a plugin for the content type, then we want to stick with the content type unless it is also an image type. If the content type is also an image type then we prefer to load based on the channel type. The image-specific check seems arbitrary or incomplete to me, the rest of this comment discusses that.

In the case of the failing reftest in the last patch, the content type indicates a PNG image but the channel type is HTML, and we want the HTML document displayed. Adding 'typeOfContent != eType_Image' in your patch makes this work because it causes us to prefer the channel type over the content type.

The test passes without your patch because 'GetTypeOfContent(mContentType) == eType_Plugin' failed, causing us to prefer the channel type (HTML). It failed because 'GetTypeOfContent' starts off with this code:

1870   if ((caps & eSupportImages) && IsSupportedImage(aMIMEType)) {
1871     return eType_Image;
1872   }

The same method, 'GetTypeOfContent', also does this:

1874   bool isSVG = aMIMEType.LowerCaseEqualsLiteral("image/svg+xml");
1875   bool supportedSVG = isSVG && (caps & eSupportSVG);
1876   if (((caps & eSupportDocuments) || supportedSVG) &&
1877       IsSupportedDocument(aMIMEType)) {
1878     return eType_Document;
1879   }

The image type check in your patch keeps the test passing but like I said before--it seems a bit too arbitrary or incomplete. Without your patch the equivalent logic relates to whether or not the content type is a plugin type, which seems more reasonable. Images are not a plugin type but there are also other non-plugin types, I'm thinking of documents in particular. Perhaps you should also have a '!= eType_Document' check in there? Or perhaps you should flip this around to say '== eType_Plugin || == eType_Null', the latter added case covering your additional acceptance of click-to-play? The former option seems safer - I'd r+ a patch with an added check for '!= eType_Document', but perhaps you have another explanation.
Attached patch patch v4 + testSplinter Review
Ok - I went with adding a check for '!= eType_Document'.
I also started a try run: https://tbpl.mozilla.org/?tree=Try&rev=aaa07b76e73a
Attachment #625188 - Attachment is obsolete: true
Attachment #625188 - Flags: review?(joshmoz)
Attachment #629286 - Flags: review?(joshmoz)
Attachment #629286 - Flags: review?(joshmoz) → review+
https://hg.mozilla.org/mozilla-central/rev/62c03a248faa
Status: ASSIGNED → RESOLVED
Closed: 12 years ago
Resolution: --- → FIXED
How can silverlight prompt to install issue (bug 743102) to be fixed in FF 15b6 and java issue only in FF 16?
Product: Core → Core Graveyard
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: