Test duration : 499.886s
Failed Tests | ||
---|---|---|
tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout | ||
testMessageDeliveryReliabilityWithoutResumptionAndWithoutFullJid | 451.317s |
2022-06-23 22:19:53 |
java.lang.AssertionError: Message was not delivered!
2022-06-23 22:19:53 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:53 | ------------------------------------ 2022-06-23 22:19:53 | [Mutex] waiting for: [message:40bff749-71bc-41ac-a30b-0a6b93a83a0b] 2022-06-23 22:19:53 | [Mutex] received everything. 2022-06-23 22:19:53 | ===== simulation of connection failure 2022-06-23 22:19:53 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:53 | ===== sending message to look for 2022-06-23 22:19:54 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:54 | ===== broadcasting presence 2022-06-23 22:19:54 | [Mutex] waiting for: [message:a62bc5bf-05f1-4bab-88ec-9b98b4826df6] 2022-06-23 22:19:54 | [Mutex] waiting for: [message:a62bc5bf-05f1-4bab-88ec-9b98b4826df6] 2022-06-23 22:27:24 | [Mutex] timeout. Not received [message:a62bc5bf-05f1-4bab-88ec-9b98b4826df6] 2022-06-23 22:27:24 | [Mutex] isItemNotified: message:a62bc5bf-05f1-4bab-88ec-9b98b4826df6 :: 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.314s |
2022-06-23 22:19:09 |
2022-06-23 22:19:09 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:09 | ------------------------------------ 2022-06-23 22:19:09 | [Mutex] waiting for: [message:0b2fa860-b2c5-43eb-a1a2-b51851737229] 2022-06-23 22:19:09 | [Mutex] received everything. 2022-06-23 22:19:09 | ===== simulation of connection failure 2022-06-23 22:19:09 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:09 | ===== sending message to look for 2022-06-23 22:19:10 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:11 | ===== broadcasting presence 2022-06-23 22:19:11 | [Mutex] received everything. 2022-06-23 22:19:11 | [Mutex] isItemNotified: message:67e48518-29be-41ba-aa66-878edb201fd5 :: true |
testMessageDeliveryReliabilityChatWithResumptionAndWithFullJidAndDelay | 3.322s |
2022-06-23 22:19:11 |
2022-06-23 22:19:11 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:11 | ------------------------------------ 2022-06-23 22:19:11 | [Mutex] waiting for: [message:f8dcf1de-c360-4fd0-ba1e-ed85a981a3e0] 2022-06-23 22:19:11 | [Mutex] waiting for: [message:f8dcf1de-c360-4fd0-ba1e-ed85a981a3e0] 2022-06-23 22:19:11 | [Mutex] received everything. 2022-06-23 22:19:11 | ===== simulation of connection failure 2022-06-23 22:19:11 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:11 | ===== sending message to look for 2022-06-23 22:19:12 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:15 | ===== broadcasting presence 2022-06-23 22:19:15 | [Mutex] received everything. 2022-06-23 22:19:15 | [Mutex] isItemNotified: message:4a398110-c184-43c3-9abe-a64a283cdacb :: true |
testMessageDeliveryReliabilityChatWithResumptionAndWithoutFullJid | 1.297s |
2022-06-23 22:19:16 |
2022-06-23 22:19:16 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:16 | ------------------------------------ 2022-06-23 22:19:16 | [Mutex] waiting for: [message:3a3dfa79-1bc7-4d9a-b532-acefd9abfbda] 2022-06-23 22:19:16 | [Mutex] waiting for: [message:3a3dfa79-1bc7-4d9a-b532-acefd9abfbda] 2022-06-23 22:19:16 | [Mutex] received everything. 2022-06-23 22:19:16 | ===== simulation of connection failure 2022-06-23 22:19:16 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:16 | ===== sending message to look for 2022-06-23 22:19:17 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:17 | ===== broadcasting presence 2022-06-23 22:19:17 | [Mutex] received everything. 2022-06-23 22:19:17 | [Mutex] isItemNotified: message:d0b73deb-80cd-4cf3-9855-09f1bd73eed0 :: true |
testMessageDeliveryReliabilityChatWithResumptionAndWithoutFullJidAndDelay | 3.309s |
2022-06-23 22:19:18 |
2022-06-23 22:19:18 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:18 | ------------------------------------ 2022-06-23 22:19:18 | [Mutex] waiting for: [message:e60f1cb2-8f20-456b-a09c-5d97be037951] 2022-06-23 22:19:18 | [Mutex] received everything. 2022-06-23 22:19:18 | ===== simulation of connection failure 2022-06-23 22:19:18 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:18 | ===== sending message to look for 2022-06-23 22:19:19 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:21 | ===== broadcasting presence 2022-06-23 22:19:21 | [Mutex] received everything. 2022-06-23 22:19:21 | [Mutex] isItemNotified: message:e24edc0e-bbb1-4999-832c-942a313752ee :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithFullJid | 1.301s |
2022-06-23 22:19:22 |
2022-06-23 22:19:22 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:22 | ------------------------------------ 2022-06-23 22:19:22 | [Mutex] waiting for: [message:fa4540b0-a09f-4401-b883-adead5673b79] 2022-06-23 22:19:22 | [Mutex] waiting for: [message:fa4540b0-a09f-4401-b883-adead5673b79] 2022-06-23 22:19:22 | [Mutex] received everything. 2022-06-23 22:19:22 | ===== simulation of connection failure 2022-06-23 22:19:22 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:22 | ===== sending message to look for 2022-06-23 22:19:23 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:23 | ===== broadcasting presence 2022-06-23 22:19:23 | [Mutex] waiting for: [message:86250dc6-5cc0-4711-b822-1da2d0551e07] 2022-06-23 22:19:23 | [Mutex] received everything. 2022-06-23 22:19:23 | [Mutex] isItemNotified: message:86250dc6-5cc0-4711-b822-1da2d0551e07 :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithFullJidAndDelay | 3.297s |
2022-06-23 22:19:24 |
2022-06-23 22:19:24 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:24 | ------------------------------------ 2022-06-23 22:19:24 | [Mutex] waiting for: [message:32a4eb74-01db-40f6-85f9-6e2f3e72759f] 2022-06-23 22:19:24 | [Mutex] waiting for: [message:32a4eb74-01db-40f6-85f9-6e2f3e72759f] 2022-06-23 22:19:24 | [Mutex] received everything. 2022-06-23 22:19:24 | ===== simulation of connection failure 2022-06-23 22:19:24 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:24 | ===== sending message to look for 2022-06-23 22:19:25 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:27 | ===== broadcasting presence 2022-06-23 22:19:27 | [Mutex] received everything. 2022-06-23 22:19:27 | [Mutex] isItemNotified: message:acf243a0-c527-4f2c-875e-77260a1eab53 :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithoutFullJid | 1.374s |
2022-06-23 22:19:28 |
2022-06-23 22:19:28 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:28 | ------------------------------------ 2022-06-23 22:19:28 | [Mutex] waiting for: [message:904be399-3c17-4f2f-a5cd-c6b12a560468] 2022-06-23 22:19:28 | [Mutex] received everything. 2022-06-23 22:19:28 | ===== simulation of connection failure 2022-06-23 22:19:28 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:28 | ===== sending message to look for 2022-06-23 22:19:29 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:29 | ===== broadcasting presence 2022-06-23 22:19:29 | [Mutex] waiting for: [message:756a926d-72be-41c6-9707-3d14b2e3f5fe] 2022-06-23 22:19:29 | [Mutex] waiting for: [message:756a926d-72be-41c6-9707-3d14b2e3f5fe] 2022-06-23 22:19:29 | [Mutex] waiting for: [message:756a926d-72be-41c6-9707-3d14b2e3f5fe] 2022-06-23 22:19:29 | [Mutex] received everything. 2022-06-23 22:19:29 | [Mutex] isItemNotified: message:756a926d-72be-41c6-9707-3d14b2e3f5fe :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithoutFullJidAndDelay | 3.386s |
2022-06-23 22:19:30 |
2022-06-23 22:19:30 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:30 | ------------------------------------ 2022-06-23 22:19:30 | [Mutex] waiting for: [message:5f3d7779-1aea-4027-a260-3949f6935036] 2022-06-23 22:19:30 | [Mutex] waiting for: [message:5f3d7779-1aea-4027-a260-3949f6935036] 2022-06-23 22:19:30 | [Mutex] received everything. 2022-06-23 22:19:30 | ===== simulation of connection failure 2022-06-23 22:19:30 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:30 | ===== sending message to look for 2022-06-23 22:19:31 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:33 | ===== broadcasting presence 2022-06-23 22:19:33 | [Mutex] waiting for: [message:a9116747-428f-41b4-8cc7-56ad32f96bda] 2022-06-23 22:19:34 | [Mutex] waiting for: [message:a9116747-428f-41b4-8cc7-56ad32f96bda] 2022-06-23 22:19:34 | [Mutex] waiting for: [message:a9116747-428f-41b4-8cc7-56ad32f96bda] 2022-06-23 22:19:34 | [Mutex] received everything. 2022-06-23 22:19:34 | [Mutex] isItemNotified: message:a9116747-428f-41b4-8cc7-56ad32f96bda :: true |
testMessageDeliveryReliabilityWithResumptionAndWithFullJid | 1.299s |
2022-06-23 22:19:34 |
2022-06-23 22:19:34 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:34 | ------------------------------------ 2022-06-23 22:19:34 | [Mutex] waiting for: [message:cdea096c-60b1-4619-9177-7d4e0fc1e9a0] 2022-06-23 22:19:34 | [Mutex] received everything. 2022-06-23 22:19:34 | ===== simulation of connection failure 2022-06-23 22:19:34 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:35 | ===== sending message to look for 2022-06-23 22:19:36 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:36 | ===== broadcasting presence 2022-06-23 22:19:36 | [Mutex] received everything. 2022-06-23 22:19:36 | [Mutex] isItemNotified: message:78c609bb-98a6-4d6f-98f0-4db08b179524 :: true |
testMessageDeliveryReliabilityWithResumptionAndWithFullJidAndDelay | 3.318s |
2022-06-23 22:19:36 |
2022-06-23 22:19:36 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:36 | ------------------------------------ 2022-06-23 22:19:36 | [Mutex] waiting for: [message:0cddc776-7ccd-4d9b-a377-b3b280dfe305] 2022-06-23 22:19:36 | [Mutex] received everything. 2022-06-23 22:19:36 | ===== simulation of connection failure 2022-06-23 22:19:36 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:37 | ===== sending message to look for 2022-06-23 22:19:38 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:40 | ===== broadcasting presence 2022-06-23 22:19:40 | [Mutex] received everything. 2022-06-23 22:19:40 | [Mutex] isItemNotified: message:ab7eba1c-c196-46d7-b682-8bad71c6e473 :: true |
testMessageDeliveryReliabilityWithResumptionAndWithoutFullJid | 1.291s |
2022-06-23 22:19:40 |
2022-06-23 22:19:40 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:40 | ------------------------------------ 2022-06-23 22:19:40 | [Mutex] waiting for: [message:56a4a37b-b05c-40cd-98aa-3036f200ff7a] 2022-06-23 22:19:40 | [Mutex] received everything. 2022-06-23 22:19:40 | ===== simulation of connection failure 2022-06-23 22:19:40 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:41 | ===== sending message to look for 2022-06-23 22:19:42 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:42 | ===== broadcasting presence 2022-06-23 22:19:42 | [Mutex] received everything. 2022-06-23 22:19:42 | [Mutex] isItemNotified: message:6e66cf4e-8979-4733-8efb-74f2dc9f7b4d :: true |
testMessageDeliveryReliabilityWithResumptionAndWithoutFullJidAndDelay | 3.302s |
2022-06-23 22:19:43 |
2022-06-23 22:19:43 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:43 | ------------------------------------ 2022-06-23 22:19:43 | [Mutex] waiting for: [message:216ec8e6-e8ee-4b55-bb44-b83100a34353] 2022-06-23 22:19:43 | [Mutex] received everything. 2022-06-23 22:19:43 | ===== simulation of connection failure 2022-06-23 22:19:43 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:43 | ===== sending message to look for 2022-06-23 22:19:44 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:46 | ===== broadcasting presence 2022-06-23 22:19:46 | [Mutex] received everything. 2022-06-23 22:19:46 | [Mutex] isItemNotified: message:928dae98-4fd7-4d14-872f-bc2f3c6a54be :: true |
testMessageDeliveryReliabilityWithoutResumptionAndWithFullJid | 1.301s |
2022-06-23 22:19:47 |
2022-06-23 22:19:47 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:47 | ------------------------------------ 2022-06-23 22:19:47 | [Mutex] waiting for: [message:76b496be-2565-4d3b-8b8d-40c801697b19] 2022-06-23 22:19:47 | [Mutex] waiting for: [message:76b496be-2565-4d3b-8b8d-40c801697b19] 2022-06-23 22:19:47 | [Mutex] received everything. 2022-06-23 22:19:47 | ===== simulation of connection failure 2022-06-23 22:19:47 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:47 | ===== sending message to look for 2022-06-23 22:19:48 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:48 | ===== broadcasting presence 2022-06-23 22:19:48 | [Mutex] waiting for: [message:d66ba574-3546-447a-968f-8a1b53f264af] 2022-06-23 22:19:48 | [Mutex] received everything. 2022-06-23 22:19:48 | [Mutex] isItemNotified: message:d66ba574-3546-447a-968f-8a1b53f264af :: true |
testMessageDeliveryReliabilityWithoutResumptionAndWithFullJidAndDelay | 3.293s |
2022-06-23 22:19:49 |
2022-06-23 22:19:49 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:19:49 | ------------------------------------ 2022-06-23 22:19:49 | [Mutex] waiting for: [message:cc656866-dbac-4a35-858d-9cf5b0ec0a2d] 2022-06-23 22:19:49 | [Mutex] waiting for: [message:cc656866-dbac-4a35-858d-9cf5b0ec0a2d] 2022-06-23 22:19:49 | [Mutex] received everything. 2022-06-23 22:19:49 | ===== simulation of connection failure 2022-06-23 22:19:49 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:19:49 | ===== sending message to look for 2022-06-23 22:19:50 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:19:52 | ===== broadcasting presence 2022-06-23 22:19:52 | [Mutex] received everything. 2022-06-23 22:19:52 | [Mutex] isItemNotified: message:3ade1604-1c49-497f-8465-2b423b454b64 :: true |
testMessageDeliveryReliabilityWithoutResumptionAndWithoutFullJidAndDelay | 3.381s |
2022-06-23 22:27:25 |
2022-06-23 22:27:25 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-23 22:27:25 | ------------------------------------ 2022-06-23 22:27:25 | [Mutex] waiting for: [message:04713b16-f982-4d57-afce-f86e0ec75807] 2022-06-23 22:27:25 | [Mutex] received everything. 2022-06-23 22:27:25 | ===== simulation of connection failure 2022-06-23 22:27:25 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-23 22:27:25 | ===== sending message to look for 2022-06-23 22:27:26 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-23 22:27:28 | ===== broadcasting presence 2022-06-23 22:27:28 | [Mutex] waiting for: [message:a8dd5066-700e-4ae3-b37b-ba46b9636a64] 2022-06-23 22:27:28 | [Mutex] waiting for: [message:a8dd5066-700e-4ae3-b37b-ba46b9636a64] 2022-06-23 22:27:28 | [Mutex] waiting for: [message:a8dd5066-700e-4ae3-b37b-ba46b9636a64] 2022-06-23 22:27:28 | [Mutex] received everything. 2022-06-23 22:27:28 | [Mutex] isItemNotified: message:a8dd5066-700e-4ae3-b37b-ba46b9636a64 :: true |