top of page
Search


Case Study: Three Years at HoneyBook, From “Soft Consensus” to a Coherent Engineering Culture
There’s a particular kind of joy in seeing seeds you planted years ago take root. Watching an engineering organization grow over the course of several years, and seeing ideas we introduced become part of its everyday rhythm, have been some of the most gratifying parts of my work. This is the story of how a small engagement with HoneyBook evolved into a multi-year partnership that shaped everything from testing to architecture to culture. What began as a simple mission of tech

Shai Yallin
Dec 28, 20256 min read


Acceptance-Testing NestJS Microservices
Acceptance Testing multiple NestJS Microservices by running them a single process communicating via a memory fake.

Shai Yallin
Sep 4, 20245 min read


Using Contract Tests for reliable memory fakes
How to make sure that memory-based fakes really behave like the production implementations they replace

Shai Yallin
Sep 3, 20244 min read


Fast and Furious Acceptance Tests for NestJS applications
Writing memory-based black-box acceptance tests for NestJS apps, testing features rather than implementation details

Shai Yallin
Sep 3, 20246 min read


You Don't Need Kubernetes (Yet)
K8s solves a problem that your new startup probably doesn't face. Invest your resources in finding product-market fit and scale up later.

Shai Yallin
May 27, 20243 min read


Shift-Left and The Pitfalls of Overplanning
PMs make overly detailed plans without dev feedback, resulting in waste. Shorten cycle time by planning briefly then develop and iterate.

Shai Yallin
May 1, 20243 min read


Unit Tests Considered Harmful
Unit tests couple us to implementation detail, restrict refactoring and don't assert that features work. Prefer bigger-scoped tests.

Shai Yallin
Apr 2, 20243 min read


Of Rigid Microservices and Flexible Monoliths
Microservices incur significant overheads in costs of change, runtime and complexity. Start with a monolith and break it down when needed.

Shai Yallin
Mar 18, 20243 min read


Fake, Don't Mock
Fakes are complete implementations of an API used to replace IO-bound adapters with memory-bound doubles to facilitate Acceptance Testing

Shai Yallin
May 2, 20236 min read


Learning Tests: better than benzos
Learning Tests are an easy and useful methodology for integration with new and unknown APIs, reducing stress and improving feedback times.

Shai Yallin
Mar 19, 20233 min read


Chronomatic: my side-project story
How I used React with TypeScript and Firebase to build my own client management system, using TDD and Acceptance Testing.

Shai Yallin
Aug 28, 20226 min read


Beautiful Object Builders in TypeScript
Fixture test data create stale and outdated data, and make tests unreliable. Object Builders are a better way, here's how to use them.

Shai Yallin
Jul 19, 20224 min read


dotenv considered harmful
Relying on .env files couples your codebase to env vars, making your software harder to change. Here's how to decouple them.

Shai Yallin
Jun 21, 20224 min read


The Anatomy Of A Rotten Codebase
Code rots because we build too many features, too fast. Emergent Design is an effective way to fight code rot and make change easier.

Shai Yallin
Apr 5, 20227 min read


Case Study: Versatile CraneView Refactoring
How I helped Versatile remove fear of change in a key subsystem by introducing TDD and refactoring to Hexagonal Architecture.

Shai Yallin
Jan 5, 20229 min read


Your Software as a Kitchen
When there are too many dirty pots and plates in the sink, it's impossible to clean them. It's the same with software and technical debt.

Shai Yallin
Nov 23, 20216 min read


Permanent Prototypes
Prototypes are a lie; when it's good enough for production, it *becomes* production. Here's how to make them easily maintainable.

Shai Yallin
Feb 1, 20216 min read


It's all about the maintenance, dummy
Writing features we might need in the future is not only a waste of time, it makes your software harder to maintain.

Shai Yallin
Dec 16, 20203 min read


Big Design Up-Front or Emergent Design? Hexagonal Architecture Gives Us Both
Hexagonal Architecture allows us to separate pure logic from external constraints and enables writing fast, integrative acceptance tests.

Shai Yallin
Nov 4, 20209 min read
bottom of page


