Generated by TestNG with ReportNG at 22:46 PDT on Friday 15 July 2022
root@f9c07ffec79b / Java 17.0.2 (Private Build) / Linux 4.14.281-212.502.amzn2.x86_64 (amd64)

Offline Messages: Testing message delivery reliability related to stream resumption and resource conflict - #4262

Suites · Log Output

Test duration : 501.074s

Failed Tests
tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout
testMessageDeliveryReliabilityChatWithoutResumptionAndWithoutFullJid 451.326s
2022-07-15 22:47:33 |

2022-07-15 22:47:33 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:47:33 | ------------------------------------

2022-07-15 22:47:33 | [Mutex] waiting for: [message:c02ebe6a-4d53-4117-b93c-4f8014487752]

2022-07-15 22:47:33 | [Mutex] waiting for: [message:c02ebe6a-4d53-4117-b93c-4f8014487752]

2022-07-15 22:47:33 | [Mutex] received everything.

2022-07-15 22:47:33 |


===== simulation of connection failure


2022-07-15 22:47:33 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:47:33 |


===== sending message to look for


2022-07-15 22:47:34 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:47:34 |


===== broadcasting presence


2022-07-15 22:47:34 | [Mutex] waiting for: [message:040d0313-f010-4405-ae23-a6b9b9664624]

2022-07-15 22:47:34 | [Mutex] waiting for: [message:040d0313-f010-4405-ae23-a6b9b9664624]

2022-07-15 22:55:04 | [Mutex] timeout. Not received [message:040d0313-f010-4405-ae23-a6b9b9664624]

2022-07-15 22:55:04 | [Mutex] isItemNotified: message:040d0313-f010-4405-ae23-a6b9b9664624 :: false

java.lang.AssertionError: Message was not delivered!
org.testng.AssertJUnit.fail(AssertJUnit.java:65)
org.testng.AssertJUnit.assertTrue(AssertJUnit.java:23)
tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout.testMessageDeliveryReliability(TestOfflineMessageDeliveryAfterSmResumptionTimeout.java:264)
tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout.testMessageDeliveryReliabilityChatWithoutResumptionAndWithoutFullJid(TestOfflineMessageDeliveryAfterSmResumptionTimeout.java:141)
java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.base/java.lang.reflect.Method.invoke(Method.java:568)
org.testng.internal.invokers.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:135)
org.testng.internal.invokers.TestInvoker.invokeMethod(TestInvoker.java:673)
org.testng.internal.invokers.TestInvoker.invokeTestMethod(TestInvoker.java:220)
org.testng.internal.invokers.MethodRunner.runInSequence(MethodRunner.java:50)
org.testng.internal.invokers.TestInvoker$MethodInvocationAgent.invoke(TestInvoker.java:945)
org.testng.internal.invokers.TestInvoker.invokeTestMethods(TestInvoker.java:193)
org.testng.internal.invokers.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:146)
org.testng.internal.invokers.TestMethodWorker.run(TestMethodWorker.java:128)
java.base/java.util.ArrayList.forEach(ArrayList.java:1511)
org.testng.TestRunner.privateRun(TestRunner.java:808)
org.testng.TestRunner.run(TestRunner.java:603)
org.testng.SuiteRunner.runTest(SuiteRunner.java:429)
org.testng.SuiteRunner.runSequentially(SuiteRunner.java:423)
org.testng.SuiteRunner.privateRun(SuiteRunner.java:383)
org.testng.SuiteRunner.run(SuiteRunner.java:326)
org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:95)
org.testng.TestNG.runSuitesSequentially(TestNG.java:1249)
org.testng.TestNG.runSuitesLocally(TestNG.java:1169)
org.testng.TestNG.runSuites(TestNG.java:1092)
org.testng.TestNG.run(TestNG.java:1060)
org.apache.maven.surefire.testng.TestNGExecutor.run(TestNGExecutor.java:283)
org.apache.maven.surefire.testng.TestNGXmlTestSuite.execute(TestNGXmlTestSuite.java:75)
org.apache.maven.surefire.testng.TestNGProvider.invoke(TestNGProvider.java:120)
org.apache.maven.surefire.booter.ForkedBooter.invokeProviderInSameClassLoader(ForkedBooter.java:384)
org.apache.maven.surefire.booter.ForkedBooter.runSuitesInProcess(ForkedBooter.java:345)
org.apache.maven.surefire.booter.ForkedBooter.execute(ForkedBooter.java:126)
org.apache.maven.surefire.booter.ForkedBooter.main(ForkedBooter.java:418)
Passed Tests
tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout
testMessageDeliveryReliabilityChatWithResumptionAndWithFullJid 1.333s
2022-07-15 22:47:14 |

