Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Migration of unmigrated content due to installation of a new plugin

...

As a simple alternative to using CDI TestingSpring Testing or Guice the camel-test module was introduced so you can perform powerful Testing of your Enterprise Integration Patterns easily.

...

The camel-test JAR is using JUnit. There is an alternative camel-testng JAR (from Camel 2.8

...

) using the TestNG test framework.

Adding to your your pom.xml

To get started using Camel Test you will need to add an entry to your pom.xml:

JUnit

...

...

TestNG

Available as of Camel 2.8

...

...

You might also want to add add slf4j and and log4j to ensure nice logging messages (and maybe adding a log4j.properties file into your your src/test/resources directory).

...

...

Writing your test

You firstly need to derive from the class class CamelTestSupport (org.apache.camel.test.CamelTestSupport, org.apache.camel.test.junit4.CamelTestSupport, or or org.apache.camel.testng.CamelTestSupport for JUnit 3.x, JUnit 4.x, and TestNG, respectively) and typically you will need to override the the createRouteBuilder() or  or createRouteBuilders() method method to create routes to be tested.

Here is an example.

...

{snippet:lang=java|id=example|url=camel/trunk/components/camel-test/src/test/java/org/apache/camel/test/patterns/FilterTest.java}

...

Notice Note: how you can use the various Camel binding and injection annotations to inject individual Endpoint objects - particularly the Mock endpoints which are very useful for Testing. Also you can inject producer objects such as ProducerTemplate or some application code interface for sending messages or invoking services.

Features Provided by by CamelTestSupport

The various various CamelTestSupport classes provide a standard set of behaviors relating to the the CamelContext used to host the route(s) under test.  The classes provide a number of methods that allow a test to alter the configuration of the the CamelContext used.  The following table describes the available customization methods and the default behavior of tests that are built from a CamelTestSupport class.

Its important to start

the

the CamelContext manually from the unit test after you are done doing all the advice with.

Method Name

Description

Default Behavior

boolean isUseRouteBuilder()

If the route builders returned from returned from either createRouteBuilder() or createRouteBuilders() should be added to the the CamelContext used in for the test should to be started.

Returns true

createRouteBuilder() or  or createRouteBuilders() are invoked and the the CamelContext is started automatically.

boolean isUseAdviceWith()

If the the CamelContext use in the test should be automatically started before test methods are invoked.


Override when using advice with and return true.  This helps in knowing the the adviceWith() is to be used, and the CamelContext will the CamelContext will not be started before the advice with takes place. This delay helps by ensuring the advice with has been property setup before the CamelContext is the CamelContext is started.

Info

Returns false. 

The   the CamelContext is started automatically before test methods are invoked.

boolean isCreateCamelContextPerClass()

See Setup CamelContext once per class, or per every test method.

The The CamelContext and routes are recreated for each test method.

String isMockEndpoints()

Triggers the auto-mocking of endpoints whose URIs match the provided filter.  The default filter is is null which disables this feature.  Return  

Return "*"  to   to match all endpoints.  

See org  See org.apache.camel.impl.InterceptSendToMockEndpointStrategy for more InterceptSendToMockEndpointStrategy for more details on the registration of the mock endpoints.

Disabled

boolean isUseDebugger()

If this method returns true, the the methods:

  • debugBefore(Exchange exchange, Processor processor, ProcessorDefinition<?> definition, String id, String label)
 and 
  • debugAfter(Exchange exchange, Processor processor, ProcessorDefinition<?> definition, String id, String label, long timeTaken)

 methods are invoked for each processor in the registered routes.

Disabled

The .  The methods are not invoked during the test.

int getShutdownTimeout()

Returns the number of seconds that Camel should wait for graceful shutdown.  

Useful  Useful for decreasing test times when a message is still in flight at the end of the test.

Returns 10 seconds.

boolean useJmx()

If JMX should be disabled on the the CamelContext used in the test.

JMX is disabled.

JndiRegistry createRegistry()

Provides a hook for adding objects into the registry.  Override this method to bind objects to the registry before test methods are invoked.

An empty registry is initialized.

useOverridePropertiesWithPropertiesComponent

Camel 2.10: Allows to add/override properties when Using PropertyPlaceholder in Camel.

null

ignoreMissingLocationWithPropertiesComponent

Camel 2.10: Allows to control if Camel should ignore missing locations for properties.

null

boolean

isDumpRouteStats

isDumpRouteCoverage

Camel 2.16: If enabled, then Camel will dump all route coverage statistics into XML files in the target/camel-route-

stats

coverage directory. These XML files contains information about "route coverage" of all the routes that was used during the unit test. This allows tooling to inspect these XML files and generate nice route coverage reports.

Disabled.

JNDI

Camel uses a Registry to allow you to configure Component or Endpoint instances or Beans used in your routes. If you are not using Spring or OSGi then JNDI is used as the default registry implementation.

So you will also need to create a jndi.properties file in your your src/test/resources directory so that there is a default registry available to initialise initialize the CamelContext.

Here is an example jndi.properties file

...

...

Dynamically Assigning Ports

Available as of Camel 2.7

Tests that use port numbers will fail if that port is already on use. AvailablePortFinder provides methods for finding unused port numbers at runtimerun time.

...

Setup CamelContext once per class, or per every test method

...

The Camel Test kit will by default setup and shutdown CamelContext per every test method in your test class. So for example if you have 3 test methods, then CamelContext is started and shutdown after each test, that is 3 times.

...

...

This feature is also supported

...

in camel-testng

...

...

When using this the CamelContext will keep state between tests, so have that in mind. So if your unit tests start to fail for no apparent reason, it could be due this fact. So use this feature with a bit of care.

You may want to do this once, to share the CamelContext between test methods, to speedup unit testing. This requires to the use of JUnit 4! In your unit test method you have to extend the org.apache.camel.test.junit4.CamelTestSupport or the org.apache.camel.test.junit4.CamelSpringTestSupport test class and override the isCreateCamelContextPerClass method and return true as shown in the following example:

...

{snippet:id=example|lang=java|title=Setup

...

CamelContext

...

once

...

per

...

class|url=camel/trunk/components/camel-test/src/test/java/org/apache/camel/test/patterns/FilterCreateCamelContextPerClassTest.java}

See Also

...