Documentation ¶
Overview ¶
Package assert enables defining test properties about your program or workload. It is part of the Antithesis Go SDK, which enables Go applications to integrate with the Antithesis platform.
Code that uses this package should be instrumented with the antithesis-go-generator utility. This step is required for the Always, Sometime, and Reachable methods. It is not required for the Unreachable and AlwaysOrUnreachable methods, but it will improve the experience of using them.
These functions are no-ops with minimal performance overhead when called outside of the Antithesis environment. However, if the environment variable ANTITHESIS_SDK_LOCAL_OUTPUT is set, these functions will log to the file pointed to by that variable using a structured JSON format defined here. This allows you to make use of the Antithesis assertions package in your regular testing, or even in production. In particular, very few assertions frameworks offer a convenient way to define Sometimes assertions, but they can be quite useful even outside Antithesis.
Each function in this package takes a parameter called message, which is a human readable identifier used to aggregate assertions. Antithesis generates one test property per unique message and this test property will be named "<message>" in the triage report.
This test property either passes or fails, which depends upon the evaluation of every assertion that shares its message. Different assertions in different parts of the code should have different message, but the same assertion should always have the same message even if it is moved to a different file.
Each function also takes a parameter called details, which is a key-value map of optional additional information provided by the user to add context for assertion failures. The information that is logged will appear in the triage report, under the details section of the corresponding property. Normally the values passed to details are evaluated at runtime.
Index ¶
- func Always(condition bool, message string, details map[string]any)
- func AlwaysGreaterThan[T Number](left, right T, message string, details map[string]any)
- func AlwaysGreaterThanOrEqualTo[T Number](left, right T, message string, details map[string]any)
- func AlwaysLessThan[T Number](left, right T, message string, details map[string]any)
- func AlwaysLessThanOrEqualTo[T Number](left, right T, message string, details map[string]any)
- func AlwaysOrUnreachable(condition bool, message string, details map[string]any)
- func AlwaysSome(named_bools []NamedBool, message string, details map[string]any)
- func AssertRaw(cond bool, message string, details map[string]any, ...)
- func BooleanGuidanceRaw(named_bools []NamedBool, message, id string, ...)
- func NumericGuidanceRaw[T Number](left, right T, message, id string, classname, funcname, filename string, ...)
- func Reachable(message string, details map[string]any)
- func Sometimes(condition bool, message string, details map[string]any)
- func SometimesAll(named_bools []NamedBool, message string, details map[string]any)
- func SometimesGreaterThan[T Number](left, right T, message string, details map[string]any)
- func SometimesGreaterThanOrEqualTo[T Number](left, right T, message string, details map[string]any)
- func SometimesLessThan[T Number](left, right T, message string, details map[string]any)
- func SometimesLessThanOrEqualTo[T Number](left, right T, message string, details map[string]any)
- func Unreachable(message string, details map[string]any)
- type NamedBool
- type Number
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Always ¶ added in v0.1.15
Always asserts that condition is true every time this function is called, and that it is called at least once. The corresponding test property will be viewable in the Antithesis SDK: Always group of your triage report.
func AlwaysGreaterThan ¶ added in v0.4.0
Equivalent to asserting Always(left > right, message, details). Information about left and right will automatically be added to the details parameter, with keys left and right. If you use this function for assertions that compare numeric quantities, you may help Antithesis find more bugs.
func AlwaysGreaterThanOrEqualTo ¶ added in v0.4.0
Equivalent to asserting Always(left >= right, message, details). Information about left and right will automatically be added to the details parameter, with keys left and right. If you use this function for assertions that compare numeric quantities, you may help Antithesis find more bugs.
func AlwaysLessThan ¶ added in v0.4.0
Equivalent to asserting Always(left < right, message, details). Information about left and right will automatically be added to the details parameter, with keys left and right. If you use this function for assertions that compare numeric quantities, you may help Antithesis find more bugs.
func AlwaysLessThanOrEqualTo ¶ added in v0.4.0
Equivalent to asserting Always(left <= right, message, details). Information about left and right will automatically be added to the details parameter, with keys left and right. If you use this function for assertions that compare numeric quantities, you may help Antithesis find more bugs.
func AlwaysOrUnreachable ¶ added in v0.1.15
AlwaysOrUnreachable asserts that condition is true every time this function is called. The corresponding test property will pass if the assertion is never encountered (unlike Always assertion types). This test property will be viewable in the “Antithesis SDK: Always” group of your triage report.
func AlwaysSome ¶ added in v0.4.0
Asserts that every time this is called, at least one bool in named_bools is true. Equivalent to Always(named_bools[0].second || named_bools[1].second || ..., message, details). If you use this for assertions about the behavior of booleans, you may help Antithesis find more bugs. Information about named_bools will automatically be added to the details parameter, and the keys will be the names of the bools.
func AssertRaw ¶ added in v0.1.18
func AssertRaw(cond bool, message string, details map[string]any, classname, funcname, filename string, line int, hit bool, mustHit bool, assertType string, displayType string, id string, )
AssertRaw is a low-level method designed to be used by third-party frameworks. Regular users of the assert package should not call it.
func BooleanGuidanceRaw ¶ added in v0.4.0
func BooleanGuidanceRaw( named_bools []NamedBool, message, id string, classname, funcname, filename string, line int, behavior string, hit bool, )
BooleanGuidanceRaw is a low-level method designed to be used by third-party frameworks. Regular users of the assert package should not call it.
func NumericGuidanceRaw ¶ added in v0.4.0
func NumericGuidanceRaw[T Number]( left, right T, message, id string, classname, funcname, filename string, line int, behavior string, hit bool, )
NumericGuidanceRaw is a low-level method designed to be used by third-party frameworks. Regular users of the assert package should not call it.
func Reachable ¶ added in v0.1.10
Reachable asserts that a line of code is reached at least once. The corresponding test property will pass if this function is ever called. (If it is never called the test property will therefore fail.) This test property will be viewable in the “Antithesis SDK: Reachablity assertions” group.
func Sometimes ¶ added in v0.1.15
Sometimes asserts that condition is true at least one time that this function was called. (If the assertion is never encountered, the test property will therefore fail.) This test property will be viewable in the “Antithesis SDK: Sometimes” group.
func SometimesAll ¶ added in v0.4.0
Asserts that at least one time this is called, every bool in named_bools is true. Equivalent to Sometimes(named_bools[0].second && named_bools[1].second && ..., message, details). If you use this for assertions about the behavior of booleans, you may help Antithesis find more bugs. Information about named_bools will automatically be added to the details parameter, and the keys will be the names of the bools.
func SometimesGreaterThan ¶ added in v0.4.0
Equivalent to asserting Sometimes(T left > T right, message, details). Information about left and right will automatically be added to the details parameter, with keys left and right. If you use this function for assertions that compare numeric quantities, you may help Antithesis find more bugs.
func SometimesGreaterThanOrEqualTo ¶ added in v0.4.0
Equivalent to asserting Sometimes(T left >= T right, message, details). Information about left and right will automatically be added to the details parameter, with keys left and right. If you use this function for assertions that compare numeric quantities, you may help Antithesis find more bugs.
func SometimesLessThan ¶ added in v0.4.0
Equivalent to asserting Sometimes(T left < T right, message, details). Information about left and right will automatically be added to the details parameter, with keys left and right. If you use this function for assertions that compare numeric quantities, you may help Antithesis find more bugs.
func SometimesLessThanOrEqualTo ¶ added in v0.4.0
Equivalent to asserting Sometimes(T left <= T right, message, details). Information about left and right will automatically be added to the details parameter, with keys left and right. If you use this function for assertions that compare numeric quantities, you may help Antithesis find more bugs.
func Unreachable ¶ added in v0.1.10
Unreachable asserts that a line of code is never reached. The corresponding test property will fail if this function is ever called. (If it is never called the test property will therefore pass.) This test property will be viewable in the “Antithesis SDK: Reachablity assertions” group.
Types ¶
type NamedBool ¶ added in v0.4.0
Used for boolean assertions
func NewNamedBool ¶ added in v0.4.0
Convenience function to construct a NamedBool used for boolean assertions