Improve nametrans local->remote folder syncing
While improving the test suite, I noticed that we would not create folders on the remote in some cases when we should (yay for test suites!). This is because we were testing the untransposed LOCAL foldername and check if it existed on the remote side when deciding whether we should potentially create a new folder. Simplify the code by transposing the LOCAL folder names in dst_hash, saving us to create another confusing "newsrc" temp variable. Make the code a bit more readable by using dst_name_t to indicate we operate a transposed folder name. This now passes test 03 (using invalid nametrans rules) when test 03 would pass before. Signed-off-by: Sebastian Spaeth <Sebastian@SSpaeth.de>
This commit is contained in:
parent
189d78cc5c
commit
ac033c68fd
@ -153,7 +153,8 @@ class BaseRepository(CustomConfig.ConfigHelperMixin, object):
|
|||||||
src_repo.getsep(), dst_repo.getsep())] = folder
|
src_repo.getsep(), dst_repo.getsep())] = folder
|
||||||
dst_hash = {}
|
dst_hash = {}
|
||||||
for folder in dst_folders:
|
for folder in dst_folders:
|
||||||
dst_hash[folder.name] = folder
|
dst_hash[folder.getvisiblename().replace(
|
||||||
|
dst_repo.getsep(), src_repo.getsep())] = folder
|
||||||
|
|
||||||
# Find new folders on src_repo.
|
# Find new folders on src_repo.
|
||||||
for src_name_t, src_folder in src_hash.iteritems():
|
for src_name_t, src_folder in src_hash.iteritems():
|
||||||
@ -172,30 +173,30 @@ class BaseRepository(CustomConfig.ConfigHelperMixin, object):
|
|||||||
status_repo.makefolder(src_name_t.replace(dst_repo.getsep(),
|
status_repo.makefolder(src_name_t.replace(dst_repo.getsep(),
|
||||||
status_repo.getsep()))
|
status_repo.getsep()))
|
||||||
# Find new folders on dst_repo.
|
# Find new folders on dst_repo.
|
||||||
for dst_name, dst_folder in dst_hash.iteritems():
|
for dst_name_t, dst_folder in dst_hash.iteritems():
|
||||||
if self.getconfboolean('readonly', False):
|
if self.getconfboolean('readonly', False):
|
||||||
# Don't create missing folder on readonly repo.
|
# Don't create missing folder on readonly repo.
|
||||||
break
|
break
|
||||||
|
|
||||||
if dst_folder.sync_this and not dst_name in src_hash:
|
if dst_folder.sync_this and not dst_name_t in src_folders:
|
||||||
# nametrans sanity check!
|
# nametrans sanity check!
|
||||||
# Does nametrans back&forth lead to identical names?
|
# Does nametrans back&forth lead to identical names?
|
||||||
#src_name is the unmodified full src_name that would be created
|
# 1) would src repo filter out the new folder name? In this
|
||||||
newsrc_name = dst_folder.getvisiblename().replace(
|
|
||||||
dst_repo.getsep(),
|
|
||||||
src_repo.getsep())
|
|
||||||
folder = self.getfolder(newsrc_name)
|
|
||||||
# would src repo filter out the new folder name? In this
|
|
||||||
# case don't create it on it:
|
# case don't create it on it:
|
||||||
if not self.folderfilter(newsrc_name):
|
if not self.folderfilter(dst_name_t):
|
||||||
self.ui.debug('', "Not creating folder '%s' (repository '%s"
|
self.ui.debug('', "Not creating folder '%s' (repository '%s"
|
||||||
"') as it would be filtered out on that repository." %
|
"') as it would be filtered out on that repository." %
|
||||||
(newsrc_name, self))
|
(dst_name_t, self))
|
||||||
continue
|
continue
|
||||||
|
# get IMAPFolder and see if the reverse nametrans
|
||||||
|
# works fine TODO: getfolder() works only because we
|
||||||
|
# succeed in getting inexisting folders which I would
|
||||||
|
# like to change. Take care!
|
||||||
|
folder = self.getfolder(dst_name_t)
|
||||||
# apply reverse nametrans to see if we end up with the same name
|
# apply reverse nametrans to see if we end up with the same name
|
||||||
newdst_name = folder.getvisiblename().replace(
|
newdst_name = folder.getvisiblename().replace(
|
||||||
src_repo.getsep(), dst_repo.getsep())
|
src_repo.getsep(), dst_repo.getsep())
|
||||||
if dst_name != newdst_name:
|
if dst_folder.name != newdst_name:
|
||||||
raise OfflineImapError("INFINITE FOLDER CREATION DETECTED! "
|
raise OfflineImapError("INFINITE FOLDER CREATION DETECTED! "
|
||||||
"Folder '%s' (repository '%s') would be created as fold"
|
"Folder '%s' (repository '%s') would be created as fold"
|
||||||
"er '%s' (repository '%s'). The latter becomes '%s' in "
|
"er '%s' (repository '%s'). The latter becomes '%s' in "
|
||||||
@ -204,18 +205,18 @@ class BaseRepository(CustomConfig.ConfigHelperMixin, object):
|
|||||||
"itories so they lead to identical names if applied bac"
|
"itories so they lead to identical names if applied bac"
|
||||||
"k and forth. 2) Use folderfilter settings on a reposit"
|
"k and forth. 2) Use folderfilter settings on a reposit"
|
||||||
"ory to prevent some folders from being created on the "
|
"ory to prevent some folders from being created on the "
|
||||||
"other side." % (dst_name, dst_repo, newsrc_name,
|
"other side." % (dst_folder.name, dst_repo, dst_name_t,
|
||||||
src_repo, newdst_name),
|
src_repo, newdst_name),
|
||||||
OfflineImapError.ERROR.REPO)
|
OfflineImapError.ERROR.REPO)
|
||||||
# end sanity check, actually create the folder
|
# end sanity check, actually create the folder
|
||||||
try:
|
try:
|
||||||
src_repo.makefolder(newsrc_name)
|
src_repo.makefolder(dst_name_t)
|
||||||
src_haschanged = True # Need to refresh list
|
src_haschanged = True # Need to refresh list
|
||||||
except OfflineImapError as e:
|
except OfflineImapError as e:
|
||||||
self.ui.error(e, exc_info()[2], "Creating folder %s on "
|
self.ui.error(e, exc_info()[2], "Creating folder %s on "
|
||||||
"repository %s" % (newsrc_name, src_repo))
|
"repository %s" % (dst_name_t, src_repo))
|
||||||
raise
|
raise
|
||||||
status_repo.makefolder(newsrc_name.replace(
|
status_repo.makefolder(dst_name_t.replace(
|
||||||
src_repo.getsep(), status_repo.getsep()))
|
src_repo.getsep(), status_repo.getsep()))
|
||||||
# Find deleted folders.
|
# Find deleted folders.
|
||||||
# TODO: We don't delete folders right now.
|
# TODO: We don't delete folders right now.
|
||||||
|
@ -72,3 +72,21 @@ class TestBasicFunctions(unittest.TestCase):
|
|||||||
self.assertEqual(res, "")
|
self.assertEqual(res, "")
|
||||||
boxes, mails = OLITestLib.count_maildir_mails('')
|
boxes, mails = OLITestLib.count_maildir_mails('')
|
||||||
logging.warn("%d boxes and %d mails" % (boxes, mails))
|
logging.warn("%d boxes and %d mails" % (boxes, mails))
|
||||||
|
|
||||||
|
def test_03_nametransmismatch(self):
|
||||||
|
"""Create mismatching remote and local nametrans rules
|
||||||
|
|
||||||
|
This should raise an error."""
|
||||||
|
config = OLITestLib.get_default_config()
|
||||||
|
config.set('Repository IMAP', 'nametrans',
|
||||||
|
'lambda f: f' )
|
||||||
|
config.set('Repository Maildir', 'nametrans',
|
||||||
|
'lambda f: f + "moo"' )
|
||||||
|
OLITestLib.write_config_file(config)
|
||||||
|
code, res = OLITestLib.run_OLI()
|
||||||
|
#logging.warn("%s %s "% (code, res))
|
||||||
|
# We expect an INFINITE FOLDER CREATION WARNING HERE....
|
||||||
|
mismatch = "ERROR: INFINITE FOLDER CREATION DETECTED!" in res
|
||||||
|
self.assertEqual(mismatch, True, "Mismatching nametrans rules did NOT"
|
||||||
|
"trigger an 'infinite folder generation' error.")
|
||||||
|
boxes, mails = OLITestLib.count_maildir_mails('')
|
||||||
|
Loading…
Reference in New Issue
Block a user