diff --git a/.swiftlint.yml b/.swiftlint.yml index a68a2ed7..56ceb34b 100644 --- a/.swiftlint.yml +++ b/.swiftlint.yml @@ -117,8 +117,6 @@ identifier_name: - id - by -empty_count: warning - trailing_whitespace: ignores_empty_lines: no diff --git a/Sources/Core/BoxJSONDecoder.swift b/Sources/Core/BoxJSONDecoder.swift index 6f16ff7a..9042c62d 100644 --- a/Sources/Core/BoxJSONDecoder.swift +++ b/Sources/Core/BoxJSONDecoder.swift @@ -8,8 +8,7 @@ import Foundation -// swiftlint:disable:next convenience_type -class BoxJSONDecoder { +enum BoxJSONDecoder { static func extractJSON(json: [String: Any], key: String) throws -> T { guard let objectJSON = json[key] else { @@ -144,10 +143,18 @@ class BoxJSONDecoder { return nil } + #if compiler(>=5.9) + if #available(iOS 17.0, *) { + guard let url = URL(string: value, encodingInvalidCharacters: false) else { + throw BoxCodingError(message: .invalidValueFormat(key: key)) + } + return url + } + #endif + guard let url = URL(string: value) else { throw BoxCodingError(message: .invalidValueFormat(key: key)) } - return url } diff --git a/Tests/Helpers/OHTTPStubs+JSONComparer.swift b/Tests/Helpers/OHTTPStubs+JSONComparer.swift index c16e8299..80535439 100644 --- a/Tests/Helpers/OHTTPStubs+JSONComparer.swift +++ b/Tests/Helpers/OHTTPStubs+JSONComparer.swift @@ -60,4 +60,27 @@ public extension QuickSpec { return match } } + + static func compareComplexQueryParam(_ key: String, _ partValues: [String], checkClosure _: CheckClosureType? = nil) -> HTTPStubsTestBlock { + return { req in + if let url = req.url { + let comps = NSURLComponents(url: url, resolvingAgainstBaseURL: true) + guard let queryItems = comps?.queryItems else { + return false + } + + guard let item = queryItems.first(where: { $0.name == key }) else { + return false + } + + guard let value = item.value else { + return false + } + + return partValues.allSatisfy { value.contains($0) } + } + + return false + } + } } diff --git a/Tests/Modules/FilesModuleSpecs.swift b/Tests/Modules/FilesModuleSpecs.swift index f1483a56..80d2571f 100644 --- a/Tests/Modules/FilesModuleSpecs.swift +++ b/Tests/Modules/FilesModuleSpecs.swift @@ -626,7 +626,7 @@ class FilesModuleSpecs: QuickSpec { waitUntil(timeout: .seconds(200)) { done in let data = "This is upload test file content".data(using: .utf8)! - var progressed: Double? + var progressed: Double? = 0 let task = sut.files.upload( data: data, name: "tigers.jpeg", @@ -667,7 +667,7 @@ class FilesModuleSpecs: QuickSpec { waitUntil(timeout: .seconds(200)) { done in let data = "This is upload test file content".data(using: .utf8)! - var progressed: Double? + var progressed: Double? = 0 var task: BoxUploadTask? task = sut.files.upload( data: data, @@ -1657,7 +1657,7 @@ class FilesModuleSpecs: QuickSpec { waitUntil(timeout: .seconds(10)) { done in let documentsURL = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask)[0] let fileURL = documentsURL.appendingPathComponent("doc.txt") - var progressed: Double? + var progressed: Double? = 0 let task = sut.files.download( fileId: "12345", destinationURL: fileURL, @@ -1670,7 +1670,7 @@ class FilesModuleSpecs: QuickSpec { case .success: fail("Expected download to be cancelled, but instead suceeded") case let .failure(error): - expect(progressed).to(equal(0.05)) + expect(progressed).to(beLessThan(1.0)) expect(error.message.description).to(equal("cancelled")) } done() diff --git a/Tests/Modules/SearchModuleSpecs.swift b/Tests/Modules/SearchModuleSpecs.swift index 34d9c7e7..f80b0832 100644 --- a/Tests/Modules/SearchModuleSpecs.swift +++ b/Tests/Modules/SearchModuleSpecs.swift @@ -69,7 +69,10 @@ class SearchModuleSpecs: QuickSpec { stub( condition: isHost("api.box.com") && isPath("/2.0/search") - && containsQueryParams(["mdfilters": "[{\"scope\":\"global\",\"templateKey\":\"marketingCollateral\",\"filters\":{\"date\":{\"gt\":\"2019-07-24T12:00:00Z\"}}}]"]) + && compareComplexQueryParam("mdfilters", ["\"filters\":{\"date\":{\"gt\":\"2019-07-24T12:00:00Z\"}}", + "\"templateKey\":\"marketingCollateral\"", + "\"scope\":\"global\"" + ]) ) { _ in HTTPStubsResponse( fileAtPath: TestAssets.path(forResource: "Search200.json")!, @@ -97,7 +100,10 @@ class SearchModuleSpecs: QuickSpec { stub( condition: isHost("api.box.com") && isPath("/2.0/search") - && containsQueryParams(["mdfilters": "[{\"scope\":\"enterprise\",\"templateKey\":\"marketingCollateral\",\"filters\":{\"date\":{\"lt\":\"2019-07-24T12:00:00Z\"}}}]"]) + && compareComplexQueryParam("mdfilters", ["\"filters\":{\"date\":{\"lt\":\"2019-07-24T12:00:00Z\"}}", + "\"templateKey\":\"marketingCollateral\"", + "\"scope\":\"enterprise\"" + ]) ) { _ in HTTPStubsResponse( fileAtPath: TestAssets.path(forResource: "Search200.json")!, @@ -125,7 +131,10 @@ class SearchModuleSpecs: QuickSpec { stub( condition: isHost("api.box.com") && isPath("/2.0/search") - && containsQueryParams(["mdfilters": "[{\"scope\":\"enterprise\",\"templateKey\":\"marketingCollateral\",\"filters\":{\"documentType\":\"dataSheet\"}}]"]) + && compareComplexQueryParam("mdfilters", ["\"filters\":{\"documentType\":\"dataSheet\"}", + "\"templateKey\":\"marketingCollateral\"", + "\"scope\":\"enterprise\"" + ]) ) { _ in HTTPStubsResponse( fileAtPath: TestAssets.path(forResource: "Search200.json")!, @@ -153,7 +162,10 @@ class SearchModuleSpecs: QuickSpec { stub( condition: isHost("api.box.com") && isPath("/2.0/search") - && containsQueryParams(["mdfilters": "[{\"scope\":\"global\",\"templateKey\":\"marketingCollateral\",\"filters\":{\"documentType\":\"dataSheet\"}}]"]) + && compareComplexQueryParam("mdfilters", ["\"filters\":{\"documentType\":\"dataSheet\"}", + "\"templateKey\":\"marketingCollateral\"", + "\"scope\":\"global\"" + ]) ) { _ in HTTPStubsResponse( fileAtPath: TestAssets.path(forResource: "Search200.json")!,