-
Notifications
You must be signed in to change notification settings - Fork 2.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add dependency removal notice for Kafka Serde provided by vert.x kafk…
…a client
- Loading branch information
1 parent
0cc407b
commit b7cfbea
Showing
18 changed files
with
459 additions
and
0 deletions.
There are no files selected for viewing
20 changes: 20 additions & 0 deletions
20
...lient/runtime/src/main/java/io/quarkus/kafka/client/serialization/BufferDeserializer.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import org.apache.kafka.common.serialization.Deserializer; | ||
|
||
import io.vertx.core.buffer.Buffer; | ||
|
||
/** | ||
* Kafka deserializer for raw bytes in a buffer | ||
*/ | ||
public class BufferDeserializer implements Deserializer<Buffer> { | ||
|
||
@Override | ||
public Buffer deserialize(String topic, byte[] data) { | ||
if (data == null) | ||
return null; | ||
|
||
return Buffer.buffer(data); | ||
} | ||
|
||
} |
13 changes: 13 additions & 0 deletions
13
...kafka-client/runtime/src/main/java/io/quarkus/kafka/client/serialization/BufferSerde.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import org.apache.kafka.common.serialization.Serdes; | ||
|
||
import io.vertx.core.buffer.Buffer; | ||
|
||
public final class BufferSerde extends Serdes.WrapperSerde<Buffer> { | ||
|
||
public BufferSerde() { | ||
super(new BufferSerializer(), new BufferDeserializer()); | ||
} | ||
|
||
} |
19 changes: 19 additions & 0 deletions
19
...-client/runtime/src/main/java/io/quarkus/kafka/client/serialization/BufferSerializer.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import org.apache.kafka.common.serialization.Serializer; | ||
|
||
import io.vertx.core.buffer.Buffer; | ||
|
||
/** | ||
* Kafka serializer for raw bytes in a buffer | ||
*/ | ||
public class BufferSerializer implements Serializer<Buffer> { | ||
|
||
@Override | ||
public byte[] serialize(String topic, Buffer data) { | ||
if (data == null) | ||
return null; | ||
|
||
return data.getBytes(); | ||
} | ||
} |
21 changes: 21 additions & 0 deletions
21
...nt/runtime/src/main/java/io/quarkus/kafka/client/serialization/JsonArrayDeserializer.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import org.apache.kafka.common.serialization.Deserializer; | ||
|
||
import io.vertx.core.buffer.Buffer; | ||
import io.vertx.core.json.JsonArray; | ||
|
||
/** | ||
* Kafka deserializer for raw bytes in a buffer | ||
*/ | ||
public class JsonArrayDeserializer implements Deserializer<JsonArray> { | ||
|
||
@Override | ||
public JsonArray deserialize(String topic, byte[] data) { | ||
if (data == null) | ||
return null; | ||
|
||
return Buffer.buffer(data).toJsonArray(); | ||
} | ||
|
||
} |
11 changes: 11 additions & 0 deletions
11
...ka-client/runtime/src/main/java/io/quarkus/kafka/client/serialization/JsonArraySerde.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import org.apache.kafka.common.serialization.Serdes; | ||
|
||
import io.vertx.core.json.JsonArray; | ||
|
||
public final class JsonArraySerde extends Serdes.WrapperSerde<JsonArray> { | ||
public JsonArraySerde() { | ||
super(new JsonArraySerializer(), new JsonArrayDeserializer()); | ||
} | ||
} |
20 changes: 20 additions & 0 deletions
20
...ient/runtime/src/main/java/io/quarkus/kafka/client/serialization/JsonArraySerializer.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import org.apache.kafka.common.serialization.Serializer; | ||
|
||
import io.vertx.core.json.JsonArray; | ||
|
||
/** | ||
* Kafka serializer for raw bytes in a buffer | ||
*/ | ||
public class JsonArraySerializer implements Serializer<JsonArray> { | ||
|
||
@Override | ||
public byte[] serialize(String topic, JsonArray data) { | ||
if (data == null) | ||
return null; | ||
|
||
return data.encode().getBytes(); | ||
} | ||
|
||
} |
21 changes: 21 additions & 0 deletions
21
...t/runtime/src/main/java/io/quarkus/kafka/client/serialization/JsonObjectDeserializer.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import org.apache.kafka.common.serialization.Deserializer; | ||
|
||
import io.vertx.core.buffer.Buffer; | ||
import io.vertx.core.json.JsonObject; | ||
|
||
/** | ||
* Kafka deserializer for raw bytes in a buffer | ||
*/ | ||
public class JsonObjectDeserializer implements Deserializer<JsonObject> { | ||
|
||
@Override | ||
public JsonObject deserialize(String topic, byte[] data) { | ||
if (data == null) | ||
return null; | ||
|
||
return Buffer.buffer(data).toJsonObject(); | ||
} | ||
|
||
} |
11 changes: 11 additions & 0 deletions
11
...a-client/runtime/src/main/java/io/quarkus/kafka/client/serialization/JsonObjectSerde.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import org.apache.kafka.common.serialization.Serdes; | ||
|
||
import io.vertx.core.json.JsonObject; | ||
|
||
public final class JsonObjectSerde extends Serdes.WrapperSerde<JsonObject> { | ||
public JsonObjectSerde() { | ||
super(new JsonObjectSerializer(), new JsonObjectDeserializer()); | ||
} | ||
} |
20 changes: 20 additions & 0 deletions
20
...ent/runtime/src/main/java/io/quarkus/kafka/client/serialization/JsonObjectSerializer.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import org.apache.kafka.common.serialization.Serializer; | ||
|
||
import io.vertx.core.json.JsonObject; | ||
|
||
/** | ||
* Kafka serializer for raw bytes in a buffer | ||
*/ | ||
public class JsonObjectSerializer implements Serializer<JsonObject> { | ||
|
||
@Override | ||
public byte[] serialize(String topic, JsonObject data) { | ||
if (data == null) | ||
return null; | ||
|
||
return data.encode().getBytes(); | ||
} | ||
|
||
} |
32 changes: 32 additions & 0 deletions
32
...t/runtime/src/test/java/io/quarkus/kafka/client/serialization/BufferDeserializerTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertEquals; | ||
import static org.junit.jupiter.api.Assertions.assertNull; | ||
|
||
import org.junit.jupiter.api.Test; | ||
|
||
import io.vertx.core.buffer.Buffer; | ||
|
||
public class BufferDeserializerTest { | ||
|
||
@Test | ||
void shouldDeserializeEntity() { | ||
BufferDeserializer deserializer = new BufferDeserializer(); | ||
Buffer actual = deserializer.deserialize("topic", "some-bytes".getBytes()); | ||
assertEquals(Buffer.buffer("some-bytes"), actual); | ||
} | ||
|
||
@Test | ||
void shouldDeserializeNullAsNullString() { | ||
BufferDeserializer deserializer = new BufferDeserializer(); | ||
Buffer actual = deserializer.deserialize("topic", "null".getBytes()); | ||
assertEquals(Buffer.buffer("null"), actual); | ||
} | ||
|
||
@Test | ||
void shouldDeserializeNullAsNull() { | ||
BufferDeserializer deserializer = new BufferDeserializer(); | ||
Buffer actual = deserializer.deserialize("topic", null); | ||
assertNull(actual); | ||
} | ||
} |
24 changes: 24 additions & 0 deletions
24
...ent/runtime/src/test/java/io/quarkus/kafka/client/serialization/BufferSerializerTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertNotNull; | ||
import static org.junit.jupiter.api.Assertions.assertNull; | ||
|
||
import org.junit.jupiter.api.Test; | ||
|
||
import io.vertx.core.buffer.Buffer; | ||
|
||
public class BufferSerializerTest { | ||
@Test | ||
void shouldSerializeEntity() { | ||
BufferSerializer serializer = new BufferSerializer(); | ||
byte[] actual = serializer.serialize("topic", Buffer.buffer("some-bytes")); | ||
assertNotNull(actual); | ||
} | ||
|
||
@Test | ||
void shouldSerializeNullAsNull() { | ||
BufferSerializer serializer = new BufferSerializer(); | ||
byte[] result = serializer.serialize("topic", null); | ||
assertNull(result); | ||
} | ||
} |
44 changes: 44 additions & 0 deletions
44
...untime/src/test/java/io/quarkus/kafka/client/serialization/JsonArrayDeserializerTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertEquals; | ||
import static org.junit.jupiter.api.Assertions.assertNotNull; | ||
import static org.junit.jupiter.api.Assertions.assertNull; | ||
import static org.junit.jupiter.api.Assertions.assertThrows; | ||
|
||
import java.util.List; | ||
import java.util.Map; | ||
|
||
import org.junit.jupiter.api.Test; | ||
|
||
import io.vertx.core.json.DecodeException; | ||
import io.vertx.core.json.JsonArray; | ||
|
||
public class JsonArrayDeserializerTest { | ||
@Test | ||
void shouldDeserializeEntity() { | ||
JsonArray expected = new JsonArray(List.of( | ||
Map.of("id", 1, "name", "entity1"), | ||
Map.of("id", 2, "name", "entity2"))); | ||
JsonArrayDeserializer deserializer = new JsonArrayDeserializer(); | ||
String actualString = "[" + | ||
"{\"id\":1,\"name\":\"entity1\"}," + | ||
"{\"id\":2,\"name\":\"entity2\"}" + | ||
"]"; | ||
JsonArray actual = deserializer.deserialize("topic", actualString.getBytes()); | ||
assertNotNull(actual); | ||
assertEquals(expected, actual); | ||
} | ||
|
||
@Test | ||
void shouldThrowDecodeExceptionOnDeserializeNull() { | ||
JsonArrayDeserializer deserializer = new JsonArrayDeserializer(); | ||
assertThrows(DecodeException.class, () -> deserializer.deserialize("topic", "null".getBytes())); | ||
} | ||
|
||
@Test | ||
void shouldDeserializeNullAsNull() { | ||
JsonArrayDeserializer deserializer = new JsonArrayDeserializer(); | ||
JsonArray actual = deserializer.deserialize("topic", null); | ||
assertNull(actual); | ||
} | ||
} |
35 changes: 35 additions & 0 deletions
35
.../runtime/src/test/java/io/quarkus/kafka/client/serialization/JsonArraySerializerTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import static org.assertj.core.api.Assertions.assertThat; | ||
import static org.junit.jupiter.api.Assertions.assertNotNull; | ||
import static org.junit.jupiter.api.Assertions.assertNull; | ||
|
||
import java.util.List; | ||
import java.util.Map; | ||
|
||
import org.junit.jupiter.api.Test; | ||
|
||
import io.vertx.core.json.JsonArray; | ||
|
||
public class JsonArraySerializerTest { | ||
|
||
@Test | ||
void shouldSerializeEntity() { | ||
JsonArraySerializer serializer = new JsonArraySerializer(); | ||
byte[] result = serializer.serialize("topic", new JsonArray(List.of( | ||
Map.of("id", 1, "name", "entity1"), | ||
Map.of("id", 2, "name", "entity2")))); | ||
assertNotNull(result); | ||
String actual = new String(result); | ||
assertThat(actual) | ||
.contains("\"id\"").contains("\"name\"").contains("\"entity1\"").contains("1") | ||
.contains("\"entity2\"").contains("2"); | ||
} | ||
|
||
@Test | ||
void shouldSerializeNullAsNull() { | ||
JsonArraySerializer serializer = new JsonArraySerializer(); | ||
byte[] result = serializer.serialize("topic", null); | ||
assertNull(result); | ||
} | ||
} |
38 changes: 38 additions & 0 deletions
38
...ntime/src/test/java/io/quarkus/kafka/client/serialization/JsonObjectDeserializerTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertEquals; | ||
import static org.junit.jupiter.api.Assertions.assertNotNull; | ||
import static org.junit.jupiter.api.Assertions.assertNull; | ||
import static org.junit.jupiter.api.Assertions.assertThrows; | ||
|
||
import java.util.Map; | ||
|
||
import org.junit.jupiter.api.Test; | ||
|
||
import io.vertx.core.json.DecodeException; | ||
import io.vertx.core.json.JsonObject; | ||
|
||
public class JsonObjectDeserializerTest { | ||
|
||
@Test | ||
void shouldDeserializeEntity() { | ||
JsonObject expected = new JsonObject(Map.of("id", 1, "name", "entity1")); | ||
JsonObjectDeserializer deserializer = new JsonObjectDeserializer(); | ||
JsonObject actual = deserializer.deserialize("topic", "{\"id\":1,\"name\":\"entity1\"}".getBytes()); | ||
assertNotNull(actual); | ||
assertEquals(expected, actual); | ||
} | ||
|
||
@Test | ||
void shouldThrowDecodeExceptionOnDeserializeNull() { | ||
JsonObjectDeserializer deserializer = new JsonObjectDeserializer(); | ||
assertThrows(DecodeException.class, () -> deserializer.deserialize("topic", "null".getBytes())); | ||
} | ||
|
||
@Test | ||
void shouldDeserializeNullAsNull() { | ||
JsonObjectDeserializer deserializer = new JsonObjectDeserializer(); | ||
JsonObject actual = deserializer.deserialize("topic", null); | ||
assertNull(actual); | ||
} | ||
} |
30 changes: 30 additions & 0 deletions
30
...runtime/src/test/java/io/quarkus/kafka/client/serialization/JsonObjectSerializerTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
package io.quarkus.kafka.client.serialization; | ||
|
||
import static org.assertj.core.api.Assertions.assertThat; | ||
import static org.junit.jupiter.api.Assertions.assertNotNull; | ||
import static org.junit.jupiter.api.Assertions.assertNull; | ||
|
||
import java.util.Map; | ||
|
||
import org.junit.jupiter.api.Test; | ||
|
||
import io.vertx.core.json.JsonObject; | ||
|
||
public class JsonObjectSerializerTest { | ||
|
||
@Test | ||
void shouldSerializeJsonObject() { | ||
JsonObjectSerializer serializer = new JsonObjectSerializer(); | ||
byte[] result = serializer.serialize("topic", new JsonObject(Map.of("id", 1, "name", "entity1"))); | ||
assertNotNull(result); | ||
String actual = new String(result); | ||
assertThat(actual).contains("\"id\"").contains("\"name\"").contains("\"entity1\"").contains("1"); | ||
} | ||
|
||
@Test | ||
void shouldSerializeNullAsNull() { | ||
JsonObjectSerializer serializer = new JsonObjectSerializer(); | ||
byte[] result = serializer.serialize("topic", null); | ||
assertNull(result); | ||
} | ||
} |
Oops, something went wrong.