So you think you can lead a team?
I’ve been talking and writing a lot about leading a software engineering team in 2025. I started thinking about it more deeply the year before when I decided to give a colleague, who was moving into team leading, some advice:
- 'Doing the work' isn't the only way to add value
- Remember to delegate
- Pick your battles
- Talk to your team every day
Out of this came a talk, “So you think you can lead a team?” which I gave at work, at meetups and at conferences in various different formats during the first quarter of 2025.
Here I am looking at Remember to Delegate and an idea which came out of discussion around the talk, The Triangle of Trust, in more detail.
Delegate
Delegation is a crucial skill for any team lead, yet it is often one of the most challenging aspects of leadership to master. Many leaders, particularly those who have risen through the ranks as individual contributors, struggle to let go of tasks, fearing a loss of control or a dip in quality. However, effective delegation is not just about offloading work; it is about empowering the team, fostering growth, and ensuring long-term success.
Delegation doesn’t always come naturally to software engineers, who are often more accustomed to executing tasks rather than taking on leadership responsibilities. Many engineers are used to being told what to do rather than deciding how work should be distributed. However, failing to delegate creates significant risks: you become the single point of failure, a bottleneck that slows down progress, and the sole repository of critical knowledge. This not only makes you a liability to the team if you are unavailable, but an unwillingness to delegate can lead to excessive workload and stress, ultimately affecting your performance and well-being.
In The One Minute Manager Meets the Monkey, Ken Blanchard introduces a compelling metaphor for tasks: monkeys that live on the backs of team members. When team members bring their monkeys to the leader, these tasks can quickly overwhelm them, leading to stress, burnout, and inefficiency. Blanchard argues that leaders must resist the urge to take on these monkeys themselves and instead ensure that each team member cares for their own responsibilities.
As the team lead your role is to guide the team and coordinate their efforts to achieve one or more specific objectives, usually by creating software to fix one or more specific problems. As a switched on team lead you must also recognise that doing the work isn’t the only way, and often not the best way, for you to add value. So when a task (or a monkey) comes your or your team's way, ask yourself two questions:
- Can I do this?
- Should I do this?
If the answer to “Can I do this?” is no, you have two choices, learn to do it or delegate. If you learn to do it, it may be interesting, but chances are one or more of your team already knows how to do it or, in most cases, it would be better for one of them to learn it and pass on the knowledge to you and the rest of the team.
If the answer to “Can I do this?” is yes, you may feel you can do it better or quicker. However, you should give it to your team and use it as a way of teaching them to do it better. A good team lead is as concerned with the development of their team as they are with the team creating solutions to the problems they are fixing. Part of a team’s responsibility, according to Ken Blanchard, is to keep the team lead happy, so teach them how to do that.
Deciding which engineer to delegate which tasks to can also be challenging. In at least one of my teams I had an engineer who wanted to do everything and in another I had an engineer who was more capable than the others. In both teams I had to consciously remember to assign the tasks to other engineers.
There’s always risk to consider too. It’s important that knowledge is shared. If all the knowledge about a particular area of your system or feature is in one engineer's head and that engineer gets moved to another team, decides to leave (or gets hit by a bus), you lose that knowledge. If you have a team made up of employed engineers and contractors, remember that contractors often move on after a period of time. If the engineer with the knowledge is on holiday when there’s a production issue, it’s going to be harder to fix. Don’t be tempted to always give the tasks for particular parts of your system or feature to the same engineer. Share the knowledge. Of course, if pair programming is part or your process, you’re already sharing knowledge.
Engineer availability and task urgency may also be a factor in who you give tasks to. Planning ahead is great, but urgent tasks and production issues come along from time to time. In my experience engineers usually prefer to finish a task before starting a new one, but remember you can move tasks between engineers, after they’re started, if you need to in order to get the best result.
But what if you want to complete a task? After all that’s why you got into software engineering in the first place! It’s the buzz you get when it works, especially when it’s been challenging or when you see your solution fulfilling a stakeholders needs.While you’re getting comfortable with delegating, give all the tasks to your team. Once comfortable, use your judgement. I find that while I’m looking after my own responsibilities as team lead, it is difficult for me to commit to any but the smallest of development tasks.
On a couple of occasions one or more of my senior engineers have stepped up to take on the majority of my team lead tasks for a few weeks. I still attended stand ups and they discussed most decisions with me on an adhoc basis. This arrangement had two benefits, the engineers had the chance to experience what it was like to be team lead and build some more confidence in themselves and I had the opportunity to get my teeth into some other projects. I used this opportunity to collaborate with other engineers and build some services which could be used across our organisation and not just in my own team. It was good for me to spend time writing code, learning new things and adding value to the organisation in a different way. Delegation can actually help you get the buzz.
Given either answer to “Can I do this?”, the answer to “Should I do this?” will almost always be no. As a team lead you are, mostly, no longer responsible for completing the team’s tasks, but you are accountable for the outcome. The difference between responsibility and accountability can be difficult to understand and get right. Of course it doesn’t help that the lines are sometimes blurred by the necessity to get the task done.
I once had a heated discussion with an engineer of mine. I wanted him to do something a particular way. I’m sorry to say I’d been unable to convince him at a technical level. I’m not proud to admit that I resorted to telling him I was responsible for what he did, so he had to do it my way . My manager, who had been part of the discussion, asked me afterwards why I was telling the engineer I was responsible for his work. He told me I was accountable for any consequences of the work the engineer did, not responsible. The engineer was responsible for his own work. What I was really trying to express was that I wanted the work done a particular way, so that I would have the confidence the code would be easy to maintain and wouldn’t have me explaining to the business why it had blown up in production. Explaining my accountability might have changed how the engineer felt about what I was asking for.
I asked ChatGPT to help me explain the difference between accountability and responsibility and I thought what it told me was really good:
Team Lead: Accountable
A team lead is accountable for the overall success of the team’s deliverables, ensuring that tasks are completed efficiently, on time, and to the required quality standard. This means:
- Ownership of Outcomes: The lead is answerable if something goes wrong, even if they did not perform the task directly.
- Delegation & Oversight: They assign tasks to engineers and ensure alignment with business goals.
- Technical & Strategic Guidance: They help resolve roadblocks, provide mentorship, and facilitate collaboration.
- Stakeholder Communication: They keep management, product teams, and other stakeholders updated on progress and risks.
Engineers: Responsible
Software engineers are responsible for executing the tasks assigned to them. This includes:
Implementing Features: Writing, testing, and debugging code according to requirements.
- Following Best Practices: Adhering to coding standards, security guidelines, and performance considerations.
- Proactive Problem-Solving: Raising concerns if they foresee issues with deadlines, scope, or technical feasibility.
- Collaborating & Learning: Working with peers, participating in code reviews, and continuously improving their skills.
Key Distinction
- Accountability is about ownership of results (Team Lead).
- Responsibility is about execution of tasks (Engineers).
A team lead ensures the right things get done, while engineers do the work to make it happen.
Once I understood responsibility and accountability, I better understood where I fitted into the team and the value I was adding, even when I wasn’t writing code.
It can be difficult to let go and to pass the tasks back to your team. Fortunately, Ken Blanchard has four rules for monkeys (or tasks) to help. The first two are relevant to delegating:
Rule 1: Describe the Monkey: The dialog must not end until appropriate “next moves” have been identified and specified.
Rule 2: Assign the Monkey: All monkeys shall be owned and handled by the lowest organisational level consistent with their welfare.
In summary, make sure the task and its next steps are understood and make sure an engineer is responsible and knows they are responsible for completing the task. If you apply these two rules to each task, all the tasks will be delegated.
Delegation is only effective if you trust your team to complete their tasks to the required standard. But how do you build that trust? Let’s look at that next.
Trust
If a team lead is to be accountable for tasks for which their team is responsible, something else is needed: trust. In my experience trust is easy, until it isn’t.
Establishing and Building Trust
Part way into my second role, and about two years into my professional career, I started building my first team. I assumed the engineers I was interviewing would be as good as their CVs indicated and I took a lot of what they should be able to do for granted. Then they came to the interview and I found they knew very little. So I started sending out questions to candidates to answer before the interview and if they couldn’t explain their answers to me in the first 10 minutes of the interview, I ended it. It was a way I could establish and start to build trust, so that I knew mine and the candidate's time was unlikely to be wasted. After I started sending out the questions in advance, I invited fewer candidates to interview and I only had one interview which I ended early.
More recently I’ve used collaborative programming exercises in interviews to get a feel for how the candidate thinks and works and to build and establish trust. However, there are some situations, such as becoming the new team lead for an existing team, getting a new team member who already works as an engineer in the same organisation or from an existing development partner, where it may not be possible or appropriate to use a programming exercise to build trust. In these situations, and when a newly hired engineer starts, I choose to assume trust. That’s the easy bit. However, from this point on the trust needs to be tested and maintained. That’s where the Triangle of Trust comes in. It helps build and test trust over time.
The Triangle of Trust
Once you have assumed trust it’s time to start building and testing it so that it can be maintained. I have found that there are some good practices to help you do that and two of Ken Blanchard's rules help as well. The practices form something which came out of the talks I gave and I have called the Triangle of Trust:
Talk
In other parts of my ‘So you think you can lead a team?’ series, I’ve written about how important it is to talk to your team. As well as establishing their trust in you, it’s a good way to help build your trust in them. The more we talk to people the more we understand them and this provides opportunities for trust to grow.
It seems most software teams have daily stand up meetings these days. I was first introduced to standup meetings in Extreme Programming Explained by Kent Beck. They are a simple, quick daily meeting where the whole team stands up and each member of the team tells the rest of the team:
- what they did yesterday
- what they’re going to do today
- about any blockers they have
The idea behind holding the meetings standing up is so that they are short, as people don’t usually enjoy standing for long periods.
I started doing standup meetings like this with my team in the early noughties. They’ve evolved over the years and slowly moved online. They’ve got longer as they encompass more activities, such as ticket reviews, demos, planning the daily releases and fun as the team enjoys each other’s company. They’re no longer as Kent Beck originally planned them, for example, only a few of us actually stand up, but they’re still productive and a useful ceremony.
The daily standup meeting fulfils the basis of the fourth rule from The One Minute Manager Meets the Monkey:
Rule 4: Check on the Monkey: Proper follow up means healthier monkeys. Every monkey should have a checkup appointment.
Everybody knows that they’ll need to give an update on their task (or monkey) everyday at the standup. You, as the team lead, have the confidence that the tasks are being progressed and that should help build and maintain trust in your engineers.
Sometimes, when a task is about to be started or part way through, an engineer may need some guidance for trust to be maintained. That’s where the third rule comes in:
Rule 3: Insure the Monkey: Every monkey leaving your presence on the back of one of your people must be covered by one of two insurances:
- Recommend, then act
- Act, then advise.
If you want a task done in a particular way, you have some useful information the engineer may not already have, you’re concerned that the engineer may get stuck or take a less desirable approach, speak to them just before they start the task. Recommend an approach and then let the engineer act on it.
Sometimes you or an engineer might prefer to start a task without guidance. It may be a simple task which doesn’t require guidance or a task that the engineer knows a lot about or has experience in completing previous similar tasks. In this situation the engineer can act without guidance and then advise you if they get stuck or encounter problems. There is a risk here that they may go too far down the wrong path. In my experience this is rarely the case though, especially if the engineers are explaining what they are doing in standup everyday.
Another engineer I know described her standups to me as:
We use the standard Beck stand up. If it needs more than five minutes of discussion the stand up finishes and then the talk continues. We all arrive 5 mins early for banter. As soon as it gets to 9.05 stand up starts - Emma Andrews
This is the same as the way my team does standups, just structured differently, but serving the same purpose. The important thing is to find what works for you and your individual engineers with the tasks you have.
Code
Software Engineers don’t just write code. There is a lot more to the role than that, but code is one of the two things all software engineers produce. Code can be good, bad and lots in between. I’m not going to try to tell you what good code is, as that is very subjective, a large topic and outside the scope here. However, as you’re accountable for the code your engineers are responsible for writing, you need to be happy with their code. This means you need to review it.
There are a lot of ways to review code, pull requests, static analysis, measuring test coverage, pair programming, etc. It’s important to find what works for you. You should have static analysis and measurement of test coverage, as part of continuous integration on every push to your version control system, as a bare minimum. I favour having pull requests (PRs) as well so that I, and/or other members of the team, can review all code before it is merged and goes into production.
How often code is reviewed depends on the task, the code, the engineer, the team lead and other factors. If you’re pair programming, the code is constantly under review. The hard and fast rule is that the code must be reviewed before it is merged. PRs can be created at any point during development and code reviewed as often as necessary. For example, if an engineer is stuck with something, creating and reviewing a PR can be a great way for you and the other engineers to see what the problem is and suggest ways to help. This is an example of Act, then Advise.
As a team lead it’s very tempting to be the PR gatekeeper and insist that you approve all PRs before they are merged. In my experience engineers hate this. Mostly because the team lead can become a bottleneck and the team manages without you when you’re not there. So why do you need to approve every PR when you are there? When working with a new team or a new team member, it’s an acceptable approach. However, you should plan to remove the constraint and allow the team to approve each other’s code when the trust is built.
Show
As well as code, all software engineers produce software. You could argue that the software is a byproduct of the code and software engineers only produce code, however in this context it doesn’t really matter.
You cannot be completely sure that the software solves the problem it is intended to, or works in the way it should from the code alone. Even passing tests cannot give you that assurance. The only way to be sure is to demonstrate the software to other people, preferably to stakeholders such as product owners, but also to the team.
Every day, in our standup, the engineers in our team demonstrate the features they have completed to the team. This includes all the engineers, the product owner, the designer and key stakeholders from other teams. It is not until everyone present has agreed that the feature is doing what it should (or at least, no one believes that it isn't), that it can be released into production. Once the software is released into production, the team lead’s real accountability starts, as putting it in front of real users is the only way to properly judge if it works as expected.
I spoke to my Product Manager about what makes a good demonstration of a feature:
In my experience, a good demo states the problem we're trying to solve. It demonstrates how we're solving it and after the demonstration, the team is aligned and in agreement that we're solving the problem. - Katie McGeehan
Encouraging engineers to demonstrate their work builds ownership and confidence, therefore building and maintaining trust between the engineers, the team, the stakeholders and the team lead.
Combining the three elements of the Triangle of Trust - talk, code, and show - helps build, test, and maintain trust, making delegation easier and helping team leads to sleep better at night.
Finally
In Staff Engineer: Leadership Beyond the Management Track, Will Larson describes a role he calls Right Hand. This made me realise that in at least two of the teams I have led, there has been a Right Hand. Not for an executive, as Will Larson suggests, but for me as a team lead. My teams were made up of a number of senior, mid and junior engineers. In both cases one of the senior engineers stood out from the others. They were someone who I could consult when I wasn’t sure of something, discuss tasks with and trust to delegate to the rest of the team when I wanted them too. Reading about the Right Hand and realising I have had them in my teams, helped me realise how accomplished and comfortable I had become with delegating as, sometimes, it meant I was one level further away from tasks the team is responsible for completing.
Delegation is an essential leadership skill that enables both team growth and long-term success. While it may not come naturally to software engineers, effective delegation is crucial in preventing bottlenecks, reducing stress, and ensuring knowledge is shared across the team. It also creates opportunities for engineers to develop new skills and gain confidence.
However, delegation is only effective when built on a foundation of trust. As a team lead, you are accountable for the outcome of your team’s work, but individual engineers remain responsible for execution. Understanding this distinction is key to balancing oversight and autonomy.
Trust is established and maintained through communication, reviewing code, and demonstrating completed work: the Triangle of Trust. Regular conversations help align expectations, code reviews ensure quality and consistency, and demos provide confidence that solutions meet stakeholder needs. By applying these principles, delegation becomes not just a necessity but a strategic advantage, empowering your team while allowing you to focus on leadership responsibilities.
Mastering delegation and trust is a journey, but getting it right and knowing how, when and who to delegate to makes you a better team lead and helps your team thrive.
Bibliography
So you think you can lead a team?: The Reading List
Thanks
Of course I couldn’t have written this alone. Thank you to:
Emma Andrews
Sam Berrington
Chris Cheshire
Steve Cresswell
Dom Davis
Laurent Douchy
Harvey Gwynn
Gavin Holmes
Alex Leslie
Katie McGeehan
Jon Moore
Het Patel
Nayana Solanki
for your input and reviews.
Comments
Post a Comment