Test duration : 500.244s
Failed Tests | ||
---|---|---|
tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout | ||
testMessageDeliveryReliabilityWithoutResumptionAndWithoutFullJid | 451.297s |
2022-08-18 22:54:49 |
java.lang.AssertionError: Message was not delivered!
2022-08-18 22:54:49 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:49 | ------------------------------------ 2022-08-18 22:54:49 | [Mutex] waiting for: [message:126e17ca-ee96-4536-b989-12537f0eddf7] 2022-08-18 22:54:49 | [Mutex] received everything. 2022-08-18 22:54:49 | ===== simulation of connection failure 2022-08-18 22:54:49 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:49 | ===== sending message to look for 2022-08-18 22:54:50 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:50 | ===== broadcasting presence 2022-08-18 22:54:50 | [Mutex] waiting for: [message:fc3fa397-91ef-4c22-8d21-77d727200ce7] 2022-08-18 22:54:50 | [Mutex] waiting for: [message:fc3fa397-91ef-4c22-8d21-77d727200ce7] 2022-08-18 23:02:20 | [Mutex] timeout. Not received [message:fc3fa397-91ef-4c22-8d21-77d727200ce7] 2022-08-18 23:02:20 | [Mutex] isItemNotified: message:fc3fa397-91ef-4c22-8d21-77d727200ce7 :: false
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.testMessageDeliveryReliabilityWithoutResumptionAndWithoutFullJid(TestOfflineMessageDeliveryAfterSmResumptionTimeout.java:100) 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.308s |
2022-08-18 22:54:05 |
2022-08-18 22:54:05 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:05 | ------------------------------------ 2022-08-18 22:54:05 | [Mutex] waiting for: [message:05bcce53-6dff-450a-83c6-870baa1653d4] 2022-08-18 22:54:05 | [Mutex] received everything. 2022-08-18 22:54:05 | ===== simulation of connection failure 2022-08-18 22:54:05 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:05 | ===== sending message to look for 2022-08-18 22:54:06 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:06 | ===== broadcasting presence 2022-08-18 22:54:06 | [Mutex] received everything. 2022-08-18 22:54:06 | [Mutex] isItemNotified: message:a04f96b9-aac4-4508-bc18-7a9de1336ca6 :: true |
testMessageDeliveryReliabilityChatWithResumptionAndWithFullJidAndDelay | 3.317s |
2022-08-18 22:54:07 |
2022-08-18 22:54:07 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:07 | ------------------------------------ 2022-08-18 22:54:07 | [Mutex] waiting for: [message:abb71b49-8a19-4e21-bc52-2dd18ebee846] 2022-08-18 22:54:07 | [Mutex] received everything. 2022-08-18 22:54:07 | ===== simulation of connection failure 2022-08-18 22:54:07 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:07 | ===== sending message to look for 2022-08-18 22:54:08 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:10 | ===== broadcasting presence 2022-08-18 22:54:10 | [Mutex] received everything. 2022-08-18 22:54:10 | [Mutex] isItemNotified: message:7d16ad85-d528-42fb-b837-7f6ca914c00c :: true |
testMessageDeliveryReliabilityChatWithResumptionAndWithoutFullJid | 1.296s |
2022-08-18 22:54:11 |
2022-08-18 22:54:11 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:11 | ------------------------------------ 2022-08-18 22:54:11 | [Mutex] waiting for: [message:1812dab5-822b-4183-9f74-10292ea17dcf] 2022-08-18 22:54:11 | [Mutex] waiting for: [message:1812dab5-822b-4183-9f74-10292ea17dcf] 2022-08-18 22:54:11 | [Mutex] received everything. 2022-08-18 22:54:11 | ===== simulation of connection failure 2022-08-18 22:54:11 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:11 | ===== sending message to look for 2022-08-18 22:54:12 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:12 | ===== broadcasting presence 2022-08-18 22:54:12 | [Mutex] received everything. 2022-08-18 22:54:12 | [Mutex] isItemNotified: message:22f156e6-9036-453a-bbd4-b236326ac08a :: true |
testMessageDeliveryReliabilityChatWithResumptionAndWithoutFullJidAndDelay | 3.297s |
2022-08-18 22:54:13 |
2022-08-18 22:54:13 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:13 | ------------------------------------ 2022-08-18 22:54:13 | [Mutex] waiting for: [message:721a28aa-07e3-4c2c-839d-02fcb741290f] 2022-08-18 22:54:13 | [Mutex] received everything. 2022-08-18 22:54:13 | ===== simulation of connection failure 2022-08-18 22:54:13 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:13 | ===== sending message to look for 2022-08-18 22:54:14 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:17 | ===== broadcasting presence 2022-08-18 22:54:17 | [Mutex] received everything. 2022-08-18 22:54:17 | [Mutex] isItemNotified: message:126a2e24-8685-4adc-8e2b-dc6fff72c387 :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithFullJid | 1.306s |
2022-08-18 22:54:17 |
2022-08-18 22:54:17 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:17 | ------------------------------------ 2022-08-18 22:54:17 | [Mutex] waiting for: [message:66eca1b5-f0b5-4ecf-b0fe-d953a05fdbb1] 2022-08-18 22:54:17 | [Mutex] received everything. 2022-08-18 22:54:17 | ===== simulation of connection failure 2022-08-18 22:54:17 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:17 | ===== sending message to look for 2022-08-18 22:54:18 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:19 | ===== broadcasting presence 2022-08-18 22:54:19 | [Mutex] waiting for: [message:ee3e8d40-73eb-4faf-a525-37b43b1d354a] 2022-08-18 22:54:19 | [Mutex] waiting for: [message:ee3e8d40-73eb-4faf-a525-37b43b1d354a] 2022-08-18 22:54:19 | [Mutex] received everything. 2022-08-18 22:54:19 | [Mutex] isItemNotified: message:ee3e8d40-73eb-4faf-a525-37b43b1d354a :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithFullJidAndDelay | 3.303s |
2022-08-18 22:54:19 |
2022-08-18 22:54:19 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:19 | ------------------------------------ 2022-08-18 22:54:19 | [Mutex] waiting for: [message:646d50ad-50fb-4660-9fc8-969ab0541836] 2022-08-18 22:54:19 | [Mutex] waiting for: [message:646d50ad-50fb-4660-9fc8-969ab0541836] 2022-08-18 22:54:19 | [Mutex] received everything. 2022-08-18 22:54:19 | ===== simulation of connection failure 2022-08-18 22:54:19 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:20 | ===== sending message to look for 2022-08-18 22:54:21 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:23 | ===== broadcasting presence 2022-08-18 22:54:23 | [Mutex] received everything. 2022-08-18 22:54:23 | [Mutex] isItemNotified: message:7a507f99-613e-4fa7-99b3-73e382e87568 :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithoutFullJid | 1.385s |
2022-08-18 22:54:24 |
2022-08-18 22:54:24 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:24 | ------------------------------------ 2022-08-18 22:54:24 | [Mutex] waiting for: [message:b1910c3d-3268-4903-9ba1-00055285e413] 2022-08-18 22:54:24 | [Mutex] received everything. 2022-08-18 22:54:24 | ===== simulation of connection failure 2022-08-18 22:54:24 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:24 | ===== sending message to look for 2022-08-18 22:54:25 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:25 | ===== broadcasting presence 2022-08-18 22:54:25 | [Mutex] waiting for: [message:7be3e04a-7e1c-498c-8d82-d8599a498bff] 2022-08-18 22:54:25 | [Mutex] received everything. 2022-08-18 22:54:25 | [Mutex] isItemNotified: message:7be3e04a-7e1c-498c-8d82-d8599a498bff :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithoutFullJidAndDelay | 3.326s |
2022-08-18 22:54:26 |
2022-08-18 22:54:26 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:26 | ------------------------------------ 2022-08-18 22:54:26 | [Mutex] waiting for: [message:97c46050-31c9-4732-814c-8a4e92b30d3a] 2022-08-18 22:54:26 | [Mutex] received everything. 2022-08-18 22:54:26 | ===== simulation of connection failure 2022-08-18 22:54:26 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:26 | ===== sending message to look for 2022-08-18 22:54:27 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:29 | ===== broadcasting presence 2022-08-18 22:54:29 | [Mutex] waiting for: [message:d796ab23-e41a-4be2-9d28-13d7dd92a243] 2022-08-18 22:54:29 | [Mutex] waiting for: [message:d796ab23-e41a-4be2-9d28-13d7dd92a243] 2022-08-18 22:54:29 | [Mutex] waiting for: [message:d796ab23-e41a-4be2-9d28-13d7dd92a243] 2022-08-18 22:54:29 | [Mutex] received everything. 2022-08-18 22:54:29 | [Mutex] isItemNotified: message:d796ab23-e41a-4be2-9d28-13d7dd92a243 :: true |
testMessageDeliveryReliabilityWithResumptionAndWithFullJid | 1.305s |
2022-08-18 22:54:30 |
2022-08-18 22:54:30 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:30 | ------------------------------------ 2022-08-18 22:54:30 | [Mutex] waiting for: [message:8f243561-62f0-4145-9987-a62c4b35b747] 2022-08-18 22:54:30 | [Mutex] received everything. 2022-08-18 22:54:30 | ===== simulation of connection failure 2022-08-18 22:54:30 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:30 | ===== sending message to look for 2022-08-18 22:54:31 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:31 | ===== broadcasting presence 2022-08-18 22:54:31 | [Mutex] received everything. 2022-08-18 22:54:31 | [Mutex] isItemNotified: message:be962467-d5b4-4343-8308-578aabe1c780 :: true |
testMessageDeliveryReliabilityWithResumptionAndWithFullJidAndDelay | 3.305s |
2022-08-18 22:54:32 |
2022-08-18 22:54:32 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:32 | ------------------------------------ 2022-08-18 22:54:32 | [Mutex] waiting for: [message:a05d599f-c9fe-4f13-919b-0d7870b6016f] 2022-08-18 22:54:32 | [Mutex] received everything. 2022-08-18 22:54:32 | ===== simulation of connection failure 2022-08-18 22:54:32 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:32 | ===== sending message to look for 2022-08-18 22:54:33 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:35 | ===== broadcasting presence 2022-08-18 22:54:35 | [Mutex] received everything. 2022-08-18 22:54:35 | [Mutex] isItemNotified: message:478b34ac-7c66-4d9b-b8b5-308d9dc669e2 :: true |
testMessageDeliveryReliabilityWithResumptionAndWithoutFullJid | 1.295s |
2022-08-18 22:54:36 |
2022-08-18 22:54:36 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:36 | ------------------------------------ 2022-08-18 22:54:36 | [Mutex] waiting for: [message:1ce380d5-d161-4168-b230-f6efa9f9d8bc] 2022-08-18 22:54:36 | [Mutex] waiting for: [message:1ce380d5-d161-4168-b230-f6efa9f9d8bc] 2022-08-18 22:54:36 | [Mutex] received everything. 2022-08-18 22:54:36 | ===== simulation of connection failure 2022-08-18 22:54:36 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:36 | ===== sending message to look for 2022-08-18 22:54:37 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:37 | ===== broadcasting presence 2022-08-18 22:54:37 | [Mutex] received everything. 2022-08-18 22:54:37 | [Mutex] isItemNotified: message:a5dddd55-383e-47e1-9140-9f15f1ec654d :: true |
testMessageDeliveryReliabilityWithResumptionAndWithoutFullJidAndDelay | 3.296s |
2022-08-18 22:54:38 |
2022-08-18 22:54:38 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:38 | ------------------------------------ 2022-08-18 22:54:38 | [Mutex] waiting for: [message:c97dd57c-7b09-40b7-a80b-632ed7ea6ce1] 2022-08-18 22:54:38 | [Mutex] waiting for: [message:c97dd57c-7b09-40b7-a80b-632ed7ea6ce1] 2022-08-18 22:54:38 | [Mutex] received everything. 2022-08-18 22:54:38 | ===== simulation of connection failure 2022-08-18 22:54:38 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:38 | ===== sending message to look for 2022-08-18 22:54:39 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:42 | ===== broadcasting presence 2022-08-18 22:54:42 | [Mutex] received everything. 2022-08-18 22:54:42 | [Mutex] isItemNotified: message:e917af10-5df9-4d3d-972f-3bad52dadfc6 :: true |
testMessageDeliveryReliabilityWithoutResumptionAndWithFullJid | 1.303s |
2022-08-18 22:54:42 |
2022-08-18 22:54:42 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:42 | ------------------------------------ 2022-08-18 22:54:42 | [Mutex] waiting for: [message:5cd7806a-2c93-4521-a4d8-8d91bbfa8deb] 2022-08-18 22:54:42 | [Mutex] waiting for: [message:5cd7806a-2c93-4521-a4d8-8d91bbfa8deb] 2022-08-18 22:54:42 | [Mutex] received everything. 2022-08-18 22:54:42 | ===== simulation of connection failure 2022-08-18 22:54:42 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:42 | ===== sending message to look for 2022-08-18 22:54:43 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:44 | ===== broadcasting presence 2022-08-18 22:54:44 | [Mutex] waiting for: [message:cb950f9f-aec7-4df1-9453-6dfbae26d795] 2022-08-18 22:54:44 | [Mutex] waiting for: [message:cb950f9f-aec7-4df1-9453-6dfbae26d795] 2022-08-18 22:54:44 | [Mutex] received everything. 2022-08-18 22:54:44 | [Mutex] isItemNotified: message:cb950f9f-aec7-4df1-9453-6dfbae26d795 :: true |
testMessageDeliveryReliabilityWithoutResumptionAndWithFullJidAndDelay | 3.307s |
2022-08-18 22:54:44 |
2022-08-18 22:54:44 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 22:54:44 | ------------------------------------ 2022-08-18 22:54:44 | [Mutex] waiting for: [message:bc18399d-0598-4555-a470-062bc883a764] 2022-08-18 22:54:44 | [Mutex] waiting for: [message:bc18399d-0598-4555-a470-062bc883a764] 2022-08-18 22:54:44 | [Mutex] received everything. 2022-08-18 22:54:44 | ===== simulation of connection failure 2022-08-18 22:54:44 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 22:54:45 | ===== sending message to look for 2022-08-18 22:54:46 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 22:54:48 | ===== broadcasting presence 2022-08-18 22:54:48 | [Mutex] received everything. 2022-08-18 22:54:48 | [Mutex] isItemNotified: message:e4816412-280b-4e9b-8e1a-4747becaff3d :: true |
testMessageDeliveryReliabilityWithoutResumptionAndWithoutFullJidAndDelay | 3.339s |
2022-08-18 23:02:21 |
2022-08-18 23:02:21 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-08-18 23:02:21 | ------------------------------------ 2022-08-18 23:02:21 | [Mutex] waiting for: [message:6e63b61c-ac0a-4a12-9787-4ba0b67cfb72] 2022-08-18 23:02:21 | [Mutex] waiting for: [message:6e63b61c-ac0a-4a12-9787-4ba0b67cfb72] 2022-08-18 23:02:21 | [Mutex] received everything. 2022-08-18 23:02:21 | ===== simulation of connection failure 2022-08-18 23:02:21 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-08-18 23:02:21 | ===== sending message to look for 2022-08-18 23:02:22 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-08-18 23:02:24 | ===== broadcasting presence 2022-08-18 23:02:24 | [Mutex] waiting for: [message:f87b1efa-a7ca-4ab6-9edd-5c31abf02345] 2022-08-18 23:02:24 | [Mutex] waiting for: [message:f87b1efa-a7ca-4ab6-9edd-5c31abf02345] 2022-08-18 23:02:24 | [Mutex] waiting for: [message:f87b1efa-a7ca-4ab6-9edd-5c31abf02345] 2022-08-18 23:02:24 | [Mutex] received everything. 2022-08-18 23:02:24 | [Mutex] isItemNotified: message:f87b1efa-a7ca-4ab6-9edd-5c31abf02345 :: true |