Heartbeats: Keeping Strategies Alive

comments 2
Growth

One of the key tasks when it comes to leadership of a large team is being able to define and communicate a strategy. When strategies are done well, they are a powerful tool for aligning individuals that are many steps removed from you: they can make decisions that align with the global maxima, without needing your input, by applying the strategic principles you set out.

However, creating a strategy is not a one-and-done thing: you need to continually keep it alive and relevant, else it will be forgotten about.

tl;dr

An example.

Let’s pretend that at the beginning of the year you wrote and communicated one of the best engineering strategies that your company has seen in a long time.

It clearly lays out the goals, the key initiatives, and the metrics that you’ll use to measure success in your department. A read of your strategy shows that it’s clear that the main focus is to build a stable platform, drive up quality, and invest in the long term, and therefore you’re going to invest in a lot of foundational work over the coming year. Nice.

Putting this strategy together was a serious amount of work. You consulted with your team, you talked to your peers, and went through multiple rounds of feedback to sure that everybody felt represented and empowered by what it contained. You made sure that it was indeed a strategy, and not a prescriptive plan: careful attention was paid to making sure that it was a guiding document, and not a list of tasks.

You even tested it against a few hypothetical scenarios to make sure that it was robust: what if you had to cut your budget in half? What if you had to double your team size? What if you had to pivot to a new product area? However, it still made sense: your strategy showed that stability and quality of your platform was the most important thing, and that all of your initiatives were aligned to that goal, no matter what.

Your strategy touches upon four key themes. Here’s what they are:

  1. Stability: You’re going to invest in a lot of foundational work to make sure that your platform is stable and reliable. Notably, this means that you will be better measuring, and scrutinizing, the availability of your key services to 99.99% uptime. This has slipped recently with some high-profile outages.
  2. Quality: The quality of your platform is going to be a key focus. App store ratings have decreased to 3.5 stars in the last year, and you’re going to make sure that they’re back up to 4.5 stars by the end of the year.
  3. Automation: The release cycle of your platform is too slow, and releases are too error-prone. You will dedicate significant engineering resources to improving this.
  4. Skilling up: Although the team has grown significantly in the last year, it is clear that there are too few staff that have the breadth of skills to contribute to the foundational work that you need to do. By careful staffing of your teams, and by investing in training, you will make sure that you have the right skills to deliver on your strategy.

You were particularly proud of the video that you recorded: your talk was pretty rad, if you do say so yourself. You even got a few compliments on your choice of background music.

However, now that it’s been a while since you’ve published it, you’re beginning to wonder whether it made an impact. You didn’t get that many questions about it when it went out. You’d kind of hoped that you’d get a few more comments or questions, given the amount of work that it took to put together.

And get this: it seems some people have forgotten the content already.

For example, just today you were in a meeting where a team was clearly not making infrastructure decisions for the long term: they were considering shipping a new database to production without sufficient load testing. That same mindset caused a major incident last year. You’re pretty sure that if they had read your strategy, they would have known that this was not the right thing to do.

So, you scroll back through your emails. You rewatch the video, and yeah, it’s still engaging.

However, it seems only a small percentage of your team has actually watched it. Less than 20%, in fact.

Hmm.

Why aren’t your engineers reading your emails? And let’s face it: have you ever glossed over that was more than a few paragraphs long because you were busy at the time?

Come on, be honest.

Maybe the problem is you.

The Heartbeat

You need to keep your strategy alive.

Too many good strategies get written once and then forgotten about, collecting digital dust in a document somewhere. Creating and communicating the strategy is only the first step of the work: you also need to show how it’s being used and how it’s relevant to the decisions that are being made.

One way to do this is to create a regular heartbeat for your strategy. The duration of this heartbeat is up to you, but aligning with one of the larger cycles of the year is a good bet: for example, perhaps you could do it quarterly or biannually.

The heartbeat is a communication that looks back at the strategy, recaps the key points, and then shows how it has been implemented in the time since the last heartbeat. It’s a chance to show how the strategy is living and relevant, and that it’s not just a document that was written once and then placed on the shelf.

