4.53.1
All checks were successful
Build-Release-Image / Build-Image (linux/amd64) (push) Successful in 3m13s
Build-Release-Image / Build-Image (linux/arm64) (push) Successful in 3m54s
Build-Release-Image / Merge-Images (push) Successful in 16s
Build-Release-Image / Create-Release (push) Successful in 40s
Build-Release-Image / Notify (push) Successful in 5s
All checks were successful
Build-Release-Image / Build-Image (linux/amd64) (push) Successful in 3m13s
Build-Release-Image / Build-Image (linux/arm64) (push) Successful in 3m54s
Build-Release-Image / Merge-Images (push) Successful in 16s
Build-Release-Image / Create-Release (push) Successful in 40s
Build-Release-Image / Notify (push) Successful in 5s
This commit is contained in:
@ -1,38 +1,72 @@
|
||||
import app.alias_utils
|
||||
from app import config
|
||||
from app.db import Session
|
||||
from app.events.event_dispatcher import GlobalDispatcher
|
||||
from app.models import (
|
||||
Alias,
|
||||
Mailbox,
|
||||
User,
|
||||
AliasMailbox,
|
||||
)
|
||||
from tests.events.event_test_utils import (
|
||||
OnMemoryDispatcher,
|
||||
_get_event_from_string,
|
||||
_create_linked_user,
|
||||
)
|
||||
from tests.utils import login
|
||||
|
||||
on_memory_dispatcher = OnMemoryDispatcher()
|
||||
|
||||
|
||||
def setup_module():
|
||||
GlobalDispatcher.set_dispatcher(on_memory_dispatcher)
|
||||
config.EVENT_WEBHOOK = "http://test"
|
||||
|
||||
|
||||
def teardown_module():
|
||||
GlobalDispatcher.set_dispatcher(None)
|
||||
config.EVENT_WEBHOOK = None
|
||||
|
||||
|
||||
def test_alias_transfer(flask_client):
|
||||
user = login(flask_client)
|
||||
mb = Mailbox.create(user_id=user.id, email="mb@gmail.com", commit=True)
|
||||
(source_user, source_user_pu) = _create_linked_user()
|
||||
source_user = login(flask_client, source_user)
|
||||
mb = Mailbox.create(user_id=source_user.id, email="mb@gmail.com", commit=True)
|
||||
|
||||
alias = Alias.create_new_random(user)
|
||||
alias = Alias.create_new_random(source_user)
|
||||
Session.commit()
|
||||
|
||||
AliasMailbox.create(alias_id=alias.id, mailbox_id=mb.id, commit=True)
|
||||
|
||||
new_user = User.create(
|
||||
email="hey@example.com",
|
||||
password="password",
|
||||
activated=True,
|
||||
commit=True,
|
||||
)
|
||||
(target_user, target_user_pu) = _create_linked_user()
|
||||
|
||||
Mailbox.create(
|
||||
user_id=new_user.id, email="hey2@example.com", verified=True, commit=True
|
||||
user_id=target_user.id, email="hey2@example.com", verified=True, commit=True
|
||||
)
|
||||
|
||||
app.alias_utils.transfer_alias(alias, new_user, new_user.mailboxes())
|
||||
on_memory_dispatcher.clear()
|
||||
app.alias_utils.transfer_alias(alias, target_user, target_user.mailboxes())
|
||||
|
||||
# refresh from db
|
||||
alias = Alias.get(alias.id)
|
||||
assert alias.user == new_user
|
||||
assert set(alias.mailboxes) == set(new_user.mailboxes())
|
||||
assert alias.user == target_user
|
||||
assert set(alias.mailboxes) == set(target_user.mailboxes())
|
||||
assert len(alias.mailboxes) == 2
|
||||
|
||||
# Check events
|
||||
assert len(on_memory_dispatcher.memory) == 2
|
||||
# 1st delete event
|
||||
event_data = on_memory_dispatcher.memory[0]
|
||||
event_content = _get_event_from_string(event_data, source_user, source_user_pu)
|
||||
assert event_content.alias_deleted is not None
|
||||
alias_deleted = event_content.alias_deleted
|
||||
assert alias_deleted.id == alias.id
|
||||
assert alias_deleted.email == alias.email
|
||||
# 2nd create event
|
||||
event_data = on_memory_dispatcher.memory[1]
|
||||
event_content = _get_event_from_string(event_data, target_user, target_user_pu)
|
||||
assert event_content.alias_created is not None
|
||||
alias_created = event_content.alias_created
|
||||
assert alias.id == alias_created.id
|
||||
assert alias.email == alias_created.email
|
||||
assert alias.note or "" == alias_created.note
|
||||
assert alias.enabled == alias_created.enabled
|
||||
|
Reference in New Issue
Block a user