=== Test case: muc_SUITE:history_since/1 (click for source code)
=== Config value:
[{watchdog,<0.65134.0>},
{preset,"pgsql_cets"},
{mim_data_dir,"/home/circleci/project/big_tests/tests/muc_SUITE_data"},
{tc_logfile,"/home/circleci/project/big_tests/ct_report/ct_run.test@fe953d6ed70e.2024-04-11_13.48.27/big_tests.tests.muc_SUITE.logs/run.2024-04-11_13.59.16/muc_suite.history_since.85636.html"},
{tc_group_properties,[{name,occupant},parallel]},
{tc_group_path,[]},
{data_dir,"/home/circleci/project/big_tests/_build/default/lib/mongoose_tests/ebin/muc_SUITE_data/"},
{priv_dir,"/home/circleci/project/big_tests/ct_report/ct_run.test@fe953d6ed70e.2024-04-11_13.48.27/big_tests.tests.muc_SUITE.logs/run.2024-04-11_13.59.16/log_private/"},
{{saved_modules,mongooseim@localhost,<<"localhost">>},
#{mod_vcard =>
#{matches => 30,
host => {prefix,<<"vjud.">>},
search => true,backend => rdbms,iqdisc => parallel},
mod_roster =>
#{backend => rdbms,iqdisc => one_queue,versioning => false,
store_current_id => false},
mod_register =>
#{access => register,iqdisc => one_queue,
registration_watchers => [],password_strength => 0,
ip_access => [{allow,"127.0.0.0/8"},{deny,"0.0.0.0/0"}]},
mod_sic => #{iqdisc => one_queue},
mod_amp => #{},
mod_disco =>
#{iqdisc => one_queue,users_can_see_hidden_services => false,
server_info => [],extra_domains => []},
mod_presence => #{},
mod_stream_management =>
#{buffer => true,ack => true,backend => cets,
stale_h =>
#{enabled => false,repeat_after => 1800,geriatric => 3600},
buffer_max => 100,ack_freq => 1,resume_timeout => 600},
mod_adhoc => #{iqdisc => one_queue,report_commands_node => false},
mod_bosh =>
#{backend => cets,inactivity => 30,max_pause => 120,
max_wait => infinity,server_acks => false},
mod_cache_users =>
#{strategy => fifo,number_of_segments => 5,time_to_live => 2},
mod_carboncopy => #{iqdisc => no_queue}}},
{escalus_users,[{alice,[{username,<<"alicE">>},
{server,<<"localhost">>},
{password,<<"matygrysa">>}]},
{bob,[{username,<<"bOb">>},
{server,<<"localhost">>},
{password,<<"makrolika">>}]},
{kate,[{username,<<"kate">>},
{server,<<"localhost">>},
{password,<<"makrowe;p">>}]}]}]
=== Current directory is "/home/circleci/project/big_tests/ct_report/ct_run.test@fe953d6ed70e.2024-04-11_13.48.27"
=== Started at 2024-04-11 13:59:29
*** User 2024-04-11 13:59:29.599 ***🔗
alicE_history_since_2474@localhost/res1 out
<stream:stream to='localhost' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2024-04-11 13:59:29.600 ***🔗
alicE_history_since_2474@localhost/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='8e47dee111a47246' from='localhost' version='1.0' xml:lang='en'>
*** User 2024-04-11 13:59:29.600 ***🔗
alicE_history_since_2474@localhost/res1 in
<stream:features>
<register xmlns='http://jabber.org/features/iq-register'/>
<starttls xmlns='urn:ietf:params:xml:ns:xmpp-tls'/>
<mechanisms xmlns='urn:ietf:params:xml:ns:xmpp-sasl'>
<mechanism>SCRAM-SHA-256</mechanism>
<mechanism>PLAIN</mechanism>
</mechanisms>
<amp xmlns='http://jabber.org/feature/amp'/>
<sm xmlns='urn:xmpp:sm:3'/>
</stream:features>
*** User 2024-04-11 13:59:29.600 ***🔗
alicE_history_since_2474@localhost/res1 out
<auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='PLAIN'>AGFsaWNFX2hpc3Rvcnlfc2luY2VfMjQ3NABtYXR5Z3J5c2E=</auth>
*** User 2024-04-11 13:59:29.603 ***🔗
alicE_history_since_2474@localhost/res1 in
<success xmlns='urn:ietf:params:xml:ns:xmpp-sasl'/>
*** User 2024-04-11 13:59:29.603 ***🔗
alicE_history_since_2474@localhost/res1 out
<stream:stream to='localhost' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2024-04-11 13:59:29.604 ***🔗
alicE_history_since_2474@localhost/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='725f38cf8f267fe4' from='localhost' version='1.0' xml:lang='en' to='alice_history_since_2474@localhost'>
Could not find element wait_for_parallel_writer in Config.
*** User 2024-04-11 13:59:29.604 ***🔗
alicE_history_since_2474@localhost/res1 in
<stream:features>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'/>
<register xmlns='http://jabber.org/features/iq-register'/>
<amp xmlns='http://jabber.org/feature/amp'/>
<sm xmlns='urn:xmpp:sm:3'/>
</stream:features>
*** User 2024-04-11 13:59:29.605 ***🔗
alicE_history_since_2474@localhost/res1 out
<iq type='set' id='a9d4c87f60756bba1a76207b101cf0d5'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<resource>res1</resource>
</bind>
</iq>
*** User 2024-04-11 13:59:29.606 ***🔗
alicE_history_since_2474@localhost/res1 in
<iq id='a9d4c87f60756bba1a76207b101cf0d5' type='result'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<jid>alice_history_since_2474@localhost/res1</jid>
</bind>
</iq>
*** User 2024-04-11 13:59:29.606 ***🔗
alice_history_since_2474@localhost/res1 out
<iq type='set' id='9c2b1c99e5a7f337201b4310f71439fc'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-11 13:59:29.608 ***🔗
alice_history_since_2474@localhost/res1 in
<iq from='localhost' to='alice_history_since_2474@localhost/res1' id='9c2b1c99e5a7f337201b4310f71439fc' type='result'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-11 13:59:29.610 ***🔗
alice_history_since_2474@localhost/res1 out
<presence/>
*** User 2024-04-11 13:59:29.613 ***🔗
alice_history_since_2474@localhost/res1 in
<presence from='alice_history_since_2474@localhost/res1' to='alice_history_since_2474@localhost/res1'/>
*** User 2024-04-11 13:59:29.615 ***🔗
bOb_history_since_2474@localhost/res1 out
<stream:stream to='localhost' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2024-04-11 13:59:29.617 ***🔗
bOb_history_since_2474@localhost/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='ae893ea98f4b2fe4' from='localhost' version='1.0' xml:lang='en'>
*** User 2024-04-11 13:59:29.617 ***🔗
bOb_history_since_2474@localhost/res1 in
<stream:features>
<register xmlns='http://jabber.org/features/iq-register'/>
<starttls xmlns='urn:ietf:params:xml:ns:xmpp-tls'/>
<mechanisms xmlns='urn:ietf:params:xml:ns:xmpp-sasl'>
<mechanism>SCRAM-SHA-256</mechanism>
<mechanism>PLAIN</mechanism>
</mechanisms>
<amp xmlns='http://jabber.org/feature/amp'/>
<sm xmlns='urn:xmpp:sm:3'/>
</stream:features>
*** User 2024-04-11 13:59:29.617 ***🔗
bOb_history_since_2474@localhost/res1 out
<auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='PLAIN'>AGJPYl9oaXN0b3J5X3NpbmNlXzI0NzQAbWFrcm9saWth</auth>
*** User 2024-04-11 13:59:29.620 ***🔗
bOb_history_since_2474@localhost/res1 in
<success xmlns='urn:ietf:params:xml:ns:xmpp-sasl'/>
*** User 2024-04-11 13:59:29.620 ***🔗
bOb_history_since_2474@localhost/res1 out
<stream:stream to='localhost' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2024-04-11 13:59:29.680 ***🔗
bOb_history_since_2474@localhost/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='9ed62d4a29779896' from='localhost' version='1.0' xml:lang='en' to='bob_history_since_2474@localhost'>
*** User 2024-04-11 13:59:29.681 ***🔗
bOb_history_since_2474@localhost/res1 in
<stream:features>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'/>
<register xmlns='http://jabber.org/features/iq-register'/>
<amp xmlns='http://jabber.org/feature/amp'/>
<sm xmlns='urn:xmpp:sm:3'/>
</stream:features>
*** User 2024-04-11 13:59:29.681 ***🔗
bOb_history_since_2474@localhost/res1 out
<iq type='set' id='ad246dd7ac70a660c4ade7e007add5cf'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<resource>res1</resource>
</bind>
</iq>
*** User 2024-04-11 13:59:29.682 ***🔗
bOb_history_since_2474@localhost/res1 in
<iq id='ad246dd7ac70a660c4ade7e007add5cf' type='result'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<jid>bob_history_since_2474@localhost/res1</jid>
</bind>
</iq>
*** User 2024-04-11 13:59:29.682 ***🔗
bob_history_since_2474@localhost/res1 out
<iq type='set' id='b71a55f76a0fb91a54b94486812ac3f0'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-11 13:59:29.684 ***🔗
bob_history_since_2474@localhost/res1 in
<iq from='localhost' to='bob_history_since_2474@localhost/res1' id='b71a55f76a0fb91a54b94486812ac3f0' type='result'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-11 13:59:29.685 ***🔗
bob_history_since_2474@localhost/res1 out
<presence/>
*** User 2024-04-11 13:59:29.687 ***🔗
bob_history_since_2474@localhost/res1 in
<presence from='bob_history_since_2474@localhost/res1' to='bob_history_since_2474@localhost/res1'/>
*** User 2024-04-11 13:59:29.690 ***🔗
kate_history_since_2474@localhost/res1 out
<stream:stream to='localhost' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2024-04-11 13:59:29.691 ***🔗
kate_history_since_2474@localhost/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='87ac19214a870572' from='localhost' version='1.0' xml:lang='en'>
*** User 2024-04-11 13:59:29.691 ***🔗
kate_history_since_2474@localhost/res1 in
<stream:features>
<register xmlns='http://jabber.org/features/iq-register'/>
<starttls xmlns='urn:ietf:params:xml:ns:xmpp-tls'/>
<mechanisms xmlns='urn:ietf:params:xml:ns:xmpp-sasl'>
<mechanism>SCRAM-SHA-256</mechanism>
<mechanism>PLAIN</mechanism>
</mechanisms>
<amp xmlns='http://jabber.org/feature/amp'/>
<sm xmlns='urn:xmpp:sm:3'/>
</stream:features>
*** User 2024-04-11 13:59:29.691 ***🔗
kate_history_since_2474@localhost/res1 out
<auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='PLAIN'>AGthdGVfaGlzdG9yeV9zaW5jZV8yNDc0AG1ha3Jvd2U7cA==</auth>
*** User 2024-04-11 13:59:29.693 ***🔗
kate_history_since_2474@localhost/res1 in
<success xmlns='urn:ietf:params:xml:ns:xmpp-sasl'/>
*** User 2024-04-11 13:59:29.693 ***🔗
kate_history_since_2474@localhost/res1 out
<stream:stream to='localhost' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2024-04-11 13:59:29.694 ***🔗
kate_history_since_2474@localhost/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='724b5ee4c3c6e9f8' from='localhost' version='1.0' xml:lang='en' to='kate_history_since_2474@localhost'>
*** User 2024-04-11 13:59:29.694 ***🔗
kate_history_since_2474@localhost/res1 in
<stream:features>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'/>
<register xmlns='http://jabber.org/features/iq-register'/>
<amp xmlns='http://jabber.org/feature/amp'/>
<sm xmlns='urn:xmpp:sm:3'/>
</stream:features>
*** User 2024-04-11 13:59:29.694 ***🔗
kate_history_since_2474@localhost/res1 out
<iq type='set' id='d65916a44916e3030eb4ee9118ea6958'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<resource>res1</resource>
</bind>
</iq>
*** User 2024-04-11 13:59:29.695 ***🔗
kate_history_since_2474@localhost/res1 in
<iq id='d65916a44916e3030eb4ee9118ea6958' type='result'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<jid>kate_history_since_2474@localhost/res1</jid>
</bind>
</iq>
*** User 2024-04-11 13:59:29.695 ***🔗
kate_history_since_2474@localhost/res1 out
<iq type='set' id='5857a4364e7e888ec60b6ebd169cc932'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-11 13:59:29.696 ***🔗
kate_history_since_2474@localhost/res1 in
<iq from='localhost' to='kate_history_since_2474@localhost/res1' id='5857a4364e7e888ec60b6ebd169cc932' type='result'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-11 13:59:29.697 ***🔗
kate_history_since_2474@localhost/res1 out
<presence/>
*** User 2024-04-11 13:59:29.700 ***🔗
kate_history_since_2474@localhost/res1 in
<presence from='kate_history_since_2474@localhost/res1' to='kate_history_since_2474@localhost/res1'/>
*** User 2024-04-11 13:59:29.700 ***🔗
alice_history_since_2474@localhost/res1 out
<presence to='room-alice_history_since_2474@muc.localhost/alice_history_since_2474'>
<x xmlns='http://jabber.org/protocol/muc'/>
</presence>
*** User 2024-04-11 13:59:29.702 ***🔗
alice_history_since_2474@localhost/res1 in
<presence from='room-alice_history_since_2474@muc.localhost/alice_history_since_2474' to='alice_history_since_2474@localhost/res1'>
<x xmlns='http://jabber.org/protocol/muc'>
<item jid='alice_history_since_2474@localhost/res1' affiliation='owner' role='moderator'/>
<status code='110'/>
<status code='201'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.702 ***🔗
alice_history_since_2474@localhost/res1 in
<message from='room-alice_history_since_2474@muc.localhost' to='alice_history_since_2474@localhost/res1' type='groupchat'>
<subject/>
<body/>
</message>
*** User 2024-04-11 13:59:29.702 ***🔗
bob_history_since_2474@localhost/res1 out
<presence to='room-alice_history_since_2474@muc.localhost/bob_history_since_2474'>
<x xmlns='http://jabber.org/protocol/muc'/>
</presence>
*** User 2024-04-11 13:59:29.703 ***🔗
alice_history_since_2474@localhost/res1 in
<presence from='room-alice_history_since_2474@muc.localhost/bob_history_since_2474' to='alice_history_since_2474@localhost/res1'>
<x xmlns='http://jabber.org/protocol/muc'>
<item jid='bob_history_since_2474@localhost/res1' affiliation='none' role='participant'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.704 ***🔗
bob_history_since_2474@localhost/res1 in
<presence from='room-alice_history_since_2474@muc.localhost/alice_history_since_2474' to='bob_history_since_2474@localhost/res1'>
<x xmlns='http://jabber.org/protocol/muc#user'>
<item affiliation='owner' role='moderator'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.704 ***🔗
bob_history_since_2474@localhost/res1 in
<presence from='room-alice_history_since_2474@muc.localhost/bob_history_since_2474' to='bob_history_since_2474@localhost/res1'>
<x xmlns='http://jabber.org/protocol/muc'>
<item affiliation='none' role='participant'/>
<status code='110'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.704 ***🔗
bob_history_since_2474@localhost/res1 in
<message from='room-alice_history_since_2474@muc.localhost' to='bob_history_since_2474@localhost/res1' type='groupchat'>
<subject/>
<body/>
</message>
*** User 2024-04-11 13:59:29.704 ***🔗
alice_history_since_2474@localhost/res1 out
<message type='groupchat' to='room-alice_history_since_2474@muc.localhost'>
<body>Hi, Bob!</body>
</message>
*** User 2024-04-11 13:59:29.706 ***🔗
alice_history_since_2474@localhost/res1 in
<message from='room-alice_history_since_2474@muc.localhost/alice_history_since_2474' to='alice_history_since_2474@localhost/res1' type='groupchat'>
<body>Hi, Bob!</body>
</message>
*** User 2024-04-11 13:59:29.706 ***🔗
bob_history_since_2474@localhost/res1 in
<message from='room-alice_history_since_2474@muc.localhost/alice_history_since_2474' to='bob_history_since_2474@localhost/res1' type='groupchat'>
<body>Hi, Bob!</body>
</message>
*** User 2024-04-11 13:59:29.706 ***🔗
bob_history_since_2474@localhost/res1 out
<message type='groupchat' to='room-alice_history_since_2474@muc.localhost'>
<body>Hi, Alice!</body>
</message>
*** User 2024-04-11 13:59:29.708 ***🔗
alice_history_since_2474@localhost/res1 in
<message from='room-alice_history_since_2474@muc.localhost/bob_history_since_2474' to='alice_history_since_2474@localhost/res1' type='groupchat'>
<body>Hi, Alice!</body>
</message>
*** User 2024-04-11 13:59:29.708 ***🔗
bob_history_since_2474@localhost/res1 in
<message from='room-alice_history_since_2474@muc.localhost/bob_history_since_2474' to='bob_history_since_2474@localhost/res1' type='groupchat'>
<body>Hi, Alice!</body>
</message>
*** User 2024-04-11 13:59:29.708 ***🔗
kate_history_since_2474@localhost/res1 out
<presence to='room-alice_history_since_2474@muc.localhost/kate_history_since_2474'>
<x xmlns='http://jabber.org/protocol/muc'>
<history since='1970-01-01T00:00:00Z'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.710 ***🔗
alice_history_since_2474@localhost/res1 in
<presence from='room-alice_history_since_2474@muc.localhost/kate_history_since_2474' to='alice_history_since_2474@localhost/res1'>
<x xmlns='http://jabber.org/protocol/muc'>
<item jid='kate_history_since_2474@localhost/res1' affiliation='none' role='participant'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.710 ***🔗
bob_history_since_2474@localhost/res1 in
<presence from='room-alice_history_since_2474@muc.localhost/kate_history_since_2474' to='bob_history_since_2474@localhost/res1'>
<x xmlns='http://jabber.org/protocol/muc'>
<item affiliation='none' role='participant'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.710 ***🔗
kate_history_since_2474@localhost/res1 in
<presence from='room-alice_history_since_2474@muc.localhost/alice_history_since_2474' to='kate_history_since_2474@localhost/res1'>
<x xmlns='http://jabber.org/protocol/muc#user'>
<item affiliation='owner' role='moderator'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.711 ***🔗
kate_history_since_2474@localhost/res1 in
<presence from='room-alice_history_since_2474@muc.localhost/bob_history_since_2474' to='kate_history_since_2474@localhost/res1'>
<x xmlns='http://jabber.org/protocol/muc#user'>
<item affiliation='none' role='participant'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.711 ***🔗
kate_history_since_2474@localhost/res1 in
<presence from='room-alice_history_since_2474@muc.localhost/kate_history_since_2474' to='kate_history_since_2474@localhost/res1'>
<x xmlns='http://jabber.org/protocol/muc'>
<item affiliation='none' role='participant'/>
<status code='110'/>
</x>
</presence>
*** User 2024-04-11 13:59:29.711 ***🔗
kate_history_since_2474@localhost/res1 in
<message from='room-alice_history_since_2474@muc.localhost/alice_history_since_2474' to='kate_history_since_2474@localhost/res1' type='groupchat'>
<body>Hi, Bob!</body>
<delay xmlns='urn:xmpp:delay' stamp='2024-04-11T13:59:29Z' from='room-alice_history_since_2474@muc.localhost'/>
</message>
*** User 2024-04-11 13:59:29.711 ***🔗
kate_history_since_2474@localhost/res1 in
<message from='room-alice_history_since_2474@muc.localhost/bob_history_since_2474' to='kate_history_since_2474@localhost/res1' type='groupchat'>
<body>Hi, Alice!</body>
<delay xmlns='urn:xmpp:delay' stamp='2024-04-11T13:59:29Z' from='room-alice_history_since_2474@muc.localhost'/>
</message>
*** User 2024-04-11 13:59:29.711 ***🔗
kate_history_since_2474@localhost/res1 in
<message from='room-alice_history_since_2474@muc.localhost' to='kate_history_since_2474@localhost/res1' type='groupchat'>
<subject/>
<body/>
</message>
*** User 2024-04-11 13:59:29.712 ***🔗
kate_history_since_2474@localhost/res1 out
</stream:stream>
*** User 2024-04-11 13:59:29.713 ***🔗
kate_history_since_2474@localhost/res1 in
</stream:stream>
*** User 2024-04-11 13:59:29.714 ***🔗
bob_history_since_2474@localhost/res1 out
</stream:stream>
*** User 2024-04-11 13:59:29.715 ***🔗
bob_history_since_2474@localhost/res1 in
</stream:stream>
*** User 2024-04-11 13:59:29.715 ***🔗
alice_history_since_2474@localhost/res1 out
</stream:stream>
*** User 2024-04-11 13:59:29.716 ***🔗
alice_history_since_2474@localhost/res1 in
</stream:stream>
*** User 2024-04-11 13:59:29.717 ***🔗
waiting for room_archive_size is done in 0 miliseconds
=== Ended at 2024-04-11 13:59:29
=== successfully completed test case
=== === Returned value: ok