Skip to content

Commit

Permalink
test(2.0.0): check correctness of realisation by reading AsyncAPI exa…
Browse files Browse the repository at this point in the history
…mple - OneOf Example

#187
  • Loading branch information
Pakisan committed Feb 29, 2024
1 parent e113d46 commit 1767c7f
Show file tree
Hide file tree
Showing 2 changed files with 135 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
package com.asyncapi.examples.v2._0_0

import com.asyncapi.v2.Reference
import com.asyncapi.v2._0_0.model.channel.ChannelItem
import com.asyncapi.v2._0_0.model.channel.message.Message
import com.asyncapi.v2._0_0.model.channel.operation.Operation
import com.asyncapi.v2._0_0.model.component.Components
import com.asyncapi.v2._0_0.model.info.Info
import com.asyncapi.v2.schema.Schema

class OneOf: AbstractExampleValidationTest() {

override fun specificationLocation(): String = "/examples/v2.0.0/oneof.yml"

override fun expectedInfo(): Info {
return Info.builder()
.title("OneOf example")
.version("1.0.0")
.build()
}

override fun expectedServers(): Map<String, Any>? = null

override fun expectedChannels(): Map<String, Any> {
return mapOf(
Pair("test", ChannelItem.builder()
.publish(Operation.builder()
.message(Reference("#/components/messages/testMessages"))
.build()
)
.build()
),
Pair("test2", ChannelItem.builder()
.subscribe(Operation.builder()
// TODO: add OneOfMessage to 2.0.0
.message(Message.builder()
.payload(Schema.builder().ref("#/components/schemas/objectWithKey").build())
.build())
.build()
)
.build()
)
)
}

override fun expectedComponents(): Components? {
return Components.builder()
.messages(mapOf(
Pair("testMessages", Message.builder()
.payload(Schema.builder()
.oneOf(listOf(
Schema.builder().ref("#/components/schemas/objectWithKey").build(),
Schema.builder().ref("#/components/schemas/objectWithKey2").build()
))
.build()
)
.build()
),
Pair("testMessage1", Message.builder()
.payload(Schema.builder().ref("#/components/schemas/objectWithKey").build())
.build()
),
Pair("testMessage2", Message.builder()
.payload(Schema.builder().ref("#/components/schemas/objectWithKey2").build())
.build()
)
))
.schemas(mapOf(
Pair("objectWithKey", Schema.builder()
.type("object")
.properties(mapOf(
Pair("key", Schema.builder()
.type("string")
.build()
)
))
.build()
),
Pair("objectWithKey2", Schema.builder()
.type("object")
.properties(mapOf(
Pair("key2", Schema.builder()
.type("string")
.build()
)
))
.build()
)
))
.build()
}

}
42 changes: 42 additions & 0 deletions asyncapi-core/src/test/resources/examples/v2.0.0/oneof.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
asyncapi: "2.0.0"
info:
title: OneOf example
version: '1.0.0'

channels:
test:
publish:
message:
$ref: '#/components/messages/testMessages'

test2:
subscribe:
message:
payload:
$ref: "#/components/schemas/objectWithKey"

components:
messages:
testMessages:
payload:
oneOf: # oneOf in payload schema
- $ref: "#/components/schemas/objectWithKey"
- $ref: "#/components/schemas/objectWithKey2"
testMessage1:
payload:
$ref: "#/components/schemas/objectWithKey"
testMessage2:
payload:
$ref: "#/components/schemas/objectWithKey2"

schemas:
objectWithKey:
type: object
properties:
key:
type: string
objectWithKey2:
type: object
properties:
key2:
type: string

0 comments on commit 1767c7f

Please sign in to comment.