Commit f75a08a
authored
Fix OH renewability/refillability to require completed dispense (#27123)
* fix: require completed dispense for OH renewability gate 3
* fix: require completed dispense for OH refillability Gate 5
Apply the same entered-in-error fix to the refill helper that was applied
to the renewability helper. Gate 5 now checks for at least one completed
MedicationDispense, preventing prescriptions with only entered-in-error
dispenses from being marked as refillable.
Bug: An Oracle Health prescription whose only MedicationDispense had
status 'entered-in-error' was incorrectly marked is_refillable: true,
causing it to appear on the Ready to Refill page even though no initial
fill was ever processed.
Root cause: Gate 5 checked medication_dispenses(resource).empty? which
passes for any dispense regardless of status. entered-in-error dispenses
represent voided records, not actual fills.
Fix: Replace the empty? check with completed_dispense_exists? which
requires at least one dispense with status == 'completed'.
* Move completed_dispense_exists? to FhirHelpers to deduplicate
completed_dispense_exists? was defined identically in both
OracleHealthRefillHelper and OracleHealthRenewabilityHelper.
Since it operates on FHIR MedicationDispense data and both helpers
already depend on FhirHelpers, move it there as the single source
of truth.
most_recent_dispense_in_progress? stays in OracleHealthRefillHelper
since it's not duplicated (only used by refill helper and adapter).
* Address Copilot review: fix dependency docs and renewability test
- Fix refill helper dependency docs: replace stale extract_expiration_date
with parse_expiration_date_utc and prescription_expired? (actual deps)
- Add completed_dispense_exists? and non_va_med? to renewability helper
dependency docs
- Fix entered-in-error renewability test: change from refills:1/non-expired
(which failed on Gate 6, not Gate 3) to refills:0/expired so the failure
is attributable to Gate 3 (completed dispense required)1 parent 9cacdf6 commit f75a08a
File tree
5 files changed
+92
-9
lines changed- lib/unified_health_data/adapters
- spec/lib/unified_health_data/adapters
5 files changed
+92
-9
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
81 | 81 | | |
82 | 82 | | |
83 | 83 | | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
84 | 94 | | |
85 | 95 | | |
86 | 96 | | |
| |||
Lines changed: 6 additions & 7 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | | - | |
12 | | - | |
13 | | - | |
14 | 11 | | |
15 | 12 | | |
16 | 13 | | |
17 | 14 | | |
| 15 | + | |
18 | 16 | | |
19 | | - | |
| 17 | + | |
| 18 | + | |
20 | 19 | | |
21 | 20 | | |
22 | 21 | | |
| |||
25 | 24 | | |
26 | 25 | | |
27 | 26 | | |
28 | | - | |
| 27 | + | |
29 | 28 | | |
30 | 29 | | |
31 | 30 | | |
| |||
37 | 36 | | |
38 | 37 | | |
39 | 38 | | |
40 | | - | |
| 39 | + | |
41 | 40 | | |
42 | 41 | | |
43 | 42 | | |
| |||
75 | 74 | | |
76 | 75 | | |
77 | 76 | | |
78 | | - | |
| 77 | + | |
79 | 78 | | |
80 | 79 | | |
81 | 80 | | |
| |||
Lines changed: 4 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
| 15 | + | |
15 | 16 | | |
| 17 | + | |
16 | 18 | | |
17 | 19 | | |
18 | 20 | | |
| |||
23 | 25 | | |
24 | 26 | | |
25 | 27 | | |
26 | | - | |
| 28 | + | |
27 | 29 | | |
28 | 30 | | |
29 | 31 | | |
| |||
35 | 37 | | |
36 | 38 | | |
37 | 39 | | |
38 | | - | |
| 40 | + | |
39 | 41 | | |
40 | 42 | | |
41 | 43 | | |
| |||
Lines changed: 36 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
127 | 127 | | |
128 | 128 | | |
129 | 129 | | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
130 | 166 | | |
131 | 167 | | |
132 | 168 | | |
| |||
Lines changed: 36 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
180 | 180 | | |
181 | 181 | | |
182 | 182 | | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
183 | 219 | | |
184 | 220 | | |
185 | 221 | | |
| |||
0 commit comments