Skip to content

Commit

Permalink
Map URL to cached data
Browse files Browse the repository at this point in the history
  • Loading branch information
Fernando Olivares committed Sep 19, 2024
1 parent f4db7fb commit 6cb89b7
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 14 deletions.
26 changes: 14 additions & 12 deletions Source/Turbo/Path Configuration/PathConfigurationLoader.swift
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ final class PathConfigurationLoader {
precondition(!url.isFileURL, "URL provided for server is a file url")

// Immediately load most recent cached version if available
if let data = cachedData() {
if let data = cachedData(for: url) {
loadData(data)
}

Expand All @@ -50,29 +50,31 @@ final class PathConfigurationLoader {
return
}

self?.loadData(data, cache: true)
self?.loadData(data, cache: true, for: url)
}.resume()
}

// MARK: - Caching

private func cacheRemoteData(_ data: Data) {
private func cacheRemoteData(_ data: Data, for url: URL) {
createCacheDirectoryIfNeeded()

do {
try data.write(to: configurationCacheURL)
let url = configurationCacheURL(for: url)
try data.write(to: url)
} catch {
debugPrint("[path-configuration-loader] error caching file error: \(error)")
}
}

private func cachedData() -> Data? {
guard FileManager.default.fileExists(atPath: configurationCacheURL.path) else {
private func cachedData(for url: URL) -> Data? {
let cachedURL = configurationCacheURL(for: url)
guard FileManager.default.fileExists(atPath: cachedURL.path) else {
return nil
}

do {
return try Data(contentsOf: configurationCacheURL)
return try Data(contentsOf: cachedURL)
} catch {
debugPrint("[path-configuration-loader] *** error loading cached data: \(error)")
return nil
Expand All @@ -94,8 +96,8 @@ final class PathConfigurationLoader {
return directory.appendingPathComponent(cacheDirectory)
}

var configurationCacheURL: URL {
cacheDirectoryURL.appendingPathComponent(configurationCacheFilename)
func configurationCacheURL(for url: URL) -> URL {
cacheDirectoryURL.appendingPathComponent(url.lastPathComponent)
}

// MARK: - File
Expand All @@ -113,17 +115,17 @@ final class PathConfigurationLoader {

// MARK: - Data

private func loadData(_ data: Data, cache: Bool = false) {
private func loadData(_ data: Data, cache: Bool = false, for url: URL? = nil) {
do {
guard let json = try JSONSerialization.jsonObject(with: data) as? [String: Any] else {
throw JSONDecodingError.invalidJSON
}

let config = try PathConfigurationDecoder(json: json)

if cache {
if cache, let url {
// Only cache once we ensure we have valid data
cacheRemoteData(data)
cacheRemoteData(data, for: url)
}

updateHandler(with: config)
Expand Down
4 changes: 2 additions & 2 deletions Tests/Turbo/PathConfigurationLoaderTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ class PathConfigurationLoaderTests: XCTestCase {
wait(for: [expectation])

XCTAssertTrue(handlerCalled)
XCTAssertTrue(FileManager.default.fileExists(atPath: loader.configurationCacheURL.path))
XCTAssertTrue(FileManager.default.fileExists(atPath: loader.configurationCacheURL(for: serverURL).path))
}

private func stubRequest(for loader: PathConfigurationLoader) -> XCTestExpectation {
Expand All @@ -64,7 +64,7 @@ class PathConfigurationLoaderTests: XCTestCase {
return HTTPStubsResponse(jsonObject: json, statusCode: 200, headers: [:])
}

clearCache(loader.configurationCacheURL)
clearCache(loader.configurationCacheURL(for: serverURL))

return expectation(description: "Wait for configuration to load.")
}
Expand Down

0 comments on commit 6cb89b7

Please sign in to comment.