Commit 02b9ae7
fix(mrs): use bracket notation for position in form-encoded requests (#95)
* fix(mrs): use bracket notation for position in form-encoded requests
GitLab API expects position fields as separate form parameters with bracket
notation (position[base_sha], position[head_sha], etc.) when using
form-encoded content type.
Previously, position was serialized as a JSON string which resulted in
400 Bad Request errors when creating diff-based discussions or draft notes.
Fixes:
- manage_mr_discussion action 'thread'
- manage_mr_discussion action 'suggest'
- manage_draft_notes action 'create'
- manage_draft_notes action 'update'
Co-Authored-By: Claude Opus 4.5 <[email protected]>
* test(mrs): update suggest tests for bracket notation position encoding
Update test expectations to match the new flattenPositionToFormFields
implementation that uses bracket notation (position[base_sha]) instead
of JSON.stringify for form-encoded requests.
Co-Authored-By: Claude Opus 4.5 <[email protected]>
* test(mrs): add unit tests for flattenPositionToFormFields helper
Export the helper function and add comprehensive unit tests covering:
- Flat position object with bracket notation
- Nested objects (2 levels)
- Deeply nested objects (3 levels - line_range.start.line_code)
- Null and undefined value handling
- Array handling at top and nested levels
- Preservation of existing body fields
- Empty position object
- Boolean and number values
Co-Authored-By: Claude Opus 4.5 <[email protected]>
* test(mrs): add integration tests for position encoding and schema validation
- Add integration tests for diff notes with position (E2E validation)
- Add integration test for draft notes with position
- Add unit tests for schema superRefine validation (list/get/compare field checks)
- Add unit tests for index.ts exports
---------
Co-authored-by: Ruslan Tabolin <[email protected]>
Co-authored-by: Claude Opus 4.5 <[email protected]>
Co-authored-by: Dmitry Prudnikov <[email protected]>1 parent 9eda6eb commit 02b9ae7
File tree
4 files changed
+555
-7
lines changed- src/entities/mrs
- tests
- integration
- setup
- unit/entities/mrs
4 files changed
+555
-7
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
13 | 51 | | |
14 | 52 | | |
15 | 53 | | |
| |||
340 | 378 | | |
341 | 379 | | |
342 | 380 | | |
343 | | - | |
| 381 | + | |
344 | 382 | | |
345 | 383 | | |
346 | 384 | | |
| |||
444 | 482 | | |
445 | 483 | | |
446 | 484 | | |
447 | | - | |
448 | 485 | | |
| 486 | + | |
449 | 487 | | |
450 | 488 | | |
451 | 489 | | |
| |||
494 | 532 | | |
495 | 533 | | |
496 | 534 | | |
497 | | - | |
| 535 | + | |
498 | 536 | | |
499 | 537 | | |
500 | 538 | | |
| |||
510 | 548 | | |
511 | 549 | | |
512 | 550 | | |
513 | | - | |
| 551 | + | |
514 | 552 | | |
515 | 553 | | |
516 | 554 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1205 | 1205 | | |
1206 | 1206 | | |
1207 | 1207 | | |
| 1208 | + | |
| 1209 | + | |
| 1210 | + | |
| 1211 | + | |
| 1212 | + | |
| 1213 | + | |
| 1214 | + | |
| 1215 | + | |
| 1216 | + | |
| 1217 | + | |
| 1218 | + | |
| 1219 | + | |
| 1220 | + | |
| 1221 | + | |
| 1222 | + | |
| 1223 | + | |
| 1224 | + | |
| 1225 | + | |
| 1226 | + | |
| 1227 | + | |
| 1228 | + | |
| 1229 | + | |
| 1230 | + | |
| 1231 | + | |
| 1232 | + | |
| 1233 | + | |
| 1234 | + | |
| 1235 | + | |
| 1236 | + | |
| 1237 | + | |
| 1238 | + | |
| 1239 | + | |
| 1240 | + | |
| 1241 | + | |
| 1242 | + | |
| 1243 | + | |
| 1244 | + | |
| 1245 | + | |
| 1246 | + | |
| 1247 | + | |
| 1248 | + | |
| 1249 | + | |
| 1250 | + | |
| 1251 | + | |
| 1252 | + | |
| 1253 | + | |
| 1254 | + | |
| 1255 | + | |
| 1256 | + | |
| 1257 | + | |
| 1258 | + | |
| 1259 | + | |
| 1260 | + | |
| 1261 | + | |
| 1262 | + | |
| 1263 | + | |
| 1264 | + | |
| 1265 | + | |
| 1266 | + | |
| 1267 | + | |
| 1268 | + | |
| 1269 | + | |
| 1270 | + | |
| 1271 | + | |
| 1272 | + | |
| 1273 | + | |
| 1274 | + | |
| 1275 | + | |
| 1276 | + | |
| 1277 | + | |
| 1278 | + | |
| 1279 | + | |
| 1280 | + | |
| 1281 | + | |
| 1282 | + | |
| 1283 | + | |
| 1284 | + | |
| 1285 | + | |
| 1286 | + | |
| 1287 | + | |
| 1288 | + | |
| 1289 | + | |
| 1290 | + | |
| 1291 | + | |
| 1292 | + | |
| 1293 | + | |
| 1294 | + | |
| 1295 | + | |
| 1296 | + | |
| 1297 | + | |
| 1298 | + | |
| 1299 | + | |
| 1300 | + | |
| 1301 | + | |
| 1302 | + | |
| 1303 | + | |
| 1304 | + | |
| 1305 | + | |
| 1306 | + | |
| 1307 | + | |
| 1308 | + | |
| 1309 | + | |
| 1310 | + | |
| 1311 | + | |
| 1312 | + | |
| 1313 | + | |
| 1314 | + | |
| 1315 | + | |
| 1316 | + | |
| 1317 | + | |
| 1318 | + | |
| 1319 | + | |
| 1320 | + | |
| 1321 | + | |
| 1322 | + | |
| 1323 | + | |
| 1324 | + | |
| 1325 | + | |
| 1326 | + | |
| 1327 | + | |
| 1328 | + | |
| 1329 | + | |
| 1330 | + | |
| 1331 | + | |
| 1332 | + | |
| 1333 | + | |
| 1334 | + | |
| 1335 | + | |
| 1336 | + | |
| 1337 | + | |
| 1338 | + | |
| 1339 | + | |
| 1340 | + | |
| 1341 | + | |
| 1342 | + | |
| 1343 | + | |
| 1344 | + | |
| 1345 | + | |
| 1346 | + | |
| 1347 | + | |
| 1348 | + | |
| 1349 | + | |
| 1350 | + | |
| 1351 | + | |
| 1352 | + | |
| 1353 | + | |
| 1354 | + | |
| 1355 | + | |
| 1356 | + | |
| 1357 | + | |
| 1358 | + | |
| 1359 | + | |
| 1360 | + | |
| 1361 | + | |
| 1362 | + | |
| 1363 | + | |
| 1364 | + | |
| 1365 | + | |
| 1366 | + | |
| 1367 | + | |
| 1368 | + | |
| 1369 | + | |
| 1370 | + | |
| 1371 | + | |
| 1372 | + | |
| 1373 | + | |
| 1374 | + | |
| 1375 | + | |
| 1376 | + | |
| 1377 | + | |
| 1378 | + | |
| 1379 | + | |
| 1380 | + | |
| 1381 | + | |
| 1382 | + | |
| 1383 | + | |
| 1384 | + | |
| 1385 | + | |
| 1386 | + | |
| 1387 | + | |
| 1388 | + | |
| 1389 | + | |
| 1390 | + | |
| 1391 | + | |
| 1392 | + | |
| 1393 | + | |
| 1394 | + | |
| 1395 | + | |
| 1396 | + | |
| 1397 | + | |
| 1398 | + | |
| 1399 | + | |
| 1400 | + | |
| 1401 | + | |
| 1402 | + | |
| 1403 | + | |
| 1404 | + | |
| 1405 | + | |
| 1406 | + | |
| 1407 | + | |
| 1408 | + | |
| 1409 | + | |
| 1410 | + | |
| 1411 | + | |
| 1412 | + | |
| 1413 | + | |
| 1414 | + | |
| 1415 | + | |
| 1416 | + | |
| 1417 | + | |
1208 | 1418 | | |
1209 | 1419 | | |
1210 | 1420 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
33 | 33 | | |
34 | 34 | | |
35 | 35 | | |
| 36 | + | |
36 | 37 | | |
37 | 38 | | |
38 | 39 | | |
| |||
0 commit comments