MailDir Repair folder in IMAP causes folder contents to be deleted
Categories
(MailNews Core :: Database, defect)
Tracking
(Not tracked)
People
(Reporter: unicorn.consulting, Unassigned)
References
Details
(Keywords: perf)
Attachments
(2 files)
Updated•6 years ago
|
Updated•6 years ago
|
Comment 5•6 years ago
|
||
related to bug 1412779 ?
Is this fundamentlaly a maildir issue?
Or just more general?
AFAIK it is maildir specific, I use repair on my local folders without any issue, but you are correct, I just tried repairing an IMAP folder with GMX and it downloading messages 1 to 102. SO I think it is a general IMAP issue, not maildir specific as I had assumed.
Comment 7•5 years ago
|
||
(In reply to Matt from comment #6)
AFAIK it is maildir specific, I use repair on my local folders without any issue, but you are correct, I just tried repairing an IMAP folder with GMX and it downloading messages 1 to 102. SO I think it is a general IMAP issue, not maildir specific as I had assumed.
My observation is that "repair" of an imap folder either re-downloads just the headers (if folder has no offline store) or the full messages (if folder does have offline store). So repairing an imap folder with 100k message and maildir or mbox offline store may take a while. (But not sure if this is a part of this issue.)
Comment 8•4 years ago
|
||
Picking through the code on this one, I the observations in comment #6 and comment #7 are right - I don't think it's a maildir-specific issue. Does anyone have any observations to the contrary?
I think the overall procedure is driven by rebuildSummary() (https://searchfox.org/comm-central/source/mail/base/content/folderPane.js#3385).
The gist of it is:
- if it's an offline folder, delete the mbox file or maildir
- force-close the database (summary file)
- call folder.updateFolder() to perform the rebuild
In step 3 I think the IMAP updateFolder() grabs headers from the server, so it'll be slow. Local folders rebuild the database by reparsing the mbox/maildir, which should be way quicker.
step 1 is another ugly little instance of folder code directly fiddling the filesystem - it should be handled in the mbox/maildir specific plugablemailstore.
With 2, I don't think this actually deletes the msf file. It just marks it invalid. I tried running "repair folder" on a disconnected IMAP folder, with mbox, and no local message downloading. I'd have expected to see all the messages disappear, but they popped right back up. So I think it just picked up the old msf file again... needs a little more investigation.
I kind of think there are enough issues with folder repair that it warrants stepping back a little and figuring out exactly what it should be doing...
https://bugzilla.mozilla.org/buglist.cgi?quicksearch=folder%20repair
Comment 9•4 years ago
|
||
Picking through the code on this one, I the observations in comment #6 and comment #7 are right - I don't think it's a maildir-specific issue. Does anyone have any observations to the contrary?
As a test, I tried to repair the maildir folder I've been working with in bug 1702692. What I see is when I repair Inbox is that the .eml files under Inbox/cur are all removed and don't come back and the message summary goes empty until you move to another folder and then back. But the .eml files never come back. It seems to be behaving like the folder is configured to not use offline store after the repair.
The only way I could get the .eml files back is to remove Inbox folder and Inbox.msf and restart tb. Then when an Inbox message is accessed the .eml files all come back after, I assume, they are finally all downloaded. (Haven't looked at code of even imap logs for this.)
I've never seen this problem with repair of mbox. However, to get rid of any redundant messages in mbox you have to at delete the mbox file and corresponding .msf to do a complete repair. Otherwise mbox repair leaves the redundant messages in the file. (By "redundant" I mean messages on server with "bad" headers that cause the file to grow as we see in bug 1702692 and friends.)
So typically if I really want to "repair" a folder, I just delete the storage file and the .msf file and let tb re-download and rebuild them rather than relying on the repair button.
Comment 10•4 years ago
|
||
Another observation that is probably off-topic and maybe deserving its own bug:
With maildir, if I configure "just mark message as deleted" instead of moving deleted to a folder, when I delete a message, as expected, the message is crossed out and the red X is put in front. However, there doesn't seem to be a way to expunge the deleted messages from that folder since maildir doesn't provide a right-click "compact" option.
There is a "compact folders" option under "File" menu but that appears to apply to multiple folders and not to a specific folder and not sure if it even works for maildir folders.
Comment 11•3 years ago
|
||
Other repair issues https://mzl.la/3AcGIi8
Comment 12•3 years ago
|
||
Maybe this was bug 1683714
Updated•3 years ago
|
Comment 13•1 year ago
|
||
(In reply to Magnus Melin [:mkmelin] from comment #12)
Maybe this was bug 1683714
Matt, do you agree, the problem is gone?
Reporter | ||
Comment 14•1 year ago
|
||
I find it difficult to say, I tried a repair of a folder to test and my Activity Manager went to bringing the folder up to date. After almost 24 hours of just sitting there with the activity manager showing the same thing, I assume hung, I restarted Thunderbird. I have not had time to look again since then.
Description
•