Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add support for clearing out old messages #40

Merged
merged 5 commits into from
Sep 28, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions src/email_relay/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ class AppSettings:
EMPTY_QUEUE_SLEEP: int = 30
EMAIL_THROTTLE: int = 0
MESSAGES_BATCH_SIZE: int | None = None
MESSAGES_RETENTION_SECONDS: int | None = None

def __getattribute__(self, __name: str) -> Any:
user_settings = getattr(settings, EMAIL_RELAY_SETTINGS_NAME, {})
Expand Down
17 changes: 17 additions & 0 deletions src/email_relay/management/commands/runrelay.py
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
from __future__ import annotations

import datetime
import logging
import time

from django.core.management import BaseCommand
from django.utils import timezone

from email_relay.conf import app_settings
from email_relay.models import Message
Expand All @@ -27,3 +29,18 @@ def handle(self, *args, **options):
logger.debug(msg)

send_all()
self.delete_old_messages()

def delete_old_messages(self):
if app_settings.MESSAGES_RETENTION_SECONDS is not None:
logger.debug("deleting old messages")
if app_settings.MESSAGES_RETENTION_SECONDS == 0:
deleted_messages = Message.objects.sent().delete()
else:
deleted_messages = Message.objects.sent_before(
timezone.now()
- datetime.timedelta(
seconds=app_settings.MESSAGES_RETENTION_SECONDS
)
).delete()
logger.debug(f"deleted {deleted_messages[0]} messages")
72 changes: 72 additions & 0 deletions tests/test_runrelay.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,16 @@
from __future__ import annotations

import datetime

import pytest
from django.core.management import call_command
from django.test.utils import override_settings
from django.utils import timezone
from model_bakery import baker

from email_relay.management.commands.runrelay import Command
from email_relay.models import Message
from email_relay.models import Status


def test_runrelay_help():
Expand All @@ -13,3 +22,66 @@ def test_runrelay_help():

# Asserting that the command exits with a successful exit code (0 for help command)
assert exec_info.value.code == 0


@pytest.fixture
def runrelay():
return Command()


@pytest.mark.django_db(databases=["default", "email_relay_db"])
def test_delete_sent_messages_based_on_retention_default(runrelay):
baker.make(
"email_relay.Message",
status=Status.SENT,
sent_at=timezone.now(),
_quantity=10,
)

runrelay.delete_old_messages()

assert Message.objects.count() == 10


@override_settings(
DJANGO_EMAIL_RELAY={
"MESSAGES_RETENTION_SECONDS": 0,
}
)
@pytest.mark.django_db(databases=["default", "email_relay_db"])
def test_delete_sent_messages_based_on_retention_zero(runrelay):
baker.make(
"email_relay.Message",
status=Status.SENT,
sent_at=timezone.now(),
_quantity=10,
)

runrelay.delete_old_messages()

assert Message.objects.count() == 0


@override_settings(
DJANGO_EMAIL_RELAY={
"MESSAGES_RETENTION_SECONDS": 600,
}
)
@pytest.mark.django_db(databases=["default", "email_relay_db"])
def test_delete_sent_messages_based_on_retention_non_zero(runrelay):
baker.make(
"email_relay.Message",
status=Status.SENT,
sent_at=timezone.now(),
_quantity=5,
)
baker.make(
"email_relay.Message",
status=Status.SENT,
sent_at=timezone.now() - datetime.timedelta(seconds=601),
_quantity=5,
)

runrelay.delete_old_messages()

assert Message.objects.count() == 5