Skip to content
This repository has been archived by the owner on Nov 27, 2023. It is now read-only.

Commit

Permalink
fix: don't lose examples on properties
Browse files Browse the repository at this point in the history
Fixes #714
  • Loading branch information
Delawen committed Jun 30, 2023
1 parent 091e933 commit d5a8c2b
Showing 18 changed files with 193 additions and 46 deletions.
Original file line number Diff line number Diff line change
@@ -372,7 +372,7 @@ void beans() throws Exception {
@ValueSource(strings = {"Camel Route#route-multi.yaml", "KameletBinding#kamelet-binding-multi.yaml",
"Kamelet#eip.kamelet.yaml", "Kamelet#kamelet-multi.yaml", "Camel Route#rest-dsl-multi.yaml",
"Camel Route#route-with-beans.yaml", "Integration#integration.yaml",
"Integration#integration-multiroute.yaml"})
"Integration#integration-multiroute.yaml", "Kamelet#jms-amqp-10-source.kamelet.yaml"})
void roundTrip(String file) throws IOException {

String[] parameters = file.split("#");
@@ -469,7 +469,7 @@ void uniqueName() throws IOException {
@ValueSource(strings = {"Kamelet#eip.kamelet.yaml", "Integration#integration.yaml",
"Camel Route#route-with-beans.yaml", "Camel Route#rest-dsl-multi.yaml",
"KameletBinding#kamelet-binding.yaml", "Kamelet#kamelet2.yaml",
"Integration#integration-multiroute.yaml"})
"Integration#integration-multiroute.yaml", "Kamelet#jms-amqp-10-source.kamelet.yaml"})
void changeNameAndDescription(String file) throws IOException {

String[] parameters = file.split("#");
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
apiVersion: camel.apache.org/v1alpha1
kind: Kamelet
metadata:
annotations:
camel.apache.org/kamelet.icon: 
camel.apache.org/kamelet.support.level: Stable
camel.apache.org/provider: Apache Software Foundation
camel.apache.org/catalog.version: 4.0.0-SNAPSHOT
camel.apache.org/kamelet.group: JMS
camel.apache.org/kamelet.namespace: Messaging
labels:
camel.apache.org/requires.runtime: camel-k
camel.apache.org/kamelet.type: source
name: jms-amqp-10-source
spec:
definition:
description: Consume data from any AMQP 1.0 compliant message broker
properties:
destinationType:
default: queue
description: The JMS destination type (queue or topic).
title: Destination Type
type: string
destinationName:
description: The JMS destination name.
title: Destination Name
type: string
remoteURI:
description: The JMS URL.
example: amqp://my-host:31616
title: Broker URL
type: string
required:
- destinationName
- remoteURI
title: JMS - AMQP 1.0 Source
type: object
dependencies:
- camel:jms
- camel:amqp
- camel:kamelet
- camel:core
template:
from:
uri: jms:{{destinationType}}:{{destinationName}}
parameters:
connectionFactory: '#bean:{{connectionFactoryBean}}'
steps:
- to:
uri: kamelet:sink
Original file line number Diff line number Diff line change
@@ -52,11 +52,11 @@ private static Step getRestParentStep() {
var parameters = new LinkedList<Parameter>();
final var path =
new StringParameter(Rest.PATH_LABEL, "Path of the endpoint",
"Path where this endpoint is listening.", null, null);
"Path where this endpoint is listening.", null, null, null,null, null);
parameters.add(path);
final var description =
new StringParameter(Rest.DESCRIPTION_LABEL, "Description of the endpoint",
"Human readable description of this endpoint.", null, null);
"Human readable description of this endpoint.", null, null, null,null, null);
parameters.add(description);
step.setParameters(parameters);
return step;
15 changes: 15 additions & 0 deletions kamelet-support/src/main/java/io/kaoto/backend/KamelPopulator.java
Original file line number Diff line number Diff line change
@@ -304,6 +304,21 @@ private void setParameters(final List<Parameter> parameters, final Definition de
}
property.setTitle(p.getTitle());
property.setType(p.getType());
property.setNullable(p.getNullable());
if (p.getEnum() != null) {
var enumerable = new LinkedList<AnyType>();
for (var enumy : p.getEnum()) {
var anyType = new AnyType();
anyType.setValue(enumy);
enumerable.add(anyType);
}
property.set_enum(enumerable);
}
if (p.getExamples() != null && p.getExamples().length > 0) {
var example = new AnyType();
example.setValue(p.getExamples()[0]);
property.setExample(example);
}
def.getProperties().put(p.getId(), property);
}
}
Original file line number Diff line number Diff line change
@@ -91,8 +91,6 @@ public class KameletRepresenter extends Representer {
public static final String PARAMETERS = "parameters";
public static final String URI = "uri";
public static final String NAME = "name";
public static final String KIND = "kind";
public static final String API_VERSION = "apiVersion";

public KameletRepresenter() {
super(new DumperOptions());
Original file line number Diff line number Diff line change
@@ -3,6 +3,7 @@
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.dataformat.yaml.YAMLFactory;
import io.fabric8.kubernetes.api.model.AnyType;
import io.fabric8.kubernetes.api.model.ObjectMeta;
import io.kaoto.backend.api.metadata.catalog.StepCatalog;
import io.kaoto.backend.api.service.step.parser.StepParserService;
@@ -122,40 +123,67 @@ private void processParameters(final ParseResult<Step> res,
Parameter p;
switch (def.getType()) {
case "string":
p = new StringParameter(key, def.getTitle(),
p = new StringParameter(key,
def.getTitle(),
def.getDescription(),
def.getNullable(),
def.get_enum() != null ? def.get_enum().toArray(new String[]{}) : null,
def.getExample() != null ?
new String[]{String.valueOf(def.getExample().getValue())} :
null,
def.get_default() != null ?
String.valueOf(def.get_default().getValue()) : null,
def.getFormat());
break;
case "number":
p = new NumberParameter(key, def.getTitle(),
def.getDescription(),
def.getDescription(), def.getNullable(),
def.get_enum() != null ? def.get_enum().toArray(new Double[]{}) : null,
def.getExample() != null ?
new Number[]{Double.valueOf(String.valueOf(def.getExample().getValue()))} :
null,
def.get_default() != null ?
Double.valueOf(String.valueOf(def.get_default().getValue()))
: null);
break;
case "integer":
p = new IntegerParameter(key, def.getTitle(),
def.getDescription(),
def.getDescription(), def.getNullable(),
def.get_enum() != null ? def.get_enum().toArray(new Integer[]{}) : null,
def.getExample() != null ?
new Integer[]{Integer.valueOf(String.valueOf(def.getExample().getValue()))} :
null,
def.get_default() != null ?
Integer.valueOf(String.valueOf(def.get_default().getValue())) : null);
break;
case "boolean":
p = new BooleanParameter(key, def.getTitle(),
def.getDescription(),
def.getDescription(), def.getNullable(),
def.get_enum() != null ? def.get_enum().toArray(new Boolean[]{}) : null,
def.getExample() != null ?
new Boolean[]{Boolean.valueOf(String.valueOf(def.getExample().getValue()))} :
null,
def.get_default() != null ?
Boolean.valueOf(String.valueOf(def.get_default().getValue())) : null);
break;
case "array":
p = new ArrayParameter(key, def.getTitle(),
def.getDescription(),
def.getDescription(), def.getNullable(),
def.get_enum() != null ? def.get_enum().toArray(new Object[][]{}) : null,
def.getExample() != null ?
new Object[][]{ (Object[]) def.getExample().getValue()} :
null,
def.get_default() != null ?
String.valueOf(def.get_default().getValue()).split(",") :
null);
break;
default:
p = new ObjectParameter(key, def.getTitle(), def.getDescription(), def.get_default());
p = new ObjectParameter(key, def.getTitle(), def.getDescription(), def.getNullable(),
def.get_enum().toArray(new AnyType[0]),
def.getExample() != null ?
new Object[]{ def.getExample().getValue()} :
null,
def.get_default());
}
res.getParameters().add(p);
}
Original file line number Diff line number Diff line change
@@ -237,6 +237,7 @@ private StringParameter getStringParameter(final ParameterEntry parameter) {
id,
parameterData.get(DISPLAY_NAME),
parameterData.get(DESCRIPTION),
null, null, null,
parameterData.getOrDefault(DEFAULT_VALUE, null),
null
);
@@ -259,6 +260,7 @@ private NumberParameter getNumberParameter(final ParameterEntry parameter) {
id,
parameterData.get(DISPLAY_NAME),
parameterData.get(DESCRIPTION),
null, null, null,
value
);
}
@@ -271,6 +273,7 @@ private ObjectParameter getObjectParameter(final ParameterEntry parameter) {
id,
parameterData.get(DISPLAY_NAME),
parameterData.get(DESCRIPTION),
null, null, null,
parameterData.getOrDefault(DEFAULT_VALUE, null)
);
}
@@ -283,6 +286,7 @@ private BooleanParameter getBooleanParameter(final ParameterEntry parameter) {
id,
parameterData.get(DISPLAY_NAME),
parameterData.get(DESCRIPTION),
null, null, null,
Boolean.parseBoolean(parameterData
.getOrDefault(DEFAULT_VALUE, "false"))
);
Original file line number Diff line number Diff line change
@@ -159,17 +159,22 @@ private Parameter getParameter(final KameletDefinitionProperty property,
return switch (type) {
//number, integer, string, boolean, array, object, or null
case "number" -> new NumberParameter(id, title, description,
null, null, null,
value != null ? Double.valueOf(String.valueOf(value)) : null);
case "integer" -> new IntegerParameter(id, title, description,
null, null, null,
value != null ? Integer.valueOf(String.valueOf(value)) : null);
case "string" -> new StringParameter(id, title, description,
null, null, null,
value != null ? String.valueOf(value) : null, property.getFormat());
case "boolean" -> new BooleanParameter(id, title, description,
null, null, null,
value != null ? Boolean.valueOf(String.valueOf(value)) : null);
case "array" -> new ArrayParameter(id, title, description,
null, null, null,
value != null ? String.valueOf(value).split(",") : null);
default -> new ObjectParameter(id, title, description,
value);
null, null, null, value);
};
}
}
Original file line number Diff line number Diff line change
@@ -61,7 +61,7 @@ void parse() {
p.setValue("loggerName");
p.setId("loggerName");
step.getParameters().add(p);
p = new StringParameter("level", "level", "", "default", null);
p = new StringParameter("level", "level", "", null, null, null,"default", null);
p.setValue("info");
step.getParameters().add(p);
steps.add(step);
@@ -99,7 +99,7 @@ void parse() {
step.setKind("EIP");
step.setName("set-body");
step.setParameters(new LinkedList<>());
p = new StringParameter("constant", "constant", "", "default", null);
p = new StringParameter("constant", "constant", "",null, null, null, "default", null);
p.setValue("Hello Llama");
step.getParameters().add(p);
steps.add(1, step);
Original file line number Diff line number Diff line change
@@ -76,21 +76,27 @@ private void assertBrowseJsonHasBeenParsedCorrectly(
Map<String, Parameter> expectedParameterValues = Map.of(
"name", new StringParameter(
"name", "Name", "d1",
null, null, null,
null, null),
"bridgeErrorHandler", new BooleanParameter(
"bridgeErrorHandler", "Bridge Error Handler",
"d2", false),
"d2",
null, null, null, false),
"exceptionHandler", new ObjectParameter(
"exceptionHandler", "Exception Handler",
"d3", null),
"d3",
null, null, null,null),
"exchangePattern", new ObjectParameter(
"exchangePattern", "Exchange Pattern",
"d4", null),
"d4",
null, null, null,null),
"lazyStartProducer", new BooleanParameter(
"lazyStartProducer", "Lazy Start Producer",
"d5", false),
"d5",
null, null, null,false),
"step-id-kaoto", new StringParameter("step-id-kaoto", "Step ID",
"Identifier of this step inside the route.", null, null)
"Identifier of this step inside the route.",
null, null, null,null, null)
);

