aboutsummaryrefslogtreecommitdiff
path: root/tests/send-to-imap.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/send-to-imap.py')
-rw-r--r--tests/send-to-imap.py108
1 files changed, 0 insertions, 108 deletions
diff --git a/tests/send-to-imap.py b/tests/send-to-imap.py
deleted file mode 100644
index df49076..0000000
--- a/tests/send-to-imap.py
+++ /dev/null
@@ -1,108 +0,0 @@
-from imaplib import IMAP4_SSL, IMAP4
-from os import listdir
-from os.path import isfile, join
-import sys
-
-# COMMAND USAGE
-#
-# start a test IMAP servers:
-# docker-compose.up
-# then call this script. eg:
-# ./send-to-imap.py all ./emails/dxflrs/
-
-
-def rebuild_body_res(b):
- bb = b''
- for e in b:
- if type(e) is tuple:
- bb += b'\r\n'.join([p for p in e])
- else:
- bb += e
-
- f = bb[bb.find(b'('):]
- return f
-
-mode = sys.argv[1]
-path = sys.argv[2]
-
-base_test_mb = "kzUXL7HyS5OjLcU8"
-parameters = {
- "dovecot": {
- "con": IMAP4_SSL,
- "port": 993,
- "user": "test",
- "pw": "pass",
- "ext": ".dovecot",
- "mb": base_test_mb,
- },
- "maddy": {
- "con": IMAP4_SSL,
- "port": 994,
- "user": "test@example.com",
- "pw": "pass",
- "ext": ".maddy",
- "mb": base_test_mb,
- },
- "cyrus": {
- "con": IMAP4,
- "port": 143,
- "user": "test",
- "pw": "pass",
- "ext": ".cyrus",
- "mb": "INBOX."+base_test_mb,
- },
- "stalwart": {
- "con": IMAP4_SSL,
- "port": 1993,
- "user": "test@example.com",
- "pw": "pass",
- "ext": ".stalwart.0.2.0",
- "mb": base_test_mb,
- }
-}
-
-queue = list(parameters.keys())
-if mode in parameters:
- queue = [ mode ]
-
-onlyfiles = [join(path, f) for f in listdir(path) if isfile(join(path, f)) and len(f) > 4 and f[-4:] == ".eml"]
-
-for target in queue:
- print(f"--- {target} ---")
- conf = parameters[target]
- test_mb = conf['mb']
-
- with conf['con'](host="localhost", port=conf['port']) as M:
- print(M.login(conf['user'], conf['pw']))
- print(M.delete(test_mb))
- print(M.create(test_mb))
-
-
- print(M.list())
- print(M.select(test_mb))
- failed = 0
- for (idx, f) in enumerate(onlyfiles):
- f_noext = f[:-4]
- try:
- with open(f, 'r+b') as mail:
- print(M.append(test_mb, [], None, mail.read()))
- seq = (f"{idx+1-failed}:{idx+1-failed}").encode()
- (r, b) = M.fetch(seq, "(BODY)")
- print((r, b))
- assert r == 'OK'
-
-
- with open(f_noext + conf['ext'] + ".body", 'w+b') as w:
- w.write(rebuild_body_res(b))
-
- (r, b) = M.fetch(seq, "(BODYSTRUCTURE)")
- print((r, b))
- assert r == 'OK'
- with open(f_noext + conf['ext'] + ".bodystructure", 'w+b') as w:
- w.write(rebuild_body_res(b))
- except:
- failed += 1
- print(f"failed {f}")
-
- M.close()
- M.logout()