NOW AVAILABLE

Learn to write testable, flexible, maintainable code

Ever wonder why your code gets worse instead of better over time? This wiki shows professional software developers the essential software design, architecture, and testing best practices they didn’t teach you in school.

📕 Over 6249 readers so far!
Read the intro

What will you learn?

Here's what's important

✨ Clean Code

Everyone raves about writing clean code, but learning how to write code humans love to work with isn't straightforward. In this chapter, you’ll learn how to write brain-friendly code using human-centered design principles. We also cover coding conventions professional developers use in their everyday work like writing useful comments, organizing & naming things, testing, refactoring, error handling, and so much more.

⚙️ Object-Oriented Programming & Domain Modeling

Ever wondered where to put your business logic? In this chapter, we learn how to use OOP properly to tackle apps of any complexity. We revisit and relearn object-oriented programming; this time, with the sole purpose of using it to create rich domain models that encode and encapsulate complex business rules by structuring it away from frameworks, dependencies, tools & ORMs like Express.js and Sequelize.

🖼️ Design Principles

Design principles are like guardrails for well-crafted code. They help you identify what makes code great, as well as what causes code to devolve into not-so-greatness... Prevent unmaintainable code by learning how to apply essential software design principles. You’ll be able to identify poor design and apply patterns to refactor towards a better one.

📦 Architectural Principles

Do you find yourself changing features in one part of your app only to break a feature in another?

To accomodate change, prevent expensive refactorings, and keep code modular, testable and flexible, we learn how to use Conway’s Law to identify boundaries, enforce em’, and package them as well-defined components.

💿 How to Build a Real-World App with Domain-Driven Design

Sometimes CRUD and Model-View-Controller just isn’t enough. Domain-Driven Design is an approach to software development that helps you translate complex problem domains into rich, expressive, and evolvable software.

You’ll learn the main ideas behind Domain-Driven Design, how companies scale codebases from monoliths to microservices, and how to design and develop a real-world Forum application using DDD.

And so much more 💫

We're learning all the essentials of software design, following the "🖼️ Software Design and Architecture Roadmap", from Clean Code to Domain-Driven Design.

Reader reviews

"I'm in the process of refactoring my backend, and your blog/solidbook has been a godsend. All the concepts are falling into place :)"

Arjun Naha
Software Developer from Wellington College

“I'm really excited about reading this book everyday. Between your book and it's links to the blog posts and @kentcdodds Testing with JavaScript, I feel like I finally have most of the instruction I need for becoming not only a better tester but SE as well. Thanks!"

Eric Bishard
Developer Advocate at Couchbase

“Spent most of my Sunday reading your articles and I found solutions to many, many issues that I've been stuck on for months! Thank you, just got your book :)

Johan de Jager
Software Engineer

"Follow Khalil for great advice on software design and architecture. His roadmap has been so helpful in my growth as a SWE. Clean code, OOP, design patterns, DDD, all best practices that not a lot of tutorials cover. +1 for a fellow 🇨🇦!"

Jeff
Student at the University of Waterloo

“Thanks for publishing this. Between the book and your blog, I've learned a lot.”

Donny
Engineering Lead at Equity Multiple

“Man I gotta say your book is a treasure."

Razhan Hameed
Software Developer

“Khalil’s blog is so good and so is his book! Wealth of knowledge made easy to understand. The post on the Client Architecture was 🤯.

I already know I'm going to refer back to his content time and time again.”

Faraz Ahmad
Software Engineer at Uber Eats

Get the book

Pricing

FOR PROFESSIONAL DEVELOPERS

Wiki & book

$29.99

Over 600 pages. Seriously.

Access to the online, wiki version of the book

PDF + EPUB


Looking for team pricing? What's the size of your team?

About The Author

Hey! I’m Khalil @khalilstemmler.

I’m a writer, developer, musician, and ex-Apollo GraphQL developer advocate currently working on essentialist.dev.

