Christoph Deppisch created CAMEL-20892:
------------------------------------------
Summary: Misleading error message when Kamelet misses mandatory
field value
Key: CAMEL-20892
URL: https://issues.apache.org/jira/browse/CAMEL-20892
Project: Camel
Issue Type: Improvement
Components: camel-kamelet
Affects Versions: 4.6.0
Reporter: Christoph Deppisch
When a Camel route uses a Kamelet but misses a mandatory field for some reason
the error message is quite misleading. The error reports a
"KameletNotFoundException" in the StackTrace which is misleading because the
real error is an "IllegalArgumentException" due to the missing mandatory field.
{noformat}
Caused by: org.apache.camel.VetoCamelContextStartException: Failure creating
route from template: set-body-action
at
org.apache.camel.component.kamelet.KameletComponent$LifecycleHandler.onContextInitialized(KameletComponent.java:451)
at
org.apache.camel.impl.engine.AbstractCamelContext.doInit(AbstractCamelContext.java:2395)
at
org.apache.camel.quarkus.core.FastCamelContext.doInit(FastCamelContext.java:194)
at
org.apache.camel.support.service.BaseService.init(BaseService.java:78)
at
org.apache.camel.impl.engine.AbstractCamelContext.init(AbstractCamelContext.java:2021)
... 23 more
Caused by: org.apache.camel.component.kamelet.KameletNotFoundException: Kamelet
with id set-body-action not found in locations:
file:/etc/camel/kamelets/kamelets-bundle-roll-dice-pipe-001,classpath:/kamelets
at
org.apache.camel.component.kamelet.KameletComponent$LifecycleHandler.createRouteForEndpoint(KameletComponent.java:439)
at
org.apache.camel.component.kamelet.KameletComponent$LifecycleHandler.onContextInitialized(KameletComponent.java:448)
... 27 more
Caused by: java.lang.IllegalArgumentException: Route template set-body-action
the following mandatory parameters must be provided: value
at
org.apache.camel.impl.DefaultModel.addRouteFromTemplate(DefaultModel.java:438)
at
org.apache.camel.impl.DefaultModel.addRouteFromTemplate(DefaultModel.java:367)
at
org.apache.camel.impl.DefaultCamelContext.addRouteFromTemplate(DefaultCamelContext.java:362)
at
org.apache.camel.component.kamelet.KameletComponent$LifecycleHandler.createRouteForEndpoint(KameletComponent.java:427)
... 28 more{noformat}
The user needs to find the right part of the StackTrace to find out what is
going on: "Route template set-body-action the following mandatory parameters
must be provided: value"
The "KameletNotFoundException" is wrong anyways as the Kamelet has been part of
the catalog in this case.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)