Skip to content

Commit

Permalink
chore: allow mixing meta while merging Body.Data
Browse files Browse the repository at this point in the history
Ignore irrelevant generic types when merging Document.Body.Data.

### Reasoning

I have a paginated request and response data has no meta and links, because it’s irrelevant for me.
  • Loading branch information
nekrich committed Sep 20, 2023
1 parent c5d1e71 commit af4a9bd
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 5 deletions.
11 changes: 6 additions & 5 deletions Sources/JSONAPI/Document/Document.swift
Original file line number Diff line number Diff line change
Expand Up @@ -261,7 +261,7 @@ extension Document {
}

extension Document.Body.Data where PrimaryResourceBody: ResourceBodyAppendable {
public func merging(_ other: Document.Body.Data,
public func merging<OtherDescription, OtherError>(_ other: Document<PrimaryResourceBody, MetaType, LinksType, IncludeType, OtherDescription, OtherError>.Body.Data,
combiningMetaWith metaMerge: (MetaType, MetaType) -> MetaType,
combiningLinksWith linksMerge: (LinksType, LinksType) -> LinksType) -> Document.Body.Data {
return Document.Body.Data(primary: primary.appending(other.primary),
Expand All @@ -272,10 +272,11 @@ extension Document.Body.Data where PrimaryResourceBody: ResourceBodyAppendable {
}

extension Document.Body.Data where PrimaryResourceBody: ResourceBodyAppendable, MetaType == NoMetadata, LinksType == NoLinks {
public func merging(_ other: Document.Body.Data) -> Document.Body.Data {
return merging(other,
combiningMetaWith: { _, _ in .none },
combiningLinksWith: { _, _ in .none })
public func merging<OtherMeta, OtherLinks, OtherDescription, OtherError>(_ other: Document<PrimaryResourceBody, OtherMeta, OtherLinks, IncludeType, OtherDescription, OtherError>.Body.Data) -> Document.Body.Data {
return Document.Body.Data(primary: primary.appending(other.primary),
includes: includes.appending(other.includes),
meta: meta,
links: links)
}
}

Expand Down
21 changes: 21 additions & 0 deletions Tests/JSONAPITests/Document/DocumentTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -1528,6 +1528,23 @@ extension DocumentTests {
XCTAssertEqual(combined.primary.values, bodyData1.primary.values + bodyData2.primary.values)
}

public func test_MergeBodyDataMixedMetaAndLinks(){
let entity1 = Article(attributes: .none, relationships: .init(author: "2"), meta: .none, links: .none)
let entity2 = Article(attributes: .none, relationships: .init(author: "3"), meta: .none, links: .none)

let bodyData1 = Document<ManyResourceBody<Article>, NoMetadata, NoLinks, NoIncludes, NoAPIDescription, UnknownJSONAPIError>.Body.Data(primary: .init(resourceObjects: [entity1]),
includes: .none,
meta: .none,
links: .none)
let bodyData2 = Document<ManyResourceBody<Article>, TestPageMetadata, TestLinks, NoIncludes, NoAPIDescription, UnknownJSONAPIError>.Body.Data(primary: .init(resourceObjects: [entity2]),
includes: .none,
meta: .init(total: 5, limit: 2, offset: 2),
links: .init(link: .init(url: "one"), link2: .init(url: .init(), meta: .init(hello: "world"))))
let combined = bodyData1.merging(bodyData2)

XCTAssertEqual(combined.primary.values, bodyData1.primary.values + bodyData2.primary.values)
}

public func test_MergeBodyDataWithMergeFunctions() {
let article1 = Article(attributes: .none, relationships: .init(author: "2"), meta: .none, links: .none)
let author1 = Author(id: "2", attributes: .none, relationships: .none, meta: .none, links: .none)
Expand Down Expand Up @@ -1649,3 +1666,7 @@ extension DocumentTests {
}
}
}

enum SomeMeta: String, JSONAPI.Meta {
case some
}

0 comments on commit af4a9bd

Please sign in to comment.