mirror of
https://github.com/mealie-recipes/mealie.git
synced 2025-07-24 15:49:42 +02:00
feat: extend email support for SSL/No Auth Email Support (#1235)
* Changes Settings to use new SMTP_AUTH_STRATEGY variable in place of SMTP_TLS with transition support #1187 * Wires up default email client to use ssl or tls authentication if enabled in settings * Updates the docs * Update template file * remove SMTP_TLS and use staticmethod for validate * consolidate test cases with params Co-authored-by: Hayden <64056131+hay-kot@users.noreply.github.com>
This commit is contained in:
parent
b2066dfe72
commit
6a88a59981
7 changed files with 98 additions and 46 deletions
|
@ -1,6 +1,10 @@
|
|||
import re
|
||||
from dataclasses import dataclass
|
||||
|
||||
import pytest
|
||||
|
||||
from mealie.core.config import get_app_settings
|
||||
from mealie.core.settings.settings import AppSettings
|
||||
|
||||
|
||||
def test_non_default_settings(monkeypatch):
|
||||
|
@ -36,29 +40,59 @@ def test_pg_connection_args(monkeypatch):
|
|||
assert app_settings.DB_URL == "postgresql://mealie:mealie@postgres:5432/mealie"
|
||||
|
||||
|
||||
def test_smtp_enable(monkeypatch):
|
||||
monkeypatch.setenv("SMTP_HOST", "")
|
||||
monkeypatch.setenv("SMTP_PORT", "")
|
||||
monkeypatch.setenv("SMTP_TLS", "true")
|
||||
monkeypatch.setenv("SMTP_FROM_NAME", "")
|
||||
monkeypatch.setenv("SMTP_FROM_EMAIL", "")
|
||||
monkeypatch.setenv("SMTP_USER", "")
|
||||
monkeypatch.setenv("SMTP_PASSWORD", "")
|
||||
@dataclass(slots=True)
|
||||
class SMTPValidationCase:
|
||||
host: str
|
||||
port: str
|
||||
auth_strategy: str
|
||||
from_name: str
|
||||
from_email: str
|
||||
user: str
|
||||
password: str
|
||||
is_valid: bool
|
||||
|
||||
get_app_settings.cache_clear()
|
||||
app_settings = get_app_settings()
|
||||
|
||||
assert app_settings.SMTP_ENABLE is False
|
||||
smtp_validation_cases = [
|
||||
(
|
||||
"bad_data_tls",
|
||||
SMTPValidationCase("", "", "tls", "", "", "", "", False),
|
||||
),
|
||||
(
|
||||
"bad_data_ssl",
|
||||
SMTPValidationCase("", "", "ssl", "", "", "", "", False),
|
||||
),
|
||||
(
|
||||
"no_auth",
|
||||
SMTPValidationCase("email.mealie.io", "25", "none", "Mealie", "mealie@mealie.io", "", "", True),
|
||||
),
|
||||
(
|
||||
"good_data_tls",
|
||||
SMTPValidationCase(
|
||||
"email.mealie.io", "587", "tls", "Mealie", "mealie@mealie.io", "mealie@mealie.io", "mealie-password", True
|
||||
),
|
||||
),
|
||||
(
|
||||
"good_data_ssl",
|
||||
SMTPValidationCase(
|
||||
"email.mealie.io", "465", "tls", "Mealie", "mealie@mealie.io", "mealie@mealie.io", "mealie-password", True
|
||||
),
|
||||
),
|
||||
]
|
||||
|
||||
monkeypatch.setenv("SMTP_HOST", "email.mealie.io")
|
||||
monkeypatch.setenv("SMTP_PORT", "587")
|
||||
monkeypatch.setenv("SMTP_TLS", "true")
|
||||
monkeypatch.setenv("SMTP_FROM_NAME", "Mealie")
|
||||
monkeypatch.setenv("SMTP_FROM_EMAIL", "mealie@mealie.io")
|
||||
monkeypatch.setenv("SMTP_USER", "mealie@mealie.io")
|
||||
monkeypatch.setenv("SMTP_PASSWORD", "mealie-password")
|
||||
smtp_cases = [x[1] for x in smtp_validation_cases]
|
||||
smtp_cases_ids = [x[0] for x in smtp_validation_cases]
|
||||
|
||||
get_app_settings.cache_clear()
|
||||
app_settings = get_app_settings()
|
||||
|
||||
assert app_settings.SMTP_ENABLE is True
|
||||
@pytest.mark.parametrize("data", smtp_cases, ids=smtp_cases_ids)
|
||||
def test_smtp_enable_with_bad_data_tls(data: SMTPValidationCase):
|
||||
is_valid = AppSettings.validate_smtp(
|
||||
data.host,
|
||||
data.port,
|
||||
data.from_name,
|
||||
data.from_email,
|
||||
data.auth_strategy,
|
||||
data.user,
|
||||
data.password,
|
||||
)
|
||||
|
||||
assert is_valid is data.is_valid
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue