v2.1.0 (2025-04-29)
- Dependency: on Clojars
- Versioning: Break Versioning
This is a major rewrite of Truss that expands the library's scope, and modernises its implementation. There are breaking changes to the ex-data produced by the 4x assertion macros (have, have?, have!, have!?) in Truss and Encore.
This should be a non-breaking update for folks not using assertion ex-data, but please ping me if you run into any unexpected trouble. Apologies for the inconvenience! - Peter Taoussanis 🙏
CHANGES since v1.x
Deprecated assertion API
set-error-fn!andwith-error-fnhave been deprecated. Please use*failed-assertion-handler*instead (see linked docstring for details).get-dataandwith-datahave been deprecated. Please use*ctx*instead.
Changes to assertion ex-data
By default, Truss throws an ex-info exception on assertion failures. The included ex-data has changed!
Old ex-data (Truss v1):
:pred ------ (Unchanged) Predicate form
:arg ------- (Unchanged) {:keys [form value type]}
:dt -------- `js/Error` or `java.util.Date`
:loc ------- {:keys [ns line column]}
:data ------ {:keys [arg dynamic]}
:env ------- {:keys [elidable? *assert*]}
:msg ------- String
:err ------- Error thrown during pred check
New ex-data (Truss v2):
:pred ------ (Unchanged) Predicate form
:arg ------- (Unchanged) {:keys [form value type]}
:inst ------ `js/Error` or `java.time.Instant` (note type change!)
:ns -------- Namespace string
:coords ---- ?[line column]
:data ------ Optional `:data` value (replaces :data/arg)
:truss/ctx - `truss/*ctx*` value (replaces :data/dynamic)
:msg ------- REMOVED (use `ex-message` instead)
:error ----- REMOVED (use `ex-cause` instead)
- You can customise ex-data by modifying
*failed-assertion-handler*. - You can keep the old ex-data by setting the
taoensso.truss.legacy-assertion-ex-dataJVM property totrue.
New since v1.x
-
Significant performance and expansion size improvements to the assertions API (
have,have?,have!,have!?). Esp. useful for ClojureScript codebases that use many assertions. -
Added new contextual exceptions API:
ex-info,ex-info!,*ctx*,set-ctx!,with-ctx,with-ctx+. -
Added new Error utils imported (moved) from Encore:
error?,try*,catching,matching-error,throws,throws?,catching-rf,catching-xform,unexpected-arg!.