Commit cd88e63
committed
backup: canonicalize DynamoDB N keys + sort schema arrays (PR #716, round 4)
Codex round 9 raised two issues on commit d67baf8:
1. P1: ddbKeyAttrToSegment was emitting `EncodeSegment([]byte(v.N))`
for numeric primary-key attributes, but DynamoDB N equality is
numeric — `"1"` and `"1.0"` (or `"100"` and `"1e2"`, or `"0.5"`
and `"5e-1"`) name the same logical item. In migration mode
where source and active rows used different decimal text for
the same value, both rows survived at distinct paths and
restore replayed duplicates. Mirror the live adapter's
canonicalNumberString (adapter/dynamodb.go:7651) which uses
big.Rat — same canonical form keeps backup filenames in lockstep
with the live equality check.
2. P2: schemaToPublic ranged over Go maps for both
global_secondary_indexes and attribute_definitions, so identical
snapshots produced different `_schema.json` byte output across
runs. Sort by name before append.
Tests:
- TestDDB_CanonicalNumberKeySegment: equivalence pairs
("1"/"1.0", "100"/"1e2", "-0"/"0", "0.5"/"5e-1") collapse
to the same key segment.
- TestDDB_SchemaJSONIsDeterministic: 32 calls to schemaToPublic
on the same schema produce identical attribute_definitions and
GSI orders, both matching the documented sort-by-name.1 parent d67baf8 commit cd88e63
2 files changed
Lines changed: 158 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| 8 | + | |
8 | 9 | | |
9 | 10 | | |
| 11 | + | |
10 | 12 | | |
11 | 13 | | |
12 | 14 | | |
| |||
378 | 380 | | |
379 | 381 | | |
380 | 382 | | |
381 | | - | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
382 | 395 | | |
383 | 396 | | |
384 | 397 | | |
385 | 398 | | |
386 | 399 | | |
387 | 400 | | |
388 | 401 | | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
389 | 417 | | |
390 | 418 | | |
391 | 419 | | |
| |||
407 | 435 | | |
408 | 436 | | |
409 | 437 | | |
410 | | - | |
411 | | - | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
| 442 | + | |
| 443 | + | |
| 444 | + | |
| 445 | + | |
| 446 | + | |
| 447 | + | |
| 448 | + | |
| 449 | + | |
412 | 450 | | |
413 | 451 | | |
414 | 452 | | |
| |||
426 | 464 | | |
427 | 465 | | |
428 | 466 | | |
429 | | - | |
430 | | - | |
431 | | - | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
| 474 | + | |
| 475 | + | |
| 476 | + | |
432 | 477 | | |
433 | 478 | | |
434 | 479 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
375 | 375 | | |
376 | 376 | | |
377 | 377 | | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
| 429 | + | |
| 430 | + | |
| 431 | + | |
| 432 | + | |
| 433 | + | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
| 437 | + | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
| 442 | + | |
| 443 | + | |
| 444 | + | |
| 445 | + | |
| 446 | + | |
| 447 | + | |
| 448 | + | |
| 449 | + | |
| 450 | + | |
| 451 | + | |
| 452 | + | |
| 453 | + | |
| 454 | + | |
| 455 | + | |
| 456 | + | |
| 457 | + | |
| 458 | + | |
| 459 | + | |
| 460 | + | |
| 461 | + | |
| 462 | + | |
| 463 | + | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
| 474 | + | |
| 475 | + | |
| 476 | + | |
| 477 | + | |
| 478 | + | |
| 479 | + | |
| 480 | + | |
| 481 | + | |
| 482 | + | |
| 483 | + | |
| 484 | + | |
378 | 485 | | |
379 | 486 | | |
380 | 487 | | |
| |||
0 commit comments