Featured Post

The great debacle of healthcare.gov

This is the first time in history when the president of the United States of America, or probably for any head of state around the world,...

Thursday, December 22, 2011

Software Development Team Management Best Practices

Though management is a skill which is generally considered as a generic skill through which a manager gets the job done by a group of people (though it is preferable to have a team rather than a group of people but I don't want to go into that debate on what makes a group of people "a team" and saving that discussion for future discussion) but there's a subtle (sometime, not so subtle) differences in managing a team to accomplish a software development project compare to a non-software development project in Information Technology.

Sometime what you learn in school of management doesn't always fit to the specific work environment you are in. Here I am summarizing some of the practices that I found very useful, specially, when I applied them in my area of work. You may treat them as best practices or as thumb rules and these would be very helpful if you managed non-software project but would like to have the transition to the software development field or you just have started managing a software development project. 

1. Any issue or questions from the Development team and business users should be documented in some forms of register. Without this there is high chance that you'll loose track of issues and queries and eventually would be dropped off of the final software deliveries - it is a "must have" when you work with geographically distributed team.
2. Always keep the delivery schedule in front of your eyes (literally like hanging the schedule on the wall of your cubicle or office) with minimum information such as the delivery date and/or possibly with the features to be delivered on the targeted date. Again, use the reference number to trace the requirements

3. Always assign number (or ID) to the user requirements and features. You can use any format ranging from word document to excel file or just a text file but each piece of the requirements should be referenced to a number for traceability purpose

4. Make sure you track the changes (it comes as a feature if you use Microsoft Word) of the the requirements and scope of works, or at least track the changes from the base requirements through highlighting the delta. This will reduce the frustration from fishing for a small changes within a large text document more over it will reduce the chance of missing out the subtle changes in requirement and as well as dropping in the actual implementation

5. You should never set priorities of a feature and, even if you have that in your mind, never mention it to users before user expresses their need/want. This is something you don't intercept - keep it with users.You can negotiate with the date later on once user put the date on the table

6. Keep versions of each and everything the team produces - from simple document (e.g. manual, requirement, design artifacts etc.) to the software itself. For documents, keeping the version histories is a must that should include track changes, the summary of changes, who has updated it and when it was updated for each of the version update. For software and software package make sure to give a version number. This will pay you off down the road, could be after few years but it will save you from a potential disaster

7. Never compromises with the IT Security e.g. access management, put control on code review,  loophole in code etc. If you need to compromise it due to a VERY high priority business case, get back to the process soon after that need is met. Otherwise you will put yourself in unnecessary troubles. It also shows your maturity in management

8. When you are talking about deadline with the development team, ask them for the date and negotiate it from their. Try to give them the date developers asked for. Developers take the responsibility of their given deadline. But make sure when you review the status and if they're lagging, never ask them when they can complete it rather, this time, you tell them the date.

9. Measure the completion of tasks numerically. Never take the development status as near completion, almost done, should be done in couple of hours etc. Just ask the the percent of work left

10. Have One-on-One session with all the member of your team. This is very helpful to get to know lot of internals that you otherwise would never get. You should ask at least 3 questions in that meeting - (a) what do you think about your performance and what you could do more; (b) What do you think we should do to improve the team's performance and (c) Open up yourself of anything related or unrelated to work

11. Measure the performance of the team and individuals quantitatively using consistent metrics. Have 360 degree evaluation if feasible

12. Clarify the meaning of any apparently simple word that might have multiple meanings which would have critical or adverse effect on your project deadline. For instance, when a developer tells you that she's going to "reuse" an existing piece of code, don't be shy to ask to explain the word "reuse". This seemingly obvious word caused one of my project to be delayed by five (5) months where the developers meant "copy the code to the new module and modify it for the purpose of the new module" whereas I assumed the literal meaning of that which was "reuse the existing code from the existing module while refactoring the code to meet both modules' need". Sometime the words - "it doesn't work" could have two meanings. One is "it doesn't give out the result as expected" and the other is "it is actually broken or it bombs"

13. Programmers take pride of what they do so don't offend them with your knowledge or or with your idea specially if it's half baked. Brainstorm with the team to come up with solutions and participate with the team not as a boss. The creativity stops sprouting when the boss is in the conference room with an attitude of bossing around. Yes, you've to take the call to stop at a point where the discussion turns into argument (yes that's very common in software development world) but do it without offending one over other