How you decide to construct your heartbeat is up to you, but here’s an example of what you might include:

  1. Recap: A brief recap of the key themes of the strategy, linking back to the original document. This is a chance to remind people of what the strategy is about, and would cover the four main themes that we discussed earlier. Imagine that you’re writing this for someone who has never seen the strategy before, and you’re trying to get them up to speed.
  2. Progress: A summary of the progress that has been made against the key initiatives. One way of doing this is underneath each of the themes to enumerate the projects that have been completed, including their measurement of succes. For example, under the “Stability” theme, you might list that the project to have multi-region failover has been completed, and this prevented a major outage last month. Lots of links here go a long way: to tickets, dashboards, the product, and design documents.
  3. Impact: A summary of the impact that the strategy has had on the team. For example, in this strategy, you might focus on the overall uptime of the platform, the app store ratings, the release cycle time, and the number of engineers that have been trained in new skills. Ensure this part is data-driven: show the before and after, and make sure that you’re using the metrics that you defined in the strategy.
  4. Staffing: A snapshot of what the staffing looks like right now. For example, if you create charts or tables that show the distribution of seniority, skills, project focus, and so on, you can show how the team is evolving to meet the needs of the strategy, and call out any anomalies and how you plan to address them. For example, you callout that your ratio of backend to frontend engineers is non-optimal, and detail your plans to ramp up hiring in the next quarter.
  5. Changes to the strategy: It’s entirely reasonable to amend your main strategy each heartbeat, if you need to. In fact, it’s an ideal time to do it. Perhaps you’ve learned something new, or the market has changed, or you’ve had a major incident that has caused you to re-evaluate your priorities. This is a chance to show that the strategy is a living document, and that it’s not set in stone. Call out what you’re changing, and why, then update the main document.
  6. Looking forward: Give your audience a brief preview of what you think will be in the next heartbeat. You can describe which projects that are underway that you’re expecting to complete, and what you’re expecting the impact to be. Not only is this exciting, it also holds you and your team accountable to the goals that you’ve set.

Getting It Out There

When it comes to communicating the heartbeat, a written document can form the core communication (you can archive each one as time goes on), but you might also want to record a video, include it in a town hall meeting with live Q&A, or even get individual teams to present their progress as detailed in your update.

The key is to make sure that the heartbeat is seen by as many people as possible, and that it’s clear that the strategy is your collective compass, as evidenced by the progress that you’re making against it.

So even though defining the strategy from scratch is the hardest part, keeping it alive with regular heartbeats is where you bring everyone else along through proof.

It’s a chance to show that the strategy is not just an academic exercise from the leadership canon, but a practical tool that is making a difference to the team. It’s a chance to reflect, to celebrate, and to keep the team aligned.

Give it a go. I guarantee that you’ll see a difference.

Scope? How about we talk about thoroughness instead?

Leave a comment
Growth

Often it isn’t writing code that is the hard part of the job: it’s trying to work out how long it’s going to take to write it. Our companies want to ensure that our engineering salaries are being spent wisely, so it follows that they care about when we expect things to be delivered.

Despite the fact that we have more tools and technologies available to us than ever before, we still struggle to get things done on time. Even the most simple project can throw curveballs when it gets dropped into the middle of an existing system in the real world. As such, we really don’t have a good sense of how long things will take. After all, building software isn’t a mechanical process: it’s a creative one.

This, as you’ve likely experienced, causes a lot of tension with our stakeholders: our customers want to know when they can expect something, our managers want to know when we’ll be done, and we want to know when we can move on to the next thing.

Sometimes it feels like we can spend more time reporting on progress than actually making that progress in the first place. All to satisfy the need for predictability.

Just go faster?

Teams that struggle with estimating and hitting deadlines may have executives or non-technical leaders offering their advice on how to get things done faster. Perhaps you’ve been told to work harder, or smarter, or to just quit messing around and “get it done.” Maybe those that are giving you advice have been absorbing much of the literature that came out of the long boom cycle of the 2010s, where the prevailing wisdom was that the way that start-ups succeeded was by going fasthard, and hacking things together. Blitzscaling, zero to one, and all that.

If you’ve read any of my previous articles, or my books, I always come back to the concept that anything you hear from others should be treated as tools rather than prescriptions. The real world is complex, context-dependent, and what works for you may not work for someone else, and vice versa. This doesn’t make for good soundbites, but it’s the truth. Read around, experiment, and find what works for you.

