From c3debf184004dddb662de750d4893d6c02f00c12 Mon Sep 17 00:00:00 2001 From: Oguz Kocer Date: Fri, 27 Mar 2020 16:03:01 -0400 Subject: [PATCH] Refactor MockEventLoggingDelegate to promoto immutability --- .../Test Helpers/Mocks.swift | 60 +++++++++++-------- .../EventLoggingUploadManagerTests.swift | 4 +- 2 files changed, 36 insertions(+), 28 deletions(-) diff --git a/Automattic-Tracks-iOSTests/Test Helpers/Mocks.swift b/Automattic-Tracks-iOSTests/Test Helpers/Mocks.swift index 96dea772..5869f1db 100644 --- a/Automattic-Tracks-iOSTests/Test Helpers/Mocks.swift +++ b/Automattic-Tracks-iOSTests/Test Helpers/Mocks.swift @@ -10,19 +10,19 @@ enum MockError: Error { } class MockEventLoggingDataSource: EventLoggingDataSource { - + private let _loggingEncryptionKey: String private let _logUploadURL: URL - + required init (loggingEncryptionKey: String, logUploadURL: URL) { _loggingEncryptionKey = loggingEncryptionKey _logUploadURL = logUploadURL } - + var loggingEncryptionKey: String { return _loggingEncryptionKey } - + var logUploadURL: URL { return _logUploadURL } @@ -40,46 +40,54 @@ class MockEventLoggingDataSource: EventLoggingDataSource { class MockEventLoggingDelegate: EventLoggingDelegate { - var didStartUploadingTriggered = false + var shouldUploadLogFiles: Bool = true + + private var _didStartUploadingTriggered = false + private var _didFinishUploadingTriggered = false + private var _uploadFailedTriggered = false + private var _uploadCancelledByDelegateTriggered = false + + var didStartUploadingTriggered: Bool { + return _didStartUploadingTriggered + } + + var didFinishUploadingTriggered: Bool { + return _didFinishUploadingTriggered + } + + var uploadFailedTriggered: Bool { + return _uploadFailedTriggered + } + + var uploadCancelledByDelegateTriggered: Bool { + return _uploadCancelledByDelegateTriggered + } + var didStartUploadingCallback: LogFileCallback? + var didFinishUploadingCallback: LogFileCallback? + var uploadCancelledByDelegateCallback: LogFileCallback? + var uploadFailedCallback: ErrorWithLogFileCallback? func didStartUploadingLog(_ log: LogFile) { - didStartUploadingTriggered = true + _didStartUploadingTriggered = true didStartUploadingCallback?(log) } - var didFinishUploadingTriggered = false - var didFinishUploadingCallback: LogFileCallback? func didFinishUploadingLog(_ log: LogFile) { - didFinishUploadingTriggered = true + _didFinishUploadingTriggered = true didFinishUploadingCallback?(log) } - var uploadCancelledByDelegateTriggered = false - var uploadCancelledByDelegateCallback: LogFileCallback? - func uploadCancelledByDelegate(_ log: LogFile) { - uploadCancelledByDelegateTriggered = true + _uploadCancelledByDelegateTriggered = true uploadCancelledByDelegateCallback?(log) } - var uploadFailedTriggered = false - var uploadFailedCallback: ErrorWithLogFileCallback? - func uploadFailed(withError error: Error, forLog log: LogFile) { - uploadFailedTriggered = true + _uploadFailedTriggered = true uploadFailedCallback?(error, log) } - - func setShouldUploadLogFiles(_ newValue: Bool) { - _shouldUploadLogFiles = newValue - } - - private var _shouldUploadLogFiles: Bool = true - var shouldUploadLogFiles: Bool { - return _shouldUploadLogFiles - } } class MockEventLoggingNetworkService: EventLoggingNetworkService { diff --git a/Automattic-Tracks-iOSTests/Tests/Event Logging/EventLoggingUploadManagerTests.swift b/Automattic-Tracks-iOSTests/Tests/Event Logging/EventLoggingUploadManagerTests.swift index 162bbdc8..29970a90 100644 --- a/Automattic-Tracks-iOSTests/Tests/Event Logging/EventLoggingUploadManagerTests.swift +++ b/Automattic-Tracks-iOSTests/Tests/Event Logging/EventLoggingUploadManagerTests.swift @@ -56,7 +56,7 @@ class EventLoggingUploadManagerTests: XCTestCase { func testThatNetworkStartDoesNotFireWhenDelegateCancelsUpload() { waitForExpectation(timeout: 1.0) { exp in - delegate.setShouldUploadLogFiles(false) + delegate.shouldUploadLogFiles = false delegate.uploadCancelledByDelegateCallback = { _ in exp.fulfill() } uploadManager.upload(LogFile.containingRandomString(), then: { _ in XCTFail("Callback should not be called") }) } @@ -68,7 +68,7 @@ class EventLoggingUploadManagerTests: XCTestCase { func testThatDelegateIsNotifiedOfMissingFiles() { waitForExpectation(timeout: 1.0) { exp in - delegate.setShouldUploadLogFiles(true) + delegate.shouldUploadLogFiles = true delegate.uploadFailedCallback = { error, _ in exp.fulfill() } uploadManager.upload(LogFile.withInvalidPath(), then: { _ in XCTFail("Callback should not be called") }) }