=== Test case: mam_SUITE:retract_message_on_stanza_id/1 (click for source code) === Config value: [{watchdog,<0.6310.1>}, {basic_group,mam_all}, {configuration,rdbms_mnesia_cache}, {mod_offline_loaded,false}, {escalus_user_db,{module,escalus_ejabberd}}, {mim_data_dir,"/home/circleci/project/big_tests/tests/mam_SUITE_data"}, {preset,"odbc_mssql_mnesia"}, {tc_logfile,"/home/circleci/project/big_tests/ct_report/ct_run.test@998557c7e1d1.2022-01-27_12.27.57/big_tests.tests.mam_SUITE.logs/run.2022-01-27_12.31.28/mam_suite.retract_message_on_stanza_id.90626.html"}, {tc_group_properties,[{name,configurable_archiveid}]}, {tc_group_path,[[{name,rdbms_mnesia_cache_mam_all},parallel]]}, {data_dir,"/home/circleci/project/big_tests/_build/default/lib/mongoose_tests/ebin/mam_SUITE_data/"}, {priv_dir,"/home/circleci/project/big_tests/ct_report/ct_run.test@998557c7e1d1.2022-01-27_12.27.57/big_tests.tests.mam_SUITE.logs/run.2022-01-27_12.31.28/log_private/"}, {config_backup,#{[shaper,fast] => {ok,#{max_rate => 50000}}, [shaper,mam_shaper] => {ok,#{max_rate => 1}}, [shaper,normal] => {ok,#{max_rate => 1000}}, [{access,<<"test type">>},max_user_sessions] => {ok,[#{acl => all,value => 10}]}}}, {{saved_modules,mongooseim@localhost,<<"test type">>}, #{mod_adhoc => [],mod_amp => [],mod_bosh => [], mod_cache_users => [{number_of_segments,5},{time_to_live,2}], mod_carboncopy => [],mod_commands => [], mod_disco => [{users_can_see_hidden_services,false}], mod_mam => [{archive_groupchats,false}], mod_mam_cache_user => [{pm,true}], mod_mam_mnesia_prefs => [{pm,true}], mod_mam_rdbms_arch => [], mod_mam_rdbms_user => [{pm,true}], mod_muc => [{host,{prefix,<<"groupchats.">>}}, {backend,rdbms}, {hibernate_timeout,2000}, {hibernated_room_check_interval,1000}, {hibernated_room_timeout,2000}, {access,muc}, {access_create,muc_create}], mod_muc_commands => [],mod_muc_light_commands => [], mod_muc_log => [{outdir,"/tmp/muclogs"},{access_log,muc}], mod_register => [{access,register}, {ip_access,[{allow,"127.0.0.0/8"},{deny,"0.0.0.0/0"}]}, {welcome_message,{[],[]}}], mod_roster => [{backend,rdbms}], mod_sic => [],mod_stream_management => [], mod_vcard => [{backend,rdbms},{host,{prefix,<<"vjud.">>}}]}}, {escalus_users,[{alice,[{username,<<"alicE">>}, {server,<<"domain.example.com">>}, {host,<<"localhost">>}, {password,<<"matygrysa">>}]}, {bob,[{username,<<"bOb">>}, {server,<<"domain.example.com">>}, {host,<<"localhost">>}, {password,<<"makrolika">>}]}, {kate,[{username,<<"kate">>}, {server,<<"domain.example.com">>}, {host,<<"localhost">>}, {password,<<"makrowe;p">>}]}, {carol,[{username,<<"carol">>}, {server,<<"domain.example.com">>}, {host,<<"localhost">>}, {password,<<"jinglebells">>}, {transport,escalus_bosh}, {path,<<"/http-bind">>}, {port,5280}]}]}] === Current directory is "/home/circleci/project/big_tests/ct_report/ct_run.test@998557c7e1d1.2022-01-27_12.27.57" === Started at 2022-01-27 12:32:33
Could not find element props in Config.
*** User 2022-01-27 12:32:33.263 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <stream:stream to='domain.example.com' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2022-01-27 12:32:33.263 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='6f3a8dd4afdc6577' from='domain.example.com' version='1.0' xml:lang='en'>
*** User 2022-01-27 12:32:33.263 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <stream:features> <starttls xmlns='urn:ietf:params:xml:ns:xmpp-tls'/> <compression xmlns='http://jabber.org/features/compress'> <method>zlib</method> </compression> <mechanisms xmlns='urn:ietf:params:xml:ns:xmpp-sasl'> <mechanism>SCRAM-SHA-256</mechanism> <mechanism>PLAIN</mechanism> </mechanisms> <register xmlns='http://jabber.org/features/iq-register'/> <amp xmlns='http://jabber.org/feature/amp'/> <sm xmlns='urn:xmpp:sm:3'/> </stream:features>
*** User 2022-01-27 12:32:33.263 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='PLAIN'>AGFsaWNFX3JldHJhY3RfbWVzc2FnZV9vbl9zdGFuemFfaWRfMTM1NwBtYXR5Z3J5c2E=</auth>
*** User 2022-01-27 12:32:33.264 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <success xmlns='urn:ietf:params:xml:ns:xmpp-sasl'/>
*** User 2022-01-27 12:32:33.264 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <stream:stream to='domain.example.com' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2022-01-27 12:32:33.264 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='3e35fed911331037' from='domain.example.com' version='1.0' xml:lang='en'>
*** User 2022-01-27 12:32:33.264 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <stream:features> <compression xmlns='http://jabber.org/features/compress'> <method>zlib</method> </compression> <bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'/> <session xmlns='urn:ietf:params:xml:ns:xmpp-session'/> <register xmlns='http://jabber.org/features/iq-register'/> <amp xmlns='http://jabber.org/feature/amp'/> <sm xmlns='urn:xmpp:sm:3'/> </stream:features>
*** User 2022-01-27 12:32:33.265 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <iq type='set' id='b2120a18b9c62cf0990b3d53095bc6c8'> <bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'> <resource>res1</resource> </bind> </iq>
*** User 2022-01-27 12:32:33.265 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <iq id='b2120a18b9c62cf0990b3d53095bc6c8' type='result'> <bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'> <jid>alicE_retract_message_on_stanza_id_1357@domain.example.com/res1</jid> </bind> </iq>
*** User 2022-01-27 12:32:33.265 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <iq type='set' id='26bd5622a586e4fc49923274d1148e72'> <session xmlns='urn:ietf:params:xml:ns:xmpp-session'/> </iq>
*** User 2022-01-27 12:32:33.265 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <iq type='result' id='26bd5622a586e4fc49923274d1148e72'> <session xmlns='urn:ietf:params:xml:ns:xmpp-session'/> </iq>
*** User 2022-01-27 12:32:33.265 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <presence/>
*** User 2022-01-27 12:32:33.267 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <presence from='alicE_retract_message_on_stanza_id_1357@domain.example.com/res1' to='alice_retract_message_on_stanza_id_1357@domain.example.com/res1' xml:lang='en'/>
*** User 2022-01-27 12:32:33.268 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 out <stream:stream to='domain.example.com' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2022-01-27 12:32:33.268 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='213d0c5c2ae9789e' from='domain.example.com' version='1.0' xml:lang='en'>
*** User 2022-01-27 12:32:33.268 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <stream:features> <starttls xmlns='urn:ietf:params:xml:ns:xmpp-tls'/> <compression xmlns='http://jabber.org/features/compress'> <method>zlib</method> </compression> <mechanisms xmlns='urn:ietf:params:xml:ns:xmpp-sasl'> <mechanism>SCRAM-SHA-256</mechanism> <mechanism>PLAIN</mechanism> </mechanisms> <register xmlns='http://jabber.org/features/iq-register'/> <amp xmlns='http://jabber.org/feature/amp'/> <sm xmlns='urn:xmpp:sm:3'/> </stream:features>
*** User 2022-01-27 12:32:33.268 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 out <auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='PLAIN'>AGJPYl9yZXRyYWN0X21lc3NhZ2Vfb25fc3RhbnphX2lkXzEzNTcAbWFrcm9saWth</auth>
*** User 2022-01-27 12:32:33.269 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <success xmlns='urn:ietf:params:xml:ns:xmpp-sasl'/>
*** User 2022-01-27 12:32:33.269 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 out <stream:stream to='domain.example.com' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2022-01-27 12:32:33.269 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='f57eb2f245839c2e' from='domain.example.com' version='1.0' xml:lang='en'>
*** User 2022-01-27 12:32:33.269 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <stream:features> <compression xmlns='http://jabber.org/features/compress'> <method>zlib</method> </compression> <bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'/> <session xmlns='urn:ietf:params:xml:ns:xmpp-session'/> <register xmlns='http://jabber.org/features/iq-register'/> <amp xmlns='http://jabber.org/feature/amp'/> <sm xmlns='urn:xmpp:sm:3'/> </stream:features>
*** User 2022-01-27 12:32:33.269 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 out <iq type='set' id='8fde30deb1ae930ec4e1ccf090cfdb03'> <bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'> <resource>res1</resource> </bind> </iq>
*** User 2022-01-27 12:32:33.270 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <iq id='8fde30deb1ae930ec4e1ccf090cfdb03' type='result'> <bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'> <jid>bOb_retract_message_on_stanza_id_1357@domain.example.com/res1</jid> </bind> </iq>
*** User 2022-01-27 12:32:33.270 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 out <iq type='set' id='a48a2b03bd214d529ae767599ac04c03'> <session xmlns='urn:ietf:params:xml:ns:xmpp-session'/> </iq>
*** User 2022-01-27 12:32:33.270 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <iq type='result' id='a48a2b03bd214d529ae767599ac04c03'> <session xmlns='urn:ietf:params:xml:ns:xmpp-session'/> </iq>
*** User 2022-01-27 12:32:33.270 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 out <presence/>
*** User 2022-01-27 12:32:33.272 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <presence from='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' to='bob_retract_message_on_stanza_id_1357@domain.example.com/res1' xml:lang='en'/>
*** User 2022-01-27 12:32:33.272 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <message to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' type='chat'> <body>OH, HAI!</body> </message>
*** User 2022-01-27 12:32:33.380 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <iq type='set' id='62a6a2848003da8653a4f6085de6c760'> <query xmlns='urn:xmpp:mam:1' queryid='q1'> <x xmlns='jabber:x:data'/> </query> </iq>
*** User 2022-01-27 12:32:33.382 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <message from='alicE_retract_message_on_stanza_id_1357@domain.example.com' to='alicE_retract_message_on_stanza_id_1357@domain.example.com/res1' id='4524e3bd-f4c0-4301-95ca-141b6697ec46'> <result queryid='q1' xmlns='urn:xmpp:mam:1' id='BLKFGCOM5GO1'> <forwarded xmlns='urn:xmpp:forward:0'> <delay xmlns='urn:xmpp:delay' stamp='2022-01-27T12:32:33Z' from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1'/> <message from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1' xmlns='jabber:client' xml:lang='en' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' type='chat'> <body>OH, HAI!</body> </message> </forwarded> </result> </message>
*** User 2022-01-27 12:32:33.382 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <iq from='alicE_retract_message_on_stanza_id_1357@domain.example.com' to='alicE_retract_message_on_stanza_id_1357@domain.example.com/res1' id='62a6a2848003da8653a4f6085de6c760' type='result'> <fin xmlns='urn:xmpp:mam:1' complete='true'> <set xmlns='http://jabber.org/protocol/rsm'> <first index='0'>BLKFGCOM5GO1</first> <last>BLKFGCOM5GO1</last> <count>1</count> </set> </fin> </iq>
*** User 2022-01-27 12:32:33.382 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <message from='alicE_retract_message_on_stanza_id_1357@domain.example.com/res1' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' xml:lang='en' type='chat'> <body>OH, HAI!</body> <stanza-id by='bOb_retract_message_on_stanza_id_1357@domain.example.com' id='BLKFGCOM5GO1' xmlns='urn:xmpp:sid:0'/> </message>
*** User 2022-01-27 12:32:33.382 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <message type='chat' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1'> <apply-to id='BLKFGCOM5GO1' xmlns='urn:xmpp:fasten:0'> <retract xmlns='urn:esl:message-retract-by-stanza-id:0'/> </apply-to> </message>
Could not find element wait_for_parallel_writer in Config.
*** User 2022-01-27 12:32:33.387 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <message from='alicE_retract_message_on_stanza_id_1357@domain.example.com/res1' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' xml:lang='en' type='chat'> <apply-to id='BLKFGCOM5GO1' xmlns='urn:xmpp:fasten:0'> <retract xmlns='urn:esl:message-retract-by-stanza-id:0'/> </apply-to> <stanza-id by='bOb_retract_message_on_stanza_id_1357@domain.example.com' id='BLKFGCPH2V01' xmlns='urn:xmpp:sid:0'/> </message>
Could not find element archive_wait in Config. Could not find element retract_on in Config.
*** User 2022-01-27 12:32:33.388 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out <iq type='set' id='b0772881298c63c35ffb6da283248e49'> <query xmlns='urn:xmpp:mam:1' queryid='q1'> <x xmlns='jabber:x:data'/> </query> </iq>
*** User 2022-01-27 12:32:33.389 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <message from='alicE_retract_message_on_stanza_id_1357@domain.example.com' to='alicE_retract_message_on_stanza_id_1357@domain.example.com/res1' id='887caa0e-8fda-4855-8a8f-cbee1ff4b8c0'> <result queryid='q1' xmlns='urn:xmpp:mam:1' id='BLKFGCOM5GO1'> <forwarded xmlns='urn:xmpp:forward:0'> <delay xmlns='urn:xmpp:delay' stamp='2022-01-27T12:32:33Z' from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1'/> <message from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1' xmlns='jabber:client' xml:lang='en' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' type='chat'> <retracted xmlns='urn:esl:message-retract-by-stanza-id:0' stamp='2022-01-27T12:32:33Z'> <stanza-id xmlns='urn:xmpp:sid:0' id='BLKFGCOM5GO1' by='alicE_retract_message_on_stanza_id_1357@domain.example.com'/> </retracted> </message> </forwarded> </result> </message>
Could not find element retract_on in Config.
*** User 2022-01-27 12:32:33.389 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <message from='alicE_retract_message_on_stanza_id_1357@domain.example.com' to='alicE_retract_message_on_stanza_id_1357@domain.example.com/res1' id='43fa6204-1696-41f1-afe5-e753cdca101f'> <result queryid='q1' xmlns='urn:xmpp:mam:1' id='BLKFGCPH2V01'> <forwarded xmlns='urn:xmpp:forward:0'> <delay xmlns='urn:xmpp:delay' stamp='2022-01-27T12:32:33Z' from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1'/> <message from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1' xmlns='jabber:client' xml:lang='en' type='chat' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1'> <apply-to id='BLKFGCOM5GO1' xmlns='urn:xmpp:fasten:0'> <retract xmlns='urn:esl:message-retract-by-stanza-id:0'/> </apply-to> </message> </forwarded> </result> </message>
*** User 2022-01-27 12:32:33.389 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in <iq from='alicE_retract_message_on_stanza_id_1357@domain.example.com' to='alicE_retract_message_on_stanza_id_1357@domain.example.com/res1' id='b0772881298c63c35ffb6da283248e49' type='result'> <fin xmlns='urn:xmpp:mam:1' complete='true'> <set xmlns='http://jabber.org/protocol/rsm'> <first index='0'>BLKFGCOM5GO1</first> <last>BLKFGCPH2V01</last> <count>2</count> </set> </fin> </iq>
*** User 2022-01-27 12:32:33.389 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 out <iq type='set' id='8226d709baf4560efbb4d85a0b2ccc4a'> <query xmlns='urn:xmpp:mam:1' queryid='q2'> <x xmlns='jabber:x:data'/> </query> </iq>
*** User 2022-01-27 12:32:33.391 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <message from='bOb_retract_message_on_stanza_id_1357@domain.example.com' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' id='c0c4ce91-92fc-4b0d-b2e8-a3cd67edfed3'> <result queryid='q2' xmlns='urn:xmpp:mam:1' id='BLKFGCOM5GO1'> <forwarded xmlns='urn:xmpp:forward:0'> <delay xmlns='urn:xmpp:delay' stamp='2022-01-27T12:32:33Z' from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1'/> <message from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1' xmlns='jabber:client' xml:lang='en' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' type='chat'> <retracted xmlns='urn:esl:message-retract-by-stanza-id:0' stamp='2022-01-27T12:32:33Z'> <stanza-id xmlns='urn:xmpp:sid:0' id='BLKFGCOM5GO1' by='bOb_retract_message_on_stanza_id_1357@domain.example.com'/> </retracted> </message> </forwarded> </result> </message>
*** User 2022-01-27 12:32:33.391 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <message from='bOb_retract_message_on_stanza_id_1357@domain.example.com' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' id='3d66849b-aae9-4a51-9b2e-5ef139906eb4'> <result queryid='q2' xmlns='urn:xmpp:mam:1' id='BLKFGCPH2V01'> <forwarded xmlns='urn:xmpp:forward:0'> <delay xmlns='urn:xmpp:delay' stamp='2022-01-27T12:32:33Z' from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1'/> <message from='alice_retract_message_on_stanza_id_1357@domain.example.com/res1' xmlns='jabber:client' xml:lang='en' type='chat' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1'> <apply-to id='BLKFGCOM5GO1' xmlns='urn:xmpp:fasten:0'> <retract xmlns='urn:esl:message-retract-by-stanza-id:0'/> </apply-to> </message> </forwarded> </result> </message>
*** User 2022-01-27 12:32:33.391 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in <iq from='bOb_retract_message_on_stanza_id_1357@domain.example.com' to='bOb_retract_message_on_stanza_id_1357@domain.example.com/res1' id='8226d709baf4560efbb4d85a0b2ccc4a' type='result'> <fin xmlns='urn:xmpp:mam:1' complete='true'> <set xmlns='http://jabber.org/protocol/rsm'> <first index='0'>BLKFGCOM5GO1</first> <last>BLKFGCPH2V01</last> <count>2</count> </set> </fin> </iq>
*** User 2022-01-27 12:32:33.391 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 out </stream:stream>
*** User 2022-01-27 12:32:33.391 *** bOb_retract_message_on_stanza_id_1357@domain.example.com/res1 in </stream:stream>
*** User 2022-01-27 12:32:33.391 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 out </stream:stream>
*** User 2022-01-27 12:32:33.392 *** alicE_retract_message_on_stanza_id_1357@domain.example.com/res1 in </stream:stream>
=== Ended at 2022-01-27 12:32:33 === successfully completed test case === === Returned value: ok
Test run history | Top level test index | Latest test result