2022-07-15 22:47:14 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:47:14 | ------------------------------------

2022-07-15 22:47:14 | [Mutex] waiting for: [message:80daf58c-9f0c-4f5c-b8c6-e3f4c25e78f4]

2022-07-15 22:47:14 | [Mutex] received everything.

2022-07-15 22:47:14 |


===== simulation of connection failure


2022-07-15 22:47:14 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:47:14 |


===== sending message to look for


2022-07-15 22:47:15 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:47:15 |


===== broadcasting presence


2022-07-15 22:47:15 | [Mutex] received everything.

2022-07-15 22:47:15 | [Mutex] isItemNotified: message:d267eaf9-3980-4701-be85-cca6fb8fa49c :: true

testMessageDeliveryReliabilityChatWithResumptionAndWithFullJidAndDelay 3.332s
2022-07-15 22:47:16 |

2022-07-15 22:47:16 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:47:16 | ------------------------------------

2022-07-15 22:47:16 | [Mutex] waiting for: [message:8da9c0a0-408a-4bad-8cc2-31a9559d8099]

2022-07-15 22:47:16 | [Mutex] received everything.

2022-07-15 22:47:16 |


===== simulation of connection failure


2022-07-15 22:47:16 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:47:16 |


===== sending message to look for


2022-07-15 22:47:17 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:47:19 |


===== broadcasting presence


2022-07-15 22:47:19 | [Mutex] received everything.

2022-07-15 22:47:19 | [Mutex] isItemNotified: message:30109fdd-7e89-43cd-b7e4-727a9b8cb5dc :: true

testMessageDeliveryReliabilityChatWithResumptionAndWithoutFullJid 1.305s
2022-07-15 22:47:20 |

2022-07-15 22:47:20 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:47:20 | ------------------------------------

2022-07-15 22:47:20 | [Mutex] waiting for: [message:ec97d926-6ba5-4901-a3b0-c1124e658e69]

2022-07-15 22:47:20 | [Mutex] waiting for: [message:ec97d926-6ba5-4901-a3b0-c1124e658e69]

2022-07-15 22:47:20 | [Mutex] received everything.

2022-07-15 22:47:20 |


===== simulation of connection failure


2022-07-15 22:47:20 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:47:20 |


===== sending message to look for


2022-07-15 22:47:21 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:47:22 |


===== broadcasting presence


2022-07-15 22:47:22 | [Mutex] received everything.

2022-07-15 22:47:22 | [Mutex] isItemNotified: message:405de9a9-5252-46f9-abe5-08026f28446a :: true

testMessageDeliveryReliabilityChatWithResumptionAndWithoutFullJidAndDelay 3.302s
2022-07-15 22:47:22 |

2022-07-15 22:47:22 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:47:22 | ------------------------------------

2022-07-15 22:47:22 | [Mutex] waiting for: [message:10d506ab-777f-4e86-8171-d23f749622b8]

2022-07-15 22:47:22 | [Mutex] received everything.

2022-07-15 22:47:22 |


===== simulation of connection failure


2022-07-15 22:47:22 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:47:22 |


===== sending message to look for


2022-07-15 22:47:23 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:47:26 |


