Sessions restore windows in random order
Categories
(Firefox :: Session Restore, defect, P2)
Tracking
()
People
(Reporter: racecarlock, Unassigned)
References
(Depends on 1 open bug, Blocks 6 open bugs)
Details
(Keywords: helpwanted, regression, Whiteboard: [fidefe-session-restore] See comment 104 for possible solution)
| Comment 4•9 years ago
           | ||
| Reporter | ||
| Comment 5•9 years ago
           | ||
| Reporter | ||
| Updated•9 years ago
           | 
|   | ||
| Updated•8 years ago
           | 
| Comment 8•8 years ago
           | ||
|   | ||
| Updated•8 years ago
           | 
| Comment 10•8 years ago
           | ||
| Comment 11•8 years ago
           | ||
|   | ||
| Comment 12•8 years ago
           | ||
| Comment 13•8 years ago
           | ||
| Comment 14•8 years ago
           | ||
|   | ||
| Comment 15•7 years ago
           | ||
| Comment 16•7 years ago
           | ||
| Comment 17•7 years ago
           | ||
|   | ||
| Comment 18•7 years ago
           | ||
| Comment 19•7 years ago
           | ||
| Comment 20•7 years ago
           | ||
| Comment 21•7 years ago
           | ||
| Comment 22•7 years ago
           | ||
| Comment 23•7 years ago
           | ||
| Updated•7 years ago
           | 
| Comment 24•7 years ago
           | ||
|   | ||
| Comment 25•7 years ago
           | ||
|   | ||
| Updated•7 years ago
           | 
| Comment 26•7 years ago
           | ||
| Comment 27•7 years ago
           | ||
| Comment 28•7 years ago
           | ||
| Comment 29•7 years ago
           | ||
| Comment 30•7 years ago
           | ||
| Comment 31•7 years ago
           | ||
| Comment 32•6 years ago
           | ||
Chrome works correctly.
New Profile
Set FF to restore session on startup
FF 67, Win10
FF 66. Win7
STR:
Do a google search for, one
Open a new Window
Do a google search for, two
Open a new Window
Do a google search for, tree
Open a new Window
Do a google search for, four
At this point, 4 Windows are open
Note their ordering along the [Windows] taskbar
one, two, three, four
Quit, saving the session, Ctrl+Shift+Q.
Open FF, restoring the session.
Note the ordering along the [Windows] taskbar
Whatever ordering it may be, it will almost assuredly not be; one, two, three four.
12 runs, doing nothing more then closing, reopening, noting, ...:
1 2 3 4
1 4 2 3
1 3 4 2
1 2 4 3
1 3 4 2
1 3 4 2
1 3 4 2
1 2 4 3
1 2 3 4 <-back in order
1 3 2 4 (nothing changed, except close & reopen)
1 4 2 3
1 2 4 3
Utterly ridiculous that this ugly bug exists.
| Comment 33•6 years ago
           | ||
Over time, various browsers & browser versions have been afflicted with this bug.
Over time, various extensions has exacerbated the situation.
FF "Legacy" has been affected, FF Quantum is affected.
There have been times where FF Quantum, natively (i.e. no extensions or anything like that) worked as expected (or at least it was very difficult to duplicate the bug).
There have been times where FF Quantum - with the addition of an extension (at the least a particular extension, NoScript 10 as it happened to be) caused this situation to occur.
There have been times where FF Quantum (currently, at the least 66 & 67) have this bug - needing no additional interactions from extensions (like NoScript) or anything else.
| Comment 34•6 years ago
           | ||
