Skip to content

VRO v2 Roadmap

Yoom Lam edited this page Mar 29, 2023 · 44 revisions

iMVP (Integrated MVP)

Workflow Diagram

Legend:

  • light-green box: implemented in v1
  • trapezoid: microservice for External APIs; listens for requests added to an associated RabbitMQ queue
  • rounded box: decision point (consider implementing using Camel Dynamic Routing)
  • "DB" all refer to the same database and "bipClaimsApi` represents the same microservice; they're drawn separately to reduce clutter
  • Also to reduce clutter, the VRO_API_error box represents returning an error code back to the VRO API client.

For details, refer to:

Another workflow digram from Mural

Tasks

(only for single-issue hypertension CFI and presumptives; targeting Dec 31st deployment)

Ordered by priority:

Handling presumptives (NEW claims):

Other tasks:

  • DB metrics
    • claim_stats_Endpoint: Add claim_stats endpoint to API for reporting and monitoring. Other metrics (from Zach):
      1. how many claims are we evaluating programmatically for sufficient evidence?
      2. how many of those claims are deemed to have sufficient evidence?
      3. how many claims deemed to have insufficient evidence lead to an auto-exam?
      4. how many claims that are deemed to have sufficient evidence lead to: a) immediate rating, and b) not an immediate rating (e.g., deferral, manual exam)?
  • Ensure RabbitMQ messages are processed despite microservices failures
  • 🏃 (Ryan, Cameron) Connect VRO non-prod env with other VA non-prod envs
  • 🏃 Clean up codebase; comment out unused dependencies
  • 🏃 (Afsin) Add more automated end-to-end and integration testing
  • 🏃 (OCTO) Document how to update version numbers of VRO, container images, etc.
  • DONE: Persist API request contents for reloading in case of failures
  • Document how to extract microservices into Docker containers and deploy them
  • Document how to debug and modify DB data in prod

Code improvements tasks

  • Mechanism to ensure microservices are idempotent and following good patterns
  • Document conventions on how requesters handle errors, such as resubmitting the request -- see comment (OBE task: Improve robustness to failures by using retry pattern -- retry logic in Camel)

Additional DevOps tasks

  • DONE: Set up test code coverage and other PR requirement checks. Search jacoco_enforce_violations in the code.
  • DONE: Enable linter and pre-commit hook
  • Set up LHDI monitoring and diagnostics tools, i.e. DataDog monitoring, Prometheus, Grafana, Jaeger
  • Set up DB querying (BI) tools for reporting, e.g., Metabase/Superset
  • Set up DB monitoring tools to detect slow queries, e.g., NewRelic
Clone this wiki locally