Debugging WildFly Arquillian test09 Mar 2017
When the worst comes in WildFly development, it is time to debug Arquillian test. In this article I want to compile instructions how to do it.
The worst thing on it is, you have to debug two JVMs in two debuggers in one time:
JVM of the test
To debug it run test in maven with following param:
This will cause the test will wait for debugger, which is supposed to listen on port 5005. In IDEA we will setup this Remote debug in test project by folowing way:
Debug - Edit configuration - Add new configuration - Remote - Socket, Listen, Port: 5005
At first we should press Debug in IDEA and start the maven test in CLI after.
JVM of WildFly
To debug JVM of WildFly use following param:
Or you can modify arquilian.xml (probably in
src/test/config/arq/arquilian.xml) - add
To the javaVmArguments:
Now just add debug configuration into IDEA by similar way, but to the project of tested component:
Debug - Edit configuration - Add new configuration - Remote - Socket, Attach, Port: 8787
In this case we can start Debug only when JVM is already running - when the test is running. You can:
- press Debug buttom randomly after
T E S T Sheadline appears in maven output (stupid but fast and often works :)
- to debug JVM of the test and connect second debugger when the test will be waiting on breakpoint
JVM of JBoss CLI
Sometime you can also need to debug JBoss CLI client. That require to uncomment following near the end of
Just note, don’t forgot to change port 8787 to samething else, if you want to debug CLI and server at one time.
How to run one concrete test using maven
To run one concrete test from WildFly testsuite you can use following maven parameters:
Run this in wildfly directory (where you cloned git repository), use
-pl to specify testsuite directory and use
-Dtest to specify test in testsuite. Use
-Delytron if you want to test it.
Do not remove
-DallTests, even through you want to run only one test - it is necessary to run any non-smoke test.