expectedParameterValues.get("name").setPath(true);
Original file line number Diff line number Diff line change
@@ -114,13 +114,19 @@ private void assertBrowseJsonHasBeenParsedCorrectly(
assertIterableEquals(List.of("name"), parsedStep.getRequired());

Map<String, Parameter> expectedParameterValues = Map.of(
"name", new StringParameter("name", "Name", "d1", null, null),
"bridgeErrorHandler", new BooleanParameter("bridgeErrorHandler", "Bridge Error Handler", "d2", false),
"exceptionHandler", new ObjectParameter("exceptionHandler", "Exception Handler", "d3", null),
"exchangePattern", new ObjectParameter("exchangePattern", "Exchange Pattern", "d4", null),
"lazyStartProducer", new BooleanParameter("lazyStartProducer", "Lazy Start Producer", "d5", false),
"name", new StringParameter("name", "Name", "d1",
null, null, null, null, null),
"bridgeErrorHandler", new BooleanParameter("bridgeErrorHandler", "Bridge Error Handler", "d2",
null, null, null,false),
"exceptionHandler", new ObjectParameter("exceptionHandler", "Exception Handler", "d3",
null, null, null,null),
"exchangePattern", new ObjectParameter("exchangePattern", "Exchange Pattern", "d4",
null, null, null,null),
"lazyStartProducer", new BooleanParameter("lazyStartProducer", "Lazy Start Producer", "d5",
null, null, null,false),
"step-id-kaoto", new StringParameter("step-id-kaoto", "Step ID", "Identifier of this step inside the " +
"route.", null, null)
"route.",
null, null, null,null, null)
);

