Search in sources :

Example 11 with TopicNameStrategy

use of io.confluent.kafka.serializers.subject.TopicNameStrategy in project kafka-rest by confluentinc.

the class ProduceActionIntegrationTest method produceAvroWithSchemaVersionAndSubjectStrategy.

@Test
public void produceAvroWithSchemaVersionAndSubjectStrategy() throws Exception {
    String clusterId = testEnv.kafkaCluster().getClusterId();
    AvroSchema keySchema = new AvroSchema("{\"type\": \"record\", \"name\": \"MyKey\", \"fields\": [{\"name\": \"foo\", " + "\"type\": \"string\"}]}");
    String keySubject = new TopicNameStrategy().subjectName(TOPIC_NAME, /* isKey= */
    true, keySchema);
    SchemaKey keySchemaKey = testEnv.schemaRegistry().createSchema(keySubject, keySchema);
    AvroSchema valueSchema = new AvroSchema("{\"type\": \"record\", \"name\": \"MyValue\", \"fields\": [{\"name\": \"bar\", " + "\"type\": \"string\"}]}");
    String valueSubject = new TopicNameStrategy().subjectName(TOPIC_NAME, /* isKey= */
    false, valueSchema);
    SchemaKey valueSchemaKey = testEnv.schemaRegistry().createSchema(valueSubject, valueSchema);
    ObjectNode key = new ObjectNode(JsonNodeFactory.instance);
    key.put("foo", "foz");
    ObjectNode value = new ObjectNode(JsonNodeFactory.instance);
    value.put("bar", "baz");
    ProduceRequest request = ProduceRequest.builder().setKey(ProduceRequestData.builder().setSubjectNameStrategy(EnumSubjectNameStrategy.TOPIC_NAME).setSchemaVersion(keySchemaKey.getSchemaVersion()).setData(key).build()).setValue(ProduceRequestData.builder().setSubjectNameStrategy(EnumSubjectNameStrategy.TOPIC_NAME).setSchemaVersion(valueSchemaKey.getSchemaVersion()).setData(value).build()).setOriginalSize(0L).build();
    Response response = testEnv.kafkaRest().target().path("/v3/clusters/" + clusterId + "/topics/" + TOPIC_NAME + "/records").request().accept(MediaType.APPLICATION_JSON).post(Entity.entity(request, MediaType.APPLICATION_JSON));
    assertEquals(Status.OK.getStatusCode(), response.getStatus());
    ProduceResponse actual = readProduceResponse(response);
    ConsumerRecord<Object, Object> produced = testEnv.kafkaCluster().getRecord(TOPIC_NAME, actual.getPartitionId(), actual.getOffset(), testEnv.schemaRegistry().createAvroDeserializer(), testEnv.schemaRegistry().createAvroDeserializer());
    GenericRecord expectedKey = new GenericData.Record(keySchema.rawSchema());
    expectedKey.put("foo", "foz");
    GenericRecord expectedValue = new GenericData.Record(valueSchema.rawSchema());
    expectedValue.put("bar", "baz");
    assertEquals(expectedKey, produced.key());
    assertEquals(expectedValue, produced.value());
}
Also used : Response(javax.ws.rs.core.Response) ErrorResponse(io.confluent.kafkarest.exceptions.v3.ErrorResponse) ProduceResponse(io.confluent.kafkarest.entities.v3.ProduceResponse) AvroSchema(io.confluent.kafka.schemaregistry.avro.AvroSchema) ObjectNode(com.fasterxml.jackson.databind.node.ObjectNode) ProduceRequest(io.confluent.kafkarest.entities.v3.ProduceRequest) ProduceResponse(io.confluent.kafkarest.entities.v3.ProduceResponse) TopicNameStrategy(io.confluent.kafka.serializers.subject.TopicNameStrategy) ConsumerRecord(org.apache.kafka.clients.consumer.ConsumerRecord) GenericRecord(org.apache.avro.generic.GenericRecord) ByteString(com.google.protobuf.ByteString) GenericRecord(org.apache.avro.generic.GenericRecord) SchemaKey(io.confluent.kafkarest.testing.SchemaRegistryFixture.SchemaKey) Test(org.junit.jupiter.api.Test)

Aggregations

TopicNameStrategy (io.confluent.kafka.serializers.subject.TopicNameStrategy)11 Test (org.junit.jupiter.api.Test)11 MockSchemaRegistryClient (io.confluent.kafka.schemaregistry.client.MockSchemaRegistryClient)7 SchemaRegistryClient (io.confluent.kafka.schemaregistry.client.SchemaRegistryClient)7 AvroSchema (io.confluent.kafka.schemaregistry.avro.AvroSchema)5 ObjectNode (com.fasterxml.jackson.databind.node.ObjectNode)4 ByteString (com.google.protobuf.ByteString)4 ParsedSchema (io.confluent.kafka.schemaregistry.ParsedSchema)4 ProduceRequest (io.confluent.kafkarest.entities.v3.ProduceRequest)4 ProduceResponse (io.confluent.kafkarest.entities.v3.ProduceResponse)4 ErrorResponse (io.confluent.kafkarest.exceptions.v3.ErrorResponse)4 RestConstraintViolationException (io.confluent.rest.exceptions.RestConstraintViolationException)4 Response (javax.ws.rs.core.Response)4 Schema (io.confluent.kafka.schemaregistry.client.rest.entities.Schema)3 RegisteredSchema (io.confluent.kafkarest.entities.RegisteredSchema)3 BadRequestException (io.confluent.kafkarest.exceptions.BadRequestException)3 SchemaProvider (io.confluent.kafka.schemaregistry.SchemaProvider)2 AvroSchemaProvider (io.confluent.kafka.schemaregistry.avro.AvroSchemaProvider)2 SchemaMetadata (io.confluent.kafka.schemaregistry.client.SchemaMetadata)2 JsonSchema (io.confluent.kafka.schemaregistry.json.JsonSchema)2