Test duration : 500.613s
Failed Tests | ||
---|---|---|
tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout | ||
testMessageDeliveryReliabilityWithoutResumptionAndWithoutFullJid | 451.314s |
2022-06-30 22:51:53 |
java.lang.AssertionError: Message was not delivered!
2022-06-30 22:51:53 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:53 | ------------------------------------ 2022-06-30 22:51:53 | [Mutex] waiting for: [message:a4e51a90-6398-40df-be9d-38fd63f64c47] 2022-06-30 22:51:53 | [Mutex] received everything. 2022-06-30 22:51:53 | ===== simulation of connection failure 2022-06-30 22:51:53 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:53 | ===== sending message to look for 2022-06-30 22:51:54 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:54 | ===== broadcasting presence 2022-06-30 22:51:54 | [Mutex] waiting for: [message:23a4fe0d-8842-4543-bc99-f6895362225f] 2022-06-30 22:51:54 | [Mutex] waiting for: [message:23a4fe0d-8842-4543-bc99-f6895362225f] 2022-06-30 22:59:24 | [Mutex] timeout. Not received [message:23a4fe0d-8842-4543-bc99-f6895362225f] 2022-06-30 22:59:24 | [Mutex] isItemNotified: message:23a4fe0d-8842-4543-bc99-f6895362225f :: 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.307s |
2022-06-30 22:51:09 |
2022-06-30 22:51:09 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:09 | ------------------------------------ 2022-06-30 22:51:09 | [Mutex] waiting for: [message:f45c0608-62cb-4fe7-9e97-a9180cae6dfa] 2022-06-30 22:51:09 | [Mutex] received everything. 2022-06-30 22:51:09 | ===== simulation of connection failure 2022-06-30 22:51:09 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:09 | ===== sending message to look for 2022-06-30 22:51:10 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:10 | ===== broadcasting presence 2022-06-30 22:51:10 | [Mutex] received everything. 2022-06-30 22:51:10 | [Mutex] isItemNotified: message:1308c13b-e8b4-41db-9dba-15d9e5a7c702 :: true |
testMessageDeliveryReliabilityChatWithResumptionAndWithFullJidAndDelay | 3.299s |
2022-06-30 22:51:11 |
2022-06-30 22:51:11 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:11 | ------------------------------------ 2022-06-30 22:51:11 | [Mutex] waiting for: [message:bddb8339-9359-4830-bbc1-30501732836a] 2022-06-30 22:51:11 | [Mutex] received everything. 2022-06-30 22:51:11 | ===== simulation of connection failure 2022-06-30 22:51:11 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:11 | ===== sending message to look for 2022-06-30 22:51:12 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:14 | ===== broadcasting presence 2022-06-30 22:51:14 | [Mutex] received everything. 2022-06-30 22:51:14 | [Mutex] isItemNotified: message:87e4190a-08d4-4b07-a723-6f07d0ca2917 :: true |
testMessageDeliveryReliabilityChatWithResumptionAndWithoutFullJid | 1.304s |
2022-06-30 22:51:15 |
2022-06-30 22:51:15 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:15 | ------------------------------------ 2022-06-30 22:51:15 | [Mutex] waiting for: [message:1a3c8fcf-754b-49d5-a29e-a59ca2755f9f] 2022-06-30 22:51:15 | [Mutex] waiting for: [message:1a3c8fcf-754b-49d5-a29e-a59ca2755f9f] 2022-06-30 22:51:15 | [Mutex] received everything. 2022-06-30 22:51:15 | ===== simulation of connection failure 2022-06-30 22:51:15 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:15 | ===== sending message to look for 2022-06-30 22:51:16 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:16 | ===== broadcasting presence 2022-06-30 22:51:16 | [Mutex] received everything. 2022-06-30 22:51:16 | [Mutex] isItemNotified: message:54e0902d-85b9-482c-98f5-05b4dd523bbc :: true |
testMessageDeliveryReliabilityChatWithResumptionAndWithoutFullJidAndDelay | 3.308s |
2022-06-30 22:51:17 |
2022-06-30 22:51:17 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:17 | ------------------------------------ 2022-06-30 22:51:17 | [Mutex] waiting for: [message:39e0a6a9-1838-43db-956f-198e67e89f04] 2022-06-30 22:51:17 | [Mutex] received everything. 2022-06-30 22:51:17 | ===== simulation of connection failure 2022-06-30 22:51:17 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:17 | ===== sending message to look for 2022-06-30 22:51:18 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:20 | ===== broadcasting presence 2022-06-30 22:51:20 | [Mutex] received everything. 2022-06-30 22:51:20 | [Mutex] isItemNotified: message:6384f3ef-67d8-4b03-a8ed-c39193688245 :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithFullJid | 1.308s |
2022-06-30 22:51:21 |
2022-06-30 22:51:21 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:21 | ------------------------------------ 2022-06-30 22:51:21 | [Mutex] waiting for: [message:a522a865-6911-4f0f-bea6-f9d93a66c354] 2022-06-30 22:51:21 | [Mutex] received everything. 2022-06-30 22:51:21 | ===== simulation of connection failure 2022-06-30 22:51:21 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:21 | ===== sending message to look for 2022-06-30 22:51:22 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:22 | ===== broadcasting presence 2022-06-30 22:51:22 | [Mutex] waiting for: [message:30fec576-b349-440d-acc1-7ce8ebfa3718] 2022-06-30 22:51:22 | [Mutex] received everything. 2022-06-30 22:51:22 | [Mutex] isItemNotified: message:30fec576-b349-440d-acc1-7ce8ebfa3718 :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithFullJidAndDelay | 3.294s |
2022-06-30 22:51:23 |
2022-06-30 22:51:23 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:23 | ------------------------------------ 2022-06-30 22:51:23 | [Mutex] waiting for: [message:f08ac394-7505-4360-acd3-bb38dbea1678] 2022-06-30 22:51:23 | [Mutex] waiting for: [message:f08ac394-7505-4360-acd3-bb38dbea1678] 2022-06-30 22:51:23 | [Mutex] received everything. 2022-06-30 22:51:23 | ===== simulation of connection failure 2022-06-30 22:51:23 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:23 | ===== sending message to look for 2022-06-30 22:51:24 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:27 | ===== broadcasting presence 2022-06-30 22:51:27 | [Mutex] received everything. 2022-06-30 22:51:27 | [Mutex] isItemNotified: message:85cf3987-2428-42b2-a596-c8e54abbf8b8 :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithoutFullJid | 1.383s |
2022-06-30 22:51:27 |
2022-06-30 22:51:27 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:27 | ------------------------------------ 2022-06-30 22:51:27 | [Mutex] waiting for: [message:064bc70d-089e-463e-9cef-c0ac8a0b014e] 2022-06-30 22:51:27 | [Mutex] waiting for: [message:064bc70d-089e-463e-9cef-c0ac8a0b014e] 2022-06-30 22:51:27 | [Mutex] received everything. 2022-06-30 22:51:27 | ===== simulation of connection failure 2022-06-30 22:51:27 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:27 | ===== sending message to look for 2022-06-30 22:51:29 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:29 | ===== broadcasting presence 2022-06-30 22:51:29 | [Mutex] waiting for: [message:2d95185b-02df-4d50-be17-c9d0fde72fe4] 2022-06-30 22:51:29 | [Mutex] waiting for: [message:2d95185b-02df-4d50-be17-c9d0fde72fe4] 2022-06-30 22:51:29 | [Mutex] waiting for: [message:2d95185b-02df-4d50-be17-c9d0fde72fe4] 2022-06-30 22:51:29 | [Mutex] received everything. 2022-06-30 22:51:29 | [Mutex] isItemNotified: message:2d95185b-02df-4d50-be17-c9d0fde72fe4 :: true |
testMessageDeliveryReliabilityChatWithoutResumptionAndWithoutFullJidAndDelay | 3.329s |
2022-06-30 22:51:30 |
2022-06-30 22:51:30 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:30 | ------------------------------------ 2022-06-30 22:51:30 | [Mutex] waiting for: [message:d32f940c-39c5-4584-9658-fbd54f703c8e] 2022-06-30 22:51:30 | [Mutex] waiting for: [message:d32f940c-39c5-4584-9658-fbd54f703c8e] 2022-06-30 22:51:30 | [Mutex] received everything. 2022-06-30 22:51:30 | ===== simulation of connection failure 2022-06-30 22:51:30 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:30 | ===== sending message to look for 2022-06-30 22:51:31 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:33 | ===== broadcasting presence 2022-06-30 22:51:33 | [Mutex] waiting for: [message:69f63b50-20d5-46e0-bbc0-21aea39a9653] 2022-06-30 22:51:33 | [Mutex] waiting for: [message:69f63b50-20d5-46e0-bbc0-21aea39a9653] 2022-06-30 22:51:33 | [Mutex] waiting for: [message:69f63b50-20d5-46e0-bbc0-21aea39a9653] 2022-06-30 22:51:33 | [Mutex] received everything. 2022-06-30 22:51:33 | [Mutex] isItemNotified: message:69f63b50-20d5-46e0-bbc0-21aea39a9653 :: true |
testMessageDeliveryReliabilityWithResumptionAndWithFullJid | 1.301s |
2022-06-30 22:51:34 |
2022-06-30 22:51:34 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:34 | ------------------------------------ 2022-06-30 22:51:34 | [Mutex] waiting for: [message:85a7d8a8-628d-4827-bf8b-726e57ab1ff1] 2022-06-30 22:51:34 | [Mutex] waiting for: [message:85a7d8a8-628d-4827-bf8b-726e57ab1ff1] 2022-06-30 22:51:34 | [Mutex] received everything. 2022-06-30 22:51:34 | ===== simulation of connection failure 2022-06-30 22:51:34 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:34 | ===== sending message to look for 2022-06-30 22:51:35 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:35 | ===== broadcasting presence 2022-06-30 22:51:35 | [Mutex] received everything. 2022-06-30 22:51:35 | [Mutex] isItemNotified: message:8f694202-0b96-4f5b-bc05-103797e9716b :: true |
testMessageDeliveryReliabilityWithResumptionAndWithFullJidAndDelay | 3.304s |
2022-06-30 22:51:36 |
2022-06-30 22:51:36 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:36 | ------------------------------------ 2022-06-30 22:51:36 | [Mutex] waiting for: [message:f59b7051-5497-4948-8483-4a518ef28dd8] 2022-06-30 22:51:36 | [Mutex] received everything. 2022-06-30 22:51:36 | ===== simulation of connection failure 2022-06-30 22:51:36 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:36 | ===== sending message to look for 2022-06-30 22:51:37 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:39 | ===== broadcasting presence 2022-06-30 22:51:39 | [Mutex] received everything. 2022-06-30 22:51:39 | [Mutex] isItemNotified: message:a5c2d6fa-13fb-42f2-91d5-b1f2c9036a40 :: true |
testMessageDeliveryReliabilityWithResumptionAndWithoutFullJid | 1.310s |
2022-06-30 22:51:40 |
2022-06-30 22:51:40 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:40 | ------------------------------------ 2022-06-30 22:51:40 | [Mutex] waiting for: [message:b57f0256-d143-4b20-b05a-de96a516dfcd] 2022-06-30 22:51:40 | [Mutex] received everything. 2022-06-30 22:51:40 | ===== simulation of connection failure 2022-06-30 22:51:40 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:40 | ===== sending message to look for 2022-06-30 22:51:41 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:42 | ===== broadcasting presence 2022-06-30 22:51:42 | [Mutex] received everything. 2022-06-30 22:51:42 | [Mutex] isItemNotified: message:56579928-9e55-4d4e-82a9-32757c9b61f9 :: true |
testMessageDeliveryReliabilityWithResumptionAndWithoutFullJidAndDelay | 3.319s |
2022-06-30 22:51:42 |
2022-06-30 22:51:42 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:42 | ------------------------------------ 2022-06-30 22:51:42 | [Mutex] waiting for: [message:285796e1-31b5-47a0-a2b5-d184cf6d12b5] 2022-06-30 22:51:42 | [Mutex] waiting for: [message:285796e1-31b5-47a0-a2b5-d184cf6d12b5] 2022-06-30 22:51:42 | [Mutex] received everything. 2022-06-30 22:51:42 | ===== simulation of connection failure 2022-06-30 22:51:42 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:43 | ===== sending message to look for 2022-06-30 22:51:44 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:46 | ===== broadcasting presence 2022-06-30 22:51:46 | [Mutex] received everything. 2022-06-30 22:51:46 | [Mutex] isItemNotified: message:975a72ab-a68e-4b55-80a4-a6aec7ebfd8f :: true |
testMessageDeliveryReliabilityWithoutResumptionAndWithFullJid | 1.369s |
2022-06-30 22:51:46 |
2022-06-30 22:51:46 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:46 | ------------------------------------ 2022-06-30 22:51:46 | [Mutex] waiting for: [message:3f3d4298-a1cd-4467-ae2f-380b1a281707] 2022-06-30 22:51:46 | [Mutex] received everything. 2022-06-30 22:51:46 | ===== simulation of connection failure 2022-06-30 22:51:46 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:47 | ===== sending message to look for 2022-06-30 22:51:48 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:48 | ===== broadcasting presence 2022-06-30 22:51:48 | [Mutex] waiting for: [message:49a24bb3-962d-41ee-841c-6d64baf4a160] 2022-06-30 22:51:48 | [Mutex] received everything. 2022-06-30 22:51:48 | [Mutex] isItemNotified: message:49a24bb3-962d-41ee-841c-6d64baf4a160 :: true |
testMessageDeliveryReliabilityWithoutResumptionAndWithFullJidAndDelay | 3.299s |
2022-06-30 22:51:49 |
2022-06-30 22:51:49 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:51:49 | ------------------------------------ 2022-06-30 22:51:49 | [Mutex] waiting for: [message:f7947902-0136-439e-ae49-44b5cbf9ada6] 2022-06-30 22:51:49 | [Mutex] received everything. 2022-06-30 22:51:49 | ===== simulation of connection failure 2022-06-30 22:51:49 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:51:49 | ===== sending message to look for 2022-06-30 22:51:50 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:51:52 | ===== broadcasting presence 2022-06-30 22:51:52 | [Mutex] received everything. 2022-06-30 22:51:52 | [Mutex] isItemNotified: message:1dfbbb41-0143-4ab8-90e5-f97b660f8b63 :: true |
testMessageDeliveryReliabilityWithoutResumptionAndWithoutFullJidAndDelay | 3.312s |
2022-06-30 22:59:25 |
2022-06-30 22:59:25 | null / [TestClass name=class tigase.tests.server.offlinemsg.TestOfflineMessageDeliveryAfterSmResumptionTimeout] 2022-06-30 22:59:25 | ------------------------------------ 2022-06-30 22:59:25 | [Mutex] waiting for: [message:89501024-300f-4f84-a81a-390d6780f1a9] 2022-06-30 22:59:25 | [Mutex] waiting for: [message:89501024-300f-4f84-a81a-390d6780f1a9] 2022-06-30 22:59:25 | [Mutex] received everything. 2022-06-30 22:59:25 | ===== simulation of connection failure 2022-06-30 22:59:25 | ===== sending dummy message so client will discover it is disconnected (workaround) 2022-06-30 22:59:25 | ===== sending message to look for 2022-06-30 22:59:26 | ===== reconnecting client (resumption of stream or binding using same resource) 2022-06-30 22:59:28 | ===== broadcasting presence 2022-06-30 22:59:28 | [Mutex] waiting for: [message:4ffefd99-4ae1-4d60-ac71-aca42fdb384e] 2022-06-30 22:59:28 | [Mutex] waiting for: [message:4ffefd99-4ae1-4d60-ac71-aca42fdb384e] 2022-06-30 22:59:28 | [Mutex] waiting for: [message:4ffefd99-4ae1-4d60-ac71-aca42fdb384e] 2022-06-30 22:59:28 | [Mutex] received everything. 2022-06-30 22:59:28 | [Mutex] isItemNotified: message:4ffefd99-4ae1-4d60-ac71-aca42fdb384e :: true |