===== broadcasting presence


2022-07-15 22:47:26 | [Mutex] received everything.

2022-07-15 22:47:26 | [Mutex] isItemNotified: message:ead64ceb-5215-4373-8f5b-ddc2e279f71c :: true

testMessageDeliveryReliabilityChatWithoutResumptionAndWithFullJid 1.356s
2022-07-15 22:47:26 |

2022-07-15 22:47:26 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:47:26 | ------------------------------------

2022-07-15 22:47:26 | [Mutex] waiting for: [message:3f2bf612-5815-41e7-8334-2b647ee2f1ba]

2022-07-15 22:47:26 | [Mutex] waiting for: [message:3f2bf612-5815-41e7-8334-2b647ee2f1ba]

2022-07-15 22:47:26 | [Mutex] received everything.

2022-07-15 22:47:26 |


===== simulation of connection failure


2022-07-15 22:47:26 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:47:27 |


===== sending message to look for


2022-07-15 22:47:28 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:47:28 |


===== broadcasting presence


2022-07-15 22:47:28 | [Mutex] waiting for: [message:a24b9936-f116-4ab2-bf95-fa2ad45633b5]

2022-07-15 22:47:28 | [Mutex] received everything.

2022-07-15 22:47:28 | [Mutex] isItemNotified: message:a24b9936-f116-4ab2-bf95-fa2ad45633b5 :: true

testMessageDeliveryReliabilityChatWithoutResumptionAndWithFullJidAndDelay 3.310s
2022-07-15 22:47:29 |

2022-07-15 22:47:29 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:47:29 | ------------------------------------

2022-07-15 22:47:29 | [Mutex] waiting for: [message:f5e38e60-ec8a-471c-a0e9-1af33aed29b0]

2022-07-15 22:47:29 | [Mutex] waiting for: [message:f5e38e60-ec8a-471c-a0e9-1af33aed29b0]

2022-07-15 22:47:29 | [Mutex] received everything.

2022-07-15 22:47:29 |


===== simulation of connection failure


2022-07-15 22:47:29 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:47:29 |


===== sending message to look for


2022-07-15 22:47:30 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:47:32 |


===== broadcasting presence


2022-07-15 22:47:32 | [Mutex] received everything.

2022-07-15 22:47:32 | [Mutex] isItemNotified: message:070de1d8-f2ff-4ced-ac77-0ee93156a490 :: true

testMessageDeliveryReliabilityChatWithoutResumptionAndWithoutFullJidAndDelay 3.331s
2022-07-15 22:55:05 |

2022-07-15 22:55:05 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:55:05 | ------------------------------------

2022-07-15 22:55:05 | [Mutex] waiting for: [message:c6506309-b5db-4430-867e-2d23e9258d59]

2022-07-15 22:55:05 | [Mutex] received everything.

2022-07-15 22:55:05 |


===== simulation of connection failure


2022-07-15 22:55:05 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:55:05 |


===== sending message to look for


2022-07-15 22:55:06 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:55:08 |


===== broadcasting presence


2022-07-15 22:55:08 | [Mutex] waiting for: [message:c0b812a8-9dd2-4a80-a33b-2a29d57316ad]

2022-07-15 22:55:08 | [Mutex] waiting for: [message:c0b812a8-9dd2-4a80-a33b-2a29d57316ad]

2022-07-15 22:55:08 | [Mutex] waiting for: [message:c0b812a8-9dd2-4a80-a33b-2a29d57316ad]

2022-07-15 22:55:08 | [Mutex] received everything.

2022-07-15 22:55:08 | [Mutex] isItemNotified: message:c0b812a8-9dd2-4a80-a33b-2a29d57316ad :: true

testMessageDeliveryReliabilityWithResumptionAndWithFullJid 1.307s
2022-07-15 22:55:09 |

2022-07-15 22:55:09 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:55:09 | ------------------------------------

