kaiyaok2 opened a new pull request, #1978: URL: https://github.com/apache/cxf/pull/1978
Fixes https://issues.apache.org/jira/browse/CXF-9042 # The Problem Some unit tests are non-idempotent, as they pass in the first run but fail in the second run in the same environment. A fix is necessary since unit tests shall be self-contained, ensuring that the state of the system under test is consistent at the beginning of each test. In practice, fixing non-idempotent tests can help proactively avoid state pollution that results in test order dependency (which could cause problems under test selection, prioritization or parallelization). # Reproduce Using the `NIOInspector` plugin that supports rerunning JUnit tests in the same environment. Use `org.apache.cxf.management.InstrumentationManagerTest#testWorkQueueInstrumentation` as an example: ``` cd rt/management mvn edu.illinois:NIOInspector:rerun -Dtest=org.apache.cxf.management.InstrumentationManagerTest#testWorkQueueInstrumentation ``` # 3 Non-Idempotent Tests & Proposed Fix ## org.apache.cxf.management.InstrumentationManagerTest#testWorkQueueInstrumentation Reason: The test creates and registers `MBean`s in the `MBeanServer` every time it runs, but it does not properly clean up those `MBean`s after the test execution. As a result, when the test is repeatedly run in the same environment, the number of `MBean`s registered with the `MBeanServer` accumulates, causing `s.size()` to increase. Error message of the test in the repeated run: ``` java.lang.AssertionError: expected:<2> but was:<4> at org.junit.Assert.fail(Assert.java:89) at org.junit.Assert.failNotEquals(Assert.java:835) at org.junit.Assert.assertEquals(Assert.java:647) at org.junit.Assert.assertEquals(Assert.java:633) at org.apache.cxf.management.InstrumentationManagerTest.testWorkQueueInstrumentation(InstrumentationManagerTest.java:91) ``` Fix: Unregister `MBean`s at the end of the test. ## org.apache.cxf.sts.operation.ValidateJWTTransformationTest#testJWTToSAMLTransformationRealm Reason: The line `wrapper = (Element) doc.getDocumentElement().appendChild(wrapper);` is not idempotent. This is because each time this line is executed, it attempts to append the wrapper element to the document's root element. If the wrapper element has already been appended to the root (as done in a previous test run), attempting to append it again will violate the document's tree structure, resulting in `org.w3c.dom.DOMException`. Error message in the repeated run: ``` org.w3c.dom.DOMException: HIERARCHY_REQUEST_ERR: An attempt was made to insert a node where it is not permitted. at java.xml/com.sun.org.apache.xerces.internal.dom.CoreDocumentImpl.insertBefore(CoreDocumentImpl.java:439) at java.xml/com.sun.org.apache.xerces.internal.dom.NodeImpl.appendChild(NodeImpl.java:230) at org.apache.cxf.sts.operation.ValidateJWTTransformationTest.testJWTToSAMLTransformationRealm(ValidateJWTTransformationTest.java:209) ``` Fix: Add a checker to avoid appending the `wrapper` if it is already part of the document. ## org.apache.cxf.systest.dispatch.DispatchClientServerTest#testJAXBObjectPAYLOADWithFeature Reason: The static counters in `TestDispatchFeature` and `TestInInterceptor` gets incremented repeatedly when `testJAXBObjectPAYLOADWithFeature()` is repeatedly run. The counters will be 1 in the first test run, but will be 2 in the second run and so on. Error message of one of the tests in the repeated run: ``` java.lang.AssertionError: Feature should be applied expected:<1> but was:<2> at org.junit.Assert.fail(Assert.java:89) at org.junit.Assert.failNotEquals(Assert.java:835) at org.junit.Assert.assertEquals(Assert.java:647) at org.apache.cxf.systest.dispatch.DispatchClientServerTest.testJAXBObjectPAYLOADWithFeature(DispatchClientServerTest.java:691) ``` Fix: Save the initial counts of the `TestDispatchFeature` before creating the bus, and then comparing the increments in the assertion checks. # Verifying this change After the patch, running the tests repeatedly in the same environment will not lead to failures. -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: dev-unsubscr...@cxf.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org