Monday, May 15, 2006

It is never too late to do the right thing.

I'm hoping to develop here a strategy to get management buy in on architectural changes that should happen (need to happen?) as my project moves forward. This is going to cost development and QA resources.

The backstory:
Currently, I am working on a project that was "acrhitected" in 2000. It's a fairly large web application, that followed the "model 2" servlets/JSP pattern, and the Servlet 1.0 spec. In 2000, the company was a startup, we had about a dozen employees and 3 customers. We had an architect, an OO-consultant, and a lot of enthusiasm. Me? It was my first Java project. I was clueless.

As time progressed, we developed harriedly with little process. We had to develop a product that people wanted to buy. Hours were long, but we were fairly successful replicating features based on the servlet-per-JSP model. We had our own persistence framework, and our own data caching solution. Meanwhile, 5 years pass, J2EE matures, frameworks are born. (The truth is that many frameworks existed already that we didn't take advantage of). We are a J2SE application trying to fake it in a J2EE world.

Now that the application is huge and our customers are many, we are really feeling the growing pains. The solution up until now has been to throw hardware at the problem. Unfortunately, this has always been
just successful enough that we haven't ever gotten schedule to get to the root of the issues.

We have always been in the position where retro-fitting new technology into our application would be an large undertaking in both development and test - and fraught with risk. So here we are.
Where do we go from here?

Well, that question is a good starting point. I need to determine what our truly critical flaws are, and get a plan together that addresses those first. In order to get the business plan to buy in, we need to address things that will show a little ROI. Everyone loves ROI. Sometimes, "so we don't crash" is as good as money in the bank (especially if software crashed yesterday).

Build it.
I'm confident now that the KoD for any proposal, especially when it involves expensive engineering resources, is to start your pitch with, "I think I can demonstrate that..." You can't sell it on paper. If you're selling technology, then you must demonstrate that technology. Build it and they will come... (at least that't the hope). There are several benefits to prototyping it before pitching it to mgmt.
  • You may be dead wrong - for whatever reason the prototype doesn't work out.
  • You mitigate perceived risk.
  • You improve your own depth of knowledge on the topic.
Have an incremental plan.
As you can imagine, "rewrite the app" is not an incremental plan. However, introducing alternate technology to do the same thing as existing technology is not an evil thing. Matter of fact, we have done this to some extent in our own application. We recently implemented some of our new screens using JSF, instead of marked up JSPs. I can't imagine that all of our other screens will go to JSF, but we're doing all new development that way.

Anticipate differences.
Using a different underlying technology/implementation may force you to handle some things differently than how things are currently done. When implementing JSF, one of the things we failed to manage was differences between how JSF and JSP handled form validation. JSF has its own validation framework. It's pretty well thought out - however it typically expects a server-round-trip to happen. Our existing JSPs had some pretty extensive client-side javascript validation. The difference wasn't huge, but it did change the user's experience somewhat.

Sometimes these differences are beneficial, sometimes detrimental. In our case, it wasn't a big deal, but the difference added to the conception that our moving to the new technology was the wrong decision. Had we thought about the differences, we could have probably also done client side validation before we shipped - and the user would have been none the wiser.

There are two goals that are typically going on in parallel. When refactoring, we're looking for the highest impact change in the lowest impact way. If execution speed is your issue, the very best we can hope for in a refactoring is that the user logs on the next time, and it's faster.

Sell it.
I work with a guy who, even though he went to a fine liberal arts college, apparently missed the class on salesmanship. You've got to make sure there is buzz around your ideas, and that they are constanly getting good press. Take opportunities to point out how the development-community-at-large is moving in the same direction you are. Forward online articles around. It's a little sad that you have to play the role of a circus barker, but there's truth to the old addage:
"Early to bed, early to rise, work like Hell and advertise!"

0 Comments:

Post a Comment

<< Home