Documentation ¶
Overview ¶
Package validations enriches YAML structures by attaching user-defined constraints (that is, validationRun rules) onto individual yamlmeta.Node's.
Validations on Data Values ¶
While "@data/values" can technically be annotated with "@assert/validate" annotations, it is expected that authors will use "@schema/validationRun" in "@data/values-schema" documents instead.
Index ¶
Constants ¶
const ( AnnotationAssertValidate template.AnnotationName = "assert/validate" KwargWhen string = "when" KwargMinLength string = "min_len" KwargMaxLength string = "max_len" KwargMin string = "min" KwargMax string = "max" KwargNotNull string = "not_null" KwargOneNotNull string = "one_not_null" KwargOneOf string = "one_of" )
Declare @assert/... annotation and keyword argument names
Variables ¶
This section is empty.
Functions ¶
func Add ¶
func Add(node yamlmeta.Node, validations []NodeValidation)
Add appends validations to node's validations metadata, later retrieved via Get().
func ProcessAssertValidateAnns ¶
ProcessAssertValidateAnns checks Assert annotations on data values and stores them on a Node as Validations. Returns an error if any Assert annotations are malformed.
func Set ¶
func Set(node yamlmeta.Node, meta []NodeValidation)
Set attaches validations to node's metadata, later retrieved via Get().
Types ¶
type Check ¶ added in v0.42.0
type Check struct {
Invalidations []Invalidation
}
Check holds the complete set of Invalidations (if any) resulting from checking all validation rules.
func Run ¶
Run takes a root Node, and threadName, and validates each Node in the tree.
When a Node's value is invalid, the errors are collected and returned in a Check. Otherwise, returns empty Check and nil error.
func (Check) HasInvalidations ¶ added in v0.43.0
HasInvalidations indicates whether this Check contains any violations.
func (Check) ResultsAsString ¶ added in v0.43.0
ResultsAsString generates the error message composed of the total set of Check.Invalidations.
type Invalidation ¶ added in v0.43.0
Invalidation describes a value that was invalidated, and how.
type NodeValidation ¶
type NodeValidation struct {
// contains filtered or unexported fields
}
NodeValidation represents a validationRun attached to a Node via an annotation.
func Get ¶
func Get(node yamlmeta.Node) []NodeValidation
Get retrieves validations from node metadata, set previously via Set().
func NewValidationFromAnn ¶ added in v0.42.0
func NewValidationFromAnn(annotation template.NodeAnnotation) (*NodeValidation, error)
NewValidationFromAnn creates a NodeValidation from the values provided in a validationRun-style annotation.
func (NodeValidation) Validate ¶
func (v NodeValidation) Validate(node yamlmeta.Node, parent yamlmeta.Node, root yamlmeta.Node, path string, thread *starlark.Thread) (Invalidation, error)
Validate runs the assertions in the rules with the node's value as arguments IF the ValidationKwargs conditional options pass.
Returns an error if the assertion returns False (not-None), or assert.fail()s. Otherwise, returns nil.