I HELP TEAMS

Master the Practice
of Software Delivery

On Strong Typing Apr 08, 2024

My first meaningful code was in Modula-2 and then C and C++ in grad school.  

All these were strongly typed languages.  

I remember naming member variables m_iPrice m for member, i for integer, etc. 

That’s when IDEs gave you no support in remembering what was what.

After that, I think I may hav...

Continue Reading...
Is Debugging Teams Similar to Debugging Code? Mar 26, 2024

Engineers are bad at debugging

🙀  

Perhaps that is a bit harsh.

Then again, I have worked with many engineers over the years and only met a few who are good at tracking problems down quickly.

Good debugging seems to come from a mixture of technique and experience.

When I debug code, I consid...

Continue Reading...
Bottlenecks to Breakthroughs Feb 14, 2024

I'm excited to share some news with you.

I'm launching a brand new course called "Bottlenecks to Breakthroughs: Master Effective Software Delivery".

This is a fresh adventure for me, and while I'm super thrilled, I won't lie, there's a bit of butterflies-in-the-stomach feeling too. 🦋

Let me give ...

Continue Reading...
Withdrawals at the bank of tech debt Dec 14, 2023

I'm back for another year of "Advent of Code" challenges! 🌟

If you haven't heard of it, it's a month-long coding frenzy where people tackle a fresh two-part problem every day.

The thrill? Competing against your friends (or peers worldwide) for the speediest solution and bragging rights. 🏁

Now, he...

Continue Reading...
Fostering Autonomy? Dec 13, 2023

If you're aiming for your teams to deliver value rapidly, fostering their autonomy is key.

Consider this: frequent cross-team meetings and decision-making processes can hinder swift progress.

A logical starting point involves examining fundamental constraints:

1️⃣ Team Structure: Defining clear o...

Continue Reading...
You’re Not That Special 🫶 Dec 11, 2023

Ever heard these statements in your team meetings?

➢ “For this project, it makes sense to have a long running branch because…”
➢ “It does not make sense to have automated tests for this code, because…”
➢ “We need to deploy this service manually because…”
➢ “The smallest possible deliverable here will ...

Continue Reading...
Tech investments can pay you back fast. ⚡️ Dec 08, 2023

I upgraded some tooling yesterday, and since it affected the code writing process (very far “left”), I was ~50% faster to getting my code to be good with the new tooling.

Which leaves me wondering why I didn’t do that sooner… 🤯

Happy Friday!!!

Continue Reading...
Rethinking Technical Debt Dec 07, 2023

Technical debt is often likened to a credit card 💳: borrow now, pay back later.

The key notion is that tech debt is something you eventually pay back.

But here's the catch: it's rarely repaid. 😮‍💨

Imagine a poorly managed country endlessly borrowing until bankruptcy.

That's the true nature of te...

Continue Reading...
High Cognitive Load ➡️ Team Crusher Dec 06, 2023

Understanding cognitive load is crucial in software engineering, yet its impact is often neglected .

👉 It starts with mental models 🧠. Does your team have a clear mental model of the systems they're working with? This foundation is essential for effective reasoning and problem-solving.

👉 The lan...

Continue Reading...
♟️ Strategic Procrastination Dec 05, 2023

There is a paradox in planning, where the most crucial decisions often need to be made early when you possess the least amount of information.

👉 “Strategic Procrastination” thus can be a counterintuitive yet effective strategy.

Here's how it can work for you:

1️⃣ Preparation is Key: Begin by mapp...

Continue Reading...
📈 Rethinking Scalability: Beyond Transactions Per Second Dec 04, 2023

In the realm of building scalable systems and architectures, a common focus is often on increasing transactions per second. However, this narrow perspective can occasionally lead us into a corner, especially when other dimensions of scalability demand attention.

Consider this: scalability isn't jus...

Continue Reading...
😜 8 Engineering Workflow Things That Drive Me Crazy Dec 01, 2023

1. “I didn’t have time to write unit tests”
2. Long running feature branches
3. “This was too small/simple to need unit tests”
4. Merge commits
5. “That won’t work because this PR is too big”
6. Sprint-end merge parties 🤬
7. “What’s a rebase?”
8. [merges PR] “It’s done now”

Happy Friday!!!

Continue Reading...