Software Development

How to Hire a Software Developer

Software engineers and developers are specialists in creating and developing web, mobile, and software applications for devices like computers or mobile devices. This hiring guide offers a set of insightful questions to help you identify amazing software engineers and developers who are experts in their field.
Share

No-Risk Trial, Pay Only If Satisfied.

Share

If you’re a software development team lead or project manager, hiring a new developer can be a hassle. If it doesn’t go well, it can not only cost you time and money, but it can also bring down your existing team’s morale and make some surprise withdrawals on your sanity savings account.

This article gives you a brief survey of some wisdom collected from the perspectives of both sides of the hiring coin. The software developer, your strategies, and perhaps most importantly, how the two fit together—these are the sources to watch.

Before you even start thinking about hiring a software developer, there are a few pitfalls you can already prepare against, which we cover in “The Experience.”

Once your organization is prepared for success with a software developer, we look at some potential “gotchas” you can avoid in the hiring process in “The Developer.”

But the bulk of the advice isn’t so one-sided: It has to do with the dynamic between the software developer and your organization, covered in “However the twain shall meet.”

You need a good team and a good software developer to be successful, but sometimes, it's more about fit than anything.

So consider this list, for the sake of not only the success of your project and your organization, but also you and your hired gun as individual people. Let’s dive in.

The Experience

1. No Useful Trial Period

You and the software developer you hire both benefit from the additional screening of a paid trial period. Make sure they understand that you expect them to dive in just as they would if it were not a trial period, but that you also want to use the time for both of you to understand as much as possible about whether they will ultimately be a good fit. Give meaningful software development work and appropriate support, and keep your instincts active as you monitor their progress.

Along the way and/or at the end, have them evaluate their experience in a blame-free setting. Whether you hire them or not, this will be valuable information for both of you, going forward.

2. Poor Onboarding

The easiest way to get a software developer off on the wrong foot is to throw them into software development blindly, without support. Sometimes, to some extent, you might expect to be able to do this—in which case, it should be made clear before you even interview them. But even then, give as much support as you are able to, because this is an investment that immediately pays off in productivity and morale. (The flip side of this is that if your onboarding is lax enough, even small mistakes can turn into disasters. Even an expert software developer will need some time to get properly oriented to your environment, even if it’s less than what a junior developer would need.)

Give them a good sense of your work culture and expectations. Give an overview of workflows, team responsibilities, boundaries, and so on. Give them enough information and/or mentoring to get them working with the actual code base as soon as possible. Give them all the documentation you have, and where you don’t have it, use their experience as an opportunity to create some.

Even if it's just pasting your Slack chat into the readme for now, having some docs for the next new team member will be better than nothing!

Find low-hanging fruit in your project to get the ball rolling for them. If possible, have someone review their code on these tasks as well–since they’re simple tasks, this should not be an undue burden on your team, but will provide invaluable information about any gaps between the work the software developer is doing and your expectations. It’s much easier to address such things sooner than later, and even with the most extensive instructions, every new hire is likely to need some time to get into the groove of your team and/or code base.

3. Unclear Requirements

The biggest hurdle you can avoid in the software engineering game is undue imprecision. Chances are slim that you will get what you want when you hire software developers if you are not clear about what that is. They are even slimmer if you yourself don’t even know.

A thought bubble with a data tree, turning into a speech bubble with an actual tree from nature, turning into the number three on a platter

So, communicate what you know with as much detail as you can. This helps developers better predict whether they have or can learn the right skills for the job. And make sure you know as much as you can to start with: Interview your main developers to find out what the key technologies and techniques are. Know at what level of detail they will need to work, from tiny code touch-ups to architectural changes. If your key developers left before you hired replacements, maybe some hints can at least be found on their resumes.

This may all seem like a bit of a pain, but it’s definitely worth keeping your stakeholders on the same page.

