from scenarios import *
scenario = (
scenarios.simple_channel_join.scenario,
# Send two channel messages
send_stanza("coucou"),
expect_stanza("/message[@from='#foo%{irc_server_one}/{nick_one}'][@to='{jid_one}/{resource_one}'][@type='groupchat']/body[text()='coucou']",
"/message/stable_id:stanza-id[@by='#foo%{irc_server_one}'][@id]"),
send_stanza("coucou 2"),
# Record the current time
expect_stanza("/message[@from='#foo%{irc_server_one}/{nick_one}'][@to='{jid_one}/{resource_one}'][@type='groupchat']/body[text()='coucou 2']",
after = save_current_timestamp_plus_delta("first_timestamp", datetime.timedelta(seconds=1))),
# Wait two seconds before sending two new messages
sleep_for(2),
send_stanza("coucou 3"),
send_stanza("coucou 4"),
expect_stanza("/message[@type='groupchat']/body[text()='coucou 3']"),
expect_stanza("/message[@type='groupchat']/body[text()='coucou 4']",
after = save_current_timestamp_plus_delta("second_timestamp", datetime.timedelta(seconds=1))),
# Retrieve the archive, after our saved datetime
send_stanza("""
urn:xmpp:mam:2
{first_timestamp}
{second_timestamp}
"""),
expect_stanza("/message/mam:result[@queryid='qid16']/forward:forwarded/delay:delay",
"/message/mam:result/forward:forwarded/client:message[@from='#foo%{irc_server_one}/{nick_one}'][@type='groupchat']/client:body[text()='coucou 3']"),
expect_stanza("/message/mam:result[@queryid='qid16']/forward:forwarded/delay:delay",
"/message/mam:result/forward:forwarded/client:message[@from='#foo%{irc_server_one}/{nick_one}'][@type='groupchat']/client:body[text()='coucou 4']"),
expect_stanza("/iq[@type='result'][@id='id8'][@from='#foo%{irc_server_one}'][@to='{jid_one}/{resource_one}']",
"/iq/mam:fin[@complete='true']/rsm:set"),
)