Bug 166776

Summary: Web Inspector: Resources disappear from the network tab when iframe gets removed from DOM
Product: WebKit Reporter: Ryosuke Niwa <rniwa>
Component: Web InspectorAssignee: Nikita Vasilyev <nvasilyev>
Status: RESOLVED FIXED    
Severity: Normal CC: bburg, commit-queue, inspector-bugzilla-changes, joepeck, nvasilyev, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: Safari Technology Preview   
Hardware: All   
OS: All   
Attachments:
Description Flags
Patch
nvasilyev: commit-queue-
[Animated GIF] With patch applied
none
Patch
mattbaker: review+
Patch none

Ryosuke Niwa
Reported 2017-01-06 13:44:40 PST
Reproduction steps: 1. Open https://polymerlabs.github.io/polymer-tests/polymer-20161208/components/polymer/test/runner.html?grep=unit%2Fbind%5C.html 2. Open Web Inspector’s Network tab 3. Reload Expected Result: It shows the list of all resources being loaded Actual Result: Inspector momentarily shows but removes a whole skew of resources at some point.
Attachments
Patch (1.94 KB, patch)
2017-01-09 13:45 PST, Nikita Vasilyev
nvasilyev: commit-queue-
[Animated GIF] With patch applied (160.41 KB, image/gif)
2017-01-09 14:35 PST, Nikita Vasilyev
no flags
Patch (1.51 KB, patch)
2017-01-10 15:57 PST, Nikita Vasilyev
mattbaker: review+
Patch (1.40 KB, patch)
2017-01-13 19:04 PST, Nikita Vasilyev
no flags
Nikita Vasilyev
Comment 1 2017-01-06 15:17:08 PST
I was able to reproduce it.
Radar WebKit Bug Importer
Comment 2 2017-01-06 15:18:11 PST
Ryosuke Niwa
Comment 3 2017-01-06 15:35:07 PST
Note that this page doesn’t run tests at all after r210052. So use STP20 or a local build before r210052 to see this problem.
Nikita Vasilyev
Comment 4 2017-01-09 11:51:18 PST
The test runner page runs tests in iframes and removes them when a test is finished.
Nikita Vasilyev
Comment 5 2017-01-09 12:05:30 PST
Nikita Vasilyev
Comment 6 2017-01-09 13:45:09 PST
Created attachment 298388 [details] Patch cq- because I'm not yet sure if this doesn't break anything. I need more time to better understand how it works.
Nikita Vasilyev
Comment 7 2017-01-09 14:35:20 PST
Created attachment 298391 [details] [Animated GIF] With patch applied This patch keeps removed iframe resources in the Network tab. It doesn't seem to affect Resources and Debugger. Chrome, for instance, keeps removed iframe resources in their Sources tab. We should probably do the same.
Joseph Pecoraro
Comment 8 2017-01-09 14:36:54 PST
(In reply to comment #7) > Created attachment 298391 [details] > [Animated GIF] With patch applied > > This patch keeps removed iframe resources in the Network tab. It doesn't > seem to affect Resources and Debugger. > > Chrome, for instance, keeps removed iframe resources in their Sources tab. > We should probably do the same. I think this would be some kind of filter of the Resources tab. To show All resources or Active / Live resources. I don't think that by default we should show iframes / Resources in the sidebar that don't exist on the page.
Nikita Vasilyev
Comment 9 2017-01-10 15:57:26 PST
Nikita Vasilyev
Comment 10 2017-01-13 14:12:39 PST
(In reply to comment #8) > (In reply to comment #7) > > Created attachment 298391 [details] > > [Animated GIF] With patch applied > > > > This patch keeps removed iframe resources in the Network tab. It doesn't > > seem to affect Resources and Debugger. > > > > Chrome, for instance, keeps removed iframe resources in their Sources tab. > > We should probably do the same. > > I think this would be some kind of filter of the Resources tab. To show All > resources or Active / Live resources. I don't think that by default we > should show iframes / Resources in the sidebar that don't exist on the page. I think in Network tab we should always show resources regardless if they're still attached to the DOM or not. I'm not opposed of the idea of adding a filter button to Resources (and Debugger tab?). However, I've never felt the need for it and I don't know what's the use case for it. I think it should be done as a separate task.
Blaze Burg
Comment 11 2017-01-13 17:08:02 PST
(In reply to comment #10) > (In reply to comment #8) > > (In reply to comment #7) > > > Created attachment 298391 [details] > > > [Animated GIF] With patch applied > > > > > > This patch keeps removed iframe resources in the Network tab. It doesn't > > > seem to affect Resources and Debugger. > > > > > > Chrome, for instance, keeps removed iframe resources in their Sources tab. > > > We should probably do the same. > > > > I think this would be some kind of filter of the Resources tab. To show All > > resources or Active / Live resources. I don't think that by default we > > should show iframes / Resources in the sidebar that don't exist on the page. > > I think in Network tab we should always show resources regardless if they're > still attached to the DOM or not. Resources are (conceptually) attached to a ScriptExecutionContext or something similarly per-document or per-frame, not the DOM. In reality, CachedResource objects can be kept alive by all kinds of things. > > I'm not opposed of the idea of adding a filter button to Resources (and > Debugger tab?). However, I've never felt the need for it and I don't know > what's the use case for it. I think it should be done as a separate task. The use case is to debug sites like the one linked by Ryosuke. This is not the normal case, so it should be an optional behavior. Furthermore, I would argue that even with this special filter that shows more resources, we should discard all resources when the main frame navigates. His bug was about subframe resources being lost/inaccessible for setting breakpoints.
Blaze Burg
Comment 12 2017-01-13 17:11:50 PST
(In reply to comment #10) > (In reply to comment #8) > > (In reply to comment #7) > > > Created attachment 298391 [details] > > > [Animated GIF] With patch applied > > > > > > This patch keeps removed iframe resources in the Network tab. It doesn't > > > seem to affect Resources and Debugger. > > > > > > Chrome, for instance, keeps removed iframe resources in their Sources tab. > > > We should probably do the same. > > > > I think this would be some kind of filter of the Resources tab. To show All > > resources or Active / Live resources. I don't think that by default we > > should show iframes / Resources in the sidebar that don't exist on the page. > > I think in Network tab we should always show resources regardless if they're > still attached to the DOM or not. Technicalities aside, I think reviewers (per IRC) are in agreement that Network Tab should be a transcript of all resource loads, regardless of whether or not the page uses them any more. So this bug can move forward. See <https://bugs.webkit.org/show_bug.cgi?id=167038> to discuss how this should be handled in other tabs that show resources (not loads).
Joseph Pecoraro
Comment 13 2017-01-13 17:15:25 PST
Comment on attachment 298518 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=298518&action=review > Source/WebInspectorUI/UserInterface/Views/NetworkSidebarPanel.js:31 > + const shouldAutoPruneStaleTopLevelResourceTreeElements = false; > + super("network", WebInspector.UIString("Network"), shouldAutoPruneStaleTopLevelResourceTreeElements); What happens on main frame navigations? shouldAutoPrune included a handler for MainResourceDidChange. Does the Network Tab get reset in another way on main frame navigations?
Nikita Vasilyev
Comment 14 2017-01-13 17:36:43 PST
(In reply to comment #13) > Comment on attachment 298518 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=298518&action=review > > > Source/WebInspectorUI/UserInterface/Views/NetworkSidebarPanel.js:31 > > + const shouldAutoPruneStaleTopLevelResourceTreeElements = false; > > + super("network", WebInspector.UIString("Network"), shouldAutoPruneStaleTopLevelResourceTreeElements); > > What happens on main frame navigations? shouldAutoPrune included a handler > for MainResourceDidChange. Does the Network Tab get reset in another way on > main frame navigations? Yes, Network Tab gets reset by TimelineManager: _mainResourceDidChange(event) { let frame = event.target; if (frame.isMainFrame()) this._persistentNetworkTimeline.reset();
Matt Baker
Comment 15 2017-01-13 18:46:28 PST
Comment on attachment 298518 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=298518&action=review >>> Source/WebInspectorUI/UserInterface/Views/NetworkSidebarPanel.js:31 >>> + super("network", WebInspector.UIString("Network"), shouldAutoPruneStaleTopLevelResourceTreeElements); >> >> What happens on main frame navigations? shouldAutoPrune included a handler for MainResourceDidChange. Does the Network Tab get reset in another way on main frame navigations? > > Yes, Network Tab gets reset by TimelineManager: > > _mainResourceDidChange(event) > { > let frame = event.target; > if (frame.isMainFrame()) > this._persistentNetworkTimeline.reset(); Let's be consistent with StorageSidebarPanel and omit the third argument rather than passing false explicitly.
Nikita Vasilyev
Comment 16 2017-01-13 19:04:35 PST
WebKit Commit Bot
Comment 17 2017-01-13 19:41:58 PST
Comment on attachment 298827 [details] Patch Clearing flags on attachment: 298827 Committed r210759: <http://trac.webkit.org/changeset/210759>
WebKit Commit Bot
Comment 18 2017-01-13 19:42:03 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.