2023-12-07 02:36:25 +00:00
|
|
|
package verification
|
|
|
|
|
|
|
|
import "github.com/pkg/errors"
|
|
|
|
|
|
|
|
// ErrMissingVerification indicates that the given verification function was never performed on the value.
|
|
|
|
var ErrMissingVerification = errors.New("verification was not performed for requirement")
|
|
|
|
|
|
|
|
// VerificationMultiError is a custom error that can be used to access individual verification failures.
|
|
|
|
type VerificationMultiError struct {
|
|
|
|
r *results
|
|
|
|
err error
|
|
|
|
}
|
|
|
|
|
|
|
|
// Unwrap is used by errors.Is to unwrap errors.
|
|
|
|
func (ve VerificationMultiError) Unwrap() error {
|
2024-03-08 18:20:38 +00:00
|
|
|
if ve.err == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2023-12-07 02:36:25 +00:00
|
|
|
return ve.err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Error satisfies the standard error interface.
|
|
|
|
func (ve VerificationMultiError) Error() string {
|
2024-03-08 18:20:38 +00:00
|
|
|
if ve.err == nil {
|
|
|
|
return ""
|
|
|
|
}
|
2023-12-07 02:36:25 +00:00
|
|
|
return ve.err.Error()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Failures provides access to map of Requirements->error messages
|
|
|
|
// so that calling code can introspect on what went wrong.
|
|
|
|
func (ve VerificationMultiError) Failures() map[Requirement]error {
|
|
|
|
return ve.r.failures()
|
|
|
|
}
|
|
|
|
|
|
|
|
func newVerificationMultiError(r *results, err error) VerificationMultiError {
|
|
|
|
return VerificationMultiError{r: r, err: err}
|
|
|
|
}
|