Skip to content

Commit

Permalink
Merge pull request #2412 from ozangunalp/in_memory_connector_docs_update
Browse files Browse the repository at this point in the history
In-memory connector docs update
  • Loading branch information
ozangunalp authored Dec 15, 2023
2 parents 9459789 + 918593e commit ada65bc
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 2 deletions.
2 changes: 1 addition & 1 deletion documentation/src/main/docs/concepts/decorators.md
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ An `IncomingInterceptor` can implement these three methods:

!!!Note
If you are willing to adapt an incoming message payload to fit a consuming method receiving type,
you can use [`MessageConverter`](./converters)s.
you can use [`MessageConverter`](./converters.md)s.

### `OutgoingInterceptor`

Expand Down
15 changes: 14 additions & 1 deletion documentation/src/main/docs/concepts/testing.md
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,12 @@ Then, in a test, you can do something like:
When switching a channel to the in-memory connector, all the
configuration properties are ignored.

!!!important
!!! warning
This connector has been designed for testing purpose only.
Switching the channel to in-memory connector means that the
original connector is not invoked at all during tests.
Therefore, if your code depends on a specific connector behaviour
or a custom metadata you need to simulate those in your tests.


The *switch* methods return `Map<String, String>` instances containing
Expand All @@ -53,3 +57,12 @@ an external process with these properties:
the messages sent to the mapped channel even when coming from multiple
producers.

## Vert.x Context with In-memory Connector

For the sake of simplicity, In-memory connector channels dispatch messages on the caller thread of `InMemorySource#send` method.
However, most of the other connectors handle context propagation dispatching messages on separate [duplicated Vert.x contexts](message-context.md).

If this causes a change of behaviour in your tests,
you can configure the in-memory connector channels with `run-on-vertx-context` attribute to dispatch events,
including messages and acknowledgements, on a Vert.x context.
Alternatively you can switch this behaviour using the `InMemorySource#runOnVertxContext` method.

0 comments on commit ada65bc

Please sign in to comment.