In Part 1, I outlined some problems with common practices in hiring programmers (or anyone else for that matter). What can the hiring manager do about these problems?
I would start by defining the tasks the position requires as honestly, realistically, and specifically as possible. This isn't as easy as it sounds. For example, many openings that I've seen for programmers require someone who can complete code "on time, within budget, and bug-free". If a company is having trouble finding programmers who meet these requirements, what is the problem? Yes, skill deficiencies in the programmers themselves can cause any or all of these issues. But so can poor requirements, poorly controlled scope creep, poor communication, etc. What exactly is the need?
A better approach might be identifying which aspects of the finished product are most important. A programmer trying to be one of the first to create a game for a new mobile system might be more focused on time and budget than bugs. To contrast, programming for medical devices would require much more focus on creating bug-free software. Along with this, be aware of any road blocks within your company preventing programmers from getting work done. Do the programmers frequently get poor requirements? While improving the requirement gathering and documenting process, I would focus on getting programmers with enough of a business sense to be able to extrapolate missing information from the requirements. Are projects frequently under time pressure? Then finding programmers who can get work done quickly should be a priority.
Once the tasks have been defined, I would then break each of the tasks down into Knowledge, Skills, and Abilities (KSA). For the sake of example, I'll start breaking down a few of the tasks and KSAs needed for a completely hypothetical mid-level ASP.NET developer position. This position might be for a mid-sized company looking to add onto a web application designed to track inventory within a supply chain looking to add a developer to a team that can handle simpler tasks to free up some senior developers to work on other projects.
Tasks:
I would start by defining the tasks the position requires as honestly, realistically, and specifically as possible. This isn't as easy as it sounds. For example, many openings that I've seen for programmers require someone who can complete code "on time, within budget, and bug-free". If a company is having trouble finding programmers who meet these requirements, what is the problem? Yes, skill deficiencies in the programmers themselves can cause any or all of these issues. But so can poor requirements, poorly controlled scope creep, poor communication, etc. What exactly is the need?
A better approach might be identifying which aspects of the finished product are most important. A programmer trying to be one of the first to create a game for a new mobile system might be more focused on time and budget than bugs. To contrast, programming for medical devices would require much more focus on creating bug-free software. Along with this, be aware of any road blocks within your company preventing programmers from getting work done. Do the programmers frequently get poor requirements? While improving the requirement gathering and documenting process, I would focus on getting programmers with enough of a business sense to be able to extrapolate missing information from the requirements. Are projects frequently under time pressure? Then finding programmers who can get work done quickly should be a priority.
Once the tasks have been defined, I would then break each of the tasks down into Knowledge, Skills, and Abilities (KSA). For the sake of example, I'll start breaking down a few of the tasks and KSAs needed for a completely hypothetical mid-level ASP.NET developer position. This position might be for a mid-sized company looking to add onto a web application designed to track inventory within a supply chain looking to add a developer to a team that can handle simpler tasks to free up some senior developers to work on other projects.
Tasks:
- Creates reusable, maintainable, reliable components in C#
- Tracks down bugs with little assistance from more experienced developers
- Integrates third-party components into web applications
Task 1 could be broken down into the following KSAs:
- Working knowledge of Object-Oriented Programming concepts
- Experience creating effective unit tests
- Makes intelligent decisions as to when a component should be broken down into sub-components
Task 2 could be broken down into the following KSAs:
- Can read and understand code in C#
- Can read and understand documentation
- Can refactor poorly written code into more usable/readable components
- Can write unit tests to reduce the amount of time testing through the user interface
Task 3 could similarly be broken down into the following KSAs:
- Can read and understand third-party documentation
- Can integrate third-party code into a larger application as seamlessly as possible
- Can anticipate problems with third-party components and comes up with reasonable work-around solutions
A real KSA breakdown would include many more tasks and KSAs, but hopefully you get the idea. Now that the needed KSAs have been identified, it is time to identify the important ones. Reading and understanding C# and documentation are common KSAs, as is seeing how small pieces fit into a whole, and writing effective unit tests. Not found is the need for keeping up with the latest technologies or understanding large-scale structural issues. (Keep in mind this is a hypothetical position - these skills may be needed in other ASP.NET positions depending on the company.)
With this information, you can design questions for interviews. Since we need to identify people with an understanding of creating reusable, maintainable components, here are some questions that we might ask:
- If you are asked to fix a method that has a return type of an object and returns a due date if the user is valid and 'false' if not, how would you go about doing so?
- If you have some functionality in one of your classes that is needed by another, what is the best way to move that functionality to the new class?
- If you are using a third-party library to send information from several different ASP.NET pages to a third-party store, where do you put the logic?
These questions are all specific and are all targeted to certain tasks I would need the interviewee to perform. I have my ideal answers for each and can evaluate the interviewee consistently. It is important to ask several questions that get to the same point because of the possibility of miscommunication or misinterpretation on either side.
It is also important to evaluate employees by watching them do work that is representative of the job they would be hired for. I might run into someone who can talk about different technologies or approaches fairly well, but when they get to doing the job, they fall short. I would take a similar approach to designing the test as I would designing questions; I would identify important KSAs and create tasks that would require them. Taking this one step further, I also like to break down my tasks into three categories: tasks that every person ought to be able to do, tasks that require skills that are "nice to have", and tasks that I don't expect the candidate to complete. This way I can get a deeper sense of the understanding a candidate has for particular skills. A candidate who can complete some of the tasks in the last category will have an advantage over those who don't.
Finally, you may be wondering about how to determine cultural fit. Unfortunately, cultural fit is tough to pin down and therefore it is difficult to create good questions to get at it. To make it even tougher, many of the questions that could be asked to ascertain cultural fit open the door to discrimination lawsuits. I don't have any good ideas here. If anyone has any ideas, please feel free to leave a comment. I'm certainly open to ideas.