in.specmatic.core.ScenarioInfo.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
import `in`.specmatic.conversions.ApiSpecification
import `in`.specmatic.core.pattern.*
import `in`.specmatic.core.value.Value
data class ScenarioInfo(
val scenarioName: String = "",
val httpRequestPattern: HttpRequestPattern = HttpRequestPattern(),
val httpResponsePattern: HttpResponsePattern = HttpResponsePattern(),
val expectedServerState: Map = emptyMap(),
val patterns: Map = emptyMap(),
val fixtures: Map = emptyMap(),
val examples: List = emptyList(),
val ignoreFailure: Boolean = false,
val references: Map = emptyMap(),
val bindings: Map = emptyMap(),
val isGherkinScenario: Boolean = false,
val sourceProvider:String? = null,
val sourceRepository:String? = null,
val sourceRepositoryBranch:String? = null,
val specification:String? = null,
val serviceType:String? = null
) {
fun matchesSignature(other: ScenarioInfo) = httpRequestPattern.matchesSignature(other.httpRequestPattern) &&
httpResponsePattern.status == other.httpResponsePattern.status
fun matchesGherkinWrapperPath(scenarioInfos: List, apiSpecification: ApiSpecification): List =
scenarioInfos.filter { openApiScenarioInfo ->
val pathPatternFromOpenApi = openApiScenarioInfo.httpRequestPattern.httpPathPattern!!.pathSegmentPatterns
val pathPatternFromWrapper = this.httpRequestPattern.httpPathPattern!!.pathSegmentPatterns
if(pathPatternFromOpenApi.size != pathPatternFromWrapper.size)
return@filter false
val resolver = Resolver(newPatterns = openApiScenarioInfo.patterns)
val zipped = pathPatternFromOpenApi.zip(pathPatternFromWrapper)
zipped.all { (openapiURLPart: URLPathSegmentPattern, wrapperURLPart: URLPathSegmentPattern) ->
val openapiType = if(openapiURLPart.pattern is ExactValuePattern) "exact" else "pattern"
val wrapperType = if(wrapperURLPart.pattern is ExactValuePattern) "exact" else "pattern"
when(Pair(openapiType, wrapperType)) {
Pair("exact", "exact") -> apiSpecification.exactValuePatternsAreEqual(openapiURLPart, wrapperURLPart)
Pair("exact", "pattern") -> false
Pair("pattern", "exact") -> {
try {
apiSpecification.patternMatchesExact(
wrapperURLPart,
openapiURLPart,
resolver
)
} catch(e: Throwable) {
false
}
}
Pair("pattern", "pattern") -> {
val valueFromOpenapi = openapiURLPart.pattern.generate(Resolver(newPatterns = openApiScenarioInfo.patterns))
val valueFromWrapper = wrapperURLPart.pattern.generate(Resolver(newPatterns = this.patterns))
valueFromOpenapi.javaClass == valueFromWrapper.javaClass
}
else -> false
}
}
}
}