• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

sonus21 / rqueue / 25621809822

10 May 2026 06:27AM UTC coverage: 83.425% (+0.03%) from 83.396%
25621809822

push

github

web-flow
Nats scheduling fix (#297)

* ci: compile main sources in coverage_report job

The coverage_report job was producing an effectively empty
jacocoTestReport.xml (3.4KB vs ~1.1MB locally) because no .class files
existed when coverageReportOnly ran — the job checked out source code
and downloaded .exec artifacts, but never compiled. JaCoCo's report
generator skips packages/classes it cannot resolve, so the merged XML
ended up with only <sessioninfo> entries and no <package> elements.

That made coverallsJacoco silently no-op via the
"source file set empty, skipping" branch in CoverallsReporter, so
"Push coverage to Coveralls" reported success without uploading.

Verified by downloading the coverage-report artifact from a recent run
and comparing its XML structure against a local build's report.

Assisted-By: Claude Code

* nats-web: implement pause / soft-delete admin ops and capability-aware Q-detail

Replace the all-stub `NatsRqueueUtilityService` with real impls for the operations
JetStream can model: `pauseUnpauseQueue` persists the `paused` flag on `QueueConfig`
in the queue-config KV bucket and notifies the local listener container so the poller
stops dispatching; `deleteMessage` is a soft delete via `MessageMetadataService`
(stream message persists, dashboard hides via the metadata flag); `getDataType`
reports `STREAM`. `moveMessage`, `enqueueMessage`, and `makeEmpty` deliberately
remain "not supported" — there is no JetStream primitive for those.

Update `RqueueQDetailServiceImpl.getRunningTasks` / `getScheduledTasks` to return
header-only tables when the broker capabilities suppress those sections, instead of
emitting zero rows or 501s on NATS.

20 new unit tests cover the pause/delete paths and lock in the still-unsupported
operations. Updates `nats-task.md` / `nats-task-v2.md` to reflect what landed.

Assisted-By: Claude Code

* nats-web: capability-aware nav / charts and stream-based peek

End-to-end browser-tested the NATS dashboard and shipp... (continued)

2628 of 3487 branches covered (75.37%)

Branch coverage included in aggregate %.

128 of 179 new or added lines in 12 files covered. (71.51%)

1 existing line in 1 file now uncovered.

7841 of 9062 relevant lines covered (86.53%)

0.87 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

0.0
/rqueue-core/src/main/java/com/github/sonus21/rqueue/metrics/RqueueQueueMetricsProvider.java
1
/*
2
 * Copyright (c) 2026 Sonu Kumar
3
 *
4
 * Licensed under the Apache License, Version 2.0 (the "License");
5
 * You may not use this file except in compliance with the License.
6
 * You may obtain a copy of the License at
7
 *
8
 *     https://www.apache.org/licenses/LICENSE-2.0
9
 *
10
 * Unless required by applicable law or agreed to in writing, software
11
 * distributed under the License is distributed on an "AS IS" BASIS,
12
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
 * See the License for the specific language governing permissions and limitations under the License.
14
 *
15
 */
16
package com.github.sonus21.rqueue.metrics;
17

18
/**
19
 * Backend-agnostic provider of queue-depth metrics. Each backend (Redis, NATS, ...) supplies its
20
 * own implementation; consumers like {@link RqueueMetrics} read sizes through this interface
21
 * instead of reaching into a Redis-shaped DAO.
22
 *
23
 * <p>The {@code queueName} argument is the user-facing queue name (the value bound on
24
 * {@code @RqueueListener(value="...")}), not an internal storage key. Implementations are
25
 * responsible for mapping it to the appropriate backend-specific key(s).
26
 *
27
 * <p>Implementations must return {@code 0} when a queue has no messages of the requested kind
28
 * (rather than throwing) so callers can use the values directly as gauge readings.
29
 */
30
public interface RqueueQueueMetricsProvider {
31

32
  /**
33
   * Number of messages waiting to be consumed from {@code queueName} — i.e. enqueued and ready for
34
   * a worker to pick up, excluding messages already in-flight (processing) or scheduled for a
35
   * future delivery time.
36
   */
37
  long getPendingMessageCount(String queueName);
38

39
  /**
40
   * Number of messages enqueued to {@code queueName} with a future delivery time that has not yet
41
   * elapsed. Backends that don't support delayed delivery return {@code 0}.
42
   */
43
  long getScheduledMessageCount(String queueName);
44

45
  /**
46
   * Number of messages currently in-flight for {@code queueName} — handed to a worker but not yet
47
   * acked or nacked. Backends without an explicit in-flight set return {@code 0}.
48
   */
49
  long getProcessingMessageCount(String queueName);
50

51
  /**
52
   * Number of messages in the dead-letter queue associated with {@code queueName}. Returns
53
   * {@code 0} when no DLQ is configured for the queue or the backend does not surface DLQ depth.
54
   */
55
  long getDeadLetterMessageCount(String queueName);
56

57
  /**
58
   * Priority-aware variant of {@link #getPendingMessageCount(String)}. The default implementation
59
   * ignores priority and returns the parent queue depth, which is the right behaviour for backends
60
   * that don't model per-priority sub-queues.
61
   */
62
  default long getPendingMessageCount(String queueName, String priority) {
63
    return getPendingMessageCount(queueName);
×
64
  }
65

66
  /** Priority-aware variant of {@link #getScheduledMessageCount(String)}. */
67
  default long getScheduledMessageCount(String queueName, String priority) {
68
    return getScheduledMessageCount(queueName);
×
69
  }
70

71
  /** Priority-aware variant of {@link #getProcessingMessageCount(String)}. */
72
  default long getProcessingMessageCount(String queueName, String priority) {
73
    return getProcessingMessageCount(queueName);
×
74
  }
75

76
  /**
77
   * Per-consumer variant of {@link #getPendingMessageCount(String)}. When two
78
   * {@code @RqueueListener} methods on the same queue declare different {@code consumerName}
79
   * overrides, each gets its own QueueDetail and its own metric registration; backends that can
80
   * report per-consumer pending depth (e.g. NATS JetStream Limits/Interest streams or any
81
   * fan-out broker) should override this. The default delegates to the queue-level call so
82
   * single-consumer queues, and backends without per-consumer state, behave unchanged.
83
   *
84
   * @param queueName    user-facing queue name
85
   * @param consumerName consumer-name override from {@code @RqueueListener(consumerName=...)};
86
   *                     {@code null} or empty when no override is set
87
   */
88
  default long getPendingMessageCountByConsumer(String queueName, String consumerName) {
NEW
89
    return getPendingMessageCount(queueName);
×
90
  }
91

92
  /** Per-consumer variant of {@link #getProcessingMessageCount(String)}. See related javadoc. */
93
  default long getProcessingMessageCountByConsumer(String queueName, String consumerName) {
NEW
94
    return getProcessingMessageCount(queueName);
×
95
  }
96
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc