mirror of
https://github.com/Instagram/IGListKit
synced 2026-05-06 06:58:26 +00:00
Summary: Actually this won't work and causes even more crashes. For example, if we reload cell 0 and insert at 0, we end up with just a single delete & insert at 0, which causes an inconsistency exception. `IGListApplyUpdatesToCollectionView` already takes care of avoiding multiple reloads of the same `NSIndexPath` by using a `NSMutableSet` when collecting the `reloadDeletePaths`. Reviewed By: apadalko Differential Revision: D21822502 fbshipit-source-id: c2382951ffe013f82c1de2492286d2911f40444d
154 lines
9.3 KiB
Objective-C
154 lines
9.3 KiB
Objective-C
/*
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#import <XCTest/XCTest.h>
|
|
|
|
#import <IGListDiffKit/IGListBatchUpdateData.h>
|
|
|
|
#import "IGListMoveIndexPathInternal.h"
|
|
|
|
// IGListMoveIndexInternal.h
|
|
@interface IGListMoveIndex (Private)
|
|
- (instancetype)initWithFrom:(NSInteger)from to:(NSInteger)to;
|
|
@end
|
|
|
|
@interface IGListBatchUpdateDataTests : XCTestCase
|
|
|
|
@end
|
|
|
|
@implementation IGListBatchUpdateDataTests
|
|
|
|
static NSIndexSet *indexSet(NSArray<NSNumber *> *arr) {
|
|
NSMutableIndexSet *set = [NSMutableIndexSet new];
|
|
for (NSNumber *n in arr) {
|
|
[set addIndex:[n integerValue]];
|
|
}
|
|
return set;
|
|
}
|
|
|
|
static NSIndexPath *newPath(NSInteger section, NSInteger item) {
|
|
return [NSIndexPath indexPathForItem:item inSection:section];
|
|
}
|
|
|
|
static IGListMoveIndexPath *newMovePath(NSInteger fromSection, NSInteger fromItem, NSInteger toSection, NSInteger toItem) {
|
|
return [[IGListMoveIndexPath alloc] initWithFrom:newPath(fromSection, fromItem) to:newPath(toSection, toItem)];
|
|
}
|
|
|
|
static IGListMoveIndex *newMove(NSInteger from, NSInteger to) {
|
|
return [[IGListMoveIndex alloc] initWithFrom:from to:to];
|
|
}
|
|
|
|
- (void)test_whenEmptyUpdates_thatResultExists {
|
|
IGListBatchUpdateData *result = [[IGListBatchUpdateData alloc] initWithInsertSections:indexSet(@[])
|
|
deleteSections:indexSet(@[])
|
|
moveSections:[NSSet new]
|
|
insertIndexPaths:@[]
|
|
deleteIndexPaths:@[]
|
|
updateIndexPaths:@[]
|
|
moveIndexPaths:@[]];
|
|
XCTAssertNotNil(result);
|
|
}
|
|
|
|
- (void)test_whenUpdatesAreClean_thatResultMatches {
|
|
IGListBatchUpdateData *result = [[IGListBatchUpdateData alloc] initWithInsertSections:indexSet(@[@0, @1])
|
|
deleteSections:indexSet(@[@5])
|
|
moveSections:[NSSet setWithArray:@[newMove(3, 4)]]
|
|
insertIndexPaths:@[newPath(0, 0)]
|
|
deleteIndexPaths:@[newPath(1, 0)]
|
|
updateIndexPaths:@[]
|
|
moveIndexPaths:@[newMovePath(6, 0, 6, 1)]];
|
|
XCTAssertEqualObjects(result.insertSections, indexSet(@[@0, @1]));
|
|
XCTAssertEqualObjects(result.deleteSections, indexSet(@[@5]));
|
|
XCTAssertEqualObjects(result.moveSections, [NSSet setWithArray:@[newMove(3, 4)]]);
|
|
XCTAssertEqualObjects(result.insertIndexPaths, @[newPath(0, 0)]);
|
|
XCTAssertEqualObjects(result.deleteIndexPaths, @[newPath(1, 0)]);
|
|
XCTAssertEqual(result.moveIndexPaths.count, 1);
|
|
XCTAssertEqualObjects(result.moveIndexPaths.firstObject, [[IGListMoveIndexPath alloc] initWithFrom:newPath(6, 0) to:newPath(6, 1)]);
|
|
}
|
|
|
|
- (void)test_whenMovingSections_withItemDeletes_thatResultConvertsConflicts_toDeletesAndInserts {
|
|
IGListBatchUpdateData *result = [[IGListBatchUpdateData alloc] initWithInsertSections:indexSet(@[])
|
|
deleteSections:indexSet(@[])
|
|
moveSections:[NSSet setWithArray:@[newMove(2, 4)]]
|
|
insertIndexPaths:@[]
|
|
deleteIndexPaths:@[newPath(2, 0), newPath(3, 4)]
|
|
updateIndexPaths:@[]
|
|
moveIndexPaths:@[]];
|
|
XCTAssertEqualObjects(result.insertSections, indexSet(@[@4]));
|
|
XCTAssertEqualObjects(result.deleteSections, indexSet(@[@2]));
|
|
XCTAssertEqualObjects(result.deleteIndexPaths, @[newPath(3, 4)]);
|
|
XCTAssertEqual(result.moveSections.count, 0);
|
|
}
|
|
|
|
- (void)test_whenMovingSections_withItemInserts_thatResultConvertsConflicts_toDeletesAndInserts {
|
|
IGListBatchUpdateData *result = [[IGListBatchUpdateData alloc] initWithInsertSections:indexSet(@[])
|
|
deleteSections:indexSet(@[])
|
|
moveSections:[NSSet setWithArray:@[newMove(2, 4)]]
|
|
insertIndexPaths:@[newPath(4, 0), newPath(3, 4)]
|
|
deleteIndexPaths:@[]
|
|
updateIndexPaths:@[]
|
|
moveIndexPaths:@[]];
|
|
XCTAssertEqualObjects(result.insertSections, indexSet(@[@4]));
|
|
XCTAssertEqualObjects(result.deleteSections, indexSet(@[@2]));
|
|
XCTAssertEqualObjects(result.insertIndexPaths, @[newPath(3, 4)]);
|
|
XCTAssertEqual(result.moveSections.count, 0);
|
|
}
|
|
|
|
- (void)test_whenMovingIndexPaths_withSectionDeleted_thatResultDropsTheMove {
|
|
IGListBatchUpdateData *result = [[IGListBatchUpdateData alloc] initWithInsertSections:indexSet(@[])
|
|
deleteSections:indexSet(@[@0])
|
|
moveSections:[NSSet new]
|
|
insertIndexPaths:@[]
|
|
deleteIndexPaths:@[]
|
|
updateIndexPaths:@[]
|
|
moveIndexPaths:@[newMovePath(0, 0, 0, 1)]];
|
|
XCTAssertEqual(result.moveIndexPaths.count, 0);
|
|
XCTAssertEqualObjects(result.deleteSections, indexSet(@[@0]));
|
|
}
|
|
|
|
- (void)test_whenMovingIndexPaths_withSectionMoved_thatResultConvertsToDeletesAndInserts {
|
|
IGListBatchUpdateData *result = [[IGListBatchUpdateData alloc] initWithInsertSections:indexSet(@[])
|
|
deleteSections:indexSet(@[])
|
|
moveSections:[NSSet setWithArray:@[newMove(0, 1)]]
|
|
insertIndexPaths:@[]
|
|
deleteIndexPaths:@[]
|
|
updateIndexPaths:@[]
|
|
moveIndexPaths:@[newMovePath(0, 0, 0, 1)]];
|
|
XCTAssertEqual(result.moveIndexPaths.count, 0);
|
|
XCTAssertEqual(result.moveSections.count, 0);
|
|
XCTAssertEqualObjects(result.deleteSections, indexSet(@[@0]));
|
|
XCTAssertEqualObjects(result.insertSections, indexSet(@[@1]));
|
|
}
|
|
|
|
- (void)test_whenMovingSections_withMoveFromConflictWithDelete_thatResultDropsTheMove {
|
|
IGListBatchUpdateData *result = [[IGListBatchUpdateData alloc] initWithInsertSections:indexSet(@[])
|
|
deleteSections:indexSet(@[@2])
|
|
moveSections:[NSSet setWithArray:@[newMove(2, 6), newMove(0, 2)]]
|
|
insertIndexPaths:@[]
|
|
deleteIndexPaths:@[]
|
|
updateIndexPaths:@[]
|
|
moveIndexPaths:@[]];
|
|
XCTAssertEqual(result.deleteSections.count, 1);
|
|
XCTAssertEqual(result.moveSections.count, 1);
|
|
XCTAssertEqual(result.insertSections.count, 0);
|
|
XCTAssertEqualObjects(result.deleteSections, indexSet(@[@2]));
|
|
XCTAssertEqualObjects(result.moveSections.anyObject, newMove(0, 2));
|
|
}
|
|
|
|
- (void)test_whenDeletingSameIndexPathMultipleTimes_thatResultDropsTheDuplicates {
|
|
IGListBatchUpdateData *result = [[IGListBatchUpdateData alloc] initWithInsertSections:indexSet(@[])
|
|
deleteSections:indexSet(@[])
|
|
moveSections:[NSSet new]
|
|
insertIndexPaths:@[]
|
|
deleteIndexPaths:@[newPath(2, 0), newPath(2, 0)]
|
|
updateIndexPaths:@[]
|
|
moveIndexPaths:@[]];
|
|
|
|
XCTAssertEqualObjects(result.deleteIndexPaths, @[newPath(2, 0)]);
|
|
}
|
|
|
|
@end
|