-
Notifications
You must be signed in to change notification settings - Fork 12
Home
This project attempts to show an interesting approach on testing Java EE Applications. It uses a CDI Container to resolve dependencies like EJBs or Resources when running unit test in a standard environment.
The name "Bean Testing" is used, since it isn't about proper unit tests. However, the feedback speed is very close to unit test and the tests look undistinguishable too.
First of all, this approach is neither a replacement for unit nor integration tests. This approach is something in the middle.
You should always write unit tests for essential business logic.
You should always write integration tests to check that everything works as expected.
So, why use this approach? Because you get the best of both worlds: You get the speed of unit tests with almost the coverage of integration tests and all this with minimal configuration and with standard and well known frameworks like JPA, CDI, Mockito and Junit.
Since you don't need an application server for running your tests, you can integrate them in your normal unit test build process. In this way, you get almost integration test coverage in your normal builds.
- Very fast test feedback (very close to unit test feedback speed).
- Dependencies are solved automatically without the need of a JEE Application Server (or Embedded Server).
- Everything is CDI so you can easliy extend the functionality.
- You get basic transaction propagation support.
- You can provide your own mocks to test external dependencies.
- You use the usual stuff for configuration: persistence.xml, beans.xml, Junit, etc.
BeanTest is currently being used in some (big) customer projects. The projects are big Java EE Applications with several subsystems (.ear's). Each subsystem consists of several modules (.jar's) as well. We haven't faced any critical problem. Usually one can fix a problem by using standard CDI features.