2022-07-15 22:55:09 | [Mutex] waiting for: [message:33c327d5-4520-49d9-8d3e-d48d3c0111a8]

2022-07-15 22:55:09 | [Mutex] received everything.

2022-07-15 22:55:09 |


===== simulation of connection failure


2022-07-15 22:55:09 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:55:09 |


===== sending message to look for


2022-07-15 22:55:10 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:55:11 |


===== broadcasting presence


2022-07-15 22:55:11 | [Mutex] received everything.

2022-07-15 22:55:11 | [Mutex] isItemNotified: message:5cac274e-a161-47e8-b02a-66776bebf307 :: true

testMessageDeliveryReliabilityWithResumptionAndWithFullJidAndDelay 3.328s
2022-07-15 22:55:11 |

2022-07-15 22:55:11 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:55:11 | ------------------------------------

2022-07-15 22:55:11 | [Mutex] waiting for: [message:dc485937-f34a-4c31-ba51-c17d83f40920]

2022-07-15 22:55:11 | [Mutex] waiting for: [message:dc485937-f34a-4c31-ba51-c17d83f40920]

2022-07-15 22:55:11 | [Mutex] received everything.

2022-07-15 22:55:11 |


===== simulation of connection failure


2022-07-15 22:55:11 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:55:12 |


===== sending message to look for


2022-07-15 22:55:13 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:55:15 |


===== broadcasting presence


2022-07-15 22:55:15 | [Mutex] received everything.

2022-07-15 22:55:15 | [Mutex] isItemNotified: message:5472e452-0a3c-4656-9db9-35e7a8c3ed3b :: true

testMessageDeliveryReliabilityWithResumptionAndWithoutFullJid 1.312s
2022-07-15 22:55:16 |

2022-07-15 22:55:16 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:55:16 | ------------------------------------

2022-07-15 22:55:16 | [Mutex] waiting for: [message:41ab8b2f-c9ec-4eb0-95ff-3cee91289995]

2022-07-15 22:55:16 | [Mutex] received everything.

2022-07-15 22:55:16 |


===== simulation of connection failure


2022-07-15 22:55:16 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:55:16 |


===== sending message to look for


2022-07-15 22:55:17 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:55:17 |


===== broadcasting presence


2022-07-15 22:55:17 | [Mutex] received everything.

2022-07-15 22:55:17 | [Mutex] isItemNotified: message:a68e3ece-afdb-4dd9-ae9e-a3b8ca21d8cc :: true

testMessageDeliveryReliabilityWithResumptionAndWithoutFullJidAndDelay 3.300s
2022-07-15 22:55:18 |

2022-07-15 22:55:18 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:55:18 | ------------------------------------

2022-07-15 22:55:18 | [Mutex] waiting for: [message:82fbfedd-4d9a-405c-8a59-3492a6386a24]

2022-07-15 22:55:18 | [Mutex] received everything.

2022-07-15 22:55:18 |


===== simulation of connection failure


2022-07-15 22:55:18 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:55:18 |


===== sending message to look for


2022-07-15 22:55:19 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:55:21 |


===== broadcasting presence


2022-07-15 22:55:21 | [Mutex] received everything.

2022-07-15 22:55:21 | [Mutex] isItemNotified: message:be1ab00e-9116-437a-9cf6-984f73784704 :: true

testMessageDeliveryReliabilityWithoutResumptionAndWithFullJid 1.303s
2022-07-15 22:55:22 |

2022-07-15 22:55:22 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:55:22 | ------------------------------------

2022-07-15 22:55:22 | [Mutex] waiting for: [message:fd4bd1cc-9b62-4d1e-b0a2-bf736ae6de11]

2022-07-15 22:55:22 | [Mutex] waiting for: [message:fd4bd1cc-9b62-4d1e-b0a2-bf736ae6de11]

2022-07-15 22:55:22 | [Mutex] received everything.

2022-07-15 22:55:22 |


===== simulation of connection failure


2022-07-15 22:55:22 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:55:22 |


