data:image/s3,"s3://crabby-images/0fbe0/0fbe0125c89e3edf4fd3f484764935e2e8190203" alt=""
21 Dec
2008
21 Dec
'08
2:34 p.m.
From: Mika Heiskanen
For example, I cannot let my server crash if it cannot fulfill a particular type of request due to a programming error. Instead it should log the error and fail that particular request.
If one invariant fails, this means your program is not reliable anymore (also when processing subsequent requests). Other invariants may become invalid too and any assumptions made during writing of your program may not hold anymore. This means that the program will most probably start behaving in an unexpected way. I think in most cases it is preferred to crash the program than allow it to produce invalid output and, for example, store it in a database.