process management rules management blog posts

Comments on jBpm 3.0

Blog: Business Process Management

Since I commented on jBpm 2.0 model earlier in this blog, I have been asked to review jBpm 3.0 beta. This is not really a review per se, but my quick observations after spending a couple of hours on jBpm-3.0-beta4 and jBpm-bpel-1.0-alpha1.

jBpm 3.0 is essentially has the same underlying model as its predecessor, and that isn't surprising. From the architectural view point, it has more of a pluggable architecture (i.e., we can plug in our own modules that take up certain workflow responsibilities, for example, task handling), which can be a good thing. There is also a new graphical designer, which I didn't check out. There are a few implementation enhancements related to persistence and such, as well as many improvements related to deployment and documentation. However, I didn't see any notable changes or improvements from the modeling perspective.

The BPEL component, which is in alpha1 stage, is in very early stages of development. A full-blown implementation of the BPEL standard is not trivial, and I don't expect to see this component being ready atleast until the end of 2005. Some BPEL constructs have been added including messages and message correlations, but I don't know how complete they are. The current model still remains void of some non-trivial constructs such as scopes, compensations, and fault handlers. Some diligent analysis is required on my part before I can conclude whether or not jBpm can support all control flow constructs that BPEL specifies.

Overall, nothing in jBpm 3.0 made me change my earlier opinion that jBpm model is ad hoc and suboptimal, but Tom Baeyens has a different opinion (I hope that he is right and I am wrong). That said, I won't hesitate to use jBpm where ever I can, if I find it sufficient to fit the needs of the situation at hand.