===== sending message to look for


2022-07-15 22:55:23 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:55:23 |


===== broadcasting presence


2022-07-15 22:55:23 | [Mutex] waiting for: [message:7dc4a789-3b39-4dd0-8697-f1606c2a4c69]

2022-07-15 22:55:23 | [Mutex] received everything.

2022-07-15 22:55:23 | [Mutex] isItemNotified: message:7dc4a789-3b39-4dd0-8697-f1606c2a4c69 :: true

testMessageDeliveryReliabilityWithoutResumptionAndWithFullJidAndDelay 3.296s
2022-07-15 22:55:24 |

2022-07-15 22:55:24 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:55:24 | ------------------------------------

2022-07-15 22:55:24 | [Mutex] waiting for: [message:32ca857b-84c8-4f06-a3a6-348e426c0d78]

2022-07-15 22:55:24 | [Mutex] received everything.

2022-07-15 22:55:24 |


===== simulation of connection failure


2022-07-15 22:55:24 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:55:24 |


===== sending message to look for


2022-07-15 22:55:25 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:55:27 |


===== broadcasting presence


2022-07-15 22:55:27 | [Mutex] received everything.

2022-07-15 22:55:27 | [Mutex] isItemNotified: message:d3dd27e4-356b-4bc2-9bb6-ab1972aaef4a :: true

testMessageDeliveryReliabilityWithoutResumptionAndWithoutFullJid 1.353s
2022-07-15 22:55:28 |

2022-07-15 22:55:28 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:55:28 | ------------------------------------

2022-07-15 22:55:28 | [Mutex] waiting for: [message:78b56447-8343-47b7-b0bb-caa2a2d096a8]

2022-07-15 22:55:28 | [Mutex] received everything.

2022-07-15 22:55:28 |


===== simulation of connection failure


2022-07-15 22:55:28 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:55:28 |


===== sending message to look for


2022-07-15 22:55:29 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:55:30 |


===== broadcasting presence


2022-07-15 22:55:30 | [Mutex] waiting for: [message:1bf2ce68-a21c-4aa8-8448-b6aecf40e036]

2022-07-15 22:55:30 | [Mutex] received everything.

2022-07-15 22:55:30 | [Mutex] isItemNotified: message:1bf2ce68-a21c-4aa8-8448-b6aecf40e036 :: true

testMessageDeliveryReliabilityWithoutResumptionAndWithoutFullJidAndDelay 3.331s
2022-07-15 22:55:30 |

2022-07-15 22:55:30 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout]

2022-07-15 22:55:30 | ------------------------------------

2022-07-15 22:55:30 | [Mutex] waiting for: [message:7ab0d452-9043-4ae5-973d-2e36e637192e]

2022-07-15 22:55:30 | [Mutex] waiting for: [message:7ab0d452-9043-4ae5-973d-2e36e637192e]

2022-07-15 22:55:30 | [Mutex] received everything.

2022-07-15 22:55:30 |


===== simulation of connection failure


2022-07-15 22:55:30 |


===== sending dummy message so client will discover it is disconnected (workaround)


2022-07-15 22:55:31 |


===== sending message to look for


2022-07-15 22:55:32 |


===== reconnecting client (resumption of stream or binding using same resource)


2022-07-15 22:55:34 |


===== broadcasting presence


2022-07-15 22:55:34 | [Mutex] waiting for: [message:7556665b-0b0b-4fbc-921e-a1d5d2095723]

2022-07-15 22:55:34 | [Mutex] waiting for: [message:7556665b-0b0b-4fbc-921e-a1d5d2095723]

2022-07-15 22:55:34 | [Mutex] waiting for: [message:7556665b-0b0b-4fbc-921e-a1d5d2095723]

2022-07-15 22:55:34 | [Mutex] received everything.

2022-07-15 22:55:34 | [Mutex] isItemNotified: message:7556665b-0b0b-4fbc-921e-a1d5d2095723 :: true