From f0478f3a827c1f91d6e2f1eb4010275aeb07da4b Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Jose=20E=2E=20Garcia=20Maci=C3=B1eiras?=
<68995937+jemacineiras@users.noreply.github.com>
Date: Wed, 15 Nov 2023 09:49:17 +0100
Subject: [PATCH] 332 comsngularkloadgenserializerprotobufserializer
nullpointerexception (#421)
---
pom-maven-central.xml | 2 +-
pom.xml | 2 +-
.../SchemaRegistryConfigElementBeanInfo.java | 4 +-
.../extractors/ExtractorFactory.java | 35 ++++----
.../extractors/avro/AvroExtractor.java | 8 +-
.../sampler/KafkaProducerSampler.java | 46 +++++-----
.../sngular/kloadgen/sampler/SamplerUtil.java | 90 +++++++++----------
.../impl/GenericSchemaRegistryAdapter.java | 1 +
.../kloadgen/sampler/SamplerUtilTest.java | 2 +
9 files changed, 90 insertions(+), 100 deletions(-)
diff --git a/pom-maven-central.xml b/pom-maven-central.xml
index d0513d7f..e81bd2ec 100644
--- a/pom-maven-central.xml
+++ b/pom-maven-central.xml
@@ -7,7 +7,7 @@
kloadgen
- 5.6.9
+ 5.6.10
KLoadGen
Load Generation Jmeter plugin for Kafka Cluster. Supporting AVRO, JSON Schema and Protobuf schema types. Generate Artificial
diff --git a/pom.xml b/pom.xml
index fe0a95c2..48bf6fcd 100644
--- a/pom.xml
+++ b/pom.xml
@@ -7,7 +7,7 @@
kloadgen
- 5.6.9
+ 5.6.10
KLoadGen
Load Generation Jmeter plugin for Kafka Cluster. Supporting AVRO, JSON Schema and Protobuf schema types. Generate Artificial
diff --git a/src/main/java/com/sngular/kloadgen/config/schemaregistry/SchemaRegistryConfigElementBeanInfo.java b/src/main/java/com/sngular/kloadgen/config/schemaregistry/SchemaRegistryConfigElementBeanInfo.java
index 8cfeae30..2a3b0aff 100644
--- a/src/main/java/com/sngular/kloadgen/config/schemaregistry/SchemaRegistryConfigElementBeanInfo.java
+++ b/src/main/java/com/sngular/kloadgen/config/schemaregistry/SchemaRegistryConfigElementBeanInfo.java
@@ -22,8 +22,8 @@ public SchemaRegistryConfigElementBeanInfo() {
super(SchemaRegistryConfigElement.class);
- createPropertyGroup("schema_registry_config", new String[]{SchemaRegistryConfigElementValue.SCHEMA_REGISTRY_NAME,
- SchemaRegistryConfigElementValue.SCHEMA_REGISTRY_PROPERTIES, SchemaRegistryConfigElementValue.SCHEMA_REGISTRY_URL});
+ createPropertyGroup("schema_registry_config", new String[] {SchemaRegistryConfigElementValue.SCHEMA_REGISTRY_NAME,
+ SchemaRegistryConfigElementValue.SCHEMA_REGISTRY_URL, SchemaRegistryConfigElementValue.SCHEMA_REGISTRY_PROPERTIES});
final PropertyDescriptor schemaRegistryName = property(SchemaRegistryConfigElementValue.SCHEMA_REGISTRY_NAME);
schemaRegistryName.setPropertyEditorClass(SchemaRegistryNamePropertyEditor.class);
diff --git a/src/main/java/com/sngular/kloadgen/extractor/extractors/ExtractorFactory.java b/src/main/java/com/sngular/kloadgen/extractor/extractors/ExtractorFactory.java
index fdf8700c..445fd070 100644
--- a/src/main/java/com/sngular/kloadgen/extractor/extractors/ExtractorFactory.java
+++ b/src/main/java/com/sngular/kloadgen/extractor/extractors/ExtractorFactory.java
@@ -2,6 +2,7 @@
import java.util.ArrayList;
import java.util.List;
+import java.util.Objects;
import java.util.Properties;
import com.sngular.kloadgen.common.SchemaRegistryEnum;
@@ -32,20 +33,12 @@ private ExtractorFactory() {
public static ExtractorRegistry getExtractor(final String schemaType) {
if (schemaType != null && EnumUtils.isValidEnum(SchemaTypeEnum.class, schemaType.toUpperCase())) {
- final ExtractorRegistry response;
- switch (SchemaTypeEnum.valueOf(schemaType.toUpperCase())) {
- case JSON:
- response = JSON_EXTRACTOR;
- break;
- case AVRO:
- response = AVRO_EXTRACTOR;
- break;
- case PROTOBUF:
- response = PROTOBUFF_EXTRACTOR;
- break;
- default:
- throw new KLoadGenException(String.format("Schema type not supported %s", schemaType));
- }
+ final ExtractorRegistry response = switch (SchemaTypeEnum.valueOf(schemaType.toUpperCase())) {
+ case JSON -> JSON_EXTRACTOR;
+ case AVRO -> AVRO_EXTRACTOR;
+ case PROTOBUF -> PROTOBUFF_EXTRACTOR;
+ default -> throw new KLoadGenException(String.format("Schema type not supported %s", schemaType));
+ };
return response;
} else {
throw new KLoadGenException(String.format("Schema type not supported %s", schemaType));
@@ -63,12 +56,14 @@ public static Pair> flatPropertiesList(final Str
final SchemaRegistryEnum schemaRegistryEnum = SchemaRegistryEnum.valueOf(registryName.toUpperCase());
final Object schema;
- //TODO change parser
- schema = switch (schemaRegistryEnum) {
- case APICURIO -> ((ApicurioAbstractParsedSchemaMetadata) abstractParsedSchemaAdapter).getSchema();
- case CONFLUENT -> abstractParsedSchemaAdapter.getRawSchema();
- };
- attributeList.addAll(getExtractor(schemaType).processSchema(schema, schemaRegistryEnum));
+ if (Objects.nonNull(registryName)) {
+ //TODO change parser
+ schema = switch (schemaRegistryEnum) {
+ case APICURIO -> ((ApicurioAbstractParsedSchemaMetadata) abstractParsedSchemaAdapter).getSchema();
+ case CONFLUENT -> abstractParsedSchemaAdapter.getRawSchema();
+ };
+ attributeList.addAll(getExtractor(schemaType).processSchema(schema, schemaRegistryEnum));
+ }
return Pair.of(schemaType, attributeList);
}
}
\ No newline at end of file
diff --git a/src/main/java/com/sngular/kloadgen/extractor/extractors/avro/AvroExtractor.java b/src/main/java/com/sngular/kloadgen/extractor/extractors/avro/AvroExtractor.java
index 32594da3..2db79a09 100644
--- a/src/main/java/com/sngular/kloadgen/extractor/extractors/avro/AvroExtractor.java
+++ b/src/main/java/com/sngular/kloadgen/extractor/extractors/avro/AvroExtractor.java
@@ -12,11 +12,11 @@
public class AvroExtractor implements ExtractorRegistry