mirror of
https://github.com/status-im/realm-js.git
synced 2025-01-10 22:36:01 +00:00
Fix RPC client error after deleting objects
Specifically for objects with lists, since the mutation listener would fire on a list that no longer is attached. If during the mutation listener that error is thrown, then the listener will be removed and the error will not be propagated.
This commit is contained in:
parent
8224cbb09e
commit
be0c2a91ea
@ -167,7 +167,14 @@ function sendRequest(command, data) {
|
|||||||
let response = JSON.parse(request.responseText);
|
let response = JSON.parse(request.responseText);
|
||||||
|
|
||||||
if (!response || response.error) {
|
if (!response || response.error) {
|
||||||
throw new Error((response && response.error) || 'Invalid response for "' + command + '"');
|
let error = response && response.error;
|
||||||
|
|
||||||
|
// Remove the type prefix from the error message (e.g. "Error: ").
|
||||||
|
if (error) {
|
||||||
|
error = error.replace(/^[a-z]+: /i, '');
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new Error(error || `Invalid response for "${command}"`);
|
||||||
}
|
}
|
||||||
|
|
||||||
return response.result;
|
return response.result;
|
||||||
|
22
lib/util.js
22
lib/util.js
@ -11,7 +11,6 @@ const {keys} = constants;
|
|||||||
const mutationListeners = {};
|
const mutationListeners = {};
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
addMutationListener,
|
|
||||||
fireMutationListeners,
|
fireMutationListeners,
|
||||||
createList,
|
createList,
|
||||||
createMethods,
|
createMethods,
|
||||||
@ -25,6 +24,13 @@ function addMutationListener(realmId, callback) {
|
|||||||
listeners.add(callback);
|
listeners.add(callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function removeMutationListener(realmId, callback) {
|
||||||
|
let listeners = mutationListeners[realmId];
|
||||||
|
if (listeners) {
|
||||||
|
listeners.delete(callback);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function fireMutationListeners(realmId) {
|
function fireMutationListeners(realmId) {
|
||||||
let listeners = mutationListeners[realmId];
|
let listeners = mutationListeners[realmId];
|
||||||
if (listeners) {
|
if (listeners) {
|
||||||
@ -87,7 +93,19 @@ function createList(prototype, realmId, info, mutable) {
|
|||||||
list[keys.type] = info.type;
|
list[keys.type] = info.type;
|
||||||
|
|
||||||
resize(info.size);
|
resize(info.size);
|
||||||
addMutationListener(realmId, resize);
|
|
||||||
|
addMutationListener(realmId, function listener() {
|
||||||
|
try {
|
||||||
|
resize();
|
||||||
|
} catch (e) {
|
||||||
|
// If the error indicates the list was deleted, then remove this listener.
|
||||||
|
if (e.message == 'Tableview is not attached') {
|
||||||
|
removeMutationListener(realmId, listener);
|
||||||
|
} else {
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
@ -276,11 +276,12 @@ module.exports = BaseTest.extend({
|
|||||||
|
|
||||||
testDeletions: function() {
|
testDeletions: function() {
|
||||||
var realm = new Realm({schema: [schemas.LinkTypes, schemas.TestObject]});
|
var realm = new Realm({schema: [schemas.LinkTypes, schemas.TestObject]});
|
||||||
|
var object;
|
||||||
var array;
|
var array;
|
||||||
|
|
||||||
realm.write(function() {
|
realm.write(function() {
|
||||||
var obj = realm.create('LinkTypesObject', [[1], [2], [[3], [4]]]);
|
object = realm.create('LinkTypesObject', [[1], [2], [[3], [4]]]);
|
||||||
array = obj.arrayCol;
|
array = object.arrayCol;
|
||||||
});
|
});
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@ -296,6 +297,14 @@ module.exports = BaseTest.extend({
|
|||||||
|
|
||||||
TestCase.assertEqual(array.length, 2);
|
TestCase.assertEqual(array.length, 2);
|
||||||
TestCase.assertEqual(array[0].doubleCol, 3);
|
TestCase.assertEqual(array[0].doubleCol, 3);
|
||||||
|
|
||||||
|
realm.write(function() {
|
||||||
|
realm.delete(object);
|
||||||
|
});
|
||||||
|
|
||||||
|
TestCase.assertThrows(function() {
|
||||||
|
array[0];
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
testLiveUpdatingResults: function() {
|
testLiveUpdatingResults: function() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user