Closed
      
        Bug 1217571
      
      
        Opened 10 years ago
          Closed 9 years ago
      
        
    
  
The imagelib cache is broken in e10s
Categories
(Core :: Graphics: ImageLib, defect)
        Core
          
        
        
      
        
    
        Graphics: ImageLib
          
        
        
      
        
    Tracking
()
        RESOLVED
        FIXED
        
    
  
        
            mozilla45
        
    
  
People
(Reporter: ehsan.akhgari, Assigned: froydnj)
References
(Depends on 1 open bug, Blocks 1 open bug)
Details
(Whiteboard: [MemShrink])
Attachments
(2 files)
| 6.82 KB,
          patch         | seth
:
              
              review+ ritu
:
              
              approval-mozilla-aurora+ | Details | Diff | Splinter Review | 
| 3.71 KB,
          patch         | seth
:
              
              review+ ritu
:
              
              approval-mozilla-aurora+ | Details | Diff | Splinter Review | 
The imagelib cache is completely broken as far as I can tell in e10s, in that it seems to be putting things into the cache, and then not using them.
The reason why this happens is that it tries to QI an nsIChannel to an nsICachingChannel to get two bits of information:
* whether the channel is cached (by calling IsFromCache())
* the expiry time of a cache entry (in the beginning of imgRequest::SetCacheValidation())
In the child process, the QIs return null and therefore we can't obtain either of the above bits of info.
| Reporter | ||
| Comment 1•10 years ago
           | ||
Note that I found this by noticing that my test for bug 1206298 is failing in the non-e10s case.  I'm going to land the test there with those checks commented out, please uncomment them when this bug is fixed.  Thanks!
| Updated•9 years ago
           | 
Assignee: nobody → mrbkap
Flags: needinfo?(mrbkap)
| Comment 2•9 years ago
           | ||
Thanks for noticing this, Ehsan.
The fix is to QI the channel to nsICacheInfoChannel (which has the expiration and isFromCache APIs). 
Historical note: we split out nsICacheInfoChannel as a base class for nsICachingChannel when we did e10s, since we can't support all the APIs in nsICachingChannel on the child.  Child channels only implement nsICacheInfoChannel while parent channels implement the full API.
Flags: needinfo?(mrbkap)
|   | ||
| Updated•9 years ago
           | 
| Updated•9 years ago
           | 
Whiteboard: [MemShrink]
|   | Assignee | |
| Comment 3•9 years ago
           | ||
nsICachingChannel isn't available in the child process; we have to use
nsICacheInfoChannel instead.
The fixes to the service worker tests come from comment 1; I'm assuming that
part is rs=ehsan, since he left a comment about fixing them in the file.
        Attachment #8686740 -
        Flags: review?(seth)
| Comment 4•9 years ago
           | ||
Comment on attachment 8686740 [details] [diff] [review]
fix the imagelib cache to work in e10s
Review of attachment 8686740 [details] [diff] [review]:
-----------------------------------------------------------------
Nice!
::: dom/workers/test/serviceworkers/test_imagecache_max_age.html
@@ +41,5 @@
>            break;
>          case 2:
>            is(e.data.url, "image-40px.png", "Correct url expected");
>            is(e.data.url2, "image-40px.png", "Correct url expected");
> +          is(e.data.width, 40, "Correct width expected");
Splinter doesn't let me see the whole file, so maybe this is obvious in the broader context, but it might be nice to add a comment here clarifying what this is testing.
        Attachment #8686740 -
        Flags: review?(seth) → review+
|   | Assignee | |
| Comment 5•9 years ago
           | ||
        Attachment #8686786 -
        Flags: review?(seth)
| Comment 6•9 years ago
           | ||
Comment on attachment 8686786 [details] [diff] [review]
add a smoketest for the image cache
Review of attachment 8686786 [details] [diff] [review]:
-----------------------------------------------------------------
LGTM!
::: image/test/mochitest/test_bug1217571.html
@@ +25,5 @@
> +  var iframes = document.getElementsByTagName("iframe");
> +  var imgs = Array.from(iframes, function (f) {
> +      return SpecialPowers.wrap(f.contentDocument.getElementsByTagName("img")[0]);
> +  });
> +  var containers = imgs.map(function (img) {
Love it, so functional.
        Attachment #8686786 -
        Flags: review?(seth) → review+
| Updated•9 years ago
           | 
Assignee: mrbkap → nfroyd
|   | ||
| Comment 8•9 years ago
           | ||
| bugherder | ||
Status: NEW → RESOLVED
Closed: 9 years ago
          status-firefox45:
          --- → fixed
Resolution: --- → FIXED
Target Milestone: --- → mozilla45
| Comment 9•9 years ago
           | ||
Nathan, can you get this uplifted to Aurora?  Seems it might be important for b2g 2.5 (which gets merges from Aurora).
Flags: needinfo?(nfroyd)
|   | Assignee | |
| Comment 10•9 years ago
           | ||
(In reply to Ben Kelly [:bkelly] from comment #9)
> Nathan, can you get this uplifted to Aurora?  Seems it might be important
> for b2g 2.5 (which gets merges from Aurora).
Yes!
Flags: needinfo?(nfroyd)
|   | Assignee | |
| Comment 11•9 years ago
           | ||
Comment on attachment 8686740 [details] [diff] [review]
fix the imagelib cache to work in e10s
This approval request is for both patches; this patch is the real fix, and the other patch is a test to try and ensure we don't regress this again.  (I collapsed them into a single commit for pushing to m-i.)
Approval Request Comment
[Feature/regressing bug #]: Unsure...possibly as long as we have had e10s?
[User impact if declined]: Slower browser, more jank.
[Describe test coverage new/current, TreeHerder]: The imagelib cache is well tested, and this patch just flips it back on.
[Risks and why]: Low risk
[String/UUID change made/needed]: None.
        Attachment #8686740 -
        Flags: approval-mozilla-aurora?
Nathan, just wondering, does the service workers test that was un-commented pass with this fix?
Flags: needinfo?(nfroyd)
Comment on attachment 8686740 [details] [diff] [review]
fix the imagelib cache to work in e10s
This fix has been in Nightly for 3 days, seems safe to uplift to Aurora44. It has also has automated tests which is always great.
        Attachment #8686740 -
        Flags: approval-mozilla-aurora? → approval-mozilla-aurora+
Comment on attachment 8686786 [details] [diff] [review]
add a smoketest for the image cache
Both patches need to be uplifted. This is a test only patch afaik.
        Attachment #8686786 -
        Flags: approval-mozilla-aurora+
          status-firefox44:
          --- → affected
          tracking-firefox44:
          --- → +
|   | ||
| Comment 16•9 years ago
           | ||
(In reply to Ritu Kothari (:ritu) from comment #15)
> Comment on attachment 8686786 [details] [diff] [review]
> add a smoketest for the image cache
> 
> Both patches need to be uplifted. This is a test only patch afaik.
the 2 patches were folded into one checkin.
https://hg.mozilla.org/releases/mozilla-aurora/rev/40f1515c4d05
|   | Assignee | |
| Comment 17•9 years ago
           | ||
(In reply to Ritu Kothari (:ritu) from comment #13)
> Nathan, just wondering, does the service workers test that was un-commented
> pass with this fix?
As far as I could tell, it passed with and without this fix; I'm not sure what Ehsan was seeing previously.  It is possible that I got my test invocations mixed up, though...
Flags: needinfo?(nfroyd)
          You need to log in
          before you can comment on or make changes to this bug.
        
Description
•