Fix preprocessor tests
This commit is contained in:
@@ -1,27 +1,23 @@
|
|||||||
import email.contentmanager
|
|
||||||
import random
|
|
||||||
import tempfile
|
import tempfile
|
||||||
import uuid
|
|
||||||
from collections import namedtuple
|
|
||||||
from email.mime.application import MIMEApplication
|
from email.mime.application import MIMEApplication
|
||||||
from email.mime.multipart import MIMEMultipart
|
from email.mime.multipart import MIMEMultipart
|
||||||
from typing import Optional
|
from typing import TYPE_CHECKING
|
||||||
from typing import Union
|
|
||||||
from unittest import mock
|
|
||||||
|
|
||||||
import gnupg
|
import gnupg
|
||||||
|
from django.test import TestCase
|
||||||
from django.test import override_settings
|
from django.test import override_settings
|
||||||
from imap_tools import EmailAddress
|
|
||||||
from imap_tools import MailMessage
|
from imap_tools import MailMessage
|
||||||
|
|
||||||
from documents.models import Correspondent
|
|
||||||
from paperless_mail.mail import MailAccountHandler
|
from paperless_mail.mail import MailAccountHandler
|
||||||
from paperless_mail.models import MailAccount
|
from paperless_mail.models import MailAccount
|
||||||
from paperless_mail.models import MailRule
|
from paperless_mail.models import MailRule
|
||||||
from paperless_mail.preprocessor import MailMessageDecryptor
|
from paperless_mail.preprocessor import MailMessageDecryptor
|
||||||
from paperless_mail.tests.test_mail import BogusMailBox
|
from paperless_mail.tests.test_mail import MailMocker
|
||||||
from paperless_mail.tests.test_mail import _AttachmentDef
|
from paperless_mail.tests.test_mail import _AttachmentDef
|
||||||
|
|
||||||
|
if TYPE_CHECKING:
|
||||||
|
import email.contentmanager
|
||||||
|
|
||||||
|
|
||||||
class MessageEncryptor:
|
class MessageEncryptor:
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
@@ -75,20 +71,10 @@ class MessageEncryptor:
|
|||||||
return encrypted_message
|
return encrypted_message
|
||||||
|
|
||||||
|
|
||||||
class TestPreprocessor:
|
class TestPreprocessor(TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.bogus_mailbox = BogusMailBox()
|
self.mailMocker = MailMocker()
|
||||||
|
self.mailMocker.setUp()
|
||||||
patcher = mock.patch("paperless_mail.mail.MailBox")
|
|
||||||
m = patcher.start()
|
|
||||||
m.return_value = self.bogus_mailbox
|
|
||||||
self.addCleanup(patcher.stop)
|
|
||||||
|
|
||||||
patcher = mock.patch("paperless_mail.mail.queue_consumption_tasks")
|
|
||||||
self._queue_consumption_tasks_mock = patcher.start()
|
|
||||||
self.addCleanup(patcher.stop)
|
|
||||||
|
|
||||||
self.reset_bogus_mailbox()
|
|
||||||
|
|
||||||
self.messageEncryptor = MessageEncryptor()
|
self.messageEncryptor = MessageEncryptor()
|
||||||
with override_settings(
|
with override_settings(
|
||||||
@@ -99,168 +85,12 @@ class TestPreprocessor:
|
|||||||
|
|
||||||
super().setUp()
|
super().setUp()
|
||||||
|
|
||||||
def create_message(
|
|
||||||
self,
|
|
||||||
attachments: Union[int, list[_AttachmentDef]] = 1,
|
|
||||||
body: str = "",
|
|
||||||
subject: str = "the subject",
|
|
||||||
from_: str = "no_one@mail.com",
|
|
||||||
to: Optional[list[str]] = None,
|
|
||||||
seen: bool = False,
|
|
||||||
flagged: bool = False,
|
|
||||||
processed: bool = False,
|
|
||||||
) -> MailMessage:
|
|
||||||
if to is None:
|
|
||||||
to = ["tosomeone@somewhere.com"]
|
|
||||||
|
|
||||||
email_msg = email.message.EmailMessage()
|
|
||||||
# TODO: This does NOT set the UID
|
|
||||||
email_msg["Message-ID"] = str(uuid.uuid4())
|
|
||||||
email_msg["Subject"] = subject
|
|
||||||
email_msg["From"] = from_
|
|
||||||
email_msg["To"] = str(" ,".join(to))
|
|
||||||
email_msg.set_content(body)
|
|
||||||
|
|
||||||
# Either add some default number of attachments
|
|
||||||
# or the provided attachments
|
|
||||||
if isinstance(attachments, int):
|
|
||||||
for i in range(attachments):
|
|
||||||
attachment = _AttachmentDef(filename=f"file_{i}.pdf")
|
|
||||||
email_msg.add_attachment(
|
|
||||||
attachment.content,
|
|
||||||
maintype=attachment.maintype,
|
|
||||||
subtype=attachment.subtype,
|
|
||||||
disposition=attachment.disposition,
|
|
||||||
filename=attachment.filename,
|
|
||||||
)
|
|
||||||
else:
|
|
||||||
for attachment in attachments:
|
|
||||||
email_msg.add_attachment(
|
|
||||||
attachment.content,
|
|
||||||
maintype=attachment.maintype,
|
|
||||||
subtype=attachment.subtype,
|
|
||||||
disposition=attachment.disposition,
|
|
||||||
filename=attachment.filename,
|
|
||||||
)
|
|
||||||
|
|
||||||
# Convert the EmailMessage to an imap_tools MailMessage
|
|
||||||
imap_msg = MailMessage.from_bytes(email_msg.as_bytes())
|
|
||||||
|
|
||||||
# TODO: Unsure how to add a uid to the actual EmailMessage. This hacks it in,
|
|
||||||
# based on how imap_tools uses regex to extract it.
|
|
||||||
# This should be a large enough pool
|
|
||||||
uid = random.randint(1, 10000)
|
|
||||||
while uid in self._used_uids:
|
|
||||||
uid = random.randint(1, 10000)
|
|
||||||
self._used_uids.add(uid)
|
|
||||||
|
|
||||||
imap_msg._raw_uid_data = f"UID {uid}".encode()
|
|
||||||
|
|
||||||
imap_msg.seen = seen
|
|
||||||
imap_msg.flagged = flagged
|
|
||||||
if processed:
|
|
||||||
imap_msg._raw_flag_data.append(b"+FLAGS (processed)")
|
|
||||||
MailMessage.flags.fget.cache_clear()
|
|
||||||
|
|
||||||
return imap_msg
|
|
||||||
|
|
||||||
def reset_bogus_mailbox(self):
|
|
||||||
self.bogus_mailbox.messages = []
|
|
||||||
self.bogus_mailbox.messages_spam = []
|
|
||||||
self.bogus_mailbox.messages.append(
|
|
||||||
self.create_message(
|
|
||||||
subject="Invoice 1",
|
|
||||||
from_="amazon@amazon.de",
|
|
||||||
to=["me@myselfandi.com", "helpdesk@mydomain.com"],
|
|
||||||
body="cables",
|
|
||||||
seen=True,
|
|
||||||
flagged=False,
|
|
||||||
processed=False,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
self.bogus_mailbox.messages.append(
|
|
||||||
self.create_message(
|
|
||||||
subject="Invoice 2",
|
|
||||||
body="from my favorite electronic store",
|
|
||||||
to=["invoices@mycompany.com"],
|
|
||||||
seen=False,
|
|
||||||
flagged=True,
|
|
||||||
processed=True,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
self.bogus_mailbox.messages.append(
|
|
||||||
self.create_message(
|
|
||||||
subject="Claim your $10M price now!",
|
|
||||||
from_="amazon@amazon-some-indian-site.org",
|
|
||||||
to="special@me.me",
|
|
||||||
seen=False,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
self.bogus_mailbox.updateClient()
|
|
||||||
|
|
||||||
def test_get_correspondent(self):
|
|
||||||
message = namedtuple("MailMessage", [])
|
|
||||||
message.from_ = "someone@somewhere.com"
|
|
||||||
message.from_values = EmailAddress(
|
|
||||||
"Someone!",
|
|
||||||
"someone@somewhere.com",
|
|
||||||
)
|
|
||||||
|
|
||||||
message2 = namedtuple("MailMessage", [])
|
|
||||||
message2.from_ = "me@localhost.com"
|
|
||||||
message2.from_values = EmailAddress(
|
|
||||||
"",
|
|
||||||
"fake@localhost.com",
|
|
||||||
)
|
|
||||||
|
|
||||||
me_localhost = Correspondent.objects.create(name=message2.from_)
|
|
||||||
someone_else = Correspondent.objects.create(name="someone else")
|
|
||||||
|
|
||||||
handler = MailAccountHandler()
|
|
||||||
|
|
||||||
rule = MailRule(
|
|
||||||
name="a",
|
|
||||||
assign_correspondent_from=MailRule.CorrespondentSource.FROM_NOTHING,
|
|
||||||
)
|
|
||||||
self.assertIsNone(handler._get_correspondent(message, rule))
|
|
||||||
|
|
||||||
rule = MailRule(
|
|
||||||
name="b",
|
|
||||||
assign_correspondent_from=MailRule.CorrespondentSource.FROM_EMAIL,
|
|
||||||
)
|
|
||||||
c = handler._get_correspondent(message, rule)
|
|
||||||
self.assertIsNotNone(c)
|
|
||||||
self.assertEqual(c.name, "someone@somewhere.com")
|
|
||||||
c = handler._get_correspondent(message2, rule)
|
|
||||||
self.assertIsNotNone(c)
|
|
||||||
self.assertEqual(c.name, "me@localhost.com")
|
|
||||||
self.assertEqual(c.id, me_localhost.id)
|
|
||||||
|
|
||||||
rule = MailRule(
|
|
||||||
name="c",
|
|
||||||
assign_correspondent_from=MailRule.CorrespondentSource.FROM_NAME,
|
|
||||||
)
|
|
||||||
c = handler._get_correspondent(message, rule)
|
|
||||||
self.assertIsNotNone(c)
|
|
||||||
self.assertEqual(c.name, "Someone!")
|
|
||||||
c = handler._get_correspondent(message2, rule)
|
|
||||||
self.assertIsNotNone(c)
|
|
||||||
self.assertEqual(c.id, me_localhost.id)
|
|
||||||
|
|
||||||
rule = MailRule(
|
|
||||||
name="d",
|
|
||||||
assign_correspondent_from=MailRule.CorrespondentSource.FROM_CUSTOM,
|
|
||||||
assign_correspondent=someone_else,
|
|
||||||
)
|
|
||||||
c = handler._get_correspondent(message, rule)
|
|
||||||
self.assertEqual(c, someone_else)
|
|
||||||
|
|
||||||
def test_decrypt_encrypted_mail(self):
|
def test_decrypt_encrypted_mail(self):
|
||||||
"""
|
"""
|
||||||
Creates a mail with attachments. Then encrypts it with a new key.
|
Creates a mail with attachments. Then encrypts it with a new key.
|
||||||
Verifies that this encrypted message can be decrypted with attachments intact.
|
Verifies that this encrypted message can be decrypted with attachments intact.
|
||||||
"""
|
"""
|
||||||
message = self.create_message(
|
message = self.mailMocker.messageBuilder.create_message(
|
||||||
body="Test message with 2 attachments",
|
body="Test message with 2 attachments",
|
||||||
attachments=[
|
attachments=[
|
||||||
_AttachmentDef(
|
_AttachmentDef(
|
||||||
@@ -294,7 +124,7 @@ class TestPreprocessor:
|
|||||||
self.assertEqual(decrypted_message.uid, message.uid)
|
self.assertEqual(decrypted_message.uid, message.uid)
|
||||||
|
|
||||||
def test_handle_encrypted_message(self):
|
def test_handle_encrypted_message(self):
|
||||||
message = self.create_message(
|
message = self.mailMocker.messageBuilder.create_message(
|
||||||
subject="the message title",
|
subject="the message title",
|
||||||
from_="Myself",
|
from_="Myself",
|
||||||
attachments=2,
|
attachments=2,
|
||||||
@@ -315,9 +145,9 @@ class TestPreprocessor:
|
|||||||
|
|
||||||
self.assertEqual(result, 3)
|
self.assertEqual(result, 3)
|
||||||
|
|
||||||
self._queue_consumption_tasks_mock.assert_called()
|
self.mailMocker._queue_consumption_tasks_mock.assert_called()
|
||||||
|
|
||||||
self.assert_queue_consumption_tasks_call_args(
|
self.mailMocker.assert_queue_consumption_tasks_call_args(
|
||||||
[
|
[
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user