Skip to content

Commit

Permalink
More tests
Browse files Browse the repository at this point in the history
  • Loading branch information
Iron-Ham committed Mar 12, 2024
1 parent 8feda09 commit 88c2788
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 0 deletions.
31 changes: 31 additions & 0 deletions Tests/ApolloPaginationTests/AsyncGraphQLQueryPagerTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -354,6 +354,37 @@ final class AsyncGraphQLQueryPagerTests: XCTestCase {
subscriber.cancel()
}

func test_equatable() async {
let pagerA = await AsyncGraphQLQueryPager(pager: createPager(), transform: { previous, initial, next in
let allPages = previous + [initial] + next
return allPages.flatMap { data in
data.hero.friendsConnection.friends.map { $0.name }
}
})

let pagerB = await AsyncGraphQLQueryPager(pager: createPager(), transform: { previous, initial, next in
let allPages = previous + [initial] + next
return allPages.flatMap { data in
data.hero.friendsConnection.friends.map { $0.name }
}
})

XCTAssertEqual(pagerA, pagerB)

pagerA._subject.send(.success((["Al-Khwarizmi", "Al-Jaziri", "Charles Babbage", "Ada Lovelace"], .cache)))
XCTAssertNotEqual(pagerA, pagerB)

pagerB._subject.send(.success((["Al-Khwarizmi", "Al-Jaziri", "Charles Babbage", "Ada Lovelace"], .cache)))
XCTAssertEqual(pagerA, pagerB)

pagerA._subject.send(.success((["Al-Khwarizmi", "Al-Jaziri", "Charles Babbage", "Ada Lovelace"], .fetch)))
XCTAssertNotEqual(pagerA, pagerB)

pagerB._subject.send(.success((["Al-Khwarizmi", "Al-Jaziri", "Charles Babbage", "Ada Lovelace"], .fetch)))
await pagerA.reset()
XCTAssertEqual(pagerA, pagerB)
}

// MARK: - Test helpers

private func createPager() -> AsyncGraphQLQueryPagerCoordinator<Query, Query> {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -256,6 +256,8 @@ extension AsyncGraphQLQueryPager: Equatable where Model: Equatable {
return leftValue == rightValue && leftSource == rightSource
case (.failure(let leftError), .failure(let rightError)):
return leftError.localizedDescription == rightError.localizedDescription
case (.none, .none):
return true
default:
return false
}
Expand Down

0 comments on commit 88c2788

Please sign in to comment.