ValidationSpecification<T> Class

Summary

Base implementation of IValidationSpecification<T>.
graph BT Type-->Base0["object"] Type-.->Interface0["IValidationSpecification<T>"] Type-.->Interface1["ISpecification<T>"] Type-.->Interface2["ISpecification"] click Interface2 "/FluentSpecification/api/FluentSpecification.Abstractions/ISpecification" Type["ValidationSpecification<T>"] class Type type-node Derived0["ExpressionSpecification<T>"]-->Type click Derived0 "/FluentSpecification/api/FluentSpecification.Common/ExpressionSpecification_1" Derived1["NegatableValidationSpecification<T>"]-->Type click Derived1 "/FluentSpecification/api/FluentSpecification.Core/NegatableValidationSpecification_1"

Syntax

[PublicAPI]
public abstract class ValidationSpecification<T> : IValidationSpecification<T>, ISpecification<T>, 
    ISpecification

Attributes

Type Description
PublicAPI

Type Parameters

Name Description
T Type of candidate to verify.

Methods

Name Value Summary
CreateFailedMessage(T) string
Gets validation failed message of Specification for candidate content.
CreateResult(T, bool) SpecificationResult
Creates SpecificationResult validation object with:
CreateTraceMessage(T, bool) string
Creates trace message based on overall result and candidate content.
GetParameters() IReadOnlyDictionary<string, object>
Get Specification internal/external parameters, used for candidate verification.
IsSatisfiedBy(T) bool
Checks if Specification is satisfied by candidate object.
IsSatisfiedBy(T, SpecificationResult) bool
Checks if Specification is satisfied by candidate object. Returns validation result no matter is satisfied or not.

Operators

Name Value Summary
implicit operator Func<T, bool>(ValidationSpecification<T>) Func<T, bool>

Extension Methods

Name Value Summary
And<T, TSpecification>() IComplexSpecification<T>
Creates logical AND Specification with newly created TSpecification.
And<T>() ICompositeSpecification<T>
Creates composite Specification proxy for final logical AND Specification.
And<T>(ISpecification<T>) IComplexSpecification<T>
Creates logical AND Specification.
AndNot<T, TSpecification>() IComplexSpecification<T>
Creates logical AND Specification with newly created and negated TSpecification.
AndNot<T>() ICompositeSpecification<T>
Creates composite Specification proxy for final logical AND Specification. Second Specification is negated.
AndNot<T>(ISpecification<T>) IComplexSpecification<T>
Creates logical AND Specification with negated other.
AsComplexSpecification<T>() IComplexSpecification<T>
Converts Specification to complex Specification.
AsExpression<T>() Expression<Func<T, bool>>
Converts Specification to Linq Expression<T>.
AsPredicate<T>() Func<T, bool>
Converts Specification to Func<T, TResult> predicate.
Not<T>() IComplexSpecification<T>
Creates logical NOT Specification.
Or<T, TSpecification>() IComplexSpecification<T>
Creates logical OR Specification with newly created TSpecification.
Or<T>() ICompositeSpecification<T>
Creates composite Specification proxy for final logical OR Specification.
Or<T>(ISpecification<T>) IComplexSpecification<T>
Creates logical OR Specification.
OrNot<T, TSpecification>() IComplexSpecification<T>
Creates logical OR Specification with newly created and negated TSpecification.
OrNot<T>() ICompositeSpecification<T>
Creates composite Specification proxy for final logical OR Specification. Second Specification is negated.
OrNot<T>(ISpecification<T>) IComplexSpecification<T>
Creates logical OR Specification with negated other.
WithMessage<T>(Func<T, IReadOnlyDictionary<string, object>, string>) IComplexSpecification<T>
Creates validation Specification proxy with specific error message factory where not satisfied by.
WithMessage<T>(Func<T, string>) IComplexSpecification<T>
Creates validation Specification proxy with specific error message factory where not satisfied by.
WithMessage<T>(string) IComplexSpecification<T>
Creates validation Specification proxy with specific error message where not satisfied by.
GitHub