[Tweaks] Models (#5)
This PR contains the work done to make improvements to the existing models. To provide further details about the work done: - [x] moved the `games3DS`, `gamesWiiU` and `gamesSwitch` properties from the `Amiibo` model to their own `Games` child model; - [x] improved the decoding of the `Result` model. Co-authored-by: Javier Cicchelli <javier@rock-n-code.com> Reviewed-on: #5
This commit is contained in:
parent
f34ce5289d
commit
a0dcdf7673
@ -4,15 +4,72 @@ public struct Amiibo {
|
|||||||
public let tail: String
|
public let tail: String
|
||||||
public let name: String
|
public let name: String
|
||||||
public let character: String
|
public let character: String
|
||||||
public let amiiboSeries: String
|
public let series: String
|
||||||
public let gameSeries: String
|
public let gameSeries: String
|
||||||
public let image: String
|
public let image: String
|
||||||
public let release: Release
|
public let release: Release
|
||||||
public let games3DS: [Game]?
|
public let games: Games?
|
||||||
public let gamesWiiU: [Game]?
|
}
|
||||||
public let gamesSwitch: [Game]?
|
|
||||||
|
// MARK: - Structs
|
||||||
|
|
||||||
|
extension Amiibo {
|
||||||
|
public struct Games: Decodable {
|
||||||
|
public let n3ds: [Game]
|
||||||
|
public let wiiu: [Game]
|
||||||
|
public let `switch`: [Game]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// MARK: - Decodable
|
// MARK: - Decodable
|
||||||
|
|
||||||
extension Amiibo: Decodable {}
|
extension Amiibo: Decodable {
|
||||||
|
|
||||||
|
// MARK: Enumerations
|
||||||
|
|
||||||
|
enum CodingKeys: String, CodingKey {
|
||||||
|
case type
|
||||||
|
case head
|
||||||
|
case tail
|
||||||
|
case name
|
||||||
|
case character
|
||||||
|
case series = "amiiboSeries"
|
||||||
|
case gameSeries
|
||||||
|
case image
|
||||||
|
case release
|
||||||
|
case games3DS
|
||||||
|
case gamesWiiU
|
||||||
|
case gamesSwitch
|
||||||
|
}
|
||||||
|
|
||||||
|
// MARK: Initialisers
|
||||||
|
|
||||||
|
public init(from decoder: Decoder) throws {
|
||||||
|
let container = try decoder.container(keyedBy: CodingKeys.self)
|
||||||
|
let games3ds = try container.decodeIfPresent([Game].self, forKey: .games3DS)
|
||||||
|
let gamesWiiU = try container.decodeIfPresent([Game].self, forKey: .gamesWiiU)
|
||||||
|
let gamesSwitch = try container.decodeIfPresent([Game].self, forKey: .gamesSwitch)
|
||||||
|
|
||||||
|
self.type = try container.decode(String.self, forKey: .type)
|
||||||
|
self.head = try container.decode(String.self, forKey: .head)
|
||||||
|
self.tail = try container.decode(String.self, forKey: .tail)
|
||||||
|
self.name = try container.decode(String.self, forKey: .name)
|
||||||
|
self.character = try container.decode(String.self, forKey: .character)
|
||||||
|
self.series = try container.decode(String.self, forKey: .series)
|
||||||
|
self.gameSeries = try container.decode(String.self, forKey: .gameSeries)
|
||||||
|
self.image = try container.decode(String.self, forKey: .image)
|
||||||
|
self.release = try container.decode(Release.self, forKey: .release)
|
||||||
|
self.games = {
|
||||||
|
if let games3ds, let gamesWiiU, let gamesSwitch {
|
||||||
|
return .init(
|
||||||
|
n3ds: games3ds,
|
||||||
|
wiiu: gamesWiiU,
|
||||||
|
switch: gamesSwitch
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
@ -9,7 +9,7 @@ extension Result: Decodable {
|
|||||||
// MARK: Enumerations
|
// MARK: Enumerations
|
||||||
|
|
||||||
enum CodingKeys: String, CodingKey {
|
enum CodingKeys: String, CodingKey {
|
||||||
case items = "amiibo"
|
case amiibo
|
||||||
}
|
}
|
||||||
|
|
||||||
// MARK: Initialisers
|
// MARK: Initialisers
|
||||||
@ -18,9 +18,9 @@ extension Result: Decodable {
|
|||||||
let container = try decoder.container(keyedBy: CodingKeys.self)
|
let container = try decoder.container(keyedBy: CodingKeys.self)
|
||||||
|
|
||||||
do {
|
do {
|
||||||
self.items = try container.decode([Model].self, forKey: .items)
|
self.items = try container.decode([Model].self, forKey: .amiibo)
|
||||||
} catch {
|
} catch {
|
||||||
self.items = [try container.decode(Model.self, forKey: .items)]
|
self.items = [try container.decode(Model.self, forKey: .amiibo)]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,12 +47,8 @@ final class AmiiboServiceTests: XCTestCase {
|
|||||||
// THEN
|
// THEN
|
||||||
XCTAssertFalse(result.isEmpty)
|
XCTAssertFalse(result.isEmpty)
|
||||||
XCTAssertEqual(result.count, 2)
|
XCTAssertEqual(result.count, 2)
|
||||||
XCTAssertNil(result.first?.games3DS)
|
XCTAssertNil(result.first?.games)
|
||||||
XCTAssertNil(result.first?.gamesWiiU)
|
XCTAssertNil(result.last?.games)
|
||||||
XCTAssertNil(result.first?.gamesSwitch)
|
|
||||||
XCTAssertNil(result.last?.games3DS)
|
|
||||||
XCTAssertNil(result.last?.gamesWiiU)
|
|
||||||
XCTAssertNil(result.last?.gamesSwitch)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func test_amiibos_withGameData() async throws {
|
func test_amiibos_withGameData() async throws {
|
||||||
@ -71,24 +67,24 @@ final class AmiiboServiceTests: XCTestCase {
|
|||||||
// THEN
|
// THEN
|
||||||
XCTAssertFalse(result.isEmpty)
|
XCTAssertFalse(result.isEmpty)
|
||||||
XCTAssertEqual(result.count, 2)
|
XCTAssertEqual(result.count, 2)
|
||||||
XCTAssertNotNil(result.first?.games3DS)
|
XCTAssertNotNil(result.first?.games)
|
||||||
XCTAssertEqual(result.first?.games3DS?.count, 21)
|
XCTAssertEqual(result.first?.games?.n3ds.count, 21)
|
||||||
XCTAssertNil(result.first?.games3DS?.first?.usage)
|
XCTAssertNil(result.first?.games?.n3ds.first?.usage)
|
||||||
XCTAssertNotNil(result.first?.gamesWiiU)
|
XCTAssertNotNil(result.first?.games?.wiiu)
|
||||||
XCTAssertEqual(result.first?.gamesWiiU?.count, 8)
|
XCTAssertEqual(result.first?.games?.wiiu.count, 8)
|
||||||
XCTAssertNil(result.first?.gamesWiiU?.first?.usage)
|
XCTAssertNil(result.first?.games?.wiiu.first?.usage)
|
||||||
XCTAssertNotNil(result.first?.gamesSwitch)
|
XCTAssertNotNil(result.first?.games?.switch)
|
||||||
XCTAssertEqual(result.first?.gamesSwitch?.count, 8)
|
XCTAssertEqual(result.first?.games?.switch.count, 8)
|
||||||
XCTAssertNil(result.first?.gamesSwitch?.first?.usage)
|
XCTAssertNil(result.first?.games?.switch.first?.usage)
|
||||||
XCTAssertNotNil(result.last?.games3DS)
|
XCTAssertNotNil(result.last?.games?.n3ds)
|
||||||
XCTAssertEqual(result.last?.games3DS?.count, 22)
|
XCTAssertEqual(result.last?.games?.n3ds.count, 22)
|
||||||
XCTAssertNil(result.last?.games3DS?.first?.usage)
|
XCTAssertNil(result.last?.games?.n3ds.first?.usage)
|
||||||
XCTAssertNotNil(result.last?.gamesWiiU)
|
XCTAssertNotNil(result.last?.games?.wiiu)
|
||||||
XCTAssertEqual(result.last?.gamesWiiU?.count, 8)
|
XCTAssertEqual(result.last?.games?.wiiu.count, 8)
|
||||||
XCTAssertNil(result.last?.gamesWiiU?.first?.usage)
|
XCTAssertNil(result.last?.games?.wiiu.first?.usage)
|
||||||
XCTAssertNotNil(result.last?.gamesSwitch)
|
XCTAssertNotNil(result.last?.games?.switch)
|
||||||
XCTAssertEqual(result.last?.gamesSwitch?.count, 9)
|
XCTAssertEqual(result.last?.games?.switch.count, 9)
|
||||||
XCTAssertNil(result.last?.gamesSwitch?.first?.usage)
|
XCTAssertNil(result.last?.games?.switch.first?.usage)
|
||||||
}
|
}
|
||||||
|
|
||||||
func test_amiibos_withUsageData() async throws {
|
func test_amiibos_withUsageData() async throws {
|
||||||
@ -107,30 +103,30 @@ final class AmiiboServiceTests: XCTestCase {
|
|||||||
// THEN
|
// THEN
|
||||||
XCTAssertFalse(result.isEmpty)
|
XCTAssertFalse(result.isEmpty)
|
||||||
XCTAssertEqual(result.count, 2)
|
XCTAssertEqual(result.count, 2)
|
||||||
XCTAssertNotNil(result.first?.games3DS)
|
XCTAssertNotNil(result.first?.games?.n3ds)
|
||||||
XCTAssertEqual(result.first?.games3DS?.count, 21)
|
XCTAssertEqual(result.first?.games?.n3ds.count, 21)
|
||||||
XCTAssertNotNil(result.first?.games3DS?.first?.usage)
|
XCTAssertNotNil(result.first?.games?.n3ds.first?.usage)
|
||||||
XCTAssertEqual(result.first?.games3DS?.first?.usage?.count, 1)
|
XCTAssertEqual(result.first?.games?.n3ds.first?.usage?.count, 1)
|
||||||
XCTAssertNotNil(result.first?.gamesWiiU)
|
XCTAssertNotNil(result.first?.games?.wiiu)
|
||||||
XCTAssertEqual(result.first?.gamesWiiU?.count, 8)
|
XCTAssertEqual(result.first?.games?.wiiu.count, 8)
|
||||||
XCTAssertNotNil(result.first?.gamesWiiU?.first?.usage)
|
XCTAssertNotNil(result.first?.games?.wiiu.first?.usage)
|
||||||
XCTAssertEqual(result.first?.gamesWiiU?.first?.usage?.count, 1)
|
XCTAssertEqual(result.first?.games?.wiiu.first?.usage?.count, 1)
|
||||||
XCTAssertNotNil(result.first?.gamesSwitch)
|
XCTAssertNotNil(result.first?.games?.switch)
|
||||||
XCTAssertEqual(result.first?.gamesSwitch?.count, 8)
|
XCTAssertEqual(result.first?.games?.switch.count, 8)
|
||||||
XCTAssertNotNil(result.first?.gamesSwitch?.first?.usage)
|
XCTAssertNotNil(result.first?.games?.switch.first?.usage)
|
||||||
XCTAssertEqual(result.first?.gamesSwitch?.first?.usage?.count, 1)
|
XCTAssertEqual(result.first?.games?.switch.first?.usage?.count, 1)
|
||||||
XCTAssertNotNil(result.last?.games3DS)
|
XCTAssertNotNil(result.last?.games?.n3ds)
|
||||||
XCTAssertEqual(result.last?.games3DS?.count, 22)
|
XCTAssertEqual(result.last?.games?.n3ds.count, 22)
|
||||||
XCTAssertNotNil(result.last?.games3DS?.first?.usage)
|
XCTAssertNotNil(result.last?.games?.n3ds.first?.usage)
|
||||||
XCTAssertEqual(result.last?.games3DS?.first?.usage?.count, 1)
|
XCTAssertEqual(result.last?.games?.n3ds.first?.usage?.count, 1)
|
||||||
XCTAssertNotNil(result.last?.gamesWiiU)
|
XCTAssertNotNil(result.last?.games?.wiiu)
|
||||||
XCTAssertEqual(result.last?.gamesWiiU?.count, 8)
|
XCTAssertEqual(result.last?.games?.wiiu.count, 8)
|
||||||
XCTAssertNotNil(result.last?.gamesWiiU?.first?.usage)
|
XCTAssertNotNil(result.last?.games?.wiiu.first?.usage)
|
||||||
XCTAssertEqual(result.last?.gamesWiiU?.first?.usage?.count, 1)
|
XCTAssertEqual(result.last?.games?.wiiu.first?.usage?.count, 1)
|
||||||
XCTAssertNotNil(result.last?.gamesSwitch)
|
XCTAssertNotNil(result.last?.games?.switch)
|
||||||
XCTAssertEqual(result.last?.gamesSwitch?.count, 9)
|
XCTAssertEqual(result.last?.games?.switch.count, 9)
|
||||||
XCTAssertNotNil(result.last?.gamesSwitch?.first?.usage)
|
XCTAssertNotNil(result.last?.games?.switch.first?.usage)
|
||||||
XCTAssertEqual(result.last?.gamesSwitch?.first?.usage?.count, 1)
|
XCTAssertEqual(result.last?.games?.switch.first?.usage?.count, 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
func test_amiibos_whenDateDecodingStrategyMismatch() async throws {
|
func test_amiibos_whenDateDecodingStrategyMismatch() async throws {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user