expectedParameterValues.get("name").setPath(true);
Original file line number Diff line number Diff line change
@@ -14,9 +14,14 @@ public class ArrayParameter extends Parameter<Object[]> {
private Integer minItems;
private Boolean uniqueItems;

public ArrayParameter(final String id, final String title,
final String description, final Object[] v) {
super(id, title, description, v);
public ArrayParameter(final String id,
final String title,
final String description,
final Boolean nullable,
final Object[][] enumeration,
final Object[][] examples,
final Object[] defaultValue) {
super(id, title, description, nullable, enumeration, examples, defaultValue);
}

public ArrayParameter() {
Original file line number Diff line number Diff line change
@@ -7,9 +7,14 @@
@JsonIgnoreProperties(ignoreUnknown = true)
public class BooleanParameter extends Parameter<Boolean> {

public BooleanParameter(final String id, final String title,
final String description, final Boolean v) {
super(id, title, description, v);
public BooleanParameter(final String id,
final String title,
final String description,
final Boolean nullable,
final Boolean[] enumeration,
final Boolean[] examples,
final Boolean defaultValue) {
super(id, title, description, nullable, enumeration, examples, defaultValue);
}

public BooleanParameter() {
Original file line number Diff line number Diff line change
@@ -14,9 +14,14 @@ public class IntegerParameter extends Parameter<Integer> {
private Integer maximum;
private Integer minimum;

public IntegerParameter(final String id, final String title,
final String description, final Integer v) {
super(id, title, description, v);
public IntegerParameter(final String id,
final String title,
final String description,
final Boolean nullable,
final Integer[] enumeration,
final Integer[] examples,
final Integer defaultValue) {
super(id, title, description, nullable, enumeration, examples, defaultValue);
}

public IntegerParameter() {
Loading

0 comments on commit d5a8c2b

Please sign in to comment.