(In reply to Robert Ab from comment #16)
I have noticed that Firefox has the problem during session restoration with more than 2 windows (always as I remember,
at least since FF3.6; Windows 7 x64). Windows (2nd, 3rd,..) after session restoration are usually in different order then in
the oryginal session before browser restart; first window remains always as first one even after multiple restarts.
Fortunately, the order of tabs is maintained. This problem is independent of Session Manager (exist with and w/o this extension).(On the contrary, Chrome during session restoration will have windows in the correct order, but most tabs in the window will be in the reverse order.)
I got similar conclusion, as presented in Bug 1235231 comment 32. Bug still exists in Firefox 66.0.5.
| Comment 35•6 years ago
           | ||
[10] Taskbar Icons r Reordered on open from Session Restore
https://forums.informaction.com/viewtopic.php?f=10&t=25142
| Comment 36•6 years ago
           | ||
therube:
There have been times where FF Quantum (currently, at the least 66 & 67) have this bug - needing no additional interactions from extensions (like NoScript) or anything else.
I cannot resist, but confirm and further note, that neither window position nor size nor content nor screen is kept with 66.0.5's session restore. In short, it is in company of the worst states of this bug in Firefox history.
BTW, this bug celebrated its 12th birthday two month ago in the form of https://bugzilla.mozilla.org/show_bug.cgi?id=372650.
| Comment 37•6 years ago
          • | ||
Oh, going out on a limb - where is that piece of wood; knock, knock...
FF 69, 20190603160429, looks to be better behaved - both on its own, & also in conjunction with NoScript.
It will still mess up - but less like to do so.
Was on 67 before, & that screwed up - immediately.
69 is more consistent - though still not "right".
Now, you're more apt to see something like:
1-2-3-4
1-2-3-4
1-2-3-4
1-2-3-4
1-2-3-4
1-2-3-4
1-2-3-4
1-2-4-3 -> broke
1-2-4-3
1-2-4-3
1-2-4-3 ... & then it remains consistent like that - for a period of time... until it changes again.
Now this is with a very simple, very basic test; just 4 windows, either 0 or 1 extension (NoScript).
Much improved - compared to FF 67 - for whatever reason.
But still not "right", still not to where things should be - as in always working correctly - period.
| Comment 38•6 years ago
           | ||
Now that's exceptionally good news.
Tumbleweed usually picks up new releases a couple of days after, well, release.
My setup consists from about 25 windows, with a few hundred tabs.
Let's see, how it behaves cross platform..
| Comment 39•5 years ago
           | ||
Firefox 70 version, I have multiple windows and every start whindows are messed, only first one is always on first place.
Mozilla PLEASE fix this issue, it is so long time and this problem still exist.
| Comment 40•5 years ago
           | ||
Thank you, I didn't know this was a known bug. I never saw this (from what I can remember) in v43 with WinXP, but it now showed up in v73 in Win10.
Hope they fix this, or that a usable workaround gets made, soon.
Thanks again,
Bram Weiser
| Comment 41•5 years ago
          • | ||
I believe this is now working correctly - at least since the last day or so (Nightly) - probably by dumb luck.
(I never really expect this to be fixed, so I just expect it to not work, so I don't particularly pay attention - anymore.
But... something has caught my attention, & this may be working correctly.
In one Profile, pretty much, newly created, only 4 windows, they have maintained their [Windows taskbar] ordering.
An older, existing, bigger [more windows/tabs - mainly because of this bug, in that I'd end up duplicating work - because my window ordering along the taskbar is out of order [aka, this bug, & others similar] also - with cursory investigation seems to have remained consistent over a number of Nightly updates & restarts.)
If it is working correctly, we really should figure out just what fixed it so that it can stay fixed.
Pleaseeee, if it is working correctly, do not break it.  Thank you.
Win7 x64
FF 76.0a1 x64 20200326213652
| Comment 42•5 years ago
           | ||
Damn, damn, damn!
On my new(ish) Profile, four windows, I bumped it up to five.
And all was well. 1.2.3.4.5.
Time & time again. Open close. Open close.
No new or updated extensions or anything.
FF itself updated, many times.
Open visit some sites, close. Open, close.
All was well - through last evening when I Quit.
(And here I sit, presently 20200327215207, with a pending update, that I'll install, momentarily.)
(Actually, I can't say if 20200327215207 is "bad" [in respect to this bug]? Maybe like I said from the outset, dumb luck? Or maybe, I hadn't had reason, didn't purposely Quit & restart after 20200327215207 went in?  Ah well, back to the dumps.)
This morning, opening, & 1.2.4.3.5.
Damn!
| Comment 43•5 years ago
           | ||
Can we expect that this bug will be fixed any time soon? It is very annoying.
| Comment 44•5 years ago
           | ||
Why there is no function to set an exact order of windows?
| Comment 45•5 years ago
           | ||
(In reply to User Dderss from comment #44)
Why there is no function to set an exact order of windows?
Wait, there is no "window count", and therefore, no "window order" (based on that count)?
| Reporter | ||
| Comment 46•3 years ago
           | ||
So, for an all too brief happy moment, this bug was fixed. And then it started happening first with restoring the session from history, tab session manager still restored them in order. Now, today, tab session manager also started restoring them in random order. So once again I have to open the windows one by one to get what I want.
| Comment 47•3 years ago
           | ||
Can confirm.
Not even the old trick of closing windows and then restoring them from "History > Recently closed windows" makes them in order that would be memorized.
The only solution for now is to use, if on Windows, "7+ Taskbar Tweaker" utility or something similar that allows to arbitrary change the order of windows within taskbar. Though, obviously, it does not solve the issue as this should be unnecessary in the first place.
| Comment 48•3 years ago
           | ||
+1
Very annoying. Only the first/initial window stays, all the other are rearranged randomly each time a restart FF.
| Reporter | ||
| Comment 49•3 years ago
           | ||
I should mention that this only popped up again in april, so it might be one of the more recent updates that broke restoring again.
| Reporter | ||
| Comment 50•3 years ago
           | ||
If I may, developers, try restoring sessions with multiple windows in versions before the april updates and then in versions with the april updates. I don't know whether or not you've already tried this.
| Comment 51•3 years ago
           | ||
I find this very irritating as when you have 20+ windows and hundreds of tabs it really comes down to muscle memory -- and having each time to readapt where the windows are (also when they don't make logical sense) slows me down. This has been an issue for a long time but then at some point a version came where it the restoration was mostly correct apart from a glitch now and then that could be easily corrected. Now again each time is absolutely different. Why just not stick to chronological?
| Comment 52•3 years ago
           | ||
I suffer from this too. I guess there is no way to create an automated test for this, is there?
| Comment 53•3 years ago
           | ||
Hello,
Apparently, the issue was not present a few weeks/months ago.
Therefore, this latest regression seems to be fairly recent.
Can one of you run the regression finder:
https://mozilla.github.io/mozregression/quickstart.html
Also, I would think the issue depends on the window manager.
People should specify their OS, and WM for Linux distros.
Regards.
| Reporter | ||
| Comment 54•3 years ago
           | ||
Windows 10 here.
| Comment 55•3 years ago
           | ||
Edition:  Windows 10 Pro
Version:  21H1
Build:      19043.1645
Windows Feature Experience Pack 120.2212.4170.0
| Comment 56•3 years ago
           | ||
Windows 10
Version 21H2
OS Build 19044.1586
| Comment hidden (me-too) | 
| Comment 58•3 years ago
           | ||
Redirect a needinfo that is pending on an inactive user to the triage owner.
:dao, since the bug has recent activity, could you have a look please?
For more information, please visit auto_nag documentation.
| Comment 59•3 years ago
           | ||
Windows 11 is also affected.
Also, I don't know if it's related but I've noticed some tabs in the last focused window may disappear after restart (when clicking restart button in the "About Firefox" popup when updates are found). I had few tabs sent from other device and applying update removed them. Looks like some race condition :(
| Comment 60•3 years ago
           | ||
If you're on Windows and looking for a workaround, I wrote a browser extension that fixes this.
It has some limitations, but it works well enough for me for a long time now.
I thought I might as well post it here, maybe it will be of use to some of you.
| Comment 61•3 years ago
           | ||
Hello Artur,
Out of curiosity, what makes your solution Windows-specific?
I am also wondering if the present issue affects only Windows?
I don't see this problem in Linux (or Andoid FWIW).
Regards
| Comment 62•3 years ago
           | ||
(In reply to Mason from comment #61)
Out of curiosity, what makes your solution Windows-specific?
I can see from the Github repo that it uses Native Messaging to instruct a locally installed host program to re-order the windows. This functionality might be available on other OSes but it's hard to develop for platforms one doesn't use.
| Comment 63•3 years ago
           | ||
(In reply to jscher2000 from comment #62)
(In reply to Mason from comment #61)
Out of curiosity, what makes your solution Windows-specific?
I can see from the Github repo that it uses Native Messaging to instruct a locally installed host program to re-order the windows.
That is indeed the case. The source of the native program in question is available here.
This functionality might be available on other OSes but it's hard to develop for platforms one doesn't use.
It's actually even worse than that. This functionality isn't even officially available on Windows. To achieve that I'm using a library that hooks into the Windows Explorer process and allows to perform these kinds of operations this way.
| Comment 64•3 years ago
           | ||
(In reply to Artur Pragacz from comment #63)
It's actually even worse than that. This functionality isn't even officially available on Windows. To achieve that I'm using a library that hooks into the Windows Explorer process and allows to perform these kinds of operations this way.
...and, assuming your taskbar provider supports it, which I'm not sure KDE's Plasma does (I didn't see anything likely in the D-Bus API), it may still be overridden by a setting like the "Sort: Manually" option I use so I can manually drag all my windows (not just Firefox) into the desired order after one of my infrequent (once every month or two) desktop session restarts.
| Comment 66•3 years ago
           | ||
I have the exact same behaviour (with a copy of the same profile) on both Windows 10 & Ubuntu 20.04 : The Windows order tends to stay roughly the same, but does occasionally change a bit. So I believe this problem is profile specific, rather than OS specific.
| Comment 67•3 years ago
           | ||
So, creating a new profile fixes it?
| Comment 69•3 years ago
           | ||
Whoops, the bug is still alive after all this time, but victims seem rare?
(Or most victims do not report/vote?)
(Meanwhile I should disable the FireFox feature to restore windows/tabs and make a automation script which opens the ones from the plugin Tab Session Manager, sound to me like the least intrusive/"painful" workaround.)
| Comment 70•3 years ago
           | ||
(In reply to MonkeyOneAap1 from comment #69)
Whoops, the bug is still alive after all this time, but victims seem rare?
(Or most victims do not report/vote?)(Meanwhile I should disable the FireFox feature to restore windows/tabs and make a automation script which opens the ones from the plugin Tab Session Manager, sound to me like the least intrusive/"painful" workaround.)
I suffer from it... I'm just lucky enough to be on Linux+X11 where I was able to cobble together a fix for this and other annoyances in a unified ~/Desktop/fix_window_positions.py script which uses wmctrl to query and reposition windows in an ansible-esque "If things are already correct, there's no harm in re-running it" way.
| Comment 71•3 years ago
           | ||
(In reply to MonkeyOneAap1 from comment #69)
Whoops, the bug is still alive after all this time, but victims seem rare?
(Or most victims do not report/vote?)
I'm suffering, too.
I try to avoid ever closing Firefox or rebooting my computer.
Doesn't work, though...
| Comment 72•3 years ago
           | ||
(In reply to Navid Vahdat from comment #71)
(In reply to MonkeyOneAap1 from comment #69)
Whoops, the bug is still alive after all this time, but victims seem rare?
(Or most victims do not report/vote?)I'm suffering, too.
I try to avoid ever closing Firefox or rebooting my computer.
Doesn't work, though...
Made worse by Firefox's various reported-long-ago resource leak bugs in contexts like watching YouTube videos, where I'm eventually forced to kill and restart it because the UI is getting really sluggish with the chrome process pegging one of my CPU cores at 100%.
| Comment 73•3 years ago
           | ||
(In reply to MonkeyOneAap1 from comment #69)
Whoops, the bug is still alive after all this time, but victims seem rare?
(Or most victims do not report/vote?)(Meanwhile I should disable the FireFox feature to restore windows/tabs and make a automation script which opens the ones from the plugin Tab Session Manager, sound to me like the least intrusive/"painful" workaround.)
Ah, no need to make a automation script, plugin Tab Session Manager has a feature in settings to load the session saved @ exit, hope this workaround is stable : ))
In my last few tests it was : ))
| Comment 74•3 years ago
           | ||
(In reply to MonkeyOneAap1 from comment #73)
(In reply to MonkeyOneAap1 from comment #69)
Whoops, the bug is still alive after all this time, but victims seem rare?
(Or most victims do not report/vote?)(Meanwhile I should disable the FireFox feature to restore windows/tabs and make a automation script which opens the ones from the plugin Tab Session Manager, sound to me like the least intrusive/"painful" workaround.)
Ah, no need to make a automation script, plugin Tab Session Manager has a feature in settings to load the session saved @ exit, hope this workaround is stable : ))
In my last few tests it was : ))
LOL after a few days getting used to the windows being correctly ordered, today, even the work around shows up in random order...
| Comment 75•3 years ago
           | ||
I found a workaround that consistently fixes this issue. If you set CPU affinity of the main process to one CPU during window creation, it seems to preserve the session order.
Detailed instructions:
- Uncheck "Open previous windows and tabs" in settings to disable session restore upon starting Firefox.
- Now after starting Firefox, it should open only one window. After Firefox starts, in Task Manager, set process affinity of the parent process to one CPU. You may to use need a different tool (e.g. Process Explorer or Process Hacker) to identify which process is the parent, or alternatively check the process ID in about:processes and it should be the process labeled "Firefox"
- Restore session via Hambuger menu -> History -> Restore previous session
- After all windows have launched, we can restore CPU affinity back to all CPUs
To me this process is rather convoluted and annoying, so if anyone can automate this it would be most welcome.
I'm not super familiar with this stuff, but the fact that CPU affinity affects this might suggest a race condition between threads in the main process.
I recently migrated to a new Windows 11 PC where this issue seemed to occur much more frequently and this process consistently fixes the order.
| Comment 76•3 years ago
           | ||
(In reply to mesvam from comment #75)
I found a workaround that consistently fixes this issue. If you set CPU affinity of the main process to one CPU during window creation, it seems to preserve the session order.
Detailed instructions:
- Uncheck "Open previous windows and tabs" in settings to disable session restore upon starting Firefox.
- Now after starting Firefox, it should open only one window. After Firefox starts, in Task Manager, set process affinity of the parent process to one CPU. You may to use need a different tool (e.g. Process Explorer or Process Hacker) to identify which process is the parent, or alternatively check the process ID in about:processes and it should be the process labeled "Firefox"
- Restore session via Hambuger menu -> History -> Restore previous session
- After all windows have launched, we can restore CPU affinity back to all CPUs
To me this process is rather convoluted and annoying, so if anyone can automate this it would be most welcome.
I'm not super familiar with this stuff, but the fact that CPU affinity affects this might suggest a race condition between threads in the main process.
I recently migrated to a new Windows 11 PC where this issue seemed to occur much more frequently and this process consistently fixes the order.
To automate this one could automate using batch/cmd file with Windows command start /?
AFFINITY    Specifies the processor affinity mask as a hexadecimal number.
The process is restricted to running on these processors.
But then you still look for a way to return to all....
This maybe THE clue to solve the bug?
It sounds to me like a multi threading problem? Due to opening all windows at once, without proper syncing order?
Anyway if you do not mind to install e.g. plugin Tab Session Manager(of any other that has the feature to remember order and open at startup)
(Tips for most safe plugin are welcome : ))
Sounds to me easiest workaround to me, it seems to fail only 1 time per month or less, but close and start again fixes this : ))
| Updated•3 years ago
           | 
| Comment 77•3 years ago
           | ||
The severity field for this bug is relatively low, S3. However, the bug has 3 duplicates, 418 votes and 75 CCs.
:dao, could you consider increasing the bug severity?
For more information, please visit auto_nag documentation.
| Comment 78•3 years ago
           | ||
The last needinfo from me was triggered in error by recent activity on the bug. I'm clearing the needinfo since this is a very old bug and I don't know if it's still relevant.
| Comment 79•2 years ago
           | ||
I thought I was having problems with some addon (Load Background Tabs Lazily) because the order was always random if more than 10 tabs were loaded at once, and of course it's the browser.
Even if "Tab Session Manager" would fix the issue is of no use for me, I need to load tabs through command-line and they are not the same tabs every time.
7 years. This is some problem.
I would like to help to test/fix this issue in daily or clean browser installations.
| Comment 80•2 years ago
           | ||
Are there any instructions on how to duplicate and test this bug?
| Comment 81•2 years ago
           | ||
(In reply to Worcester12345 from comment #80)
Are there any instructions on how to duplicate and test this bug?
Sorry, for now all I know the scenario was:
1 every is fine on windows portable version
2 best guess some update
3 noticing strange behavior that window order is shuffled
4 went looking if the bug was reported, it was reported here
5 went looking for work around until fixed ("normally" I have about 20 windows with about 250 tabs open)
(Found that Tab Session Manager could reopen windows @startup which seems to work 99.9% of the times, for the 0.1% 1 time exit and start will work)
Now I also notice when I turn my 3 screens off and on again, some times windows are shuffled?
Exit and start ( Tab Session Manager reopen windows @startup) solves the problem...
Maybe this info helps?
| Comment 83•1 year ago
           | ||
I have suffered with this problem for a long time now and it's one of the irritations that may yet drive me to a different browser.
(So firstly: here's a big +1 and a plea to give this some attention! :-))
I'm on Windows 10, for info.
The workaround described above by @mesvam (CPU affinity) sounds like a pretty darn strong clue about the nature of the root cause.
Since I'm reluctant to abandon FF and this bug is currently unassigned, I am pondering having a go at fixing it myself, though I have no idea how much a learning curve that would represent.
(I will now go and read "How To Contribute Code To Firefox". I may be some time...)
| Comment 84•1 year ago
           | ||
Isn't this some recent regression?
This bug may be 8 years old but I'm pretty sure this behavior started only about a year ago, maybe bug 1776448 (Firefox 101) would be a good starting point for the regression window check (if anyone knows how to do that).
| Comment 85•1 year ago
           | ||
(In reply to juraj.masiar from comment #84)
Isn't this some recent regression?
This bug may be 8 years old but I'm pretty sure this behavior started only about a year ago, maybe bug 1776448 (Firefox 101) would be a good starting point for the regression window check (if anyone knows how to do that).
It feels like well over 2 years since I started experiencing it but I can't be sure.
| Comment 86•1 year ago
           | ||
It was OK for me briefly a couple of years ago. But otherwise its been a pain for a very long time.
| Updated•1 year ago
           | 
| Updated•1 year ago
           | 
| Comment hidden (admin-reviewed) | 
| Comment 88•1 year ago
           | ||
@pinosuit: This is a polite reminder that Bugzilla is our professional working environment as well as our issue tracker. I encourage you to review our Community Participation and Bugzilla Etiquette guidelines; comments that help move issues towards a resolution are always welcome. Comments that add nothing more than demands that a resolution occur, however, are not.
| Comment 89•1 year ago
           | ||
@pinosuit: for further info, "RESOLVED DUPLICATE..." has a very different meaning from "RESOLVED FIXED...".
| Comment hidden (advocacy) | 
| Comment hidden (advocacy) | 
| Comment hidden (advocacy) | 
| Comment 95•1 year ago
           | ||
I would like to see this bug fixed. It has priority P2, which shuffles it up in an admittedly long list. Yes, its been open for ages. I can't roll back the years and nor can I make promises, but I'm also not ok with it staying open for another 9 years. If anyone wants to look into it, I would start at _restoreWindowsInReversedZOrder where we take the array of windows to restore, and sort them by their z-index property. In theory that should be the right thing to do - to get the windows back into the order they were previously in - but something is going wrong. It could be when the session is saved and the z-index we record is not correct. Or it could be we don't actually put them back in the indicated order for some reason. Some logging in there should help elucidate.
| Comment 96•1 year ago
           | ||
Note that this is not a 9 years old bug - as stated in comment 49, this issue "reappeared" only about two years ago (I clearly remember this was always working fine, up until 2 years ago).
So regression window could be used to find exact code change.
The only issue is, I can't reproduce it.
Not with my nightly and not with my main profile (Developer Edition), where it 100% happens all the time... except when I want it to happen.
Maybe it happens only during browser updates?!
I've checked the code (I'm not a Firefox dev though), but oh man... mutations, global variables, even vars are actually used:
    do {
      var ID = "window" + Math.random();
    } while (ID in this._statesToRestore);
    WINDOW_RESTORE_IDS.set(window, ID);
This is some serious technical dept... seeing this will haunt me this night for sure!
Best of luck guys!
| Comment 97•1 year ago
           | ||
This bug is definitely NOT 2 years old. It is ancient, over the years it has intermittently gone away for some releases, but then reappeared again.
The reason is that this is a timing issue and that depends on many factors which are present during the session restore.
Also I would rather start investigating with the _openWindows, not _restoreWindowsInReversedZOrder. The latter seems to late in the initialisation sequence.
| Comment 98•1 year ago
           | ||
I guess this isn't the place to conduct a discussion at too detailed a level, but I'll note a couple of things in response to comments above.
One of the things I tried several months ago was to put some console.log() entries into _openWindowWithState.
I concluded that this function was indeed being called for all of the windows in the correct order, indicating that the session close-out had saved them in the correct order. The restored windows were not, however, appearing in the correct Z-order in the Windows session... (This was repeatable from the very first sessions in a brand new FF installation, in a new+clean VM, using a Nightly version from late November 2023.)
I then tried some stupid/basic things like inserting delays, which didn't work as expected (I guess some parts of this stage may be single threaded?) but did influence the final Z-order somewhat.
It was around that point that I ran out of talent/knowledge and resorted to Element for assistance (unsuccessfully), and then took an indefinite break from it. I'm still basically keen to help solve the bug though, so if there's a non-Element way to seek some guidance, I'm all ears.
| Comment 99•1 year ago
           | ||
What does Z-order have to do with anything here?
This issue is not about Z-order at all.
Why is it keep being mentioned?
| Comment 100•1 year ago
           | ||
(In reply to Artur Pragacz from comment #99)
This issue is not about Z-order at all.
True. In my post at least, you can just delete "Z-" from the text and it'll be back to making sense ;)
| Comment 101•1 year ago
           | ||
Element is just a matrix client. There are others listed at https://matrix.org/ecosystem/clients/
We're talking about z-order because the session restore code tries to open windows in reverse z-order, so that they end up in the same order as they were closed. Its a stack similar to:
ssi_restoreWindow@resource:///modules/sessionstore/SessionStore.sys.mjs:5071:29
_restoreWindowsFeaturesAndTabs@resource:///modules/sessionstore/SessionStore.sys.mjs:5245:12
_restoreWindowsInReversedZOrder@resource:///modules/sessionstore/SessionStore.sys.mjs:5269:10
ssi_restoreWindows/<@resource:///modules/sessionstore/SessionStore.sys.mjs:5340:12
That's my understanding of the likely source of this bug. But I'm open to suggestions.
| Comment 102•1 year ago
           | ||
You are misunderstanding the issue.
The code does not attempt to open windows in reverse Z-order. That wouldn't even make sense. It's supposed to open windows according to their creation time, so that they end up in the same order on the Windows Taskbar. That is the part that is bugged.
Only after that step it restores other window features, like its position, whether it's minimised, etc. and yes, also its Z-order. That part mostly works fine (there is a small bug here as well, but honestly it is not that problematic).
| Comment 103•1 year ago
           | ||
Indeed, the Z-order for me is generally correct, at least for the window that was uppermost at the time I shut down Firefox (it ends up focussed again after I restart, even though it is generally no longer in the same place on the Windows Taskbar). Ironic that the unimportant bit of the restoration is nice and reliable :-)
Wacky question:
I gather from the thread above that some (many?) people are unable to reproduce this, and am wondering why. I've observed it on many machines, all of which run Windows 10 Pro except for the fresh dev VM I mentioned above which runs Windows 11 Enterprise. Is anyone observing the bug on Windows 10/11 Home?
| Comment 104•1 year ago
          • | ||
(In reply to Artur Pragacz from comment #102)
The code does not attempt to open windows in reverse Z-order. That wouldn't even make sense. It's supposed to open windows according to their creation time, so that they end up in the same order on the Windows Taskbar. That is the part that is bugged.
Ooooh, I see. Apologies, I guess I've been conflating 2 bugs - because if I quit Firefox with windows "a", "b" and "c" open, with "b" being the active window, when the session is restored, I invariably end up with "a" as the top-most, active window. That was my interpretation of the issue here. I've re-read the earlier comments and it looks like window creation and window z-ordering should be considered 2 steps, and we're mostly interested in the former for this bug. Thanks for the clarification.
So, for window opening its this code in _openWindows. So all the calls to open the windows are made in parallel. Maybe they could be chained such that we don't attempt to open the next until we've got the browser-window-before-show notification from the previous one. Its likely not that simple as this is such an old bug, but seems worth a shot?
| Comment 105•1 year ago
           | ||
(In reply to Sam Foster [:sfoster] (he/him) from comment #104)
Ooooh, I see. Apologies, I guess I've been conflating 2 bugs - because if I quit Firefox with windows "a", "b" and "c" open, with "b" being the active window, when the session is restored, I invariably end up with "a" as the top-most, active window.
Yes, that is precisely the "small bug here as well, but honestly it is not that problematic" that I was referring to. It always focuses and brings forward the first window that was ever created. I think the code here is responsible. But that is indeed a separate bug, not what this issue is about.
So, for window opening its this code in _openWindows. So all the calls to open the windows are made in parallel. Maybe they could be chained such that we don't attempt to open the next until we've got the
browser-window-before-shownotification from the previous one. Its likely not that simple as this is such an old bug, but seems worth a shot?
Actually that is probably right on. This is what this issue is about in my estimation. The calls are made in the correct order, they are just made in parallel, not sequentially. Whether it then works correctly depends on specifics that are present, which is why I wrote that it is a "timing issue that depends on many factors which are present during the session restore". The code basically can luck out to work, it is not designed to work. At least in my cursory search I couldn't find any logic that would make it happen.
That being said there is one caveat to that solution: performance. If a user has a lot of windows (and I mean a lot, like 50+), the restore may become so slow as to being a real problem. I am not sure, it would require testing. One way it could potentially be counteracted is if we still created windows in parallel and just showed them sequentially.
So ideally we would do something like this:
- Create all windows in parallel, but all of them hidden.
- Show (unhide) all windows sequentially according to their creation time, all of them minimised (to prevent them jumping in and out of view).
- Restore all the windows properties, like their size, position, Z-order, etc., focusing first on those not minimised.
The parts in bold are currently missing / non-functioning. The 1 and 2 points are about this issue, whereas the problems with 3, namely the one issue with Z-order you've mentioned and the small QoL tweak to prioritising I'm proposing here, would be another.
| Comment 106•1 year ago
           | ||
(In reply to Artur Pragacz from comment #105)
That being said there is one caveat to that solution: performance. If a user has a lot of windows (and I mean a lot, like 50+), the restore may become so slow as to being a real problem.
Our telemetry shows that 5+ windows is getting into sub 0.1% of sessions restored. So we should weigh that against real reliability and usability gains for 99+% of users.
I'm not sure if there would be any unexpected ramifications from creating hidden windows then un-hiding them. My gut says that might get complicated but I don't know. I'd rather at least try out the queue of windows first. Dao do you have a preference or any historical context that might be relevant here?
| Comment 107•1 year ago
           | ||
(In reply to Sam Foster [:sfoster] (he/him) from comment #106)
I'm not sure if there would be any unexpected ramifications from creating hidden windows then un-hiding them. My gut says that might get complicated but I don't know. I'd rather at least try out the queue of windows first. Dao do you have a preference or any historical context that might be relevant here?
My experience with WinAPI says that it shouldn't cause any issues. This is in fact a standard parameter to window creation functions. That being said a browser is quite a complex beast and I haven't looked at the code to see whether there are any special considerations that might be relevant. I also cannot speak as to the other platforms.
Our telemetry shows that 5+ windows is getting into sub 0.1% of sessions restored. So we should weigh that against real reliability and usability gains for 99+% of users.
As a mathematician I have to caution against such use of statistics. This is not actually the relevant data. What you are interested in is the number of windows for a typical user for whom this bug is relevant. I would venture a guess that a large majority of users have typically only one window open. They will therefore significantly influence the average, while not being interested in this bug resolution and related changes at all. The typical user for whom this bug matters in a substantial way, is probably a user with a long-lived session. That session will therefore likely be skewed to being quite a bit bigger than usual.
That said, you should definitely implement it as a simple queue first as you laid out. But you should also definitely test out the solution with a really large session as well. For some context my typical browsing session is between 50 and 100 windows. I do have a powerful machine though, so that is also a consideration. Off course a second or two won't matter much, all I'm saying is that you should make sure that you don't make the browser unusable for users like me.
As a final point, even if you judge it to be not necessary to create windows as hidden, I would very strongly encourage you to at least create all of them minimised. Then in _restoreWindowsInReversedZOrder they will have their minimisation state (and also dimensions, position, etc.) restored. That way the windows that were meant to be minimised will not jump on and off the screen. This will improve the experience for everyone, but especially so for users with a large session, for whom the number of minimised browser windows will typically be substantial.
| Comment 108•1 year ago
           | ||
(In reply to Sam Foster [:sfoster] (he/him) from comment #106)
Our telemetry shows that 5+ windows is getting into sub 0.1% of sessions restored. So we should weigh that against real reliability and usability gains for 99+% of users.
I'd expect 5+ windows to be a minority of users but 0.1% is shockingly low - so low that I would take a hard look at the validity of the data. What fraction of users send telemetry? What's the best estimate for the fraction of tech-savvy users that send telemetry?
(No reason not to believe that the affected userbase is reasonably small, but if there's any reason to think that "power" users are more likely to disable telemetry, then you might conclude that the uncertainty window on that figure is very large, e.g. 0.1% - 10%.)
This said, I disagree with Artur about the relevance of the percentage in question. In my view it's perfectly fair for a dev team to care about the number of users who will benefit from a fix, given the finite amount of dev time and infinite amount of bugs...
Back on the topic of the actual bug:
To expand on what I hinted at earlier: when I inserted significant (100s of milliseconds) delays, in _openWindowWithState, I found that
- none of the windows opened, until after the final call to _openWindowWithState (from which I infer that this part of the restore is single-threaded...)
- despite that (and to my enormous surprise), the reliability of the window sequence restoration was greatly improved... Surreal.
I put my investigations on hold before working out exactly where in the sequence the actual Windows API calls were being fired.
(In reply to Sam Foster [:sfoster] (he/him) from comment #104)
So, for window opening its this code in _openWindows. So all the calls to open the windows are made in parallel. Maybe they could be chained such that we don't attempt to open the next until we've got the
browser-window-before-shownotification from the previous one. Its likely not that simple as this is such an old bug, but seems worth a shot?
I think this approach would be guaranteed to work but I share Artur's concerns about performance impact. (I regularly have 10-20 windows open.)
I also don't know where in the code this adjustment could most easily be made (any idea?).
(In reply to Artur Pragacz from comment #105)
Actually that is probably right on. This is what this issue is about in my estimation. The calls are made in the correct order, they are just made in parallel, not sequentially. Whether it then works correctly depends on specifics that are present, which is why I wrote that it is a "timing issue that depends on many factors which are present during the session restore". The code basically can luck out to work, it is not designed to work. At least in my cursory search I couldn't find any logic that would make it happen.
Agreed; it's some kind of race condition. IIRC, forcing my test VM to a single CPU removed the issue entirely.
(In reply to Artur Pragacz from comment #105)
So ideally we would do something like this:
- Create all windows in parallel, but all of them hidden.
- Show (unhide) all windows sequentially according to their creation time, all of them minimised (to prevent them jumping in and out of view).
- Restore all the windows properties, like their size, position, Z-order, etc., focusing first on those not minimised.
The parts in bold are currently missing / non-functioning. The 1 and 2 points are about this issue, whereas the problems with 3, namely the one issue with Z-order you've mentioned and the small QoL tweak to prioritising I'm proposing here, would be another.
This sounds like another very viable fix, which may well have much less performance impact than Sam's proposal above, but the size of the PR is likely to be rather bigger... :-) (I can see why that might be very off-putting for the dev team.)
Again, I'm not sure where best to make these changes for testing purposes, but I'm tempted to have another go if anyone can provide a couple of pointers.
| Comment 109•1 year ago
           | ||
Essentially a patch would be changing the window opening code in SessionStore and how we work with the WINDOW_SHOWING_PROMISES - all of which should be in SessionStore.sys.mjs. It might not even be that big of a patch, but it gets a little hairy because 1) you'd need to get all the existing tests to pass, and 2) we know this is a race condition that is hard to reproduce on demand so building confidence in the change might be difficult. At the same time, its not something that is easy to a/b test. Implementing and maintaining both pathways in SessionStore even for a short time would require significant refactoring, which in turn adds risk. Likely we'd test as best we can locally on all supported platforms, land the patch in Nightly - early on in a release cycle - and be prepared to back it out.
| Updated•1 year ago
           | 
| Comment hidden (me-too) | 
| Comment hidden (off-topic) | 
| Comment hidden (off-topic) | 
| Comment hidden (off-topic) | 
| Comment hidden (off-topic) | 
| Updated•1 year ago
           | 
| Comment 115•1 month ago
           | ||
This bug _appears _to have reduced its hit rate, or maybe it's even just plain fixed now.
I first tentatively observed this a few weeks back, but have been unwilling to regard it as definitive (especially in the absence of a declared fix here, so maybe whatever happened to improve things was unrelated/accidental). Since then, I've restarted the browser a few times (including for updates) and the window order appears to be static.
I don't suppose anyone reading this has any idea what changes were made that impacted the issue?
| Comment 117•9 days ago
           | ||
I don't know whether this is a separate bug: random order (not the order in which windows were restored) occurs in KDE Plasma task manager if the number of items in the manager grows large enough for Firefox items to be grouped, temporarily, as a single button.
The disorder is apparent after grouping ends.
Kubuntu 25.04, Wayland, Firefox 143.0.4 (64-bit).
| Comment 118•9 days ago
           | ||
As I posted in https://bugzilla.mozilla.org/show_bug.cgi?id=1993853 (sorry about the dupe, somehow bugzilla and google search did not find this one for me) - with all the projects I am involved in, I fall into the category of users with many windows (not uncommon to have about 30 windows with 10 to 50 tabs in each). So not-finding them in expected locations from one reboot to another adds a huge overhead to working patterns.
The problem was merely annoying for the past couple of years - I occasionally edited recovery.jsonlz4 and the order of at least several first entries was upheld. Around the time of update to Firefox 143.0.4 (64-bit, Windows 11) this became a trainwreck with every restart placing non-first windows randomly and differently every time.
| Comment 119•9 days ago
           | ||
Thinking out of the box: if for some reason code structure has to remain parallel, but session restoration is known (per claims above) to behave well on single-CPU machines, can we request a single-core CPU affinity while restoring the windows (and then switch back to multi-CPU)? Or is this generally something like niceness or ulimit - you may constrain yourself into the corner but (as a non-root/admin) may never un-constrain?
| Comment hidden (me-too) | 
| Comment hidden (me-too) | 
| Comment hidden (me-too) | 
| Comment hidden (me-too) | 
| Comment hidden (me-too) | 
Description
•