Commit fdfc464
Issue #9 — list_tables returned [] for bases where the getApplicationScaffoldingData
endpoint returns tableById + visibleTableOrder alongside an empty tables:[] stub.
Empty arrays are truthy in JS, so the || chain short-circuited at tables:[] before
reaching Object.values(tableById).
Fix: extracted parsing into AirtableClient.parseScaffoldingTables() which guards
each candidate with .length > 0, handles visibleTableOrder in addition to tableOrder,
and uses Object.values(tableById) as the final fallback. list_tables handler now
delegates to this method. 5 regression tests added.
Issue #10 — query_records returned {count:0, rows:[]} for views with real records.
Two bugs:
1. Wrong response field: code read queryResults[queryId].rows but the readQueries
endpoint returns querySlices[0].rowIds + tableDataById[tableId].partialRowById
(confirmed from capture 2026-05-21T14-16-09-125Z.json).
2. Silent failure: res.json().catch(()=>({})) swallowed non-JSON (msgpack) parse
errors, masking the problem entirely.
Fix: rewrote response parsing to use the correct querySlices + tableDataById path.
res.json() replaced with res.text() + explicit JSON.parse that throws a descriptive
error on msgpack/binary responses instead of returning empty. failureReasonByQueryId
now surfaces query-level errors. Debug mode now exposes the raw API response instead
of the already-processed result. 4 regression tests added.
249 tests pass (245 before + 9 new).
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
1 parent 6b1bc6a commit fdfc464
3 files changed
Lines changed: 209 additions & 18 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
494 | 494 | | |
495 | 495 | | |
496 | 496 | | |
| 497 | + | |
| 498 | + | |
| 499 | + | |
| 500 | + | |
| 501 | + | |
| 502 | + | |
| 503 | + | |
| 504 | + | |
| 505 | + | |
| 506 | + | |
| 507 | + | |
| 508 | + | |
| 509 | + | |
| 510 | + | |
497 | 511 | | |
498 | 512 | | |
499 | 513 | | |
| |||
2282 | 2296 | | |
2283 | 2297 | | |
2284 | 2298 | | |
2285 | | - | |
2286 | | - | |
2287 | | - | |
| 2299 | + | |
| 2300 | + | |
| 2301 | + | |
| 2302 | + | |
| 2303 | + | |
| 2304 | + | |
| 2305 | + | |
| 2306 | + | |
| 2307 | + | |
| 2308 | + | |
| 2309 | + | |
| 2310 | + | |
| 2311 | + | |
2288 | 2312 | | |
2289 | | - | |
| 2313 | + | |
| 2314 | + | |
| 2315 | + | |
| 2316 | + | |
| 2317 | + | |
| 2318 | + | |
| 2319 | + | |
| 2320 | + | |
| 2321 | + | |
| 2322 | + | |
| 2323 | + | |
| 2324 | + | |
| 2325 | + | |
| 2326 | + | |
| 2327 | + | |
| 2328 | + | |
| 2329 | + | |
2290 | 2330 | | |
2291 | 2331 | | |
2292 | 2332 | | |
| |||
2305 | 2345 | | |
2306 | 2346 | | |
2307 | 2347 | | |
2308 | | - | |
2309 | | - | |
2310 | | - | |
2311 | | - | |
2312 | | - | |
2313 | | - | |
| 2348 | + | |
| 2349 | + | |
| 2350 | + | |
| 2351 | + | |
| 2352 | + | |
| 2353 | + | |
| 2354 | + | |
| 2355 | + | |
| 2356 | + | |
2314 | 2357 | | |
2315 | 2358 | | |
2316 | 2359 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1570 | 1570 | | |
1571 | 1571 | | |
1572 | 1572 | | |
1573 | | - | |
1574 | | - | |
1575 | | - | |
1576 | | - | |
1577 | | - | |
1578 | | - | |
| 1573 | + | |
1579 | 1574 | | |
1580 | 1575 | | |
1581 | 1576 | | |
| |||
2245 | 2240 | | |
2246 | 2241 | | |
2247 | 2242 | | |
2248 | | - | |
2249 | | - | |
| 2243 | + | |
| 2244 | + | |
2250 | 2245 | | |
2251 | 2246 | | |
2252 | 2247 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
333 | 333 | | |
334 | 334 | | |
335 | 335 | | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
| 365 | + | |
| 366 | + | |
| 367 | + | |
| 368 | + | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
336 | 389 | | |
337 | 390 | | |
338 | 391 | | |
| |||
827 | 880 | | |
828 | 881 | | |
829 | 882 | | |
| 883 | + | |
| 884 | + | |
| 885 | + | |
| 886 | + | |
| 887 | + | |
| 888 | + | |
| 889 | + | |
| 890 | + | |
| 891 | + | |
| 892 | + | |
| 893 | + | |
| 894 | + | |
| 895 | + | |
| 896 | + | |
| 897 | + | |
| 898 | + | |
| 899 | + | |
| 900 | + | |
| 901 | + | |
| 902 | + | |
| 903 | + | |
| 904 | + | |
| 905 | + | |
| 906 | + | |
| 907 | + | |
| 908 | + | |
| 909 | + | |
| 910 | + | |
| 911 | + | |
| 912 | + | |
| 913 | + | |
| 914 | + | |
| 915 | + | |
| 916 | + | |
| 917 | + | |
| 918 | + | |
| 919 | + | |
| 920 | + | |
| 921 | + | |
| 922 | + | |
| 923 | + | |
| 924 | + | |
| 925 | + | |
| 926 | + | |
| 927 | + | |
| 928 | + | |
| 929 | + | |
| 930 | + | |
| 931 | + | |
| 932 | + | |
| 933 | + | |
| 934 | + | |
| 935 | + | |
| 936 | + | |
| 937 | + | |
| 938 | + | |
| 939 | + | |
| 940 | + | |
| 941 | + | |
| 942 | + | |
| 943 | + | |
| 944 | + | |
| 945 | + | |
| 946 | + | |
| 947 | + | |
| 948 | + | |
| 949 | + | |
| 950 | + | |
| 951 | + | |
| 952 | + | |
| 953 | + | |
| 954 | + | |
| 955 | + | |
| 956 | + | |
| 957 | + | |
| 958 | + | |
| 959 | + | |
| 960 | + | |
| 961 | + | |
| 962 | + | |
| 963 | + | |
| 964 | + | |
| 965 | + | |
| 966 | + | |
| 967 | + | |
| 968 | + | |
| 969 | + | |
| 970 | + | |
| 971 | + | |
| 972 | + | |
| 973 | + | |
| 974 | + | |
| 975 | + | |
| 976 | + | |
| 977 | + | |
| 978 | + | |
| 979 | + | |
| 980 | + | |
| 981 | + | |
| 982 | + | |
830 | 983 | | |
831 | 984 | | |
832 | 985 | | |
| |||
0 commit comments