upgrade deltachat library and fix tests
This commit is contained in:
parent
8681358317
commit
b9f274bbe9
|
@ -24,7 +24,7 @@ install_requires =
|
||||||
pyinfra
|
pyinfra
|
||||||
pickleDB
|
pickleDB
|
||||||
qrcode
|
qrcode
|
||||||
deltachat>=1.133.1
|
deltachat>=1.136.2
|
||||||
|
|
||||||
[options.packages.find]
|
[options.packages.find]
|
||||||
where = src
|
where = src
|
||||||
|
|
|
@ -80,7 +80,7 @@ def tmp_file_path(request, tmpdir):
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def relaycrew(crew):
|
def relaycrew(crew) -> deltachat.Chat:
|
||||||
crew.bot.relayplugin = RelayPlugin(crew.bot, crew.kvstore)
|
crew.bot.relayplugin = RelayPlugin(crew.bot, crew.kvstore)
|
||||||
crew.bot.add_account_plugin(crew.bot.relayplugin)
|
crew.bot.add_account_plugin(crew.bot.relayplugin)
|
||||||
assert not crew.bot.relayplugin.is_relay_group(crew)
|
assert not crew.bot.relayplugin.is_relay_group(crew)
|
||||||
|
@ -88,7 +88,7 @@ def relaycrew(crew):
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def crew(team_bot, team_user, tmpdir):
|
def crew(team_bot, team_user, tmpdir) -> deltachat.Chat:
|
||||||
from team_bot.bot import SetupPlugin
|
from team_bot.bot import SetupPlugin
|
||||||
|
|
||||||
crew = team_bot.create_group_chat(
|
crew = team_bot.create_group_chat(
|
||||||
|
@ -104,12 +104,7 @@ def crew(team_bot, team_user, tmpdir):
|
||||||
crew.bot.setupplugin = setupplugin
|
crew.bot.setupplugin = setupplugin
|
||||||
|
|
||||||
# wait until old user is properly added to crew
|
# wait until old user is properly added to crew
|
||||||
last_message = team_user.wait_next_incoming_message().text
|
team_user._evtracker.wait_securejoin_joiner_progress(1000)
|
||||||
while (
|
|
||||||
f"Member Me ({team_user.get_config('addr')}) added by bot" not in last_message
|
|
||||||
):
|
|
||||||
print("User received message:", last_message)
|
|
||||||
last_message = team_user.wait_next_incoming_message().text
|
|
||||||
|
|
||||||
crew.kvstore = pickledb.load(tmpdir + "pickle.db", True)
|
crew.kvstore = pickledb.load(tmpdir + "pickle.db", True)
|
||||||
crew.kvstore.set("crew_id", crew.id)
|
crew.kvstore.set("crew_id", crew.id)
|
||||||
|
@ -117,7 +112,7 @@ def crew(team_bot, team_user, tmpdir):
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def team_bot(tmpdir):
|
def team_bot(tmpdir) -> deltachat.Account:
|
||||||
ac = account(tmpdir + "/bot.sqlite", show_ffi=True)
|
ac = account(tmpdir + "/bot.sqlite", show_ffi=True)
|
||||||
yield ac
|
yield ac
|
||||||
ac.shutdown()
|
ac.shutdown()
|
||||||
|
@ -125,7 +120,7 @@ def team_bot(tmpdir):
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def team_user(tmpdir):
|
def team_user(tmpdir) -> deltachat.Account:
|
||||||
ac = account(tmpdir + "/user.sqlite")
|
ac = account(tmpdir + "/user.sqlite")
|
||||||
yield ac
|
yield ac
|
||||||
ac.shutdown()
|
ac.shutdown()
|
||||||
|
@ -133,19 +128,20 @@ def team_user(tmpdir):
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def outsider(tmpdir):
|
def outsider(tmpdir) -> deltachat.Account:
|
||||||
ac = account(tmpdir + "/outsider.sqlite")
|
ac = account(tmpdir + "/outsider.sqlite")
|
||||||
yield ac
|
yield ac
|
||||||
ac.shutdown()
|
ac.shutdown()
|
||||||
ac.wait_shutdown()
|
ac.wait_shutdown()
|
||||||
|
|
||||||
|
|
||||||
def account(db_path, show_ffi=False):
|
def account(db_path, show_ffi=False) -> deltachat.Account:
|
||||||
token = os.environ.get(
|
token = os.environ.get(
|
||||||
"DCC_NEW_TMP_EMAIL", "https://nine.testrun.org/cgi-bin/newemail.py"
|
"DCC_NEW_TMP_EMAIL", "https://nine.testrun.org/cgi-bin/newemail.py"
|
||||||
)
|
)
|
||||||
print(token)
|
print(token)
|
||||||
ac = deltachat.Account(str(db_path))
|
ac = deltachat.Account(str(db_path))
|
||||||
|
ac._evtracker = ac.add_account_plugin(deltachat.events.FFIEventTracker(ac))
|
||||||
credentials = requests.post(token).json()
|
credentials = requests.post(token).json()
|
||||||
email = credentials["email"]
|
email = credentials["email"]
|
||||||
password = credentials["password"]
|
password = credentials["password"]
|
||||||
|
|
|
@ -22,39 +22,43 @@ def get_user_crew(crewuser: deltachat.Account) -> deltachat.Chat:
|
||||||
return user_crew
|
return user_crew
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.timeout(60)
|
@pytest.mark.timeout(TIMEOUT * 3)
|
||||||
def test_not_relay_groups(relaycrew, outsider):
|
def test_not_relay_groups(relaycrew, outsider, lp):
|
||||||
bot = relaycrew.bot
|
bot = relaycrew.bot
|
||||||
user = relaycrew.user
|
user = relaycrew.user
|
||||||
|
|
||||||
# bot <-> outsider 1:1 chat
|
lp.sec("bot <-> outsider 1:1 chat")
|
||||||
outsider_botcontact = outsider.create_contact(bot.get_config("addr"))
|
outsider_botcontact = outsider.create_contact(bot.get_config("addr"))
|
||||||
outsider_outside_chat = outsider.create_chat(outsider_botcontact)
|
outsider_outside_chat = outsider.create_chat(outsider_botcontact)
|
||||||
outsider_outside_chat.send_text("test 1:1 message to bot")
|
outsider_outside_chat.send_text("test 1:1 message to bot")
|
||||||
|
|
||||||
bot_message_from_outsider = bot.wait_next_incoming_message()
|
bot_message_from_outsider = bot._evtracker.wait_next_incoming_message()
|
||||||
bot_outside_chat = bot_message_from_outsider.chat
|
bot_outside_chat = bot_message_from_outsider.chat
|
||||||
assert not bot.relayplugin.is_relay_group(bot_outside_chat)
|
assert not bot.relayplugin.is_relay_group(bot_outside_chat)
|
||||||
|
|
||||||
# bot <-> outsider group chat
|
lp.sec("bot <-> outsider group chat")
|
||||||
outsider_bot_group = outsider.create_group_chat(
|
outsider_bot_group = outsider.create_group_chat(
|
||||||
"test with outsider", contacts=[outsider_botcontact]
|
"test with outsider", contacts=[outsider_botcontact]
|
||||||
)
|
)
|
||||||
outsider_bot_group.send_text("test message to outsider group")
|
outsider_bot_group.send_text("test message to outsider group")
|
||||||
bot_message_from_outsider = bot.wait_next_incoming_message()
|
bot_message_from_outsider = bot._evtracker.wait_next_incoming_message()
|
||||||
assert not bot.relayplugin.is_relay_group(bot_message_from_outsider.chat)
|
assert not bot.relayplugin.is_relay_group(bot_message_from_outsider.chat)
|
||||||
|
|
||||||
# bot <-> user 1:1 chat
|
lp.sec("bot <-> user 1:1 chat")
|
||||||
user_botcontact = user.create_contact(bot.get_config("addr"))
|
user_botcontact = user.create_contact(bot.get_config("addr"))
|
||||||
user_to_bot = user.create_chat(user_botcontact)
|
user_to_bot = user.create_chat(user_botcontact)
|
||||||
user_to_bot.send_text("test message to bot")
|
user_to_bot.send_text("test message to bot")
|
||||||
bot_message_from_user = bot.wait_next_incoming_message()
|
# somehow the message doesn't trigger DC_EVENT_INCOMING_MSG
|
||||||
|
bot_message_from_user = bot.get_chats()[-3].get_messages()[-1] # bot._evtracker.wait_next_incoming_message()
|
||||||
|
while bot_message_from_user.text != "test message to bot":
|
||||||
|
bot_message_from_user = bot.get_chats()[-3].get_messages()[-1] # bot._evtracker.wait_next_incoming_message()
|
||||||
|
time.sleep(1)
|
||||||
assert not bot.relayplugin.is_relay_group(bot_message_from_user.chat)
|
assert not bot.relayplugin.is_relay_group(bot_message_from_user.chat)
|
||||||
|
|
||||||
# bot <-> user group chat
|
lp.sec("bot <-> user group chat")
|
||||||
user_group = user.create_group_chat("test with user", contacts=[user_botcontact])
|
user_group = user.create_group_chat("test with user", contacts=[user_botcontact])
|
||||||
user_group.send_text("testing message to user group")
|
user_group.send_text("testing message to user group")
|
||||||
bot_message_from_user = bot.wait_next_incoming_message()
|
bot_message_from_user = bot._evtracker.wait_next_incoming_message()
|
||||||
assert not bot.relayplugin.is_relay_group(bot_message_from_user.chat)
|
assert not bot.relayplugin.is_relay_group(bot_message_from_user.chat)
|
||||||
|
|
||||||
|
|
||||||
|
@ -69,18 +73,18 @@ def test_relay_group_forwarding(relaycrew, outsider):
|
||||||
outsider_outside_chat.send_text("test 1:1 message to bot")
|
outsider_outside_chat.send_text("test 1:1 message to bot")
|
||||||
|
|
||||||
# get outside chat
|
# get outside chat
|
||||||
message_from_outsider = bot.wait_next_incoming_message()
|
message_from_outsider = bot._evtracker.wait_next_incoming_message()
|
||||||
bot_outside_chat = message_from_outsider.chat
|
bot_outside_chat = message_from_outsider.chat
|
||||||
assert not bot.relayplugin.is_relay_group(bot_outside_chat)
|
assert not bot.relayplugin.is_relay_group(bot_outside_chat)
|
||||||
|
|
||||||
# get relay group
|
# get relay group
|
||||||
user.wait_next_incoming_message() # group added message
|
user._evtracker.wait_next_incoming_message() # group added message
|
||||||
user_forwarded_message_from_outsider = user.wait_next_incoming_message()
|
user_forwarded_message_from_outsider = user._evtracker.wait_next_incoming_message()
|
||||||
user_relay_group = user_forwarded_message_from_outsider.create_chat()
|
user_relay_group = user_forwarded_message_from_outsider.create_chat()
|
||||||
user_relay_group.send_text(
|
user_relay_group.send_text(
|
||||||
"Chatter in relay group"
|
"Chatter in relay group"
|
||||||
) # send normal reply, not forwarded
|
) # send normal reply, not forwarded
|
||||||
bot_chatter_in_relay_group = bot.wait_next_incoming_message()
|
bot_chatter_in_relay_group = bot._evtracker.wait_next_incoming_message()
|
||||||
bot_relay_group = bot_chatter_in_relay_group.chat
|
bot_relay_group = bot_chatter_in_relay_group.chat
|
||||||
|
|
||||||
# check if relay group has relay group properties
|
# check if relay group has relay group properties
|
||||||
|
@ -104,7 +108,7 @@ def test_relay_group_forwarding(relaycrew, outsider):
|
||||||
assert sent_id == user_direct_reply.id
|
assert sent_id == user_direct_reply.id
|
||||||
|
|
||||||
# check that direct reply was forwarded to outsider
|
# check that direct reply was forwarded to outsider
|
||||||
outsider_direct_reply = outsider.wait_next_incoming_message()
|
outsider_direct_reply = outsider._evtracker.wait_next_incoming_message()
|
||||||
assert outsider_direct_reply.text == "This should be forwarded to the outsider"
|
assert outsider_direct_reply.text == "This should be forwarded to the outsider"
|
||||||
assert outsider_direct_reply.chat == outsider_outside_chat
|
assert outsider_direct_reply.chat == outsider_outside_chat
|
||||||
assert outsider_direct_reply.get_sender_contact() == outsider_botcontact
|
assert outsider_direct_reply.get_sender_contact() == outsider_botcontact
|
||||||
|
@ -118,7 +122,7 @@ def test_relay_group_forwarding(relaycrew, outsider):
|
||||||
outsider_outside_chat.send_text("Second message by outsider")
|
outsider_outside_chat.send_text("Second message by outsider")
|
||||||
|
|
||||||
# check that outsider's reply ends up in the same chat
|
# check that outsider's reply ends up in the same chat
|
||||||
user_second_message_from_outsider = user.wait_next_incoming_message()
|
user_second_message_from_outsider = user._evtracker.wait_next_incoming_message()
|
||||||
assert user_second_message_from_outsider.chat == user_relay_group
|
assert user_second_message_from_outsider.chat == user_relay_group
|
||||||
|
|
||||||
# check that relay group explanation is not forwarded to outsider
|
# check that relay group explanation is not forwarded to outsider
|
||||||
|
@ -137,7 +141,7 @@ def test_default_outside_help(relaycrew, outsider):
|
||||||
outsider_outside_chat.send_text("/help")
|
outsider_outside_chat.send_text("/help")
|
||||||
|
|
||||||
# get response
|
# get response
|
||||||
outside_help_message = outsider.wait_next_incoming_message()
|
outside_help_message = outsider._evtracker.wait_next_incoming_message()
|
||||||
assert "I forward messages to the " in outside_help_message.text
|
assert "I forward messages to the " in outside_help_message.text
|
||||||
|
|
||||||
# assert no relay group was created
|
# assert no relay group was created
|
||||||
|
@ -156,7 +160,7 @@ def test_empty_outside_help(relaycrew, outsider):
|
||||||
assert user_crew.get_name().startswith("Team")
|
assert user_crew.get_name().startswith("Team")
|
||||||
user_crew.send_text("/set_outside_help")
|
user_crew.send_text("/set_outside_help")
|
||||||
# ensure /set_outside_help arrives before sending /help
|
# ensure /set_outside_help arrives before sending /help
|
||||||
bot.wait_next_incoming_message()
|
bot._evtracker.wait_next_incoming_message()
|
||||||
|
|
||||||
# create outside chat
|
# create outside chat
|
||||||
outsider_botcontact = outsider.create_contact(bot.get_config("addr"))
|
outsider_botcontact = outsider.create_contact(bot.get_config("addr"))
|
||||||
|
@ -164,9 +168,10 @@ def test_empty_outside_help(relaycrew, outsider):
|
||||||
outsider_outside_chat.send_text("/help")
|
outsider_outside_chat.send_text("/help")
|
||||||
|
|
||||||
# get forwarded /help message
|
# get forwarded /help message
|
||||||
user.wait_next_incoming_message() # group added message
|
user._evtracker.wait_next_incoming_message() # group added message
|
||||||
user.wait_next_incoming_message() # explanation message
|
user._evtracker.wait_next_incoming_message() # "Removed help message for outsiders"
|
||||||
user_forwarded_message_from_outsider = user.wait_next_incoming_message()
|
user._evtracker.wait_next_incoming_message() # explanation message
|
||||||
|
user_forwarded_message_from_outsider = user._evtracker.wait_next_incoming_message()
|
||||||
assert user_forwarded_message_from_outsider.text == "/help"
|
assert user_forwarded_message_from_outsider.text == "/help"
|
||||||
|
|
||||||
|
|
||||||
|
@ -182,7 +187,7 @@ def test_changed_outside_help(relaycrew, outsider):
|
||||||
outside_help_text = "Hi friend :) send me messages to chat with the team"
|
outside_help_text = "Hi friend :) send me messages to chat with the team"
|
||||||
user_crew.send_text("/set_outside_help " + outside_help_text)
|
user_crew.send_text("/set_outside_help " + outside_help_text)
|
||||||
# ensure /set_outside_help arrives before sending /help
|
# ensure /set_outside_help arrives before sending /help
|
||||||
bot.wait_next_incoming_message()
|
bot._evtracker.wait_next_incoming_message()
|
||||||
|
|
||||||
# create outside chat
|
# create outside chat
|
||||||
outsider_botcontact = outsider.create_contact(bot.get_config("addr"))
|
outsider_botcontact = outsider.create_contact(bot.get_config("addr"))
|
||||||
|
@ -190,7 +195,7 @@ def test_changed_outside_help(relaycrew, outsider):
|
||||||
outsider_outside_chat.send_text("/help")
|
outsider_outside_chat.send_text("/help")
|
||||||
|
|
||||||
# get response
|
# get response
|
||||||
outside_help_message = outsider.wait_next_incoming_message()
|
outside_help_message = outsider._evtracker.wait_next_incoming_message()
|
||||||
assert outside_help_message.text == outside_help_text
|
assert outside_help_message.text == outside_help_text
|
||||||
|
|
||||||
# assert no relay group was created
|
# assert no relay group was created
|
||||||
|
@ -222,11 +227,12 @@ def test_change_avatar(relaycrew):
|
||||||
sent_id = dclib.dc_send_msg(user._dc_context, user_crew.id, msg._dc_msg)
|
sent_id = dclib.dc_send_msg(user._dc_context, user_crew.id, msg._dc_msg)
|
||||||
assert sent_id == msg.id
|
assert sent_id == msg.id
|
||||||
|
|
||||||
group_avatar_changed_msg = user.wait_next_incoming_message()
|
user._evtracker.wait_next_incoming_message() # chat successfully created
|
||||||
|
group_avatar_changed_msg = user._evtracker.wait_next_incoming_message()
|
||||||
assert "Group image changed" in group_avatar_changed_msg.text
|
assert "Group image changed" in group_avatar_changed_msg.text
|
||||||
assert user_crew.get_profile_image()
|
assert user_crew.get_profile_image()
|
||||||
|
|
||||||
confirmation_msg = user.wait_next_incoming_message()
|
confirmation_msg = user._evtracker.wait_next_incoming_message()
|
||||||
assert confirmation_msg.text == "Avatar changed to this image."
|
assert confirmation_msg.text == "Avatar changed to this image."
|
||||||
assert botcontact.get_profile_image()
|
assert botcontact.get_profile_image()
|
||||||
|
|
||||||
|
@ -247,7 +253,9 @@ def test_forward_sending_errors_to_relay_group(relaycrew):
|
||||||
|
|
||||||
while len(relaycrew.user.get_chats()) < 2 and int(time.time()) < begin + TIMEOUT:
|
while len(relaycrew.user.get_chats()) < 2 and int(time.time()) < begin + TIMEOUT:
|
||||||
time.sleep(0.1)
|
time.sleep(0.1)
|
||||||
relay_group = relaycrew.user.get_chats()[-2]
|
for chat in relaycrew.user.get_chats():
|
||||||
|
if "This Message will fail" in chat.get_name():
|
||||||
|
relay_group = chat
|
||||||
|
|
||||||
while len(relay_group.get_messages()) < 3 and int(time.time()) < begin + TIMEOUT:
|
while len(relay_group.get_messages()) < 3 and int(time.time()) < begin + TIMEOUT:
|
||||||
print(relay_group.get_messages()[-1].text)
|
print(relay_group.get_messages()[-1].text)
|
||||||
|
|
Loading…
Reference in a new issue