I spent years following my curiosity, trying to master what the experts from over the last 40 years of software design, architecture & testing discovered actually works. It took me around 7 years of reading and synthesizing their books with practice to developed my own practice (called FA^2STR) and a set of principles that guide my work today, which I call "The 12 Essentials".

Ultimately, my mission with essentialist.dev is to help developers master what matters so they can take on new opportunities with confidence. It's a community of developers committed to becoming great at what they do so that they can get more out of their careers and their lives.

What you're looking at here is the wiki I created along that path. It's an ontology, a map, a world that explains all of the major topics (OO, RDD, Design Patterns, Design Principles, software craftsmanship, etc) and how they connect together.

This initial world-building was really important for me - to stick with it and untangle the web of topics to see the bigger picture.

If you're just coming into this space and you'd like to understand (from the bottom up), how everything fits together, solidbook can help you with the first step: clarity.

If you're not familiar with my work, check out my blog. You'll find topics on Domain-Driven Design, Enterprise Node.js, and Client-Side React Architecture.

Frequently asked questions

Why did you write this?

The truth is, not a lot has changed about the fundamentals of software design over the past 20 years, but there's a huge lack of training on it.

I tend to agree with Eric Elliot, who writes excellent content about software composition.

He says, "99% of working developers lack solid training in software design and architecture fundamentals. 3/4 of developers are self-trained, and 1/4 of devs are poorly trained by dysfunctional CS curriculum. And almost zero companies make up for those deficiencies with in-house training and mentorship. In other words, if you simply accept the status quo and refuse to offer training in-house, your team will be the blind leading the blind."

The fact that over $85 billion was spent fixing bad code in 2018, and that massively influential engineering companies like Uber are only now discovering Domain-Driven Design and other essential architectural patterns after 2200+ microservices, is a sign we could do better.

“Those who know not of history are also doomed to repeat their mistakes” (Santayana’s curse).

Software development is a relatively young trade compared to other trades out there. The way we perform our jobs isn't normalized the same way building a house or fixing a car is. Software developers with livelihoods and reputations can't afford to make big mistakes.

Who is this for?

Anyone paid to write software to provide value for a business, and to do it consistently.

Developers who want to learn how to design large-scale applications.

Developers frustrated with writing buggy code and breaking things all the time.

Developers who care about shipping quality code and want to learn how to write code that can actually be tested.

Developers who want to see their codebase actually improve as more code gets added to it, rather than degrade over time.

Junior full-stack developers who are comfortable with JavaScript & Node.js that want to learn how to write clean, flexible, testable, and maintainable software.

Bootcamp graduates who are curious to learn more about backend development.

Team leads, engineering managers, and CTOs who want a single resource to ramp their Junior developers up.

Blog readers interested in Domain-Driven Design.

How can I get future updates?

The wiki is done! But if there are any updates, you'll get an email and can check out the Updates tab in the wiki.

Tell me about the wiki

Books aren’t great mediums. They go out of date and they’re hard to update.

I take all my notes and manage my knowledge in Notion. I wrote a program that takes my Notion and executes a script that converts it to both a book (PDF, EPUB) and the wiki!

Readers who have purchased the book have access to the wiki, which lets you bookmark pages, download new versions, and submit feedback.

Refund policy?

Sorry, we can't offer refunds on this one.

Do you offer Purchasing Power Parity or Student Discounts?

Get in contact with me and I’ll hook you up with a discount.

I already bought the book, how do I download new versions?

Jump over to the wiki and go to the Downloads) page. If you’re not logged in, you can send yourself a login link by entering your email.

How do I access the wiki?

If you’ve bought the book, you can use your login link to read the wiki. If you’re not logged in, you can send yourself a login link by entering your email.

Your site’s not working!

The wiki won’t work properly if you have Third Party Cookies disabled. If you’re using Chrome, you can fix this in chrome://settings/cookies. If you’re experiencing any other issue, let me knowand I’ll fix it.

I have another question!

Hit me up. I’m happy to hear from you.