Testing a Plug-in
If you're writing a plug-in for general consumption, it would be good if you could ensure that it is working fine. You don't want to release something buggy, right? This lab will show you how to write automated tests for your plug-in.
How do I do that?
You can write two types of tests: Java unit tests and functional tests. Writing
Java unit tests makes sense only if your plug-in is relying on Java
source code. You add JUnit tests to your plug-in project just as you
do for any Maven project: you add them to an src/test directory defined using the
unitTestSourceDirectory
element in
your project.xml file. When you
execute the plugin:install
goal,
your unit tests will run automatically.
As most Maven plug-ins rely on Jelly script, it makes more sense
to focus on writing functional tests than it does to focus on JUnit
tests. The Plugin plug-in has a special plugin:test
goal which automatically starts
your functional tests, provided you have put them in the src/plugin-test directory. A functional
test is simply a Maven project that you put in src/plugin-test. This Maven test project
has to meet only one condition: it must have a custom goal named
testPlugin
that you write in its
maven.xml file. Under the hood,
this is the goal that will be called when you execute the plugin:test
goal.
As you might need several functional tests for your plug-in, the best practice is to set up a Multiproject project in src/plugin-test. For example, for the Jarexec plug-in you might want ...
Get Maven: A Developer's Notebook now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.