Do we need technical design?

Recently, the trend is for XP ( Extreme Programming) and Agile management with Sprint/Scrum, so do we still need technical design for a project?

The purpose of Agile developement is to supply the deliverable product sustainably and XP helps team accomplish the goal. Over the internet, we have found many principles, tips, best practises about coding, how to make a better code. However, noone talks about good technical design. In fact, none exists.

With the agile developement, the project is splitted up into small tasks. Each has acceptance test and customer relation. And most important, the customer is involved and the delivered product satisfy customer and we are ready for the change from them.

Now, let’s assume that we have all stories need to implement in one sprint. And the whole team will discuss how to do it. The question is how to make the technical design for those stories? and does it make sence to make the design for only those parts and the next sprint will continue next parts? I think NO.

Someone will say YES. Then i assume that you have made the technical design for those parts. Then come to the coding. Click here to see XP Practice . In summary it says:

  1. Write unit test and acceptance test, if you follow TDD.
  2. Write code to pass those test
  3. Refactoring code, of course make sure the tests are green.

And how can we refect the refactoring in Technical Design? So still say NO to technical design.

And consider time you spend on that

Someone will say: It keeps the thing we did in case when new comer want to get a preference. Do you really use the technical design to get understanding about the code or you will look directly into the code? if the code wrote 1 year ago and now you come in, what will you do in order to understand it? You only do this if the code has never been refacted.

My conclusion is that: If you are in XP and Agile development, you DO NOT need technical design. Instead of spending time on making the technical design, you should spend time on learning OOP principles, best practices. Then the code will explain itself.

Oobs, Are you throwing technical design away or is it useless? NO. We should consider it as a general documents of the project not the technical thing in detail.

Evaluation about SPM course at FMIT

Last month, i got a chance to attend the Soft skills for Project Manager at FMIT institude, sponsor by the company. You can find more here FMIT

It was also the first course i took about those skills. It is hard to find those course in Vietnam. Before taking this, i was afraid of not getting any result. However, Yeah It is.

First, i want to say thank you to the teachers and administrative staffs. They are so nice 🙂 . The teachers are experienced, have strong knowledge. They orginized the class in open, laughing and sharing environment. After a month, all students get acquainted with each other.

Second, the infrastructure, it was not so good however, it was comfortable.

And the third, the materials, always on our hand when we came to the class 🙂

I achieve a lot from the class. It helps me in normal life, the communication with other, the presentation skill, negotiation skill,… It does not take affect immediately, of course. It is like a guiding start when you have problems.

Thank Catglobe for sponsor us!

If you are looking for something similar, i suggest FMIT. Or if you alread took and had bad experience, you can share.