From f55998cb2f4fc656342d84e9ea8e7205be406dd9 Mon Sep 17 00:00:00 2001 From: "marcin.polak" Date: Tue, 22 Oct 2024 21:11:08 +0200 Subject: [PATCH 1/2] refacor: remove redundant async when refreshing --- .../FeaturevisorSDK/Instance+Refresh.swift | 49 +++++++++---------- .../FeaturevisorSDKTests/InstanceTests.swift | 16 +++--- 2 files changed, 32 insertions(+), 33 deletions(-) diff --git a/Sources/FeaturevisorSDK/Instance+Refresh.swift b/Sources/FeaturevisorSDK/Instance+Refresh.swift index 29c1954..935f199 100644 --- a/Sources/FeaturevisorSDK/Instance+Refresh.swift +++ b/Sources/FeaturevisorSDK/Instance+Refresh.swift @@ -19,38 +19,35 @@ extension FeaturevisorInstance { statuses.refreshInProgress = true - Task { [weak self] in - try? await self? - .fetchDatafileContent( - from: datafileUrl, - handleDatafileFetch: handleDatafileFetch - ) { [weak self] result in - guard let self else { - return - } + try? fetchDatafileContent( + from: datafileUrl, + handleDatafileFetch: handleDatafileFetch + ) { [weak self] result in + guard let self else { + return + } - switch result { - case .success(let datafileContent): - let currentRevision = self.getRevision() - let newRevision = datafileContent.revision - let isNotSameRevision = currentRevision != newRevision + switch result { + case .success(let datafileContent): + let currentRevision = self.getRevision() + let newRevision = datafileContent.revision + let isNotSameRevision = currentRevision != newRevision - self.datafileReader = DatafileReader(datafileContent: datafileContent) - logger.info("refreshed datafile") + self.datafileReader = DatafileReader(datafileContent: datafileContent) + logger.info("refreshed datafile") - self.emitter.emit(.refresh) + self.emitter.emit(.refresh) - if isNotSameRevision { - self.emitter.emit(.update) - } + if isNotSameRevision { + self.emitter.emit(.update) + } - self.statuses.refreshInProgress = false + self.statuses.refreshInProgress = false - case .failure(let error): - self.logger.error("failed to refresh datafile", ["error": error]) - self.statuses.refreshInProgress = false - } - } + case .failure(let error): + self.logger.error("failed to refresh datafile", ["error": error]) + self.statuses.refreshInProgress = false + } } } diff --git a/Tests/FeaturevisorSDKTests/InstanceTests.swift b/Tests/FeaturevisorSDKTests/InstanceTests.swift index d28c1ca..7108ab9 100644 --- a/Tests/FeaturevisorSDKTests/InstanceTests.swift +++ b/Tests/FeaturevisorSDKTests/InstanceTests.swift @@ -1111,7 +1111,7 @@ class FeaturevisorInstanceTests: XCTestCase { func testHandleDatafileFetchReturnsValidResponse() { // GIVEN - let expectation = expectation(description: "datafile_error_response_expectation") + let expectation = expectation(description: "datafile_success_response_expectation") var options = InstanceOptions.default options.datafileUrl = "https://featurevisor.datafilecontent.com" options.onReady = { _ in @@ -1150,11 +1150,8 @@ class FeaturevisorInstanceTests: XCTestCase { let expectation = expectation(description: "datafile_error_response_expectation") var wasDatafileContentFetchErrorThrown = false var errorThrownDetails: String? + var options = InstanceOptions.default - options.datafileUrl = "https://featurevisor.datafilecontent.com" - options.handleDatafileFetch = { _ in - return .failure(FeaturevisorError.unparseableJSON(data: nil, errorMessage: "Error :(")) - } options.logger = createLogger { level, message, details in guard case .error = level else { return @@ -1167,6 +1164,10 @@ class FeaturevisorInstanceTests: XCTestCase { expectation.fulfill() } + options.datafileUrl = "https://featurevisor.datafilecontent.com" + options.handleDatafileFetch = { _ in + .failure(FeaturevisorError.unparseableJSON(data: nil, errorMessage: "Error :(")) + } options.datafile = DatafileContent( schemaVersion: "1", revision: "0.0.1", @@ -1177,9 +1178,10 @@ class FeaturevisorInstanceTests: XCTestCase { // WHEN let sdk = try! createInstance(options: options) - - // THEN waitForExpectations(timeout: 1) + + // THEN + XCTAssertFalse(sdk.isReady()) XCTAssertTrue(wasDatafileContentFetchErrorThrown) XCTAssertEqual( errorThrownDetails, From 157e45a9353dccea98bf4f7576f3391ab5c69a07 Mon Sep 17 00:00:00 2001 From: "marcin.polak" Date: Tue, 22 Oct 2024 21:28:48 +0200 Subject: [PATCH 2/2] Fix swift lint issue --- Tests/FeaturevisorSDKTests/InstanceTests.swift | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Tests/FeaturevisorSDKTests/InstanceTests.swift b/Tests/FeaturevisorSDKTests/InstanceTests.swift index 7108ab9..c6bd8ec 100644 --- a/Tests/FeaturevisorSDKTests/InstanceTests.swift +++ b/Tests/FeaturevisorSDKTests/InstanceTests.swift @@ -1150,7 +1150,7 @@ class FeaturevisorInstanceTests: XCTestCase { let expectation = expectation(description: "datafile_error_response_expectation") var wasDatafileContentFetchErrorThrown = false var errorThrownDetails: String? - + var options = InstanceOptions.default options.logger = createLogger { level, message, details in guard case .error = level else { @@ -1166,7 +1166,7 @@ class FeaturevisorInstanceTests: XCTestCase { } options.datafileUrl = "https://featurevisor.datafilecontent.com" options.handleDatafileFetch = { _ in - .failure(FeaturevisorError.unparseableJSON(data: nil, errorMessage: "Error :(")) + .failure(FeaturevisorError.unparseableJSON(data: nil, errorMessage: "Error :(")) } options.datafile = DatafileContent( schemaVersion: "1", @@ -1179,7 +1179,7 @@ class FeaturevisorInstanceTests: XCTestCase { // WHEN let sdk = try! createInstance(options: options) waitForExpectations(timeout: 1) - + // THEN XCTAssertFalse(sdk.isReady()) XCTAssertTrue(wasDatafileContentFetchErrorThrown)