Closed
Bug 748276
Opened 13 years ago
Closed 13 years ago
Navigation Timing treats javascript: loads as starting a new navigation, which affects all timing for the next navigation in the browsing context
Categories
(Core :: DOM: Navigation, defect)
Tracking
()
RESOLVED
FIXED
mozilla15
People
(Reporter: peter.de.keer, Assigned: bzbarsky)
Details
Attachments
(1 file)
User Agent: Mozilla/5.0 (Windows NT 5.1) AppleWebKit/536.5 (KHTML, like Gecko) Chrome/19.0.1084.30 Safari/536.5 Steps to reproduce: Install bookmarktlet from http://kaaes.github.com/timing/ Go to webpage (to keep it simple) http://www.mozilla.org/robots.txt Click on bookmarktlet => all is good! Wait 5 seconds on page and reload (CTRL+F5, ENTER in url bar) Click on bookmarktlet => wait time on the page is added to Navigation Timing (fetchStart) Expected results: Page spent on the page should not be added to Navigation Timing See behaviour in Google Chrome. These numbers are sent to Google Analytics, and it is there that I viewed strange numbers first. (https://groups.google.com/a/googleproductforums.com/d/topic/analytics/IdxoGvoSDzM/discussion)
Reporter | ||
Comment 1•13 years ago
|
||
Error in my description Expected results: *Time* spent on the page should not be added to Navigation Timing.
Reporter | ||
Comment 2•13 years ago
|
||
created video to try to explain the issue better! http://www.youtube.com/watch?v=1dvZA1ngAc4
Reporter | ||
Comment 3•13 years ago
|
||
The developer of the 'bookmarklet' confirmed it's a bug in firefox and not in her code! https://github.com/kaaes/timing/issues/1 https://skitch.com/kaaes/83aq6/dock
Assignee | ||
Comment 4•13 years ago
|
||
All that's happening here is that the time when the javascript: load starts is being counted as the navigationStart. Olli, Igor, how is this stuff supposed to work, exactly? It looks to me like we're not tracking on the docshell's timing object which channel its doing timing for, which we probably should...
Status: UNCONFIRMED → NEW
Component: Untriaged → Document Navigation
Ever confirmed: true
Product: Firefox → Core
QA Contact: untriaged → docshell
Summary: Navigation Timing adds 'time on page' on fetchStart → Navigation Timing treats javascript: loads as starting a new navigation, which affects all timing for the next navigation in the browsing context
Assignee | ||
Comment 5•13 years ago
|
||
Looking at nsDocShell::InternalLoad, a similar issue would arise if a beforeunload handler disallowed leaving the page. We'd record the navigationStart at the point before running that handler, and then if we managed to leave the page sometime use _that_ navigationStart... I had been going to move the MaybeInitTiming call to the point where we create the channel for the navigation (and thus know whether it's a background channel or not, which would fix the javascript: case), but the beforeunload thing makes that ... complicated. I think I can still fix the javascript: issue, but the beforeunload part will still be broken.
Assignee | ||
Comment 6•13 years ago
|
||
But I still think the right design for the timing stuff would have it know which exact channel it's doing timing for....
Assignee | ||
Comment 7•13 years ago
|
||
Attachment #626317 -
Flags: review?(bugs)
Assignee | ||
Updated•13 years ago
|
Assignee: nobody → bzbarsky
Whiteboard: [need review]
Updated•13 years ago
|
Attachment #626317 -
Flags: review?(bugs) → review+
Assignee | ||
Comment 8•13 years ago
|
||
https://hg.mozilla.org/integration/mozilla-inbound/rev/7e85b068db34 This could really use a test, but testing timing stuff is a PITA. :(
Flags: in-testsuite?
Whiteboard: [need review]
Target Milestone: --- → mozilla15
Comment 9•13 years ago
|
||
https://hg.mozilla.org/mozilla-central/rev/7e85b068db34
Status: NEW → RESOLVED
Closed: 13 years ago
Resolution: --- → FIXED
Reporter | ||
Comment 10•13 years ago
|
||
Is there a browser version of firefox in wich we can test the solution? Nightly? Beta?
Assignee | ||
Comment 11•13 years ago
|
||
Any nightly, for now. In a few days, also Aurora.
Reporter | ||
Comment 12•12 years ago
|
||
OK, thanks, I tested it and it works great! Now I discovered a new bug! https://bugzilla.mozilla.org/show_bug.cgi?id=770463
You need to log in
before you can comment on or make changes to this bug.
Description
•