=== Test case: carboncopy_SUITE:unavailable_resources_dont_get_carbons/1 (click for source code)
=== Config value:
[{watchdog,<0.10489.0>},
{preset,"pgsql_mnesia"},
{mim_data_dir,"/home/circleci/project/big_tests/tests/carboncopy_SUITE_data"},
{tc_logfile,"/home/circleci/project/big_tests/ct_report/ct_run.test@82e417e9e7f3.2024-04-15_15.52.32/big_tests.tests.carboncopy_SUITE.logs/run.2024-04-15_15.53.17/carboncopy_suite.unavailable_resources_dont_get_carbons.15363.html"},
{tc_group_properties,[{name,one2one},parallel]},
{tc_group_path,[]},
{data_dir,"/home/circleci/project/big_tests/_build/default/lib/mongoose_tests/ebin/carboncopy_SUITE_data/"},
{priv_dir,"/home/circleci/project/big_tests/ct_report/ct_run.test@82e417e9e7f3.2024-04-15_15.52.32/big_tests.tests.carboncopy_SUITE.logs/run.2024-04-15_15.53.17/log_private/"}]
=== Current directory is "/home/circleci/project/big_tests/ct_report/ct_run.test@82e417e9e7f3.2024-04-15_15.52.32"
=== Started at 2024-04-15 15:53:17
*** User 2024-04-15 15:53:17.437 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@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 2024-04-15 15:53:17.437 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='84975af3879d6959' from='domain.example.com' version='1.0' xml:lang='en'>
*** User 2024-04-15 15:53:17.437 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/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-15 15:53:17.437 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='PLAIN'>AGFsaWNFX3VuYXZhaWxhYmxlX3Jlc291cmNlc19kb250X2dldF9jYXJib25zXzYwNgBtYXR5Z3J5c2E=</auth>
*** User 2024-04-15 15:53:17.439 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<success xmlns='urn:ietf:params:xml:ns:xmpp-sasl'/>
*** User 2024-04-15 15:53:17.439 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@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 2024-04-15 15:53:17.440 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='e18bd1ca3f795885' from='domain.example.com' version='1.0' xml:lang='en' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com'>
*** User 2024-04-15 15:53:17.440 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/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-15 15:53:17.440 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<iq type='set' id='4d6fa7a89715828a95ac6a18640fb5ba'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<resource>res1</resource>
</bind>
</iq>
*** User 2024-04-15 15:53:17.440 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<iq id='4d6fa7a89715828a95ac6a18640fb5ba' type='result'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<jid>alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1</jid>
</bind>
</iq>
*** User 2024-04-15 15:53:17.441 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<iq type='set' id='0a646dc594f6f2ff5e30b0b18abbf414'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-15 15:53:17.441 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<iq from='domain.example.com' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' id='0a646dc594f6f2ff5e30b0b18abbf414' type='result'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-15 15:53:17.441 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<presence/>
*** User 2024-04-15 15:53:17.443 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<presence from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1'/>
*** User 2024-04-15 15:53:17.443 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 out
<stream:stream to='domain.example.com' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2024-04-15 15:53:17.444 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='d6098de8929c9dbd' from='domain.example.com' version='1.0' xml:lang='en'>
*** User 2024-04-15 15:53:17.444 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 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-15 15:53:17.444 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 out
<auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='PLAIN'>AGFsaWNFX3VuYXZhaWxhYmxlX3Jlc291cmNlc19kb250X2dldF9jYXJib25zXzYwNgBtYXR5Z3J5c2E=</auth>
*** User 2024-04-15 15:53:17.445 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<success xmlns='urn:ietf:params:xml:ns:xmpp-sasl'/>
*** User 2024-04-15 15:53:17.445 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 out
<stream:stream to='domain.example.com' version='1.0' xml:lang='en' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams'>
*** User 2024-04-15 15:53:17.445 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='690eb02306926677' from='domain.example.com' version='1.0' xml:lang='en' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com'>
*** User 2024-04-15 15:53:17.445 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 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-15 15:53:17.446 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 out
<iq type='set' id='3f0b107cea6f4bacec44ac5b270f1f74'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<resource>res2</resource>
</bind>
</iq>
*** User 2024-04-15 15:53:17.446 ***🔗
alicE_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<iq id='3f0b107cea6f4bacec44ac5b270f1f74' type='result'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<jid>alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2</jid>
</bind>
</iq>
*** User 2024-04-15 15:53:17.446 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 out
<iq type='set' id='1330c9ec3d451891516eb4f4be2eedb3'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-15 15:53:17.447 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<iq from='domain.example.com' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2' id='1330c9ec3d451891516eb4f4be2eedb3' type='result'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-15 15:53:17.447 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 out
<presence/>
*** User 2024-04-15 15:53:17.448 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<presence from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2'/>
*** User 2024-04-15 15:53:17.449 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<presence from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2'>
<delay xmlns='urn:xmpp:delay' stamp='2024-04-15T15:53:17.442789Z' from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1'/>
</presence>
*** User 2024-04-15 15:53:17.449 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<presence from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1'/>
*** User 2024-04-15 15:53:17.449 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@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 2024-04-15 15:53:17.450 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='c50f7bed2ca11599' from='domain.example.com' version='1.0' xml:lang='en'>
*** User 2024-04-15 15:53:17.450 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@domain.example.com/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-15 15:53:17.450 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='PLAIN'>AGJPYl91bmF2YWlsYWJsZV9yZXNvdXJjZXNfZG9udF9nZXRfY2FyYm9uc182MDYAbWFrcm9saWth</auth>
*** User 2024-04-15 15:53:17.451 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<success xmlns='urn:ietf:params:xml:ns:xmpp-sasl'/>
*** User 2024-04-15 15:53:17.451 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@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 2024-04-15 15:53:17.452 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' id='7fab13ce6d0cfd25' from='domain.example.com' version='1.0' xml:lang='en' to='bob_unavailable_resources_dont_get_carbons_606@domain.example.com'>
*** User 2024-04-15 15:53:17.452 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@domain.example.com/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-15 15:53:17.452 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<iq type='set' id='d0bfbc67a855e021b1d7611bcf2af30a'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<resource>res1</resource>
</bind>
</iq>
*** User 2024-04-15 15:53:17.453 ***🔗
bOb_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<iq id='d0bfbc67a855e021b1d7611bcf2af30a' type='result'>
<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'>
<jid>bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1</jid>
</bind>
</iq>
*** User 2024-04-15 15:53:17.453 ***🔗
bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<iq type='set' id='ce1fb2eac635a05151a1c8b2b80cf58c'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-15 15:53:17.453 ***🔗
bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<iq from='domain.example.com' to='bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' id='ce1fb2eac635a05151a1c8b2b80cf58c' type='result'>
<session xmlns='urn:ietf:params:xml:ns:xmpp-session'/>
</iq>
*** User 2024-04-15 15:53:17.454 ***🔗
bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<presence/>
*** User 2024-04-15 15:53:17.455 ***🔗
bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<presence from='bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' to='bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1'/>
*** User 2024-04-15 15:53:17.455 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<iq xmlns='jabber:client' type='set' id='6c5360befce02e5979f2c55c659d5074'>
<enable xmlns='urn:xmpp:carbons:2'/>
</iq>
*** User 2024-04-15 15:53:17.455 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<iq from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' id='6c5360befce02e5979f2c55c659d5074' type='result'/>
*** User 2024-04-15 15:53:17.455 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 out
<iq xmlns='jabber:client' type='set' id='8a4e49fff550c2dda5f165aab9debb25'>
<enable xmlns='urn:xmpp:carbons:2'/>
</iq>
*** User 2024-04-15 15:53:17.456 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<iq from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2' id='8a4e49fff550c2dda5f165aab9debb25' type='result'/>
*** User 2024-04-15 15:53:17.456 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<presence type='unavailable'/>
*** User 2024-04-15 15:53:17.457 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<presence from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2' type='unavailable'/>
*** User 2024-04-15 15:53:17.457 ***🔗
bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<message type='chat' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2'>
<body>And pious action</body>
</message>
*** User 2024-04-15 15:53:17.457 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<message from='bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2' type='chat'>
<body>And pious action</body>
</message>
*** User 2024-04-15 15:53:17.457 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<presence/>
*** User 2024-04-15 15:53:17.458 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<presence from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1'/>
*** User 2024-04-15 15:53:17.458 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<presence from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1'>
<delay xmlns='urn:xmpp:delay' stamp='2024-04-15T15:53:17.448586Z' from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2'/>
</presence>
*** User 2024-04-15 15:53:17.458 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<presence from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2'/>
*** User 2024-04-15 15:53:17.458 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<iq xmlns='jabber:client' type='set' id='c068ea4f3cc00e6d0a517e528afcc107'>
<enable xmlns='urn:xmpp:carbons:2'/>
</iq>
*** User 2024-04-15 15:53:17.461 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<iq from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' id='c068ea4f3cc00e6d0a517e528afcc107' type='result'/>
*** User 2024-04-15 15:53:17.461 ***🔗
bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
<message type='chat' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2'>
<body>carbonated</body>
</message>
*** User 2024-04-15 15:53:17.465 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
<message from='bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2' type='chat'>
<body>carbonated</body>
</message>
*** User 2024-04-15 15:53:17.466 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
<message from='alice_unavailable_resources_dont_get_carbons_606@domain.example.com' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' xmlns='jabber:client' type='chat'>
<received xmlns='urn:xmpp:carbons:2'>
<forwarded xmlns='urn:xmpp:forward:0'>
<message from='bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1' to='alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2' type='chat' xmlns='jabber:client'>
<body>carbonated</body>
</message>
</forwarded>
</received>
</message>
*** User 2024-04-15 15:53:17.466 ***🔗
bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
</stream:stream>
*** User 2024-04-15 15:53:17.466 ***🔗
bob_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
</stream:stream>
*** User 2024-04-15 15:53:17.466 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 out
</stream:stream>
*** User 2024-04-15 15:53:17.466 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res2 in
</stream:stream>
*** User 2024-04-15 15:53:17.466 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 out
</stream:stream>
*** User 2024-04-15 15:53:17.467 ***🔗
alice_unavailable_resources_dont_get_carbons_606@domain.example.com/res1 in
</stream:stream>
=== Ended at 2024-04-15 15:53:18
=== successfully completed test case
=== === Returned value: ok