This is all assuming your candidate is approaching you honestly, which you hope you can assume most of them will be. But, this charitable assumption can sometimes be a pitfall, too, as we’ll find out in the next section…

The Developer

4. Resume Padding or Copying

This one’s not always easy to detect, but a little bit of internet searching can go a long way. If you find another resume out there with the same text, it’s not necessarily your person who is the copycat! There’s a great article about this on the Toptal Blog; particularly, we recommend the section “What if I hire contractors?” The advice there applies equally well to non-freelancer resumes.

Copying entire resumes is not the only problem. Some resume-padders are more subtle than that. Fact-check what you can. Any confirmed resume plagiarism or over-the-top exaggerations (e.g., if they claimed to have written a much higher percentage of a project’s code than they did) should be considered a major red flag at best.

Cartoon of an interview with the candidate saying "I even invented the internet!"

5. Lack of Empathy

It can be a bit difficult to pick up on this in an interview, but a trial period should afford some opportunities to see how well a person relates to coworkers and/or clients.

In fixed software engineering jobs, this might be something that some workplace training could improve, but budgets don’t usually cover that sort of thing for freelance software developers.

Regardless, you’ll want to hire software developers who already have a decent amount of this sort of soft skill. Otherwise, be prepared to spend time helping iron out extra wrinkles in the social dynamics of your organization.

6. Lack of Temet Nosce

“Know yourself” is a pretty important meta-skill for a software developer. Of course, nobody knows everything, and the more you know, the more you know how little you know—so, to some extent, this is not a show-stopper. But a software developer should at least have an inkling of how capable they actually are of accomplishing a given task. (How long it should take is another story altogether.)

If you’re asking them to do something they’ve done before, ask what they would have done differently if they could have done it again. If it’s a new task for them, ask for their approach, and get a second and third opinion on it if it’s too technical for you to comment on yourself. Either way, ask them to “think out loud” as much as possible for this, and pay attention to their thought process. This can be a good way to glean whether a software developer has illusions of grandeur.

Leave open the possibility of a follow-up explanation, though. Software experts are human, too, and it’s natural to be nervous during an interview. Some who would do an excellent job might make some obvious mistakes during an interview, but would be more than comfortable and capable once on the job. That’s where the next pitfall comes in…

However the Twain Shall Meet

7. Ignoring Your Instinct

It’s a well-studied fact that our guts are worth listening to, whether or not there’s something definitive and factual to corroborate with. That’s not to say we shouldn’t analyze our own biases to keep them in check. If you have a strong feeling about a software developer not being a good fit, and this isn’t coming from a stereotype or preconceived notion, then you are doing everyone a favor to take it seriously.

(If you’re looking for some great stories exploring how the mind’s epic brilliance and horrendous failure can both be found in experiences of intuition, you won’t regret checking out Malcolm Gladwell’s book, Blink.)

8. Incompatible Expectations

Make sure you clearly agree on prioritization and other work boundaries, making your assumptions known. If you assume a new hire is on call for software development 24x7, and they assume they have weekends off, there will soon be unnecessary conflicts.

Before you hire a developer, talk it through. Be clear what’s no problem, and what’s a concession; invite this from them, too.

9. Consistently Poor Communication

No act of communication between any two people is ever 100% perfect. That said, if you notice that misunderstandings between your software developer and others on your team (or even just you, at the interview stage) are more common than average, and that they’re not tending to decrease with time, this may be an indicator of a bad match.

"The single biggest problem in communication is the illusion it has taken place." --George Bernard Shaw

In most cases, it’s not a matter of fault, but of fit. If you’re able to address it with them, and they’re adaptable enough, it may improve—but chances are, finding someone who fits your communication style more readily will save you both a lot of headaches over the course of the contract.

10. Shoehorning

It can be tempting to hire software developers who are perfectly wonderful and capable candidates, even if they are terrible matches for the particular context where you need someone. This will likely help neither of you in the end. They would simply fit better elsewhere: maybe in your organization, but maybe not. The pitfall here is assuming that the candidate wants to and will be able to adapt themselves so drastically. It’s possible, but unlikely–so it’s very much worth asking further questions about this to give more opportunity for your instincts to chime in.

