Code Quality Improvement Plan
This document tracks code quality improvements for the Prometheus Java Client library. Work through these items incrementally across sessions.
High Priority
1. Add Missing Test Coverage for Exporter Modules
2. Eliminate Dropwizard Module Duplication
3. Address Technical Debt (TODOs)
4. Improve Exception Handling
Replace broad catch (Exception e) with specific exception types:
Medium Priority
5. Add Branch Coverage to JaCoCo
<limit>
<counter>BRANCH</counter>
<value>COVEREDRATIO</value>
<minimum>0.50</minimum>
</limit>
6. Raise Minimum Coverage Thresholds
Current thresholds to review:
7. Add SpotBugs
8. Narrow Checkstyle Suppressions
Lower Priority
9. Refactor Large Classes
10. Document Configuration Classes
11. Consolidate Servlet Exporter Duplication
12. Add Mutation Testing
Progress Notes
Add notes here as items are completed:
| Date |
Item |
Notes |
| 2026-01-24 |
Missing Test Coverage for Exporter Modules |
Added 55 tests across 4 modules: exporter-common (22 tests), servlet-jakarta (14 tests), servlet-javax (14 tests), otel-agent-resources (5 tests). All tests passing. |
| 2026-01-24 |
Eliminate Dropwizard Module Duplication |
Created AbstractDropwizardExports base class (267 lines) with generic type parameters. Reduced dropwizard module from 297 to 209 lines (-88 lines, -30%), dropwizard5 module from 297 to 212 lines (-85 lines, -29%). All tests passing (32 tests dropwizard5, 13 tests dropwizard). |
Code Quality Improvement Plan
This document tracks code quality improvements for the Prometheus Java Client library. Work through these items incrementally across sessions.
High Priority
1. Add Missing Test Coverage for Exporter Modules
prometheus-metrics-exporter-common- base module, no testsprometheus-metrics-exporter-servlet-jakarta- no testsprometheus-metrics-exporter-servlet-javax- no testsprometheus-metrics-exporter-opentelemetry-otel-agent-resources- no tests2. Eliminate Dropwizard Module Duplication
prometheus-metrics-instrumentation-dropwizardandprometheus-metrics-instrumentation-dropwizard5(~297 lines each, nearly identical)3. Address Technical Debt (TODOs)
prometheus-metrics-core/src/main/java/io/prometheus/metrics/core/metrics/Histogram.java:965- "reset interval isn't tested yet"prometheus-metrics-core/src/main/java/io/prometheus/metrics/core/metrics/Summary.java:205- "Exemplars (are hard-coded as empty)"prometheus-metrics-core/src/main/java/io/prometheus/metrics/core/metrics/SlidingWindow.java:18- "synchronized implementation, room for optimization"prometheus-metrics-config/src/main/java/io/prometheus/metrics/config/PrometheusPropertiesLoader.java:105- "Add environment variables like EXEMPLARS_ENABLED"prometheus-metrics-exporter-opentelemetry/src/main/java/io/prometheus/metrics/exporter/opentelemetry/PrometheusMetricProducer.java:44- "filter configuration for OpenTelemetry exporter"prometheus-metrics-config/src/main/java/io/prometheus/metrics/config/ExporterOpenTelemetryProperties.java:7- "JavaDoc missing"4. Improve Exception Handling
Replace broad
catch (Exception e)with specific exception types:prometheus-metrics-instrumentation-dropwizard5/src/main/java/.../DropwizardExports.java:237prometheus-metrics-instrumentation-caffeine/src/main/java/.../CacheMetricsCollector.java:229prometheus-metrics-exporter-opentelemetry/src/main/java/.../PrometheusInstrumentationScope.java:47prometheus-metrics-exporter-opentelemetry/src/main/java/.../OtelAutoConfig.java:115prometheus-metrics-instrumentation-jvm/src/main/java/.../JvmNativeMemoryMetrics.java:166prometheus-metrics-exporter-httpserver/src/main/java/.../HttpExchangeAdapter.java:115Medium Priority
5. Add Branch Coverage to JaCoCo
pom.xmlto add branch coverage requirement (~50% minimum)6. Raise Minimum Coverage Thresholds
Current thresholds to review:
prometheus-metrics-exporter-httpserver- 45% (raise to 60%)prometheus-metrics-instrumentation-dropwizard5- 50% (raise to 60%)prometheus-metrics-exposition-textformats- 50% (raise to 60%)prometheus-metrics-instrumentation-jvm- 55% (raise to 60%)7. Add SpotBugs
spotbugs-maven-plugintopom.xml8. Narrow Checkstyle Suppressions
checkstyle-suppressions.xml- currently suppresses ALL Javadoc checks globallyLower Priority
9. Refactor Large Classes
prometheus-metrics-core/src/main/java/.../Histogram.java(978 lines) - consider extracting native histogram logic10. Document Configuration Classes
PrometheusPropertiesLoader- add JavaDocExporterPropertiesand related classes - add JavaDocExporterOpenTelemetryProperties- add JavaDoc (noted in TODO)11. Consolidate Servlet Exporter Duplication
servlet-jakartaandservlet-javaxintoexporter-common12. Add Mutation Testing
pitest-maven) for critical modulesprometheus-metrics-coreandprometheus-metrics-modelProgress Notes
Add notes here as items are completed: