[ 
https://issues.apache.org/jira/browse/CAMEL-23880?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Claus Ibsen updated CAMEL-23880:
--------------------------------
    Issue Type: Test  (was: Improvement)

> camel-pulsar - Fix flaky integration tests caused by topic name collisions 
> and resource leaks
> ---------------------------------------------------------------------------------------------
>
>                 Key: CAMEL-23880
>                 URL: https://issues.apache.org/jira/browse/CAMEL-23880
>             Project: Camel
>          Issue Type: Test
>          Components: camel-pulsar
>            Reporter: Guillaume Nodet
>            Assignee: Guillaume Nodet
>            Priority: Major
>              Labels: test-flaky
>
> Several camel-pulsar integration tests are flaky, causing spurious CI 
> failures on unrelated PRs.
> The primary root causes are:
> 1. *Topic name collisions*: PulsarConsumerNoAcknowledgementIT and 
> PulsarConsumerReadCompactedIT share the same topic URI 
> (persistent://public/default/camel-topic) with the same subscription name. 
> Since all integration tests share a singleton Pulsar container, messages and 
> subscription state leak between tests, causing non-deterministic message 
> counts.
> 2. *Cross-method contamination*: PulsarConsumerNoAcknowledgementIT has two 
> test methods sharing the same @EndpointInject endpoint (same topic and 
> subscription). Unacknowledged messages from the first test method leak into 
> the second.
> 3. *Resource leaks*: PulsarClient instances created with givenPulsarClient() 
> are never closed, leaking threads and network resources.
> 4. *Exact message count assertions*: Tests use expectedMessageCount(N) 
> instead of expectedMinimumMessageCount(N) for redelivery-based tests where 
> the exact count is timing-dependent.
> 5. *Guava sleep in ReadCompactedIT*: Uninterruptibles.sleepUninterruptibly 
> used instead of Awaitility for waiting on compaction status.
> The fix:
> - Give each test class and test method a unique topic name to prevent 
> cross-contamination
> - Replace @EndpointInject for consumer endpoints with programmatic endpoint 
> creation in @BeforeEach
> - Add proper @AfterEach cleanup to close endpoints, producers, and routes
> - Change expectedMessageCount to expectedMinimumMessageCount for 
> timing-dependent assertions
> - Replace Guava Uninterruptibles.sleepUninterruptibly with Awaitility



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to