14. This kind of goes against the current stream - Never call the programmers as a "resource". This offends the very nature of humanity (and programmers are human at work). I also have seen where managers call them as "body" like "I need three more bodies for my project". It's very subtle and often the person who you're referring to may not even notice that but eventually it has profound impact on your behavior on how you would treat a member of your team. Treat them as human and I would strongly stand with the fact that the programmers are actually more emotional compare with people of other industries

15. Recognize the excellent performance of individual member of your team. There's a debate on where you should single out a person to reward or recognize and I agree that there's pros and cons of that as it may go against the spirit of team work. But I prefer to recognize a best performer of your team while keeping the team spirit as one of the criteria to select one. It's like mixing of Socialism with Capitalism where you create the sense of common ownership but also reward individuals for their extra mile run that goes beyond the set expectation

16. Remember Newton's first Law of Motion: An object at rest stays at rest and an object in motion stays in motion. Same is true for your team that you manage or lead. If the team is in a habit of failing the deadlines, they would keep it like that until you force it to turn around. So, make sure that every tiny little milestones, deliveries or commitments are met. If you think a deadline won't work, reset it early enough (but don't wait for it to fail). Once your team is in meeting their commitments mode, you can relieve the pressure but keep the monitoring in place so that the hard earned team's state doesn't get rusty

Thursday, August 11, 2011

Sending email from telnet

I did it as a fun by sending email from telnet console. Here are the steps:

1. connect to your mail server
telnet [mail.domain.com] 25

Trying xxx.xxx.xxx.xxx...
Connected to mailserver.domain.com.
Escape character is '^]'.
220 mailserver.domain.com ESMTP

2. Enter from address
mail from: validsender@emailaddress.com

250 sender ok

3. Enter to address
rcpt to: validrecepient@emailaddress.com

250 recipient ok

4. Enter message body text
data [hit enter]

subject: [subject line]
[hit enter twice]

[Type your message]

enter "." at a new line

250 ok: Message 4570431 accepted

5. Quit

Resources:

http://www.yuki-onna.co.uk/email/smtp.html - Send email from Telnet

Saturday, July 2, 2011

Managing a Software Development Team and its process

Managing a Software Development Team is different from Leading a Software Development Team. Here is how I differentiate Managing a Team with Leading a Team -

Leading a Development Team is a full time technical role to provide the team the right direction, best solution and appropriate guidance. This role requires a person with highly knowledgeable and skilled in technologies relevant to the job, and who can lead through example. Also can rolls up his/her sleeves to get to the solution when the team needs it.

Managing a Development Team is a blend of Management and Technical knowledge that provides a person to lead the team technically and orchestrate the team's development activity to achieve efficiency with the means of development process, tools, techniques and best practices. I'll explain the process, tools and techniques with example in the subsequent sections.

Here are the processes, tools and techniques:

1. Review the Requirement Specifications with the Full Team

Process: Team Review -> Feedback
Tools: Meeting; Review Feedback Document

2. Create the Draft Development Detail Plan and publish to the team. Review with the team members to firm up the work effort and Update the Development plan and publish the finalized plan

Process: Individual discussion to vet the work effort
Tools: Development Project Plan

3. Unit Testing

Process: create unit test scenario including regression test cases
Tools: Unit Test Cases documents

4. Peer Review: should review code, any technical specifications, unit test cases and test the functionality. The review should start with a one to one session between the coder and reviewer

Process: One-on-One review session
Tools: Peer Review Feedback Document

5. Sanity checking of deployed code - Have a sanity check list of all the high level functionalities and features that needs to checked before releasing to Testing Team

Process: Test in Development environment and Deployed environment
Tools: Sanity check result

6. Lesson Learned at the end of each Release (Retrospective meeting style discussion in Agile terminology)