in AmplifyPlugins/DataStore/AWSDataStoreCategoryPluginIntegrationTests/DataStoreConsecutiveUpdatesTests.swift [138:237]
func testSaveAndImmediatelyDelete() throws {
try startAmplifyAndWaitForSync()
let newPost = Post(title: "MyPost",
content: "This is my post.",
createdAt: .now(),
rating: 3,
status: .published)
let saveSyncReceived = expectation(description: "Received create mutation event on subscription for Post")
let deleteSyncReceived = expectation(description: "Received delete mutation event on subscription for Post")
let hubListener = Amplify.Hub.listen(
to: .dataStore,
eventName: HubPayload.EventName.DataStore.syncReceived) { payload in
guard let mutationEvent = payload.data as? MutationEvent else {
XCTFail("Can't cast payload as mutation event")
return
}
guard let post = try? mutationEvent.decodeModel() as? Post, post.id == newPost.id else {
return
}
if mutationEvent.mutationType == GraphQLMutationType.create.rawValue {
XCTAssertEqual(post, newPost)
XCTAssertEqual(mutationEvent.version, 1)
saveSyncReceived.fulfill()
return
}
if mutationEvent.mutationType == GraphQLMutationType.delete.rawValue {
XCTAssertEqual(post, newPost)
XCTAssertEqual(mutationEvent.version, 2)
deleteSyncReceived.fulfill()
return
}
}
guard try HubListenerTestUtilities.waitForListener(with: hubListener, timeout: 5.0) else {
XCTFail("Listener not registered for hub")
return
}
let saveAndImmediatelyDelete = expectation(description: "Post is saved and then immediately deleted")
Amplify.DataStore.save(newPost) { result in
switch result {
case .success:
Amplify.DataStore.delete(newPost) { result in
switch result {
case .success:
saveAndImmediatelyDelete.fulfill()
case .failure(let error):
XCTFail("Error: \(error)")
}
}
case .failure(let error):
XCTFail("Error: \(error)")
}
}
wait(for: [saveAndImmediatelyDelete], timeout: networkTimeout)
// query the deleted post immediately
let queryResult = queryPost(byId: newPost.id)
XCTAssertNil(queryResult)
wait(for: [saveSyncReceived, deleteSyncReceived], timeout: networkTimeout)
// query the deleted post in eventual consistent state
let queryResultAfterSync = queryPost(byId: newPost.id)
XCTAssertNil(queryResultAfterSync)
let queryRequest =
GraphQLRequest<MutationSyncResult?>.query(modelName: newPost.modelName, byId: newPost.id)
let apiQuerySuccess = expectation(description: "API query is successful")
Amplify.API.query(request: queryRequest) { result in
switch result {
case .success(let mutationSyncResult):
switch mutationSyncResult {
case .success(let data):
guard let post = data else {
XCTFail("Failed to get data")
return
}
XCTAssertEqual(post.model["title"] as? String, newPost.title)
XCTAssertEqual(post.model["content"] as? String, newPost.content)
XCTAssertEqual(post.model["rating"] as? Double, newPost.rating)
XCTAssertTrue(post.syncMetadata.deleted)
XCTAssertEqual(post.syncMetadata.version, 2)
apiQuerySuccess.fulfill()
case .failure(let error):
XCTFail("Error: \(error)")
}
case .failure(let error):
XCTFail("Error: \(error)")
}
}
wait(for: [apiQuerySuccess], timeout: networkTimeout)
}