[Engine-devel] Simplifying our POJOs
Mike Kolesnik
mkolesni at redhat.com
Wed Feb 1 06:03:47 UTC 2012
----- Original Message -----
> On 01/31/2012 12:45 PM, Doron Fediuck wrote:
> > On 31/01/12 12:39, Livnat Peer wrote:
> >> On 31/01/12 12:02, Mike Kolesnik wrote:
> >>> Hi,
> >>>
> >>> Today many POJO
> >>> <http://en.wikipedia.org/wiki/Plain_Old_Java_Object>s
> >>> are used throughout the system to convey data:
> >>>
> >>> * Parameters - To send data to commands.
> >>> * Business Entities - To transfer data in the parameters &
> >>> to/from
> >>> the DB.
> >>>
> >>> These POJOs are (usually) very verbose and full of boilerplate
> >>> code
> >>> <http://en.wikipedia.org/wiki/Boilerplate_code>.
> >>>
> >>> This, in turn, reduces their readability and maintainability for
> >>> a
> >>> couple of reasons (that I can think of):
> >>>
> >>> * It's hard to know what does what:
> >>> o Who participates in equals/hashCode?
> >>> o What fields are printed in toString?
> >>> * Consistency is problematic:
> >>> o A field may be part of equals but not hashCode, or vice
> >>> versa.
> >>> o This breaks the Object.hashCode()
> >>> <http://docs.oracle.com/javase/6/docs/api/java/lang/Object.html#hashCode%28%29>
> >>> contract!
> >>> * Adding/Removing fields take more time since you need to
> >>> synchronize
> >>> the change to all boilerplate methods.
> >>> o Again, we're facing the consistency problem.
> >>> * These simple classes tend to be very long and not very
> >>> readable.
> >>> * Boilerplate code makes it harder to find out which methods
> >>> *don't*
> >>> behave the default way.
> >>> * Javadoc, if existent, is usually meaningless (but you might
> >>> see some
> >>> banal documentation that doesn't add any real value).
> >>> * Our existing classes are not up to standard!
> >>>
> >>>
> >>> So what can be done to remedy the situation?
> >>>
> >>> We could, of course, try to simplify the classes as much as we
> >>> can and
> >>> maybe address some of the issues.
> >>> This won't alleviate the boilerplate code problem altogether,
> >>> though.
> >>>
> >>> We could write annotations to do some of the things for us
> >>> automatically.
> >>> The easiest approach would be runtime-based, and would hinder
> >>> performance.
> >>> This also means we need to maintain this "infrastructure" and all
> >>> the
> >>> implications of such a decision.
> >>>
> >>>
> >>> Luckily, there is a much easier solution: Someone else already
> >>> did it!
> >>>
> >>> Check out Project Lombok: http://projectlombok.org
> >>> What Lombok gives us, among some other things, is a way to
> >>> greatly
> >>> simplify our POJOs by using annotations to get the boilerplate
> >>> code
> >>> automatically generated.
> >>> This means we get the benefit of annotations which would simplify
> >>> the
> >>> code a whole lot, while not imposing a performance cost (since
> >>> the
> >>> boilerplate code is generated during compilation).
> >>> However, it's also possible to create the methods yourself if you
> >>> want
> >>> them to behave differently.
> >>> Outside the POJO itself, you would see it as you would always see
> >>> it.
> >>>
> >>> So what are the downsides to this approach?
> >>>
> >>> * First of all, Lombok provides also some other capabilities
> >>> which I'm
> >>> not sure are required/wanted at this time.
> >>> o That's why I propose we use it for commons project, and
> >>> make use
> >>> of it's POJO-related annotations ONLY.
> >>> * There might be a problem debugging the code since it's
> >>> auto-generated.
> >>> o I think this is rather negligible, since usually you
> >>> don't debug
> >>> POJOs anyway.
> >>> * There might be a problem if the auto-generated code throws an
> >>> Exception.
> >>> o As before, I'm rather sure this is an edge-case which we
> >>> usually
> >>> won't hit (if at all).
> >>>
> >>>
> >>> Even given these possible downsides, I think that we would
> >>> benefit
> >>> greatly if we would introduce this library.
> >>>
> >>> If you have any questions, you're welcome to study out the
> >>> project site
> >>> which has very thorough documentation: http://projectlombok.org
> >>>
> >>> Your thoughts on the matter?
> >>>
> >>
> >> - I think an example of before/after pojo would help demonstrating
> >> how
> >> good the framework is.
> >>
> >> - Would it work when adding JPA annotations?
> I suspect that yes (needs to be checked)
> Will it work with GWT (if we create new business entity that needs to
> be
> exposed to GWT guys) ?
As it is stated on the site, it supports GWT.
> >>
> >>> Regards,
> >>> Mike
> >>>
> >
> > Watching the demo it looks like we'll get less code, which in many
> > cases is a good thing.
> > What I'm concerned about is traceability; or- how can we track
> > issues coming from the field
> > when function calls and line numbers in the stack trace will not
> > match the code we know.
> >
>
> _______________________________________________
> Engine-devel mailing list
> Engine-devel at ovirt.org
> http://lists.ovirt.org/mailman/listinfo/engine-devel
>
More information about the Devel
mailing list