11. Excluding Good Generalists

On the flip side of the previous pitfall, this can happen if you obsess too much over finding the perfect candidate. Clear requirements are still important, as mentioned earlier, but insisting on finding someone who has experience in every last specialization, especially nowadays, is pure folly. Sometimes it will make it simply impossible to find anyone. Even if you do find some candidates, though, you may have excluded the best ones from consideration.

A critique of generalists and specialists to help you balance your view of them when considering software development services

Sometimes a good renaissance developer will learn quickly and ultimately do a better job than a seasoned specialist. Not always, but don’t preemptively deprive yourself of a potentially better option.

12. Assuming Money Is the Only Factor

The wily economy, such as it is, sometimes tricks us into equating money with power. There’s some truth to it, of course, but money is definitely not the only factor driving software engineering. Will someone work 5x better for 5x the wage? Maybe, but not likely sustainably, if they also have to work in a toxic environment.

When you hire software developers, what exactly do you expect for your money? And what else do you offer, besides it?

Flexibility can mean a much happier software developer, but others may prefer a set structure. Work culture can make the difference between getting paid to do what you love, and the daily grind from Hell. Organizational values (expressed on numerous levels) can also be significant. After all, not-for-profits sometimes can attract great developers more affordably, because such work can give a greater sense of purpose.

12½. Neglecting to Learn from the Pitfalls Most Applicable to You

We hinted at this in the trial period section, but it also applies beyond that, to ongoing contracts: Provide a safe space and dedicated time for your developers to take a step back, evaluate their experience, and share about it honestly. Do this regularly (even if infrequently) and/or as needed (e.g., following an incident.)

Especially do this whenever someone will be leaving your software engineering team. Exit interviews are your opportunity to get the most candid and valuable feedback possible, provided they know that any criticism they give will not come back to bite them later. This can be one of the best ways to learn which software developer hiring pitfalls dog you and your team the most.

May the Workforce Be with You

Hiring a software developer can be a very effective way to throw money at a problem, but it certainly isn’t foolproof.

Sometimes the experience and environment you provide a developer just isn’t conducive to their productivity, nor to even noticing that anything is amiss. Other times, you’ll need to be on your guard against some undesirable qualities and practices in your potential hire.

Mostly, though, it’s a matter of continuing to hone your managerial instinct while keeping your biases in check. Does the software developer in question honestly fit the role and fit your team? It’s your call.

Hire a Top Software Developer Now

Toptal is a marketplace for top software developers. Top companies and start-ups choose Toptal freelancers for their mission-critical software projects.

See Their Profiles

Other Software Development Tools and Tips

Job Description TemplateInterview QuestionsJobs

Matthew Newman

Freelance Software Developer
United StatesFreelance Software Development Developer at Toptal Since November 8, 2019

Matthew has over 15 years of experience in database management and software development, with a strong focus on full-stack web applications. He specializes in Django and Vue.js with expertise deploying to both server and serverless environments on AWS. He also works with relational databases and large datasets.

Show More

Marcela Kashiwagi Silveira

Freelance Software Developer
United StatesFreelance Software Development Developer at Toptal Since June 20, 2012

Marcela is an experienced web and mobile developer from Brazil currently living in Silicon Valley. She has a very strong understanding of software architecture and also a very strong mathematical background. She was selected by ZDNet as one of ten most influential female tech innovators in Brazil, as well as mentioned on Mashable, Forbes, and others several times.

Show More

Nate Gibson

Freelance Software Developer
United StatesFreelance Software Development Developer at Toptal Since September 13, 2022