Speed versus thoroughness

Back to time: everyone wants you to go faster. But what does that actually mean? If we assume that every team is working sustainably hard and is motivated, then the amount of work that can be done in a given time period is fixed. You can’t just “go faster” without sacrificing something else.

The typical answer to the question of what gets sacrificed is “quality.” But what does that mean? Does it mean that you’re shipping bugs? I wouldn’t want a team to release bad work on purpose. Does it mean that you’re not writing tests? Maybe, depending on the context. But fundamentally I don’t think that “quality” is the whole picture: a good engineering team that are worth their salt should have a generally fixed quality bar also. They would find it hard to do purposefully bad work.

Instead, I think that a healthier way to encapsulate speed, scope and quality is thoroughness. Thoroughness is about how much you’re willing to explore the problem domain, how much you’re willing to experiment versus build resilient systems, and how long what you’re going to build is intended to last.

I like the term thoroughness as opposed to scope because, with time, scope has come to mean “what my product manager has said we need to build”, rather than encapsulating the full range of potential engineering work that needs to be done.

I think of thoroughness as the superset of scopescalability, and sustainability:

  • Scope is what you’re building.
  • Scalability is how well it will work as you grow.
  • Sustainability is how well it will work over time.

These three things are in tension with each other and make for a much more nuanced discussion than just “go faster.” Instead, we can have a conversation about what it means to be thorough, and what the trade-offs are around the time to deliver.

Trade offs

The more thorough that a team is in a project, the more time that they will need to spend on it. The right amount of thoroughness should be a conversation across disciplines, stakeholders, and the team.

For example, if you were building a first version of a product at a start-up and trying to see whether you get product-market fit, you might want to aim for low thoroughness and not worry too much about scalability or sustainability right now. After all, if nobody wants your product, then it doesn’t matter how scalable or sustainable it is. However, importantly, you can still have low thoroughness and a rich product scope: it’s the other parts of thoroughness that suffer. You can still build a lot of features, but you wouldn’t want to waste time on work that may get discarded.

The opposite would be true if you were building some critical global banking infrastructure: you’d want to be very thorough in your design and implementation, and you’d definitely want to make sure that it was scalable and sustainable. Even if the feature was a tightly scoped data store, you’d want to make sure that it was built to last and was highly performant and robust.

Depending on your problem domain context, the size of your company, and the maturity of your product, the shape of the curve plotted by speed versus thoroughness may differ. For example, it might be the case that as thoroughness increases, the time to deliver a feature increases linearly (e.g. a to-do list webapp). Or it might be that it increases exponentially (e.g. something simple but not straightforward like Instagram).

With this curve in mind, for a given project, you can have a discussion about where you want to be on the curve that represents acceptability.

Having a think about the effect of thoroughness in your team in general, or on a specific new project, is an interesting discussion to have. It brings another dimension to the typical iron triangle of scope, resources, and time. With thoroughness you can have more productive discussions about what it means to be thorough at this moment in time, and what the trade-offs are around the time to deliver.

For example, the distance between your present state and the desirable level of thoroughness may be a long way. However, if you are able to release to increasing numbers of cohorts of users as you progress on that thoroughness journey, you can get feedback, iterate, and still actually ship. This might work for you and your team getting a new product off the ground.

Or, instead, maybe you need to be highly thorough from the start, and therefore a long build duration before the first release is deemed acceptable with consensus amongst stakeholders achieved up front. This quells the “why is it taking so long?” questions with a constructive answer about the trade-offs that you’re making. This might work for adding a new feature to a mature product whilst maintaining the high quality bar that your customers expect.

There’s no free lunch

If you have a good team, there’s no magical and sustainable way to “just go faster”. And scope very rarely tells the whole story; at least, how we often use that word: it can overindex on a product-centric view of the world.

Instead, champion thoroughness. It’s a more nuanced discussion around scope, scalability, and sustainability, and I think it’s a more productive way for all of us to think about how we are spending our time.

Talk to your team about it:

  • What does thoroughness mean to you?
  • Do you maintain a similar level of thoroughness across all projects, or does it vary?
  • How do you communicate the trade-offs around thoroughness to your stakeholders?
  • How do you know when you’ve been thorough enough? What do you measure?
  • How do you know when you’ve been too thorough?