Commit a3d4798
committed
Add
Added a private helper method, `IsExtendedAttributeMismatch()`, to `TopicRepositoryBase`, which will detect a mismatch between where an existing `AttributeValue` _has been_ saved, and where it _should be_ saved according to the `AttributeDescriptor. This allows us to identify scenarios where the conigured storage location has changed since the attribute value was last saved.
This `IsExtendedAttributeMismatch()` method is encorporated into the `GetAttributes()` method such that any mismatched attributes will be returned if `isDirty` is `true`—even if `AttributeValue.IsDirty` is `false`. This is important because even though the _value_ hasn't changed, the _storage location_ has and, therefore, it should be treated _as though_ it were `IsDirty`.
This includes two unit test cases to validate this functionality—one to make sure that `!IsDirty` attributes are returned if `IsExtendedAttributeMismatch()` is true, and another to make sure they _aren't_ returned if the `isExtendedAttribute` parameter doesn't match the `AttributeDescriptor.IsExtendedAttribute` property.IsExtendedAttributeMismatch() logic into GetAttributes()
1 parent 0d44c08 commit a3d4798
2 files changed
Lines changed: 91 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
129 | 129 | | |
130 | 130 | | |
131 | 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 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
132 | 177 | | |
133 | 178 | | |
134 | 179 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
515 | 515 | | |
516 | 516 | | |
517 | 517 | | |
518 | | - | |
| 518 | + | |
519 | 519 | | |
520 | 520 | | |
521 | 521 | | |
| |||
536 | 536 | | |
537 | 537 | | |
538 | 538 | | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
| 543 | + | |
| 544 | + | |
| 545 | + | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
539 | 552 | | |
540 | 553 | | |
541 | 554 | | |
| |||
643 | 656 | | |
644 | 657 | | |
645 | 658 | | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
646 | 691 | | |
647 | 692 | | |
648 | 693 | | |
| |||
0 commit comments