Nate is a highly skilled software developer who started his professional career in business intelligence in 2010 after years of programming as a hobby. After graduating in computer science in 2013, he worked primarily in web application development, ERP (NetSuite) customization, and system integrations. Proficient in several languages, frameworks, and tools, Nate also spearheaded, architected, and developed countless projects as a lead developer.

Show More

Marianna Petrovich

Freelance Software Developer
United StatesFreelance Software Development Developer at Toptal Since June 18, 2020

For the past two decades, Marianna has worked as a database developer and a full-stack .NET developer, primarily focusing on databases. Database development is her strongest suit, including tuning, programming, ETL processes, and more. Marianna has worked with well-known corporations such as CBS, Lifetime Television, Elsevier, and Universal Studios. She is looking for projects that deal with new reporting tools and different databases.

Show More

Muhammad Anees Tahir

Freelance Software Developer
GermanyFreelance Software Development Developer at Toptal Since October 14, 2022

Anees is a confident DevOps software engineer and certified AWS developer associate with over seven years of experience in software development. He is proficient in Google Cloud Platform (GCP), AWS, and Azure. He has deployed applications from various domains, such as data engineering, machine learning (ML), and recommendation engines. Anees has a proven ability to develop ETL applications on AWS and build CI/CD pipelines for ML platforms (including observability and scalability of systems).

Show More

Simon Cruise

Freelance Software Developer
United KingdomFreelance Software Development Developer at Toptal Since September 12, 2022

Simon is a software engineer and technical architect with over 20 years of commercial experience working with an enviable list of companies, from Electronic Arts and Sony PlayStation to BBC, Cable, and Wireless. A champion of behavior-driven and test-driven software development processes in an Agile environment, he has led teams and overseen various projects throughout his career. Simon can manage multiple clients as he is adaptable and can quickly fit into a company workflow.

Show More

Erik Arakelyan

Freelance Software Developer
DenmarkFreelance Software Development Developer at Toptal Since April 8, 2022

Erik is an ML researcher currently pursuing a PhD in machine learning at the University of Copenhagen (UCPH), specializing in topics of NLP, Knowledge Graphs optimizations, and explainability in NLP. He is looking for opportunities to apply his deep learning and software engineering skills in an exciting and challenging project.

Show More

Pablo Lopez

Freelance Software Developer
MexicoFreelance Software Development Developer at Toptal Since October 30, 2012

Pablo is a senior software developer with over twenty years of experience writing applications, especially web and back-end applications. He works well in teams, communicates clearly and succinctly, and is always interested in new and engaging challenges.

Show More

Antonio Stepien

Freelance Software Developer
New ZealandFreelance Software Development Developer at Toptal Since November 3, 2020

Antonio's experience is in the areas of embedded systems, firmware, hardware, and software development. He has worked in the automotive, avionic, and defense sectors as a senior software engineer with full hands-on in all software development levels, including performance, functional, integration, system, regression, and user acceptance testing. Antonio is a supportive and passionate team player and a leader dedicated to streamlining processes and efficiently resolving project issues.

Show More

Michael Pi

Freelance Software Developer
United StatesFreelance Software Development Developer at Toptal Since March 10, 2022

Michael is a broadly experienced, results-driven software engineering leader and architect with extensive knowledge in the analysis, design, development, and implementation of software applications across a variety of areas and technologies. Proficient in using various software tools, languages, development methodologies, and patterns, Michel is also skilled at team collaboration and team management.

Show More

Juan Mendoza

Freelance Software Developer
GermanyFreelance Software Development Developer at Toptal Since November 9, 2022

Juan is a self-motivated software engineer and a certified AWS architect. With more than 14 years of experience in software engineering, leading and being part of successful cross-functional teams, Juan loves to work in close collaboration with the product and design teams to achieve the company goals and OKRs.

Show More

Discover More Software Developers in the Toptal Network

Start Hiring
See also:Toptal’s growing, community-driven list of essential Software Development interview questions

Toptal Connects the Top 3% of Freelance Talent All Over The World.

Join the Toptal community.