144: Gary Bernhardt - TypeScript and Testing
Episode
84 min
Read time
2 min
Topics
Software Development, Product & Tech Trends, Crypto & Web3
AI-Generated Summary
Key Takeaways
- ✓Test reduction through types: TypeScript enables a 4:1 production-to-test code ratio compared to typical 1:2 ratios in dynamic languages. The entire React frontend has zero component tests, relying instead on type checking and minimal Cypress smoke tests covering all lessons.
- ✓Runtime validation with IOTs: IOTs library solves TypeScript's type erasure problem by defining schemas that generate both runtime validation and static types from a single definition. This allows untrusted API request data to safely enter the typed system without manual synchronization between validators and types.
- ✓Conditional code placement: Push conditional logic deeper into system layers rather than at API endpoints or controllers. Testing database models directly requires no HTTP request setup and runs orders of magnitude faster, while TypeScript guarantees the wiring between layers works correctly without explicit tests.
- ✓Discriminated unions for state: Use literal types with a "kind" property to model exclusive states. Execute Program defines five user subscription states as literal string unions, ensuring every switch statement handles all cases. Adding a sixth state triggers compile errors at every location requiring updates.
- ✓Structural typing flexibility: TypeScript's structural type system allows union types to combine existing types without modifying source code or introducing artificial base classes. Functions accepting "user or group" unions can be created without touching either original type definition, containing complexity within the function itself.
What It Covers
Gary Bernhardt explains why he rebuilt Execute Program as a full-stack TypeScript application, detailing how static typing reduces test requirements by 80% while maintaining code quality through strategic testing of core logic layers.
Key Questions Answered
- •Test reduction through types: TypeScript enables a 4:1 production-to-test code ratio compared to typical 1:2 ratios in dynamic languages. The entire React frontend has zero component tests, relying instead on type checking and minimal Cypress smoke tests covering all lessons.
- •Runtime validation with IOTs: IOTs library solves TypeScript's type erasure problem by defining schemas that generate both runtime validation and static types from a single definition. This allows untrusted API request data to safely enter the typed system without manual synchronization between validators and types.
- •Conditional code placement: Push conditional logic deeper into system layers rather than at API endpoints or controllers. Testing database models directly requires no HTTP request setup and runs orders of magnitude faster, while TypeScript guarantees the wiring between layers works correctly without explicit tests.
- •Discriminated unions for state: Use literal types with a "kind" property to model exclusive states. Execute Program defines five user subscription states as literal string unions, ensuring every switch statement handles all cases. Adding a sixth state triggers compile errors at every location requiring updates.
- •Structural typing flexibility: TypeScript's structural type system allows union types to combine existing types without modifying source code or introducing artificial base classes. Functions accepting "user or group" unions can be created without touching either original type definition, containing complexity within the function itself.
Notable Moment
Bernhardt reveals that changing a database column type automatically cascades through the entire stack via TypeScript errors, guiding developers from database layer through API handlers to React components. This eliminates the forgotten edge cases that tests cannot anticipate, catching issues no test suite would find.
You just read a 3-minute summary of a 81-minute episode.
Get Full Stack Radio summarized like this every Monday — plus up to 2 more podcasts, free.
Pick Your Podcasts — FreeKeep Reading
More from Full Stack Radio
153: DHH – Omarchy and Designing Your Own OS on Arch Linux
Aug 21 · 76 min
Beyond Biotech
How Eli Lilly's biotech collaboration model is rewriting early-stage innovation
Feb 6
More from Full Stack Radio
152: Ben Orenstein - How to Stand Out When Applying for a Job at a Small Company
Jan 28 · 47 min
Lenny's Podcast
Why LinkedIn is turning PMs into AI-powered "full stack builders” | Tomer Cohen (LinkedIn CPO)
Dec 4
Books, tools, and gear mentioned in this episode
SignalCast may earn commission on purchases via these links.
Tools
- IOTsRecommended
“IOTs library solves TypeScript's type erasure problem by defining schemas that generate both runtime validation and static types from a single definition.”
“The entire React frontend has zero component tests, relying instead on type checking and minimal Cypress smoke tests covering all lessons.”
- CypressRecommended
“The entire React frontend has zero component tests, relying instead on type checking and minimal Cypress smoke tests covering all lessons.”
- TypeScriptRecommended
“Gary Bernhardt explains why he rebuilt Execute Program as a full-stack TypeScript application, detailing how static typing reduces test requirements by 80% while maintaining code quality through strategic testing of core logic layers.”
More from Full Stack Radio
We summarize every new episode. Want them in your inbox?
153: DHH – Omarchy and Designing Your Own OS on Arch Linux
152: Ben Orenstein - How to Stand Out When Applying for a Job at a Small Company
151: DHH – Building HEY with Hotwire
150: Secret Screencasting Tips & Behind the Scenes of Tailwind CSS 2.0
149: Choosing a Payment Processor, Radical Icons & W3C Hype
Similar Episodes
Related episodes from other podcasts
Beyond Biotech
Feb 6
How Eli Lilly's biotech collaboration model is rewriting early-stage innovation
Lenny's Podcast
Dec 4
Why LinkedIn is turning PMs into AI-powered "full stack builders” | Tomer Cohen (LinkedIn CPO)
Odd Lots
Jun 29
Baidu's CFO on How It Became a Full-Stack AI Player
a16z Podcast
Apr 17
The System Behind Self-Driving: Waymo’s Dmitri Dolgov
My First Million
Nov 14
How Alex Hormozi Gets Other People To Build His $100M+ Empire
Explore Related Topics
This podcast is featured in Best Cybersecurity Podcasts (2026) — ranked and reviewed with AI summaries.
Read this week's Software Engineering Podcast Insights — cross-podcast analysis updated weekly.
You're clearly into Full Stack Radio.
Every Monday, we deliver AI summaries of the latest episodes from Full Stack Radio and 192+ other podcasts. Free for one show.
Start My Monday DigestNo credit card · Unsubscribe anytime