diff --git a/Sources/Unbox.swift b/Sources/Unbox.swift index 1312cb1..05752e7 100644 --- a/Sources/Unbox.swift +++ b/Sources/Unbox.swift @@ -482,6 +482,20 @@ public class Unboxer { /// Unbox a required Array containing values of a raw type public func unbox(key: String, isKeyPath: Bool = true) -> [T] { + if let rawValue = UnboxValueResolver<[T]>(self).resolveOptionalValueForKey(key, isKeyPath: isKeyPath) { + return rawValue + } + + let transformedStringArray = UnboxValueResolver<[String]>(self).resolveOptionalValueForKey(key, isKeyPath: isKeyPath, transform: { stringArray -> [T]? in + return stringArray.flatMap { + return T.transformUnboxedString($0) + } + }) + + if let transformedStringArray = transformedStringArray { + return transformedStringArray + } + return UnboxValueResolver<[T]>(self).resolveRequiredValueForKey(key, isKeyPath: isKeyPath, fallbackValue: []) } diff --git a/Tests/UnboxTests.swift b/Tests/UnboxTests.swift index e7d74ab..fd8ad00 100644 --- a/Tests/UnboxTests.swift +++ b/Tests/UnboxTests.swift @@ -1358,6 +1358,27 @@ class UnboxTests: XCTestCase { } } + func testUnboxingArrayOfStringTransformedToInt() { + let dictionary: UnboxableDictionary = ["intArray": ["123", "456", "789"]] + + struct ModelA: Unboxable { + let intArray: [Int] + init(unboxer: Unboxer) { + intArray = unboxer.unbox("intArray") + } + } + + do { + let modelA: ModelA = try Unbox(dictionary) + XCTAssertEqual(modelA.intArray[0], 123) + XCTAssertEqual(modelA.intArray[1], 456) + XCTAssertEqual(modelA.intArray[2], 789) + } catch { + print(error) + XCTFail() + } + } + } private func UnboxTestDictionaryWithAllRequiredKeysWithValidValues(nested: Bool) -> UnboxableDictionary {