d6da65b18f
1) Fix test #4 by deleting all local mailfolders remaining from previous tests, the mailfolder count will be off, otherwise. 2) Make folder deletion work in python3, it weirdly enough needs to be quoted like this to work in python3 (I found a python bug about this somewhere). Signed-off-by: Sebastian Spaeth <Sebastian@SSpaeth.de>
130 lines
5.4 KiB
Python
130 lines
5.4 KiB
Python
# Copyright (C) 2012- Sebastian Spaeth & contributors
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
import random
|
|
import unittest
|
|
import logging
|
|
import os, sys
|
|
from test.OLItest import OLITestLib
|
|
|
|
# Things need to be setup first, usually setup.py initializes everything.
|
|
# but if e.g. called from command line, we take care of default values here:
|
|
if not OLITestLib.cred_file:
|
|
OLITestLib(cred_file='./test/credentials.conf', cmd='./offlineimap.py')
|
|
|
|
|
|
def setUpModule():
|
|
logging.info("Set Up test module %s" % __name__)
|
|
tdir = OLITestLib.create_test_dir(suffix=__name__)
|
|
|
|
def tearDownModule():
|
|
logging.info("Tear Down test module")
|
|
# comment out next line to keep testdir after test runs. TODO: make nicer
|
|
OLITestLib.delete_test_dir()
|
|
|
|
#Stuff that can be used
|
|
#self.assertEqual(self.seq, range(10))
|
|
# should raise an exception for an immutable sequence
|
|
#self.assertRaises(TypeError, random.shuffle, (1,2,3))
|
|
#self.assertTrue(element in self.seq)
|
|
#self.assertFalse(element in self.seq)
|
|
|
|
class TestBasicFunctions(unittest.TestCase):
|
|
#@classmethod
|
|
#def setUpClass(cls):
|
|
#This is run before all tests in this class
|
|
# cls._connection = createExpensiveConnectionObject()
|
|
|
|
#@classmethod
|
|
#This is run after all tests in this class
|
|
#def tearDownClass(cls):
|
|
# cls._connection.destroy()
|
|
|
|
# This will be run before each test
|
|
#def setUp(self):
|
|
# self.seq = range(10)
|
|
|
|
def test_01_olistartup(self):
|
|
"""Tests if OLI can be invoked without exceptions
|
|
|
|
Cleans existing remote tet folders. Then syncs all "OLItest*
|
|
(specified in the default config) to our local Maildir. The
|
|
result should be 0 folders and 0 mails."""
|
|
OLITestLib.delete_remote_testfolders()
|
|
code, res = OLITestLib.run_OLI()
|
|
self.assertEqual(res, "")
|
|
boxes, mails = OLITestLib.count_maildir_mails('')
|
|
self.assertTrue((boxes, mails)==(0,0), msg="Expected 0 folders and 0 "
|
|
"mails, but sync led to {} folders and {} mails".format(
|
|
boxes, mails))
|
|
|
|
def test_02_createdir(self):
|
|
"""Create local OLItest 1 & OLItest "1" maildir, sync
|
|
|
|
Folder names with quotes used to fail and have been fixed, so
|
|
one is included here as a small challenge."""
|
|
OLITestLib.create_maildir('INBOX.OLItest 1')
|
|
OLITestLib.create_maildir('INBOX.OLItest "1"')
|
|
code, res = OLITestLib.run_OLI()
|
|
#logging.warn("%s %s "% (code, res))
|
|
self.assertEqual(res, "")
|
|
boxes, mails = OLITestLib.count_maildir_mails('')
|
|
self.assertTrue((boxes, mails)==(2,0), msg="Expected 2 folders and 0 "
|
|
"mails, but sync led to {} folders and {} mails".format(
|
|
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, msg="Mismatching nametrans rules did "
|
|
"NOT trigger an 'infinite folder generation' error. Output was:\n"
|
|
"{}".format(res))
|
|
# Write out default config file again
|
|
OLITestLib.write_config_file()
|
|
|
|
def test_04_createmail(self):
|
|
"""Create mail in OLItest 1, sync, wipe folder sync
|
|
|
|
Currently, this will mean the folder will be recreated
|
|
locally. At some point when remote folder deletion is
|
|
implemented, this behavior will change."""
|
|
OLITestLib.delete_remote_testfolders()
|
|
OLITestLib.delete_maildir('') #Delete all local maildir folders
|
|
OLITestLib.create_maildir('INBOX.OLItest')
|
|
OLITestLib.create_mail('INBOX.OLItest')
|
|
code, res = OLITestLib.run_OLI()
|
|
#logging.warn("%s %s "% (code, res))
|
|
self.assertEqual(res, "")
|
|
boxes, mails = OLITestLib.count_maildir_mails('')
|
|
self.assertTrue((boxes, mails)==(1,1), msg="Expected 1 folders and 1 "
|
|
"mails, but sync led to {} folders and {} mails".format(
|
|
boxes, mails))
|
|
# The local Mail should have been assigned a proper UID now, check!
|
|
uids = OLITestLib.get_maildir_uids('INBOX.OLItest')
|
|
self.assertFalse (None in uids, msg = "All mails should have been "+ \
|
|
"assigned the IMAP's UID number, but {} messages had no valid ID "\
|
|
.format(len([None for x in uids if x==None])))
|