From a7d88fc09515963818a664b4dab48f21c991e624 Mon Sep 17 00:00:00 2001 From: Bogdan Iusco Date: Wed, 22 Jun 2016 11:56:06 +0300 Subject: [PATCH] Add cancel all operations method in base datasource. --- BIObjCHelpers.xcodeproj/project.pbxproj | 36 ++++++- .../Datasource/Base/BIDatasourceBase.h | 4 + .../Datasource/Base/BIDatasourceBase.m | 22 ++++ .../Operations/BIOperationNotifier.h | 1 + .../Operations/BIOperationNotifier.m | 4 + .../MockBIOperationNotifierListener.h | 15 +++ .../MockBIOperationNotifierListener.m | 13 +++ .../Base/BIDatasourceBaseTestCase.m | 100 ++++++++++++++++++ .../TableView/BIDatasourceBaseTestCase.m | 36 ------- .../Operations/BIOperationNotifier+Tests.h | 15 +++ .../Operations/BIOperationNotifierTestCase.m | 45 ++++++++ 11 files changed, 251 insertions(+), 40 deletions(-) create mode 100644 BIObjCHelpersTests/Mocks/Operations/MockBIOperationNotifierListener.h create mode 100644 BIObjCHelpersTests/Mocks/Operations/MockBIOperationNotifierListener.m create mode 100644 BIObjCHelpersTests/Tests/Datasource/Base/BIDatasourceBaseTestCase.m delete mode 100644 BIObjCHelpersTests/Tests/Datasource/TableView/BIDatasourceBaseTestCase.m create mode 100644 BIObjCHelpersTests/Tests/Operations/BIOperationNotifier+Tests.h create mode 100644 BIObjCHelpersTests/Tests/Operations/BIOperationNotifierTestCase.m diff --git a/BIObjCHelpers.xcodeproj/project.pbxproj b/BIObjCHelpers.xcodeproj/project.pbxproj index 192cc5a..a716fe8 100644 --- a/BIObjCHelpers.xcodeproj/project.pbxproj +++ b/BIObjCHelpers.xcodeproj/project.pbxproj @@ -22,6 +22,9 @@ 43D3BFF31D12E0DB000C840C /* MockNSFetchedResultsController.m in Sources */ = {isa = PBXBuildFile; fileRef = 43D3BFF21D12E0DB000C840C /* MockNSFetchedResultsController.m */; }; 43D3BFF71D12E592000C840C /* MockUINib.m in Sources */ = {isa = PBXBuildFile; fileRef = 43D3BFF61D12E592000C840C /* MockUINib.m */; }; 43D3BFFC1D12FCC0000C840C /* MockBITableView.m in Sources */ = {isa = PBXBuildFile; fileRef = 43D3BFFB1D12FCC0000C840C /* MockBITableView.m */; }; + 43D3BFFE1D1A8080000C840C /* BIOperationNotifierTestCase.m in Sources */ = {isa = PBXBuildFile; fileRef = 43D3BFFD1D1A8080000C840C /* BIOperationNotifierTestCase.m */; }; + 43D3C0021D1A8143000C840C /* MockBIOperationNotifierListener.m in Sources */ = {isa = PBXBuildFile; fileRef = 43D3C0011D1A8143000C840C /* MockBIOperationNotifierListener.m */; }; + 43D3C0081D1A832C000C840C /* BIDatasourceBaseTestCase.m in Sources */ = {isa = PBXBuildFile; fileRef = 43D3C0071D1A832C000C840C /* BIDatasourceBaseTestCase.m */; }; 43F541CD1CD0F276002EB6C6 /* BIObjCHelpers.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 43F541C31CD0F275002EB6C6 /* BIObjCHelpers.framework */; }; 43F541DC1CD0F2AD002EB6C6 /* _BIScrollViewProxy.m in Sources */ = {isa = PBXBuildFile; fileRef = 91614A821B94790400D00EB2 /* _BIScrollViewProxy.m */; }; 43F541DE1CD0F2AD002EB6C6 /* UIScrollView+BIBatching.m in Sources */ = {isa = PBXBuildFile; fileRef = 432001971C7B26C0006A8BB7 /* UIScrollView+BIBatching.m */; }; @@ -105,7 +108,6 @@ 43FA5D591CD2323B00FA754E /* NSDateBIAttributedStringTestCase.m in Sources */ = {isa = PBXBuildFile; fileRef = 43BE6CDC1B568ECB001F0A00 /* NSDateBIAttributedStringTestCase.m */; }; 43FA5D5A1CD2323E00FA754E /* NSStringBIExtraTestCase.m in Sources */ = {isa = PBXBuildFile; fileRef = 43BE6CDE1B568ECB001F0A00 /* NSStringBIExtraTestCase.m */; }; 43FA5D5B1CD2324300FA754E /* BIDatasourceFetchedCollectionViewTestCase.m in Sources */ = {isa = PBXBuildFile; fileRef = 43BE6CE11B568ECB001F0A00 /* BIDatasourceFetchedCollectionViewTestCase.m */; }; - 43FA5D5D1CD2324D00FA754E /* BIDatasourceBaseTestCase.m in Sources */ = {isa = PBXBuildFile; fileRef = 43329F6E1BFC7D6F0081FDA3 /* BIDatasourceBaseTestCase.m */; }; 43FA5D5E1CD2325200FA754E /* BIDatasourceTableViewTestCase.m in Sources */ = {isa = PBXBuildFile; fileRef = 4304A9B51B70D892009739B3 /* BIDatasourceTableViewTestCase.m */; }; 43FA5D5F1CD2325400FA754E /* BIDatasourceFeedTableViewTestCase.m in Sources */ = {isa = PBXBuildFile; fileRef = 43BE6CE61B568ECB001F0A00 /* BIDatasourceFeedTableViewTestCase.m */; }; 43FA5D601CD2325700FA754E /* BIDatasourceFetchedTableViewTestCase.m in Sources */ = {isa = PBXBuildFile; fileRef = 43BE6CE71B568ECB001F0A00 /* BIDatasourceFetchedTableViewTestCase.m */; }; @@ -136,7 +138,6 @@ 431124911CE36CDC00950918 /* BIOperationNotifier.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = BIOperationNotifier.m; path = Operations/BIOperationNotifier.m; sourceTree = ""; }; 432001961C7B26C0006A8BB7 /* UIScrollView+BIBatching.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = "UIScrollView+BIBatching.h"; path = "Views/ScrollView/UIScrollView+BIBatching.h"; sourceTree = ""; }; 432001971C7B26C0006A8BB7 /* UIScrollView+BIBatching.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = "UIScrollView+BIBatching.m"; path = "Views/ScrollView/UIScrollView+BIBatching.m"; sourceTree = ""; }; - 43329F6E1BFC7D6F0081FDA3 /* BIDatasourceBaseTestCase.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = BIDatasourceBaseTestCase.m; sourceTree = ""; }; 433DEB481C4D1A16002296AE /* BIScrollAdditionalViewBase.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = BIScrollAdditionalViewBase.h; path = Views/TableView/Additions/BIScrollAdditionalViewBase.h; sourceTree = ""; }; 433DEB491C4D1A16002296AE /* BIScrollAdditionalViewBase.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = BIScrollAdditionalViewBase.m; path = Views/TableView/Additions/BIScrollAdditionalViewBase.m; sourceTree = ""; }; 433DEB4B1C4D1A52002296AE /* BIScrollAdditionalErrorNoContentView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = BIScrollAdditionalErrorNoContentView.h; path = Views/TableView/Additions/BIScrollAdditionalErrorNoContentView.h; sourceTree = ""; }; @@ -221,6 +222,11 @@ 43D3BFF61D12E592000C840C /* MockUINib.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = MockUINib.m; path = Mocks/UIKit/UINib/MockUINib.m; sourceTree = ""; }; 43D3BFFA1D12FCC0000C840C /* MockBITableView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = MockBITableView.h; path = Mocks/Views/TableView/MockBITableView.h; sourceTree = ""; }; 43D3BFFB1D12FCC0000C840C /* MockBITableView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = MockBITableView.m; path = Mocks/Views/TableView/MockBITableView.m; sourceTree = ""; }; + 43D3BFFD1D1A8080000C840C /* BIOperationNotifierTestCase.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = BIOperationNotifierTestCase.m; path = Operations/BIOperationNotifierTestCase.m; sourceTree = ""; }; + 43D3C0001D1A8143000C840C /* MockBIOperationNotifierListener.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = MockBIOperationNotifierListener.h; path = Mocks/Operations/MockBIOperationNotifierListener.h; sourceTree = ""; }; + 43D3C0011D1A8143000C840C /* MockBIOperationNotifierListener.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = MockBIOperationNotifierListener.m; path = Mocks/Operations/MockBIOperationNotifierListener.m; sourceTree = ""; }; + 43D3C0031D1A8287000C840C /* BIOperationNotifier+Tests.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = "BIOperationNotifier+Tests.h"; path = "Operations/BIOperationNotifier+Tests.h"; sourceTree = ""; }; + 43D3C0071D1A832C000C840C /* BIDatasourceBaseTestCase.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = BIDatasourceBaseTestCase.m; path = Base/BIDatasourceBaseTestCase.m; sourceTree = ""; }; 43DA594B1B6217F400ECAAC0 /* BITableViewTestCase.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = BITableViewTestCase.m; path = Views/TableView/BITableViewTestCase.m; sourceTree = ""; }; 43F23F7C1B9EFC0D00CEAD8C /* BIBatchHelpers.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BIBatchHelpers.h; sourceTree = ""; }; 43F23F7D1B9EFC0D00CEAD8C /* BIBatchHelpers.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = BIBatchHelpers.m; sourceTree = ""; }; @@ -318,6 +324,8 @@ isa = PBXGroup; children = ( 43A5B5561CFD733300F79359 /* BIOperationBaseTestCase.m */, + 43D3BFFD1D1A8080000C840C /* BIOperationNotifierTestCase.m */, + 43D3C0031D1A8287000C840C /* BIOperationNotifier+Tests.h */, ); name = Operations; sourceTree = ""; @@ -669,6 +677,7 @@ 43BE6CDF1B568ECB001F0A00 /* Datasource */ = { isa = PBXGroup; children = ( + 43D3C0061D1A8315000C840C /* Base */, 43BE6CE01B568ECB001F0A00 /* CollectionView */, 43BE6CE51B568ECB001F0A00 /* TableView */, ); @@ -686,7 +695,6 @@ 43BE6CE51B568ECB001F0A00 /* TableView */ = { isa = PBXGroup; children = ( - 43329F6E1BFC7D6F0081FDA3 /* BIDatasourceBaseTestCase.m */, 4304A9B51B70D892009739B3 /* BIDatasourceTableViewTestCase.m */, 43BE6CE61B568ECB001F0A00 /* BIDatasourceFeedTableViewTestCase.m */, 43BE6CE71B568ECB001F0A00 /* BIDatasourceFetchedTableViewTestCase.m */, @@ -751,6 +759,7 @@ 43D3BFD81D12DCA6000C840C /* Mocks */ = { isa = PBXGroup; children = ( + 43D3BFFF1D1A8127000C840C /* Operations */, 43D3BFF81D12FCA4000C840C /* Views */, 43D3BFE71D12DF5D000C840C /* Handlers */, 43D3BFDA1D12DCAD000C840C /* UIKit */, @@ -859,6 +868,23 @@ name = TableView; sourceTree = ""; }; + 43D3BFFF1D1A8127000C840C /* Operations */ = { + isa = PBXGroup; + children = ( + 43D3C0001D1A8143000C840C /* MockBIOperationNotifierListener.h */, + 43D3C0011D1A8143000C840C /* MockBIOperationNotifierListener.m */, + ); + name = Operations; + sourceTree = ""; + }; + 43D3C0061D1A8315000C840C /* Base */ = { + isa = PBXGroup; + children = ( + 43D3C0071D1A832C000C840C /* BIDatasourceBaseTestCase.m */, + ); + name = Base; + sourceTree = ""; + }; 43DA58F21B5D1CAB00ECAAC0 /* ActivityIndicator */ = { isa = PBXGroup; children = ( @@ -1185,7 +1211,6 @@ 43FA5D541CD2321E00FA754E /* BITableViewTestCase.m in Sources */, 43FA5D661CD2326F00FA754E /* BIStartersFactoryTestCase.m in Sources */, 43D3BFE21D12DD5B000C840C /* MockUITableView.m in Sources */, - 43FA5D5D1CD2324D00FA754E /* BIDatasourceBaseTestCase.m in Sources */, 43D3BFE61D12DDC1000C840C /* MockUICollectionView.m in Sources */, 43FA5D601CD2325700FA754E /* BIDatasourceFetchedTableViewTestCase.m in Sources */, 43FA5D621CD2326000FA754E /* BIHandlerTableViewTestCase.m in Sources */, @@ -1200,10 +1225,13 @@ 43D3BFFC1D12FCC0000C840C /* MockBITableView.m in Sources */, 43FA5D571CD2322900FA754E /* BIBatchHelpersTestCase.m in Sources */, 43FA5D591CD2323B00FA754E /* NSDateBIAttributedStringTestCase.m in Sources */, + 43D3C0081D1A832C000C840C /* BIDatasourceBaseTestCase.m in Sources */, 43FA5D641CD2326800FA754E /* BISerialOperationQueueTestCase.m in Sources */, + 43D3C0021D1A8143000C840C /* MockBIOperationNotifierListener.m in Sources */, 43FA5D551CD2322400FA754E /* BIBatchRequestTestCase.m in Sources */, 43FA5D561CD2322700FA754E /* BIBatchResponseTestCase.m in Sources */, 43D3BFF31D12E0DB000C840C /* MockNSFetchedResultsController.m in Sources */, + 43D3BFFE1D1A8080000C840C /* BIOperationNotifierTestCase.m in Sources */, 43FA5D681CD2327600FA754E /* BIMockStarter.m in Sources */, 43FA5D581CD2323800FA754E /* NSBundleBIExtraTestCase.m in Sources */, 43D3BFEF1D12E0B1000C840C /* MockNSFetchedResultsSectionInfo.m in Sources */, diff --git a/BIObjCHelpers/Datasource/Base/BIDatasourceBase.h b/BIObjCHelpers/Datasource/Base/BIDatasourceBase.h index 9d81ee6..54cd021 100644 --- a/BIObjCHelpers/Datasource/Base/BIDatasourceBase.h +++ b/BIObjCHelpers/Datasource/Base/BIDatasourceBase.h @@ -8,8 +8,12 @@ #import "BILifecycle.h" +#import + @interface BIDatasourceBase : BILifecycle @property (nonatomic, strong, nonnull, readonly) NSHashTable *operations; +- (void)cancelAllCurrentOperations:(BOOL)silently; + @end diff --git a/BIObjCHelpers/Datasource/Base/BIDatasourceBase.m b/BIObjCHelpers/Datasource/Base/BIDatasourceBase.m index cc474cf..f72ccf9 100644 --- a/BIObjCHelpers/Datasource/Base/BIDatasourceBase.m +++ b/BIObjCHelpers/Datasource/Base/BIDatasourceBase.m @@ -7,6 +7,8 @@ // #import "BIDatasourceBase.h" +#import "BIOperationBase.h" +#import "BIOperationNotifier.h" @interface BIDatasourceBase () @@ -17,6 +19,26 @@ @interface BIDatasourceBase () @implementation BIDatasourceBase +#pragma mark - Public methods + +- (void)cancelAllCurrentOperations:(BOOL)silently { + NSHashTable *copiedOperations = [self.operations copy]; + for (id object in copiedOperations) { + if ([object isKindOfClass:[BIOperationBase class]]) { + BIOperationBase *operation = (BIOperationBase *)object; + if (silently) { + operation.didFinishWithErrorCallback = nil; + if ([operation isKindOfClass:[BIOperationNotifier class]]) { + BIOperationNotifier *notifierOperation = (BIOperationNotifier *)operation; + [notifierOperation removeAllListeners]; + } + } + [operation cancel]; + } + } + [self.operations removeAllObjects]; +} + #pragma mark - Property methods - (NSHashTable *)operations { diff --git a/BIObjCHelpers/Operations/BIOperationNotifier.h b/BIObjCHelpers/Operations/BIOperationNotifier.h index e6b07c8..78d5b1f 100644 --- a/BIObjCHelpers/Operations/BIOperationNotifier.h +++ b/BIObjCHelpers/Operations/BIOperationNotifier.h @@ -25,5 +25,6 @@ - (void)registerOperationFinishedListener:(id __nonnull)listener; - (void)unregisterOperationFinishedListener:(id __nonnull)listener; +- (void)removeAllListeners; @end diff --git a/BIObjCHelpers/Operations/BIOperationNotifier.m b/BIObjCHelpers/Operations/BIOperationNotifier.m index 3c7b6a1..b8d4f52 100644 --- a/BIObjCHelpers/Operations/BIOperationNotifier.m +++ b/BIObjCHelpers/Operations/BIOperationNotifier.m @@ -26,6 +26,10 @@ - (void)unregisterOperationFinishedListener:(id)lis [self.operationFinishedListeners removeObject:listener]; } +- (void)removeAllListeners { + [self.operationFinishedListeners removeAllObjects]; +} + #pragma mark - BIOperationBase methods - (void)safeCallDidFinishWithErrorCallback:(nonnull NSError *)error { diff --git a/BIObjCHelpersTests/Mocks/Operations/MockBIOperationNotifierListener.h b/BIObjCHelpersTests/Mocks/Operations/MockBIOperationNotifierListener.h new file mode 100644 index 0000000..9606f27 --- /dev/null +++ b/BIObjCHelpersTests/Mocks/Operations/MockBIOperationNotifierListener.h @@ -0,0 +1,15 @@ +// +// MockBIOperationNotifierListener.h +// BIObjCHelpers +// +// Created by Bogdan Iusco on 6/22/16. +// Copyright © 2016 iGama Apps. All rights reserved. +// + +#import +#import + +@interface MockBIOperationNotifierListener : NSObject + + +@end diff --git a/BIObjCHelpersTests/Mocks/Operations/MockBIOperationNotifierListener.m b/BIObjCHelpersTests/Mocks/Operations/MockBIOperationNotifierListener.m new file mode 100644 index 0000000..0da2b80 --- /dev/null +++ b/BIObjCHelpersTests/Mocks/Operations/MockBIOperationNotifierListener.m @@ -0,0 +1,13 @@ +// +// MockBIOperationNotifierListener.m +// BIObjCHelpers +// +// Created by Bogdan Iusco on 6/22/16. +// Copyright © 2016 iGama Apps. All rights reserved. +// + +#import "MockBIOperationNotifierListener.h" + +@implementation MockBIOperationNotifierListener + +@end diff --git a/BIObjCHelpersTests/Tests/Datasource/Base/BIDatasourceBaseTestCase.m b/BIObjCHelpersTests/Tests/Datasource/Base/BIDatasourceBaseTestCase.m new file mode 100644 index 0000000..2fb4f4f --- /dev/null +++ b/BIObjCHelpersTests/Tests/Datasource/Base/BIDatasourceBaseTestCase.m @@ -0,0 +1,100 @@ +// +// BIDatasourceBaseTestCase.m +// BIObjCHelpers +// +// Created by Bogdan Iusco on 6/22/16. +// Copyright © 2016 iGama Apps. All rights reserved. +// + +#import +#import + +#import "MockBIOperationNotifierListener.h" +#import "BIOperationNotifier+Tests.h" + +@interface BIDatasourceBaseTestCase : XCTestCase + +@property (nonatomic, strong, nullable, readwrite) BIDatasourceBase *datasource; + +@end + +@implementation BIDatasourceBaseTestCase + +- (void)setUp { + [super setUp]; + self.datasource = [BIDatasourceBase new]; +} + +#pragma mark - Test init + +- (void)test_init { + BIDatasourceBase *datasource = [BIDatasourceBase new]; + XCTAssertNotNil(datasource); + XCTAssertNotNil(datasource.operations); + XCTAssertEqual(datasource.operations.count, 0U); +} + +#pragma mark - Test cancelAllCurrentOperations + +- (void)test_cancelAllCurrentOperations_silent { + // GIVEN: A set of operations + NSInteger countOperations = arc4random_uniform(10); + NSMutableArray *operations = [NSMutableArray new]; + __block NSError *returnedError; + for (NSInteger index = 0; index < countOperations; index++) { + BIOperationNotifier *operation = [BIOperationNotifier new]; + operation.didFinishWithErrorCallback = ^(NSError *__nonnull error) { + returnedError = error; + }; + MockBIOperationNotifierListener *listener = [MockBIOperationNotifierListener new]; + [operation registerOperationFinishedListener:listener]; + [self.datasource.operations addObject:operation]; + [operations addObject:operation]; + } + // WHEN: cancelAllCurrentOperations method is called + [self.datasource cancelAllCurrentOperations:YES]; + // THEN: Datasource should have no operations + XCTAssertEqual(self.datasource.operations.count, 0); + // THEN: All operations should not have a didFinishWithErrorCallback set + for (BIOperationNotifier *operation in operations) { + XCTAssertNil(operation.didFinishWithErrorCallback); + } + // THEN: All operations should have no listeners + for (BIOperationNotifier *operation in operations) { + XCTAssertEqual(operation.operationFinishedListeners.count, 0); + } + + // THEN: Operation's didFinishWithErrorCallback should not have been called + XCTAssertNil(returnedError); +} + +- (void)test_cancelAllCurrentOperations_notSilent { + // GIVEN: A set of operations + NSInteger countOperations = arc4random_uniform(10); + NSMutableArray *operations = [NSMutableArray new]; + __block NSError *returnedError; + for (NSInteger index = 0; index < countOperations; index++) { + BIOperationNotifier *operation = [BIOperationNotifier new]; + operation.didFinishWithErrorCallback = ^(NSError *__nonnull error) { + returnedError = error; + }; + MockBIOperationNotifierListener *listener = [MockBIOperationNotifierListener new]; + [operation registerOperationFinishedListener:listener]; + [self.datasource.operations addObject:operation]; + [operations addObject:operation]; + } + // WHEN: cancelAllCurrentOperations method is called + [self.datasource cancelAllCurrentOperations:NO]; + // THEN: Datasource should have no operations + XCTAssertEqual(self.datasource.operations.count, 0); + // THEN: All operations should have a didFinishWithErrorCallback set + for (BIOperationNotifier *operation in operations) { + XCTAssertNotNil(operation.didFinishWithErrorCallback); + } + // THEN: All operations should have listeners + for (BIOperationNotifier *operation in operations) { + XCTAssertEqual(operation.operationFinishedListeners.count, 1); + } +} + +@end diff --git a/BIObjCHelpersTests/Tests/Datasource/TableView/BIDatasourceBaseTestCase.m b/BIObjCHelpersTests/Tests/Datasource/TableView/BIDatasourceBaseTestCase.m deleted file mode 100644 index f750ca2..0000000 --- a/BIObjCHelpersTests/Tests/Datasource/TableView/BIDatasourceBaseTestCase.m +++ /dev/null @@ -1,36 +0,0 @@ -// -// BIDatasourceBaseTestCase.m -// BIObjCHelpers -// -// Created by Bogdan Iusco on 18/11/15. -// Copyright © 2015 iGama Apps. All rights reserved. -// - -#import "BIDatasourceBase.h" - -#import - -@interface BIDatasourceBaseTestCase : XCTestCase - -@end - -@implementation BIDatasourceBaseTestCase - -- (void)setUp { - [super setUp]; -} - -- (void)tearDown { - [super tearDown]; -} - -#pragma mark - Test init - -- (void)test_init { - BIDatasourceBase *datasource = [BIDatasourceBase new]; - XCTAssertNotNil(datasource); - XCTAssertNotNil(datasource.operations); - XCTAssertEqual(datasource.operations.count, 0U); -} - -@end diff --git a/BIObjCHelpersTests/Tests/Operations/BIOperationNotifier+Tests.h b/BIObjCHelpersTests/Tests/Operations/BIOperationNotifier+Tests.h new file mode 100644 index 0000000..1147392 --- /dev/null +++ b/BIObjCHelpersTests/Tests/Operations/BIOperationNotifier+Tests.h @@ -0,0 +1,15 @@ +// +// BIOperationNotifier+Tests.h +// BIObjCHelpers +// +// Created by Bogdan Iusco on 6/22/16. +// Copyright © 2016 iGama Apps. All rights reserved. +// + +#import + +@interface BIOperationNotifier (Tests) + +@property (nonatomic, strong, nullable, readwrite) NSHashTable > *operationFinishedListeners; + +@end diff --git a/BIObjCHelpersTests/Tests/Operations/BIOperationNotifierTestCase.m b/BIObjCHelpersTests/Tests/Operations/BIOperationNotifierTestCase.m new file mode 100644 index 0000000..647dc36 --- /dev/null +++ b/BIObjCHelpersTests/Tests/Operations/BIOperationNotifierTestCase.m @@ -0,0 +1,45 @@ +// +// BIOperationNotifierTestCase.m +// BIObjCHelpers +// +// Created by Bogdan Iusco on 6/22/16. +// Copyright © 2016 iGama Apps. All rights reserved. +// + +#import +#import + +#import "MockBIOperationNotifierListener.h" +#import "BIOperationNotifier+Tests.h" + +@interface BIOperationNotifierTestCase : XCTestCase + +@property (nonatomic, strong, nullable, readwrite) BIOperationNotifier *operation; + +@end + +@implementation BIOperationNotifierTestCase + +- (void)setUp { + [super setUp]; + self.operation = [BIOperationNotifier new]; +} + +#pragma mark - Test removeAllListeners + +- (void)test_removeAllListeners { + // GIVEN: An array of listener + NSInteger countListeners = arc4random_uniform(10); + NSMutableArray *listeners = [NSMutableArray new]; + for (NSInteger index = 0; index < countListeners; index++) { + MockBIOperationNotifierListener *listener = [MockBIOperationNotifierListener new]; + [self.operation registerOperationFinishedListener:listener]; + [listeners addObject:listener]; + } + // WHEN: calling the removeAllListeners + [self.operation removeAllListeners]; + // THEN: all listeners should be removed + XCTAssertEqual(self.operation.operationFinishedListeners.count, 0); +} + +@end