2024-04-08 21:29:26 +02:00
|
|
|
"""
|
|
|
|
|
Unit tests for the mailbox model
|
|
|
|
|
"""
|
|
|
|
|
|
2024-08-08 18:28:01 +02:00
|
|
|
from django.core import exceptions
|
2024-08-30 17:05:23 +02:00
|
|
|
from django.test.utils import override_settings
|
2024-04-08 21:29:26 +02:00
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
|
2024-08-05 12:20:44 +02:00
|
|
|
from mailbox_manager import enums, factories, models
|
2024-04-08 21:29:26 +02:00
|
|
|
|
|
|
|
|
pytestmark = pytest.mark.django_db
|
|
|
|
|
|
|
|
|
|
# LOCAL PART FIELD
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__local_part_cannot_be_empty():
|
|
|
|
|
"""The "local_part" field should not be empty."""
|
2024-08-08 18:28:01 +02:00
|
|
|
with pytest.raises(exceptions.ValidationError, match="This field cannot be blank"):
|
2024-04-08 21:29:26 +02:00
|
|
|
factories.MailboxFactory(local_part="")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__local_part_cannot_be_null():
|
|
|
|
|
"""The "local_part" field should not be null."""
|
2024-08-08 18:28:01 +02:00
|
|
|
with pytest.raises(exceptions.ValidationError, match="This field cannot be null"):
|
2024-04-08 21:29:26 +02:00
|
|
|
factories.MailboxFactory(local_part=None)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__local_part_matches_expected_format():
|
|
|
|
|
"""
|
|
|
|
|
The local part should contain alpha-numeric caracters
|
|
|
|
|
and a limited set of special caracters ("+", "-", ".", "_").
|
|
|
|
|
"""
|
2024-08-27 18:05:46 +02:00
|
|
|
# "-", ".", "_" are allowed
|
|
|
|
|
factories.MailboxFactory(local_part="Marie-Jose.Perec_2024")
|
2024-04-08 21:29:26 +02:00
|
|
|
|
2024-08-27 18:05:46 +02:00
|
|
|
# other special characters should raise a validation error
|
|
|
|
|
# "+" included, as this test is about mail creation
|
|
|
|
|
for character in ["+", "@", "!", "$", "%", " "]:
|
2024-08-08 18:28:01 +02:00
|
|
|
with pytest.raises(exceptions.ValidationError, match="Enter a valid value"):
|
2024-08-05 12:20:44 +02:00
|
|
|
factories.MailboxFactory(local_part=f"marie{character}jo")
|
2024-04-08 21:29:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__local_part_unique_per_domain():
|
|
|
|
|
"""Local parts should be unique per domain."""
|
|
|
|
|
|
|
|
|
|
existing_mailbox = factories.MailboxFactory()
|
|
|
|
|
|
|
|
|
|
# same local part on another domain should not be a problem
|
|
|
|
|
factories.MailboxFactory(local_part=existing_mailbox.local_part)
|
|
|
|
|
|
|
|
|
|
# same local part on the same domain should not be possible
|
|
|
|
|
with pytest.raises(
|
2024-08-08 18:28:01 +02:00
|
|
|
exceptions.ValidationError,
|
|
|
|
|
match="Mailbox with this Local_part and Domain already exists.",
|
2024-04-08 21:29:26 +02:00
|
|
|
):
|
|
|
|
|
factories.MailboxFactory(
|
|
|
|
|
local_part=existing_mailbox.local_part, domain=existing_mailbox.domain
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# DOMAIN FIELD
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__domain_must_be_a_maildomain_instance():
|
|
|
|
|
"""The "domain" field should be an instance of MailDomain."""
|
|
|
|
|
expected_error = '"Mailbox.domain" must be a "MailDomain" instance.'
|
|
|
|
|
with pytest.raises(ValueError, match=expected_error):
|
|
|
|
|
factories.MailboxFactory(domain="")
|
|
|
|
|
|
|
|
|
|
with pytest.raises(ValueError, match=expected_error):
|
|
|
|
|
factories.MailboxFactory(domain="domain-as-string.com")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__domain_cannot_be_null():
|
|
|
|
|
"""The "domain" field should not be null."""
|
2024-08-05 12:20:44 +02:00
|
|
|
with pytest.raises(models.MailDomain.DoesNotExist, match="Mailbox has no domain."):
|
2024-04-08 21:29:26 +02:00
|
|
|
factories.MailboxFactory(domain=None)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# SECONDARY_EMAIL FIELD
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__secondary_email_cannot_be_empty():
|
|
|
|
|
"""The "secondary_email" field should not be empty."""
|
2024-08-08 18:28:01 +02:00
|
|
|
with pytest.raises(exceptions.ValidationError, match="This field cannot be blank"):
|
2024-04-08 21:29:26 +02:00
|
|
|
factories.MailboxFactory(secondary_email="")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__secondary_email_cannot_be_null():
|
|
|
|
|
"""The "secondary_email" field should not be null."""
|
2024-08-08 18:28:01 +02:00
|
|
|
with pytest.raises(exceptions.ValidationError, match="This field cannot be null"):
|
2024-04-08 21:29:26 +02:00
|
|
|
factories.MailboxFactory(secondary_email=None)
|
2024-07-07 01:16:33 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__cannot_be_created_for_disabled_maildomain():
|
|
|
|
|
"""Mailbox creation is allowed only for a domain enabled.
|
|
|
|
|
A disabled status for the mail domain raises an error."""
|
|
|
|
|
with pytest.raises(
|
2024-08-08 18:28:01 +02:00
|
|
|
exceptions.ValidationError,
|
|
|
|
|
match="You can create mailbox only for a domain enabled",
|
2024-07-07 01:16:33 +02:00
|
|
|
):
|
|
|
|
|
factories.MailboxFactory(
|
|
|
|
|
domain=factories.MailDomainFactory(
|
|
|
|
|
status=enums.MailDomainStatusChoices.DISABLED
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__cannot_be_created_for_failed_maildomain():
|
|
|
|
|
"""Mailbox creation is allowed only for a domain enabled.
|
|
|
|
|
A failed status for the mail domain raises an error."""
|
|
|
|
|
with pytest.raises(
|
2024-08-08 18:28:01 +02:00
|
|
|
exceptions.ValidationError,
|
|
|
|
|
match="You can create mailbox only for a domain enabled",
|
2024-07-07 01:16:33 +02:00
|
|
|
):
|
|
|
|
|
factories.MailboxFactory(
|
|
|
|
|
domain=factories.MailDomainFactory(
|
|
|
|
|
status=enums.MailDomainStatusChoices.FAILED
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_models_mailboxes__cannot_be_created_for_pending_maildomain():
|
|
|
|
|
"""Mailbox creation is allowed only for a domain enabled.
|
|
|
|
|
A pending status for the mail domain raises an error."""
|
|
|
|
|
with pytest.raises(
|
2024-08-08 18:28:01 +02:00
|
|
|
exceptions.ValidationError,
|
|
|
|
|
match="You can create mailbox only for a domain enabled",
|
2024-07-07 01:16:33 +02:00
|
|
|
):
|
|
|
|
|
# MailDomainFactory initializes a mail domain with default values,
|
|
|
|
|
# so mail domain status is pending!
|
|
|
|
|
factories.MailboxFactory(domain=factories.MailDomainFactory())
|
2024-08-05 12:20:44 +02:00
|
|
|
|
|
|
|
|
|
2024-09-17 15:24:35 +02:00
|
|
|
### REACTING TO DIMAIL-API
|
|
|
|
|
### We mock dimail's responses to avoid testing dimail's container too
|
2024-08-05 12:20:44 +02:00
|
|
|
|
|
|
|
|
|
2024-08-30 17:05:23 +02:00
|
|
|
@override_settings(MAIL_PROVISIONING_API_CREDENTIALS=None)
|
2024-09-09 19:08:05 +02:00
|
|
|
def test_models_mailboxes__dimail_no_credentials():
|
2024-08-30 17:05:23 +02:00
|
|
|
"""
|
|
|
|
|
If MAIL_PROVISIONING_API_CREDENTIALS setting is not configured,
|
|
|
|
|
trying to create a mailbox should raise an error.
|
|
|
|
|
"""
|
|
|
|
|
domain = factories.MailDomainEnabledFactory()
|
2024-08-05 12:20:44 +02:00
|
|
|
|
|
|
|
|
with pytest.raises(
|
2024-08-08 18:28:01 +02:00
|
|
|
exceptions.ValidationError,
|
2024-08-30 17:05:23 +02:00
|
|
|
match="Please configure MAIL_PROVISIONING_API_CREDENTIALS before creating any mailbox.",
|
2024-08-05 12:20:44 +02:00
|
|
|
):
|
|
|
|
|
factories.MailboxFactory(domain=domain)
|