Class BrokerRunningSupport
java.lang.Object
org.springframework.amqp.rabbit.junit.BrokerRunningSupport
A class that can be used to prevent integration tests from failing if the Rabbit broker application is
 not running or not accessible. If the Rabbit broker is not running in the background
 all the tests here will simply be skipped (by default) because of a violated assumption
 (showing as successful).
 
 If you wish to enforce the broker being available, for example, on a CI server,
 set the environment variable "RABBITMQ_SERVER_REQUIRED" to true and the
 tests will fail fast.
- Since:
- 2.2
- Author:
- Dave Syer, Gary Russell, Artem Bilan
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classTheRuntimeExceptionthrown when broker is not available on the provided host port.
- 
Field SummaryFields
- 
Method SummaryModifier and TypeMethodDescriptionstatic voidClear any environment variable overrides set insetEnvironmentVariableOverrides(Map).voiddeleteExchanges(String... exchanges) Delete arbitrary exchanges from the broker.voiddeleteQueues(String... queuesToDelete) Delete arbitrary queues from the broker.static booleanfatal()Generate the connection id for the connection used by the rule's connection factory.Return the admin password.Return the admin uri.Return the admin user.com.rabbitmq.client.ConnectionFactoryGet the connection factory used by this rule.Return the port.Return the password.intgetPort()Return the port.getUser()Return the user.static BrokerRunningSupportstatic BrokerRunningSupportstatic BrokerRunningSupportbooleanstatic BrokerRunningSupportstatic BrokerRunningSupportisRunningWithEmptyQueues(String... names) Ensure the broker is running and has a empty queue(s) with the specified name(s) in the default exchange.voidDelete and re-declare all the configured queues.voidremoveExchanges(String... exchanges) Remove exchanges from the broker.voidremoveTestQueues(String @Nullable ... additionalQueues) Remove any test queues that were created by anisRunningWithEmptyQueues(String...)method.voidsetAdminPassword(String password) Set the password for the management REST API connection default "guest".voidsetAdminUri(String adminUri) Set the uri for the REST API.voidsetAdminUser(String user) Set the user for the management REST API connection default "guest".static voidsetEnvironmentVariableOverrides(Map<String, String> environmentVariables) Set environment variable overrides for host, port etc.voidsetHostName(String hostName) voidsetPassword(String password) Set the password for the amqp connection default "guest".voidsetPort(int port) voidsetPurgeAfterEach(boolean purgeAfterEach) Purge the test queues after each test (JUnit 5).voidSet the user for the amqp connection default "guest".voidtest()Check connectivity to the broker and create any queues.
- 
Field Details- 
BROKER_ADMIN_URI- See Also:
 
- 
BROKER_HOSTNAME- See Also:
 
- 
BROKER_PORT- See Also:
 
- 
BROKER_USER- See Also:
 
- 
BROKER_PW- See Also:
 
- 
BROKER_ADMIN_USER- See Also:
 
- 
BROKER_ADMIN_PW- See Also:
 
- 
BROKER_REQUIRED- See Also:
 
- 
DEFAULT_QUEUE_NAME
 
- 
- 
Method Details- 
setEnvironmentVariableOverridesSet environment variable overrides for host, port etc. Will override any real environment variables, if present.The variables will only apply to rule instances that are created after this method is called. The overrides will remain until - Parameters:
- environmentVariables- the variables.
 
- 
clearEnvironmentVariableOverridespublic static void clearEnvironmentVariableOverrides()Clear any environment variable overrides set insetEnvironmentVariableOverrides(Map).
- 
isRunningWithEmptyQueuesEnsure the broker is running and has a empty queue(s) with the specified name(s) in the default exchange.- Parameters:
- names- the queues to declare for the test.
- Returns:
- a new rule that assumes an existing running broker
 
- 
isRunning- Returns:
- a new rule that assumes an existing running broker
 
- 
isNotRunning- Returns:
- a new rule that assumes there is no existing broker
 
- 
isBrokerAndManagementRunning- Returns:
- a new rule that assumes an existing broker with the management plugin
 
- 
isBrokerAndManagementRunningWithEmptyQueues- Parameters:
- queues- the queues.
- Returns:
- a new rule that assumes an existing broker with the management plugin with the provided queues declared (and emptied if needed)..
 
- 
setPortpublic void setPort(int port) - Parameters:
- port- the port to set
 
- 
setHostName- Parameters:
- hostName- the hostName to set
 
- 
setUserSet the user for the amqp connection default "guest".- Parameters:
- user- the user.
 
- 
setPasswordSet the password for the amqp connection default "guest".- Parameters:
- password- the password.
 
- 
setAdminUriSet the uri for the REST API.- Parameters:
- adminUri- the uri.
 
- 
setAdminUserSet the user for the management REST API connection default "guest".- Parameters:
- user- the user.
 
- 
setAdminPasswordSet the password for the management REST API connection default "guest".- Parameters:
- password- the password.
 
- 
getPortpublic int getPort()Return the port.- Returns:
- the port.
 
- 
getHostName
- 
getUser
- 
getPassword
- 
getAdminUser
- 
getAdminPassword
- 
isPurgeAfterEachpublic boolean isPurgeAfterEach()
- 
setPurgeAfterEachpublic void setPurgeAfterEach(boolean purgeAfterEach) Purge the test queues after each test (JUnit 5).- Parameters:
- purgeAfterEach- true to purge.
 
- 
testCheck connectivity to the broker and create any queues.- Throws:
- BrokerRunningSupport.BrokerNotAliveException- if the broker is not available.
 
- 
fatalpublic static boolean fatal()
- 
generateIdGenerate the connection id for the connection used by the rule's connection factory.- Returns:
- the id.
 
- 
removeTestQueuesRemove any test queues that were created by anisRunningWithEmptyQueues(String...)method.- Parameters:
- additionalQueues- additional queues to remove that might have been created by tests.
 
- 
removeExchangesRemove exchanges from the broker.- Parameters:
- exchanges- the exchanges.
- Since:
- 2.3
 
- 
purgeTestQueuespublic void purgeTestQueues()Delete and re-declare all the configured queues. Can be used between tests when a test might leave stale data and multiple tests use the same queue.
- 
deleteQueuesDelete arbitrary queues from the broker.- Parameters:
- queuesToDelete- the queues to delete.
 
- 
deleteExchangesDelete arbitrary exchanges from the broker.- Parameters:
- exchanges- the exchanges to delete.
 
- 
getConnectionFactorypublic com.rabbitmq.client.ConnectionFactory getConnectionFactory()Get the connection factory used by this rule.- Returns:
- the connection factory.
 
- 
getAdminUri
 
-