I've been seeing odd behaviour from my Maven 2.2.1 installation whilst doing war installs.
Occasionally, I will update a class but the updated version is not packaged up in the artifact produced by mvn install.
So far, I have determined that an updated .class file is produced in the target directory, and that the class of the same name in the produced .war is not the same (different date modified, different size)
Running Maven from the command line with the -X flag produced debug output for the class like:
[DEBUG] * WEB-INF/classes/mypackage/MyClass.class is up to date.
I think I've also had the same problem before where the file that was cached(?) was an incomplete compile from Eclipse, causing 'Unresolved Compilation Problem' errors from the Maven build, but a working artifact from an Eclipse export.
- How does Maven determine whether a file 'is up to date' during the install process?
- Where are the files Maven is comparing to?
- Can I force Maven to build a package from scratch?
- Any other ideas would be appreciated!
Just to be sure, the classes should be built under
target\classes
, nottarget
.You can force a full build by running
This performs a
clean
(essentially removes thetarget
directory) before running the install phase.Also - check for copies of your classes outside of the Maven build directory. In this case as it is a webapp, check
src/main/webapp/WEB-INF/classes