in AmplifyPlugins/DataStore/AWSDataStoreCategoryPluginFlutterIntegrationTests/DataStoreFlutterConsecutiveUpdatesTests.swift [137:238]
func testSaveAndImmediatelyDelete() throws {
try startAmplifyAndWaitForSync()
let plugin: AWSDataStorePlugin = try Amplify.DataStore.getPlugin(for: "awsDataStorePlugin") as! AWSDataStorePlugin
let newPost = try PostWrapper(title: "MyPost",
content: "This is my post.",
createdAt: Temporal.DateTime.now().iso8601String,
rating: 3)
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? PostWrapper(json: mutationEvent.json) as! PostWrapper, post.idString() == newPost.idString() 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")
plugin.save(newPost.model, modelSchema: Post.schema) { result in
switch result {
case .success:
sleep(3)
plugin.delete(newPost.model, modelSchema: Post.schema, where: Post.keys.id.eq(newPost.idString())) { 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(id: newPost.idString(), plugin: plugin)
XCTAssertNil(queryResult)
wait(for: [saveSyncReceived, deleteSyncReceived], timeout: networkTimeout)
// query the deleted post in eventual consistent state
let queryResultAfterSync = queryPost(id: newPost.idString(), plugin: plugin)
XCTAssertNil(queryResultAfterSync)
let queryRequest =
GraphQLRequest<MutationSyncResult?>.query(modelName: "Post", byId: newPost.idString())
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
}
let testPost = self.convertToTestPost(model: post.model.instance as! Post)
XCTAssertNotNil(testPost)
XCTAssertEqual(testPost?.title(), newPost.title())
XCTAssertEqual(testPost?.content(), newPost.content())
XCTAssertEqual(testPost?.rating(), 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)
}