in.specmatic.core.pattern.ExactValuePattern.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of specmatic-core Show documentation
Show all versions of specmatic-core Show documentation
Turn your contracts into executable specifications. Contract Driven Development - Collaboratively Design & Independently Deploy MicroServices & MicroFrontends.
Deprecation Notice for group ID "in.specmatic"
******************************************************************************************************
Updates for "specmatic-core" will no longer be available under the deprecated group ID "in.specmatic".
Please update your dependencies to use the new group ID "io.specmatic".
******************************************************************************************************
package `in`.specmatic.core.pattern
import `in`.specmatic.core.Resolver
import `in`.specmatic.core.Result
import `in`.specmatic.core.mismatchResult
import `in`.specmatic.core.value.Value
data class ExactValuePattern(override val pattern: Value, override val typeAlias: String? = null) : Pattern {
override fun matches(sampleData: Value?, resolver: Resolver): Result {
return when (pattern == sampleData) {
true -> Result.Success()
else -> mismatchResult(pattern, sampleData, resolver.mismatchMessages)
}
}
override fun encompasses(otherPattern: Pattern, thisResolver: Resolver, otherResolver: Resolver, typeStack: TypeStack): Result {
if(otherPattern !is ExactValuePattern || this.pattern != otherPattern.pattern)
return Result.Failure("Expected ${this.typeName}, got ${otherPattern.typeName}")
return Result.Success()
}
override fun fitsWithin(otherPatterns: List, thisResolver: Resolver, otherResolver: Resolver, typeStack: TypeStack): Result {
val results = otherPatterns.map { it.matches(pattern, otherResolver) }
return results.find { it is Result.Success } ?: results.firstOrNull() ?: Result.Failure("No matching patterns.")
}
override fun listOf(valueList: List, resolver: Resolver): Value {
return pattern.listOf(valueList)
}
override fun generate(resolver: Resolver) = pattern
override fun newBasedOn(row: Row, resolver: Resolver): Sequence = sequenceOf(this)
override fun newBasedOn(resolver: Resolver): Sequence = sequenceOf(this)
override fun negativeBasedOn(row: Row, resolver: Resolver): Sequence> {
val nullPattern: ReturnValue = HasValue(NullPattern)
return sequenceOf(nullPattern).plus(pattern.type().negativeBasedOn(Row(), resolver).filterValueIsNot { it == NullPattern })
}
override fun parse(value: String, resolver: Resolver): Value = pattern.type().parse(value, resolver)
override val typeName: String = pattern.displayableValue()
override fun toString(): String = pattern.toStringLiteral()
}