Book a demo

Technical recruiting is a hot topic nowadays as companies scramble to attract and hire the best engineers.

And while there are a lot of tactics different hiring teams use to try and get the leg up on each other, I’ve found that the most important factor is to get the basic skeleton of your technical interview process down pat.

In the first post of my mini series with Codility, I’ll discuss the four main elements of an effective technical interview process. They are:

  1. The screening interview: An initial phone conversation to ensure both the candidate and hiring manager are happy to proceed. If both parties are happy then the next stage is a technical assessment.
  2. The initial technical assessment: A chance for the candidate to show their skills and abilities. It’s also an opportunity for the hiring team to review the candidate’s solution for style and approach. If the solution meets expectations, the next step is a face-to-face interview.
  3. The face-to-face interview: Another technical challenge and plenty of time for questions.
  4. The decision-making meeting: The final element of an effective interview process. In this meeting the hiring team comes to a consensus of whether to hire the candidate.

So, let’s walk through this process each stage at a time.

The Screening Interview

The screening interview is an initial phone conversation that is a high touch but low investment session. It doesn’t take long to organize and is typically a 30-minute call. It’s a brilliant way for both the candidate and hiring manager to find out more about each other.

I always suggest starting the call with a brief introduction to the role and company. This sets the scene and provides the context for further discussions. The candidate is then given time to ask any questions before moving on to interview questions.

The screening interview works best with a hiring manager and a developer conducting it. This tends to make the interview less daunting for the candidate and they can ask a wider range of questions.

Try a video interview instead of a phone conversation. Being able to see each other can make the call more personal. Be sure to communicate call details to the candidate ahead of time and allow time at the start for getting the conference call connected.

The next stage is a technical assessment for the candidate if everyone is happy to continue.

Person typing on laptop
Technical assessments give candidates a chance to show their skills and abilities.


The Initial Technical Assessment 

Technical assessments are a great way for the candidate to show off their technical skills. They are also a way for the hiring team to assess a candidate’s skills and experience.

The technical assessment should be time bound and completed on the candidate’s own time. By setting a deadline, it gives the candidate a clear delivery expectation. It also helps to keep the technical interview process moving at a fair momentum.

The technical assessment should be relevant to the role and the skill of the candidate. There is little point in setting an advanced challenge for a junior candidate. The challenge should be fun yet challenging. If it’s not fun, there will be less enthusiasm and engagement from the candidate. If it’s not challenging enough, you are unlikely to discover the candidate’s real potential.

Candidates can also choose their own coding language for completing the challenge. However, I do recommend suggesting they complete it in the same core language that your team uses.

Once the coding test is complete and meets expectations, it is time to move to a face-to-face interview.

If the code does not meet expectations, the candidate will receive feedback. Someone from the hiring team will explain what the hiring team was looking for. It’s important to be transparent in the criteria around technical assessments.

Good candidates expect feedback about where they may not have met expectations.

The Face-to-Face Interview

The face-to-face interview is an opportunity for the hiring team to discover more about the candidate and whether they can fulfil the needs of the role.

It’s also an opportunity for the candidate to meet people from the team, understand more about the role, and aspects of culture within the team and organization.

There is very little reason not to complete the face-to-face interview in a single interview. Good candidates won’t like to take multiple days away from work for interviews. The norm now is for single interview sessions. It makes sense to offer the same option.

A good face-to-face interview lasts anywhere between three to four hours. This is an intense interview, but it is over in a single session. With proper care and attention there is no reason why it can’t be an engaging process for all involved.

I recommend splitting the interview into three distinct sections:

  1. The first section should have two people from a management or leadership level. This section is all about the candidate’s team fit, skills and experience. It should be orientated around behavioral interview questions. This section is one hour in duration and focused around what the candidate has done in the past and what they learned from their experience. It’s also a chance to explore the company values and goals with the candidate. The candidate also has the opportunity to ask questions of managers and senior leaders.
  2. The second section is another technical assessment. This time the challenge is a real-time coding test with technical members from the hiring team. I recommend this section being 1.5 hours in duration and run by at least two team members.During this challenge, the candidate must extend their initial solution to the first technical assessment. This simulates a change of requirements and how the candidate copes with extending their own code.There are many reasons for asking candidates to extend their original coding solution. One reason is to understand how they cope with having to change and extend their own code. Another reason is an opportunity for the candidate to ask questions of the technical people in the team.

    A final reason to extend the code is to ensure the candidate wrote the original solution. A very small number of people have submitted code that someone else has written. This was either copied from the internet, or they submitted code a friend had created for them. It doesn’t happen very often and as such is not a primary reason for extending their original code, but it can happen.

    During this technical assessment, the hiring team must discover as much about the candidate’s approach to writing code as they can. It’s important that the candidate writes new code during this section and discusses their implementation with the technical recruiting team. After all, this is what they will be doing as part of their role.

  3. The third and final section of the technical interview is a chance for someone from HR to ask questions. This section focuses on career ambitions, candidate strengths and company fit. This section should be around 20 minutes in length and conducted by at least two people. I recommend a short break between each section as it can be a long and demanding interview. After the interview the candidate has a tour of the office. This is so they can see others at work, get a feel for the environment, and the different aspects of culture within the company.
A group of people having a meeting.
Coding tests ensure a fair and unbiased interview process.


The Decision-Making Meeting

The last stage of the interview process is the decision-making meeting. This is where the interview team comes together to make a decision about hiring the candidate.

Everyone involved in the interview should share their observations and evidence. The evidence from the technical assessment should form part of the discussion, alongside the candidate’s answers to behavioral questions. The discussion should center around evidence and observations to root out biases and opinions. This is also why each interview section should have at least two people present, to ensure a fair and unbiased assessment.

After everyone has aired their evidence and observations, there should be time to discuss anything further. A decision-making process follows this. The goal is to decide whether to hire the candidate based on the presented evidence.

If there is no consensus, then a discussion should be had based around the evidence. People may then change their minds based on the discussions. To avoid influencing based on hierarchy or bias always return to the evidence.

If somebody still does not want to hire the candidate, then my suggestion is not to hire that person. Hiring candidates should be a democratic consensus based on available evidence. No consensus to hire, no hire.

Communicate the decision to the candidate as soon as possible. Do not leave it too long though as good candidates don’t stay on the open market very long.

Closing Thoughts

The technical interview is a two-way process designed to give both the candidate and hiring teams information to make a decision. As such, it’s important to create space for the candidate to ask questions, show off their skills and discuss technical aspects of the role with the hiring team. Equally, the interview is the best opportunity hiring managers have to see code being written and to ask relevant behavioral-based interview questions.

An effective technical interview process can help you to keep the bar high whilst also ensure you hire the best technical talent.

Check out our ebook for more information on the anatomy of great technical recruiting and click here to access part two of my blog series.

Director @ Cultivated Management, Rob loves bringing improved communication and a personal touch to Management and HR teams to improve their effectiveness and to drive greater business value. Rob has managed Dev and HR teams and lead agile transitions. He now helps other companies achieve agility through the blend of HR and Management initiatives. Rob also enjoys spending time with his family, writing books and driving his classic car.

Connect on LinkedIn