Commit 988dc24
committed
perf(api): collapse stats on issue detail endpoints to save 100-300ms
Switch getIssueInOrg and getIssueByShortId from @sentry/api SDK to raw
apiRequestToRegion() to enable passing the collapse query parameter.
The SDK types declare query?: never on retrieveAnIssue and
resolveAShortId, blocking query params entirely.
Add ISSUE_DETAIL_COLLAPSE constant that collapses stats, lifetime,
filtered, and unhandled fields on all single-issue API calls. These
fields are never displayed in issue view, explain, or plan commands.
The count, userCount, firstSeen, and lastSeen fields remain unaffected
as they are top-level fields outside the collapsed sub-objects.
Also add collapse to resolveSelector() which calls listIssuesPaginated
with perPage: 1 — previously fetched all fields for a single issue
that only needed identity data.
Estimated savings: 100-300ms per issue detail request by skipping
expensive Snuba/ClickHouse queries on the backend.1 parent 7da52e0 commit 988dc24
File tree
6 files changed
+221
-49
lines changed- src
- commands/issue
- lib
- api
- test/lib
6 files changed
+221
-49
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
880 | 880 | | |
881 | 881 | | |
882 | 882 | | |
| 883 | + | |
| 884 | + | |
883 | 885 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| 14 | + | |
14 | 15 | | |
15 | 16 | | |
16 | 17 | | |
| |||
137 | 138 | | |
138 | 139 | | |
139 | 140 | | |
140 | | - | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
141 | 144 | | |
142 | 145 | | |
143 | 146 | | |
| |||
182 | 185 | | |
183 | 186 | | |
184 | 187 | | |
185 | | - | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
186 | 191 | | |
187 | 192 | | |
188 | 193 | | |
| |||
240 | 245 | | |
241 | 246 | | |
242 | 247 | | |
243 | | - | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
244 | 251 | | |
245 | 252 | | |
246 | 253 | | |
| |||
255 | 262 | | |
256 | 263 | | |
257 | 264 | | |
258 | | - | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
259 | 270 | | |
260 | 271 | | |
261 | 272 | | |
| |||
327 | 338 | | |
328 | 339 | | |
329 | 340 | | |
330 | | - | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
331 | 344 | | |
332 | 345 | | |
333 | 346 | | |
| |||
413 | 426 | | |
414 | 427 | | |
415 | 428 | | |
416 | | - | |
| 429 | + | |
| 430 | + | |
417 | 431 | | |
418 | 432 | | |
419 | 433 | | |
420 | 434 | | |
| 435 | + | |
421 | 436 | | |
422 | 437 | | |
423 | 438 | | |
| |||
483 | 498 | | |
484 | 499 | | |
485 | 500 | | |
486 | | - | |
487 | | - | |
| 501 | + | |
| 502 | + | |
| 503 | + | |
| 504 | + | |
488 | 505 | | |
489 | 506 | | |
490 | 507 | | |
| |||
542 | 559 | | |
543 | 560 | | |
544 | 561 | | |
545 | | - | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
546 | 565 | | |
547 | 566 | | |
548 | 567 | | |
| |||
551 | 570 | | |
552 | 571 | | |
553 | 572 | | |
554 | | - | |
| 573 | + | |
| 574 | + | |
| 575 | + | |
555 | 576 | | |
556 | 577 | | |
557 | 578 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
48 | 48 | | |
49 | 49 | | |
50 | 50 | | |
| 51 | + | |
51 | 52 | | |
52 | 53 | | |
53 | 54 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
8 | | - | |
9 | | - | |
10 | | - | |
11 | | - | |
12 | | - | |
| 8 | + | |
13 | 9 | | |
14 | 10 | | |
15 | 11 | | |
16 | 12 | | |
| 13 | + | |
17 | 14 | | |
18 | 15 | | |
19 | 16 | | |
20 | 17 | | |
| 18 | + | |
21 | 19 | | |
22 | 20 | | |
23 | 21 | | |
24 | 22 | | |
25 | | - | |
26 | 23 | | |
27 | 24 | | |
28 | 25 | | |
| |||
74 | 71 | | |
75 | 72 | | |
76 | 73 | | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
77 | 92 | | |
78 | 93 | | |
79 | 94 | | |
| |||
237 | 252 | | |
238 | 253 | | |
239 | 254 | | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
240 | 258 | | |
241 | | - | |
242 | | - | |
243 | | - | |
244 | | - | |
245 | | - | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
246 | 266 | | |
247 | 267 | | |
248 | 268 | | |
249 | 269 | | |
250 | 270 | | |
251 | | - | |
| 271 | + | |
252 | 272 | | |
253 | 273 | | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
254 | 278 | | |
255 | 279 | | |
| 280 | + | |
256 | 281 | | |
257 | 282 | | |
258 | 283 | | |
259 | | - | |
| 284 | + | |
| 285 | + | |
260 | 286 | | |
261 | | - | |
262 | | - | |
263 | | - | |
264 | | - | |
265 | | - | |
266 | | - | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
267 | 296 | | |
268 | 297 | | |
269 | 298 | | |
270 | 299 | | |
271 | 300 | | |
272 | 301 | | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
273 | 310 | | |
274 | 311 | | |
275 | 312 | | |
276 | | - | |
| 313 | + | |
| 314 | + | |
277 | 315 | | |
278 | 316 | | |
279 | | - | |
| 317 | + | |
280 | 318 | | |
281 | | - | |
282 | | - | |
283 | | - | |
284 | | - | |
285 | | - | |
286 | | - | |
287 | | - | |
288 | | - | |
289 | | - | |
| 319 | + | |
290 | 320 | | |
291 | | - | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
292 | 329 | | |
293 | 330 | | |
294 | 331 | | |
| |||
308 | 345 | | |
309 | 346 | | |
310 | 347 | | |
311 | | - | |
312 | | - | |
313 | | - | |
| 348 | + | |
314 | 349 | | |
315 | 350 | | |
316 | 351 | | |
317 | 352 | | |
318 | 353 | | |
319 | 354 | | |
320 | | - | |
| 355 | + | |
321 | 356 | | |
322 | 357 | | |
323 | 358 | | |
| |||
333 | 368 | | |
334 | 369 | | |
335 | 370 | | |
336 | | - | |
| 371 | + | |
| 372 | + | |
337 | 373 | | |
338 | 374 | | |
339 | | - | |
| 375 | + | |
340 | 376 | | |
341 | 377 | | |
342 | 378 | | |
| |||
0 commit comments