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:
Scott Kyle 2015-12-01 14:05:33 -08:00
parent 8224cbb09e
commit be0c2a91ea
3 changed files with 39 additions and 5 deletions

View File

@ -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;

View File

@ -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;
} }

View File

@ -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() {