Search code examples
javaspring-bootapache-camelspring-dslapache-camel-3

FailedToCreateRouteException: Failed to create route.. at: >>> SetHeader[null, constant{}] <<< in route: because of headerName must be specified


I'm creating a route like that:

<routes xmlns="http://camel.apache.org/schema/spring">
   <route id="ESP_01.Handle_Movement">
      <from uri="mqtt:ESP_01.Handle_Movement?host=tcp://localhost:1883&amp;subscribeTopicName=ESP_01/Handle Movement&amp;version=3.1&amp;maxReadRate=0&amp;qualityOfService=AtLeastOnce" />
      <to uri="micrometer:timer:camel.proxy.mqtt.kafka.stream?action=start" />
      <to uri="log://camel.proxy?groupInterval=3&amp;level=INFO" />
      <to uri="kafka://ESP_01.Handle_Movement?brokers=localhost:9092" />
      <to uri="micrometer:timer:camel.proxy.mqtt.kafka.stream?action=stop" />
      <to uri="micrometer:timer:camel.proxy.cache?action=start" />
      <setHeader name="CamelCacheKey">
         <constant>Test ESP_01.Handle_Movement</constant>
      </setHeader>
      <setHeader name="CamelCacheOperation">
         <constant>Update</constant>
      </setHeader>
      <to uri="cache://Test ESP_01.Handle_Movement?maxElementsInMemory=10&amp;eternal=true" />
      <to uri="micrometer:timer:camel.proxy.cache?action=stop" />
   </route>
</routes>

I have

      <setHeader name="CamelCacheKey">
         <constant>Test ESP_01.Handle_Movement</constant>
      </setHeader>
      <setHeader name="CamelCacheOperation">
         <constant>Update</constant>
      </setHeader>

according to the example, however I'm getting the error message from the title that required already existing name parameter is missed:

org.apache.camel.FailedToCreateRouteException: Failed to create route ESP_01.Handle_Movement at: >>> SetHeader[null, constant{Test ESP_01.Handle_Movement}] <<< in route: Route(ESP_01.Handle_Movement)[[From[mqtt:ESP_01.Handle_Movem... because of headerName must be specified

Solution

  • That's probably due to the bug of <camel.version>2.24.3</camel.version>

    In Spring DSL the validated parameter is name, while in the class of the header the parameter name is headerName, that is set to null. If I try to use headerName parameter in Spring DSL I'm getting this error:

    "org.xml.sax.SAXParseException; lineNumber: 1; columnNumber: 633; cvc-complex-type.3.2.2: Attribute 'headerName' is not allowed to appear in element 'setHeader'.",