Skip to main content
Full Stack Radio

144: Gary Bernhardt - TypeScript and Testing

84 min episode · 2 min read
·

Episode

84 min

Read time

2 min

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.

Know someone who'd find this useful?

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 — Free

Keep Reading

More from Full Stack Radio

We summarize every new episode. Want them in your inbox?

Similar Episodes

Related episodes from other podcasts

This podcast is featured in Best Cybersecurity Podcasts (2026) — ranked and reviewed with AI summaries.

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 up to 3 shows.

Start My Monday Digest

No credit card · Unsubscribe anytime