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"), )