mirror of
https://github.com/simple-login/app.git
synced 2024-11-15 21:26:25 +08:00
f3d47a1eaa
* Feature: Preserve original unsubscribe request * Updated tests * Updated settings * PR comments * reduced prefix length * Include migrate users for new unsub behaviour * PR comments Co-authored-by: Adrià Casajús <adria.casajus@proton.ch>
116 lines
3.8 KiB
Python
116 lines
3.8 KiB
Python
import pytest
|
|
|
|
from app import config
|
|
from app.handler.unsubscribe_encoder import (
|
|
UnsubscribeData,
|
|
UnsubscribeAction,
|
|
UnsubscribeEncoder,
|
|
UnsubscribeOriginalData,
|
|
)
|
|
|
|
legacy_subject_test_data = [
|
|
("3=", UnsubscribeData(UnsubscribeAction.DisableAlias, 3)),
|
|
("438_", UnsubscribeData(UnsubscribeAction.DisableContact, 438)),
|
|
("4325*", UnsubscribeData(UnsubscribeAction.UnsubscribeNewsletter, 4325)),
|
|
]
|
|
|
|
|
|
@pytest.mark.parametrize("expected_subject, expected_deco", legacy_subject_test_data)
|
|
def test_legacy_unsub_subject(expected_subject, expected_deco):
|
|
info = UnsubscribeEncoder.decode_subject(expected_subject)
|
|
assert info == expected_deco
|
|
|
|
|
|
legacy_url_test_data = [
|
|
(
|
|
f"{config.URL}/dashboard/unsubscribe/3",
|
|
UnsubscribeData(UnsubscribeAction.DisableAlias, 3),
|
|
),
|
|
(
|
|
f"{config.URL}/dashboard/block_contact/5",
|
|
UnsubscribeData(UnsubscribeAction.DisableContact, 5),
|
|
),
|
|
]
|
|
|
|
|
|
@pytest.mark.parametrize("expected_url, unsub_data", legacy_url_test_data)
|
|
def test_encode_decode_unsub_subject(expected_url, unsub_data):
|
|
url = UnsubscribeEncoder.encode_url(unsub_data.action, unsub_data.data)
|
|
assert expected_url == url
|
|
|
|
|
|
legacy_mail_or_link_test_data = [
|
|
(
|
|
f"{config.URL}/dashboard/unsubscribe/3",
|
|
False,
|
|
UnsubscribeData(UnsubscribeAction.DisableAlias, 3),
|
|
),
|
|
(
|
|
"mailto:me@nowhere.net?subject=un.WzIsIDld.ONeJMiTW6CosJg4PMR1MPcDs-6GWoTOQFMfA2A",
|
|
True,
|
|
UnsubscribeData(UnsubscribeAction.DisableAlias, 9),
|
|
),
|
|
(
|
|
f"{config.URL}/dashboard/block_contact/8",
|
|
False,
|
|
UnsubscribeData(UnsubscribeAction.DisableContact, 8),
|
|
),
|
|
(
|
|
"mailto:me@nowhere.net?subject=un.WzMsIDhd.eo_Ynk0eNyPtsHXMpTqw7HMFgYmm1Up_wWUc3g",
|
|
True,
|
|
UnsubscribeData(UnsubscribeAction.DisableContact, 8),
|
|
),
|
|
(
|
|
"mailto:me@nowhere.net?subject=un.WzEsIDgzXQ.NZAWqfpCmLEszwc5nWuQwDSLJ3TXO3rcOe_73Q",
|
|
True,
|
|
UnsubscribeData(UnsubscribeAction.UnsubscribeNewsletter, 83),
|
|
),
|
|
(
|
|
f"{config.URL}/dashboard/unsubscribe/encoded?data=un.WzQsIFswLCAxLCAiYUBiLmMiLCAic3ViamVjdCJdXQ.aU3T5XNzJIG4LDm6-pqJk4vxxJxpgVYzc9MEFQ",
|
|
False,
|
|
UnsubscribeData(
|
|
UnsubscribeAction.OriginalUnsubscribeMailto,
|
|
UnsubscribeOriginalData(1, "a@b.c", "subject"),
|
|
),
|
|
),
|
|
(
|
|
"mailto:me@nowhere.net?subject=un.WzQsIFswLCAxLCAiYUBiLmMiLCAic3ViamVjdCJdXQ.aU3T5XNzJIG4LDm6-pqJk4vxxJxpgVYzc9MEFQ",
|
|
True,
|
|
UnsubscribeData(
|
|
UnsubscribeAction.OriginalUnsubscribeMailto,
|
|
UnsubscribeOriginalData(1, "a@b.c", "subject"),
|
|
),
|
|
),
|
|
]
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"expected_link, via_mail, unsub_data", legacy_mail_or_link_test_data
|
|
)
|
|
def test_encode_legacy_link(expected_link, via_mail, unsub_data):
|
|
if via_mail:
|
|
config.UNSUBSCRIBER = "me@nowhere.net"
|
|
else:
|
|
config.UNSUBSCRIBER = None
|
|
link_info = UnsubscribeEncoder.encode(unsub_data.action, unsub_data.data)
|
|
assert via_mail == link_info.via_email
|
|
assert expected_link == link_info.link
|
|
|
|
|
|
encode_decode_test_data = [
|
|
UnsubscribeData(UnsubscribeAction.DisableContact, 3),
|
|
UnsubscribeData(UnsubscribeAction.DisableContact, 10),
|
|
UnsubscribeData(UnsubscribeAction.DisableAlias, 101),
|
|
UnsubscribeData(
|
|
UnsubscribeAction.OriginalUnsubscribeMailto,
|
|
UnsubscribeOriginalData(323, "a@b.com", "some subject goes here"),
|
|
),
|
|
]
|
|
|
|
|
|
@pytest.mark.parametrize("unsub_data", encode_decode_test_data)
|
|
def test_encode_decode_unsub(unsub_data):
|
|
encoded = UnsubscribeEncoder.encode_subject(unsub_data.action, unsub_data.data)
|
|
decoded = UnsubscribeEncoder.decode_subject(encoded)
|
|
assert unsub_data.action == decoded.action
|
|
assert unsub_data.data == decoded.data
|