857 lines
32 KiB
JavaScript
857 lines
32 KiB
JavaScript
////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Copyright 2016 Realm Inc.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
'use strict';
|
|
|
|
var Realm = require('realm');
|
|
var TestCase = require('./asserts');
|
|
var schemas = require('./schemas');
|
|
|
|
module.exports = {
|
|
testResultsConstructor: function() {
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
var objects = realm.objects('TestObject');
|
|
|
|
TestCase.assertTrue(objects instanceof Realm.Results);
|
|
TestCase.assertTrue(objects instanceof Realm.Collection);
|
|
|
|
TestCase.assertThrows(function() {
|
|
new Realm.Results();
|
|
});
|
|
|
|
TestCase.assertEqual(typeof Realm.Results, 'function');
|
|
TestCase.assertTrue(Realm.Results instanceof Function);
|
|
},
|
|
|
|
testResultsLength: function() {
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
var objects = realm.objects('TestObject');
|
|
TestCase.assertEqual(objects.length, 0);
|
|
|
|
realm.write(function() {
|
|
realm.create('TestObject', {doubleCol: 1});
|
|
TestCase.assertEqual(objects.length, 1);
|
|
});
|
|
TestCase.assertEqual(objects.length, 1);
|
|
},
|
|
|
|
testResultsSubscript: function() {
|
|
var realm = new Realm({schema: [schemas.PersonObject]});
|
|
TestCase.assertEqual(realm.objects('PersonObject')[0], undefined);
|
|
|
|
realm.write(function() {
|
|
realm.create('PersonObject', {name: 'name1', age: 1});
|
|
realm.create('PersonObject', {name: 'name2', age: 2});
|
|
});
|
|
|
|
var people = realm.objects('PersonObject');
|
|
TestCase.assertEqual(people[0].age, 1);
|
|
TestCase.assertEqual(people[1].age, 2);
|
|
TestCase.assertEqual(people[2], undefined);
|
|
TestCase.assertEqual(people[-1], undefined);
|
|
TestCase.assertTrue(Object.getPrototypeOf(people[0]) === schemas.PersonObject.prototype);
|
|
TestCase.assertTrue(people[0] instanceof schemas.PersonObject);
|
|
},
|
|
|
|
testResultsReadonly: function() {
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
var objects = realm.objects('TestObject');
|
|
|
|
realm.write(function() {
|
|
realm.create('TestObject', {doubleCol: 1});
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
|
objects[-1] = {doubleCol: 0};
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
objects[0] = {doubleCol: 0};
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
objects[1] = {doubleCol: 0};
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
objects.length = 0;
|
|
});
|
|
},
|
|
|
|
testResultsInvalidProperty: function() {
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
var objects = realm.objects('TestObject');
|
|
TestCase.assertEqual(undefined, objects.ablasdf);
|
|
},
|
|
|
|
testResultsInvalidObjectType: function() {
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
TestCase.assertThrows(function() {
|
|
realm.objects('NotTestObject');
|
|
});
|
|
},
|
|
|
|
testResultsEnumerate: function() {
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
var objects = realm.objects('TestObject');
|
|
var index;
|
|
|
|
for (index in objects) {
|
|
TestCase.assertTrue(false, "No objects should have been enumerated");
|
|
}
|
|
|
|
realm.write(function() {
|
|
realm.create('TestObject', {doubleCol: 1});
|
|
TestCase.assertEqual(objects.length, 1);
|
|
});
|
|
|
|
var count = 0;
|
|
var keys = Object.keys(objects);
|
|
for (index in objects) {
|
|
TestCase.assertEqual(count++, +index);
|
|
TestCase.assertEqual(keys[index], index);
|
|
}
|
|
|
|
TestCase.assertEqual(count, 1);
|
|
TestCase.assertEqual(keys.length, 1);
|
|
},
|
|
|
|
testResultsFiltered: function() {
|
|
var realm = new Realm({schema: [schemas.PersonObject, schemas.DefaultValues, schemas.TestObject]});
|
|
|
|
realm.write(function() {
|
|
realm.create('PersonObject', {name: 'Ari', age: 10});
|
|
realm.create('PersonObject', {name: 'Tim', age: 11});
|
|
realm.create('PersonObject', {name: 'Bjarne', age: 12});
|
|
realm.create('PersonObject', {name: 'Alex', age: 12, married: true});
|
|
});
|
|
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered("truepredicate").length, 4);
|
|
TestCase.assertEqual(realm.objects('PersonObject').length, 4);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age = 11').length, 1);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age = 11')[0].name, 'Tim');
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age = 12').length, 2);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age = 13').length, 0);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age < 12').length, 2);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age > 10 && age < 13').length, 3);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age > 10').filtered('age < 13').length, 3);
|
|
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age >= 11 && age < 13').length, 3);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('name = "Tim"').length, 1);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('name = \'Tim\'').length, 1);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('married == TRUE').length, 1);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('married == false').length, 3);
|
|
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('name = $0', 'Tim').length, 1);
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age > $1 && age < $0', 13, 10).length, 3);
|
|
|
|
TestCase.assertThrows(function() {
|
|
realm.objects('PersonObject').filtered('age > $2 && age < $0', 13, 10)
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
realm.objects('PersonObject').filtered("invalidQuery");
|
|
});
|
|
|
|
realm.write(function() {
|
|
realm.create('DefaultValuesObject', {'dateCol': new Date(3)});
|
|
realm.create('DefaultValuesObject', {'dateCol': new Date(4)});
|
|
realm.create('DefaultValuesObject', {'dateCol': new Date(5)});
|
|
});
|
|
|
|
TestCase.assertEqual(realm.objects('DefaultValuesObject').filtered('dateCol > $0', new Date(4)).length, 1);
|
|
TestCase.assertEqual(realm.objects('DefaultValuesObject').filtered('dateCol <= $0', new Date(4)).length, 2);
|
|
},
|
|
|
|
testResultsFilteredByForeignObject: function() {
|
|
var realm = new Realm({schema: [schemas.LinkTypes, schemas.TestObject]});
|
|
var realm2 = new Realm({path: '2.realm', schema: realm.schema});
|
|
var object;
|
|
|
|
realm2.write(function() {
|
|
object = realm2.create('TestObject', {doubleCol: 1});
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
|
realm.objects('LinkTypesObject').filtered('objectCol = $0', object);
|
|
});
|
|
},
|
|
|
|
testResultsSorted: function() {
|
|
var realm = new Realm({schema: [schemas.IntPrimary]});
|
|
var objects = realm.objects('IntPrimaryObject');
|
|
|
|
realm.write(function() {
|
|
realm.create('IntPrimaryObject', {primaryCol: 2, valueCol: 'a'});
|
|
realm.create('IntPrimaryObject', {primaryCol: 3, valueCol: 'a'});
|
|
realm.create('IntPrimaryObject', {primaryCol: 1, valueCol: 'b'});
|
|
realm.create('IntPrimaryObject', {primaryCol: 4, valueCol: 'c'});
|
|
realm.create('IntPrimaryObject', {primaryCol: 0, valueCol: 'c'});
|
|
});
|
|
|
|
var primaries = function(results) {
|
|
return results.map(function(object) {
|
|
return object.primaryCol;
|
|
});
|
|
};
|
|
|
|
objects = objects.sorted([]);
|
|
TestCase.assertArraysEqual(primaries(objects), [2, 3, 1, 4, 0]);
|
|
|
|
objects = objects.sorted('primaryCol');
|
|
TestCase.assertArraysEqual(primaries(objects), [0, 1, 2, 3, 4]);
|
|
|
|
objects = objects.sorted('primaryCol', true);
|
|
TestCase.assertArraysEqual(primaries(objects), [4, 3, 2, 1, 0]);
|
|
|
|
objects = objects.sorted(['primaryCol', 'valueCol']);
|
|
TestCase.assertArraysEqual(primaries(objects), [0, 1, 2, 3, 4]);
|
|
|
|
objects = objects.sorted([['primaryCol', true], ['valueCol', true]]);
|
|
TestCase.assertArraysEqual(primaries(objects), [4, 3, 2, 1, 0]);
|
|
|
|
objects = objects.sorted([['primaryCol', false], 'valueCol']);
|
|
TestCase.assertArraysEqual(primaries(objects), [0, 1, 2, 3, 4]);
|
|
|
|
objects = objects.sorted(['valueCol', 'primaryCol']);
|
|
TestCase.assertArraysEqual(primaries(objects), [2, 3, 1, 0, 4]);
|
|
|
|
objects = objects.sorted([['valueCol', false], ['primaryCol', true]]);
|
|
TestCase.assertArraysEqual(primaries(objects), [3, 2, 1, 4, 0]);
|
|
|
|
objects = objects.sorted([['valueCol', true], ['primaryCol', false]]);
|
|
TestCase.assertArraysEqual(primaries(objects), [0, 4, 1, 2, 3]);
|
|
|
|
objects = objects.sorted([['valueCol', true], ['primaryCol', true]]);
|
|
TestCase.assertArraysEqual(primaries(objects), [4, 0, 1, 3, 2]);
|
|
|
|
TestCase.assertThrows(function() {
|
|
objects.sorted();
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
objects.sorted(1);
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
objects.sorted([1]);
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
objects.sorted('fish');
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
objects.sorted(['valueCol', 'fish']);
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
objects.sorted(['valueCol', 'primaryCol'], true);
|
|
});
|
|
},
|
|
|
|
testResultsSortedAllTypes: function() {
|
|
var realm = new Realm({schema: [schemas.BasicTypes]});
|
|
var objects = realm.objects('BasicTypesObject');
|
|
|
|
realm.write(function() {
|
|
realm.create('BasicTypesObject', [false, 0, 0, 0, '0', new Date(0), new ArrayBuffer()]);
|
|
realm.create('BasicTypesObject', [true, 2, 2, 2, '2', new Date(2), new ArrayBuffer()]);
|
|
realm.create('BasicTypesObject', [false, 1, 1, 1, '1', new Date(1), new ArrayBuffer()]);
|
|
});
|
|
|
|
var numberProps = ['intCol', 'floatCol', 'doubleCol', 'stringCol'];
|
|
for (var i = 0; i < numberProps.length; i++) {
|
|
var prop = numberProps[i];
|
|
|
|
objects = objects.sorted(prop, false);
|
|
TestCase.assertEqual('' + objects[0][prop], '0', 'first element ascending for ' + prop);
|
|
TestCase.assertEqual('' + objects[2][prop], '2', 'second element ascending for ' + prop);
|
|
|
|
objects = objects.sorted(prop, true);
|
|
TestCase.assertEqual('' + objects[0][prop], '2', 'first element descending for ' + prop);
|
|
TestCase.assertEqual('' + objects[2][prop], '0', 'second element descending for ' + prop);
|
|
}
|
|
|
|
objects = objects.sorted('dateCol', false);
|
|
TestCase.assertEqual(objects[0].dateCol.getTime(), 0);
|
|
TestCase.assertEqual(objects[2].dateCol.getTime(), 2);
|
|
|
|
objects = objects.sorted('dateCol', true);
|
|
TestCase.assertEqual(objects[0].dateCol.getTime(), 2);
|
|
TestCase.assertEqual(objects[2].dateCol.getTime(), 0);
|
|
|
|
objects = objects.sorted('boolCol', false);
|
|
TestCase.assertEqual(objects[0].boolCol, false, 'first element ascending for boolCol');
|
|
TestCase.assertEqual(objects[0].boolCol, false, 'second element ascending for boolCol');
|
|
TestCase.assertEqual(objects[2].boolCol, true, 'third element ascending for boolCol');
|
|
|
|
objects = objects.sorted('boolCol', true);
|
|
TestCase.assertEqual(objects[0].boolCol, true, 'first element descending for boolCol');
|
|
TestCase.assertEqual(objects[1].boolCol, false, 'second element descending for boolCol');
|
|
TestCase.assertEqual(objects[2].boolCol, false, 'third element descending for boolCol');
|
|
},
|
|
|
|
testResultsInvalidation: function() {
|
|
let realm = new Realm({schema: [schemas.TestObject]});
|
|
realm.write(function() {
|
|
for (var i = 10; i > 0; i--) {
|
|
realm.create('TestObject', [i]);
|
|
}
|
|
});
|
|
|
|
var resultsVariants = [
|
|
realm.objects('TestObject'),
|
|
realm.objects('TestObject').filtered('doubleCol > 1'),
|
|
realm.objects('TestObject').filtered('doubleCol > 1').sorted('doubleCol'),
|
|
realm.objects('TestObject').filtered('doubleCol > 1').snapshot()
|
|
];
|
|
|
|
// test isValid
|
|
resultsVariants.forEach(function(objects) {
|
|
TestCase.assertEqual(objects.isValid(), true);
|
|
});
|
|
|
|
// close and test invalidated accessors
|
|
realm.close();
|
|
realm = new Realm({
|
|
schemaVersion: 1,
|
|
schema: [schemas.TestObject, schemas.DateObject]
|
|
});
|
|
|
|
resultsVariants.forEach(function(objects) {
|
|
TestCase.assertEqual(objects.isValid(), false);
|
|
TestCase.assertThrows(function() { objects[0]; });
|
|
TestCase.assertThrows(function() { objects.filtered('doubleCol < 42'); });
|
|
TestCase.assertThrows(function() { objects.sorted('doubleCol', true); });
|
|
TestCase.assertThrows(function() { objects.snapshot(); });
|
|
});
|
|
},
|
|
|
|
testResultsDeletedObjects: function() {
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
|
|
var createTestObjects = function(n) {
|
|
for (var i = 0; i < n; i++) {
|
|
realm.create('TestObject', {doubleCol: i});
|
|
}
|
|
|
|
return realm.objects('TestObject');
|
|
}
|
|
|
|
realm.write(function() {
|
|
var objects = createTestObjects(10);
|
|
var snapshot = objects.snapshot();
|
|
|
|
realm.deleteAll();
|
|
TestCase.assertEqual(objects.length, 0);
|
|
TestCase.assertEqual(snapshot.length, 10);
|
|
TestCase.assertEqual(snapshot[0], null);
|
|
});
|
|
|
|
realm.write(function() {
|
|
var objects = createTestObjects(10);
|
|
realm.deleteAll();
|
|
|
|
var snapshot = objects.snapshot();
|
|
TestCase.assertEqual(objects.length, 0);
|
|
TestCase.assertEqual(snapshot.length, 0);
|
|
});
|
|
|
|
realm.write(function() {
|
|
var objects = createTestObjects(10);
|
|
var snapshot = objects.snapshot();
|
|
|
|
realm.delete(snapshot);
|
|
TestCase.assertEqual(objects.length, 0);
|
|
TestCase.assertEqual(snapshot.length, 10);
|
|
TestCase.assertEqual(snapshot[0], null);
|
|
});
|
|
|
|
realm.write(function() {
|
|
var objects = createTestObjects(10);
|
|
realm.delete(objects);
|
|
|
|
var snapshot = objects.snapshot();
|
|
TestCase.assertEqual(objects.length, 0);
|
|
TestCase.assertEqual(snapshot.length, 0);
|
|
});
|
|
},
|
|
|
|
testResultsFindIndexOfObject: function() {
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
|
|
var object1, object2, object3;
|
|
realm.write(function() {
|
|
object1 = realm.create('TestObject', {doubleCol: 1});
|
|
object2 = realm.create('TestObject', {doubleCol: 2});
|
|
object3 = realm.create('TestObject', {doubleCol: 2});
|
|
});
|
|
|
|
// Search in base table
|
|
const objects = realm.objects('TestObject');
|
|
TestCase.assertEqual(objects.indexOf(object1), 0);
|
|
TestCase.assertEqual(objects.indexOf(object2), 1);
|
|
TestCase.assertEqual(objects.indexOf(object3), 2);
|
|
|
|
// Search in filtered query
|
|
const results = objects.filtered("doubleCol == 2");
|
|
TestCase.assertEqual(results.indexOf(object1), -1);
|
|
TestCase.assertEqual(results.indexOf(object2), 0);
|
|
TestCase.assertEqual(results.indexOf(object3), 1);
|
|
|
|
const nonRealmObject = {test: "this is an object"};
|
|
TestCase.assertEqual(objects.indexOf(nonRealmObject), -1);
|
|
|
|
// Searching for object from the wrong realm
|
|
var realm2 = new Realm({path: '2.realm', schema: realm.schema});
|
|
var object4;
|
|
realm2.write(function() {
|
|
object4 = realm2.create('TestObject', {doubleCol: 1});
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
objects.indexOf(object4);
|
|
});
|
|
},
|
|
|
|
testAddListener: function() {
|
|
if (typeof navigator !== 'undefined' && /Chrome/.test(navigator.userAgent)) { // eslint-disable-line no-undef
|
|
// FIXME: async callbacks do not work correctly in Chrome debugging mode
|
|
return;
|
|
}
|
|
|
|
const realm = new Realm({ schema: [schemas.TestObject] });
|
|
realm.write(() => {
|
|
realm.create('TestObject', { doubleCol: 1 });
|
|
realm.create('TestObject', { doubleCol: 2 });
|
|
realm.create('TestObject', { doubleCol: 3 });
|
|
});
|
|
|
|
let resolve, first = true;
|
|
return new Promise((r, _reject) => {
|
|
resolve = r;
|
|
realm.objects('TestObject').addListener((testObjects, changes) => {
|
|
if (first) {
|
|
TestCase.assertEqual(testObjects.length, 3);
|
|
TestCase.assertEqual(changes.insertions.length, 0);
|
|
}
|
|
else {
|
|
TestCase.assertEqual(testObjects.length, 4);
|
|
TestCase.assertEqual(changes.insertions.length, 1);
|
|
}
|
|
first = false;
|
|
resolve();
|
|
});
|
|
}).then(() => {
|
|
return new Promise((r, _reject) => {
|
|
realm.write(() => {
|
|
realm.create('TestObject', { doubleCol: 1 });
|
|
});
|
|
resolve = r;
|
|
});
|
|
})
|
|
},
|
|
|
|
testResultsAggregateFunctions: function() {
|
|
var realm = new Realm({ schema: [schemas.NullableBasicTypes] });
|
|
const N = 50;
|
|
realm.write(() => {
|
|
for(var i = 0; i < N; i++) {
|
|
realm.create('NullableBasicTypesObject', {
|
|
intCol: i+1,
|
|
floatCol: i+1,
|
|
doubleCol: i+1,
|
|
dateCol: new Date(i+1)
|
|
});
|
|
}
|
|
});
|
|
|
|
var results = realm.objects('NullableBasicTypesObject');
|
|
TestCase.assertEqual(results.length, N);
|
|
|
|
// int, float & double columns support all aggregate functions
|
|
['intCol', 'floatCol', 'doubleCol'].forEach(colName => {
|
|
TestCase.assertEqual(results.min(colName), 1);
|
|
TestCase.assertEqual(results.max(colName), N);
|
|
TestCase.assertEqual(results.sum(colName), N*(N+1)/2);
|
|
TestCase.assertEqual(results.avg(colName), (N+1)/2);
|
|
});
|
|
|
|
// date columns support only 'min' & 'max'
|
|
TestCase.assertEqual(results.min('dateCol').getTime(), new Date(1).getTime());
|
|
TestCase.assertEqual(results.max('dateCol').getTime(), new Date(N).getTime());
|
|
},
|
|
|
|
testResultsAggregateFunctionsWithNullColumnValues: function() {
|
|
var realm = new Realm({ schema: [schemas.NullableBasicTypes] });
|
|
|
|
const N = 50;
|
|
const M = 10;
|
|
|
|
realm.write(() => {
|
|
for(var i = 0; i < N; i++) {
|
|
realm.create('NullableBasicTypesObject', {
|
|
intCol: i+1,
|
|
floatCol: i+1,
|
|
doubleCol: i+1,
|
|
dateCol: new Date(i+1)
|
|
});
|
|
}
|
|
|
|
// add some null valued data, which should be ignored by the aggregate functions
|
|
for(var j = 0; j < M; j++) {
|
|
realm.create('NullableBasicTypesObject', {
|
|
intCol: null,
|
|
floatCol: null,
|
|
doubleCol: null,
|
|
dateCol: null
|
|
});
|
|
}
|
|
});
|
|
|
|
var results = realm.objects('NullableBasicTypesObject');
|
|
|
|
TestCase.assertEqual(results.length, N + M);
|
|
|
|
// int, float & double columns support all aggregate functions
|
|
// the M null valued objects should be ignored
|
|
['intCol', 'floatCol', 'doubleCol'].forEach(colName => {
|
|
TestCase.assertEqual(results.min(colName), 1);
|
|
TestCase.assertEqual(results.max(colName), N);
|
|
TestCase.assertEqual(results.sum(colName), N*(N+1)/2);
|
|
TestCase.assertEqual(results.avg(colName), (N+1)/2);
|
|
});
|
|
|
|
// date columns support only 'min' & 'max'
|
|
TestCase.assertEqual(results.min('dateCol').getTime(), new Date(1).getTime());
|
|
TestCase.assertEqual(results.max('dateCol').getTime(), new Date(N).getTime());
|
|
|
|
// call aggregate functions on empty results
|
|
var emptyResults = realm.objects('NullableBasicTypesObject').filtered('intCol < 0');
|
|
TestCase.assertEqual(emptyResults.length, 0);
|
|
['intCol', 'floatCol', 'doubleCol'].forEach(colName => {
|
|
TestCase.assertUndefined(emptyResults.min(colName));
|
|
TestCase.assertUndefined(emptyResults.max(colName));
|
|
TestCase.assertEqual(emptyResults.sum(colName), 0);
|
|
TestCase.assertUndefined(emptyResults.avg(colName));
|
|
});
|
|
|
|
TestCase.assertUndefined(emptyResults.min('dateCol'));
|
|
TestCase.assertUndefined(emptyResults.max('dateCol'));
|
|
},
|
|
|
|
testResultsAggregateFunctionsUnsupported: function() {
|
|
var realm = new Realm({ schema: [schemas.NullableBasicTypes] });
|
|
realm.write(() => {
|
|
realm.create('NullableBasicTypesObject', {
|
|
boolCol: true,
|
|
stringCol: "hello",
|
|
dataCol: new ArrayBuffer(12),
|
|
});
|
|
});
|
|
|
|
var results = realm.objects('NullableBasicTypesObject');
|
|
|
|
// bool, string & data columns don't support 'min'
|
|
['boolCol', 'stringCol', 'dataCol'].forEach(colName => {
|
|
TestCase.assertThrows(function() {
|
|
results.min(colName);
|
|
}
|
|
)});
|
|
|
|
// bool, string & data columns don't support 'max'
|
|
['boolCol', 'stringCol', 'dataCol'].forEach(colName => {
|
|
TestCase.assertThrows(function() {
|
|
results.max(colName);
|
|
}
|
|
)});
|
|
|
|
// bool, string, date & data columns don't support 'avg'
|
|
['boolCol', 'stringCol', 'dateCol', 'dataCol'].forEach(colName => {
|
|
TestCase.assertThrows(function() {
|
|
results.avg(colName);
|
|
}
|
|
)});
|
|
|
|
// bool, string, date & data columns don't support 'sum'
|
|
['boolCol', 'stringCol', 'dateCol', 'dataCol'].forEach(colName => {
|
|
TestCase.assertThrows(function() {
|
|
results.sum(colName);
|
|
}
|
|
)});
|
|
},
|
|
|
|
testResultsAggregateFunctionsWrongProperty: function() {
|
|
var realm = new Realm({ schema: [ schemas.TestObject ]});
|
|
realm.write(() => {
|
|
realm.create('TestObject', { doubleCol: 42 });
|
|
});
|
|
var results = realm.objects('TestObject');
|
|
TestCase.assertThrows(function() {
|
|
results.min('foo')
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
results.max('foo')
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
results.sum('foo')
|
|
});
|
|
TestCase.assertThrows(function() {
|
|
results.avg('foo')
|
|
});
|
|
},
|
|
|
|
testIterator: function() {
|
|
var realm = new Realm({ schema: [ schemas.TestObject ]});
|
|
realm.write(() => {
|
|
realm.create('TestObject', { doubleCol: 2 });
|
|
realm.create('TestObject', { doubleCol: 3 });
|
|
});
|
|
|
|
var results = realm.objects('TestObject').filtered('doubleCol >= 2');
|
|
TestCase.assertEqual(results.length, 2);
|
|
var calls = 0;
|
|
for(let obj of results) {
|
|
realm.write(() => {
|
|
obj.doubleCol = 1;
|
|
});
|
|
calls++;
|
|
}
|
|
TestCase.assertEqual(results.length, 0);
|
|
TestCase.assertEqual(calls, 2);
|
|
},
|
|
|
|
testResultsUpdate: function() {
|
|
const N = 5;
|
|
|
|
var realm = new Realm({schema: [schemas.NullableBasicTypes]});
|
|
realm.write(() => {
|
|
for(var i = 0; i < N; i++) {
|
|
realm.create('NullableBasicTypesObject', { intCol: 10 });
|
|
}
|
|
});
|
|
|
|
// update should work on a basic result set
|
|
var results = realm.objects('NullableBasicTypesObject');
|
|
TestCase.assertEqual(results.length, 5);
|
|
realm.write(() => {
|
|
results.update('intCol', 20);
|
|
});
|
|
TestCase.assertEqual(results.length, 5);
|
|
TestCase.assertEqual(realm.objects('NullableBasicTypesObject').filtered('intCol = 20').length, 5);
|
|
|
|
// update should work on a filtered result set
|
|
results = realm.objects('NullableBasicTypesObject').filtered('intCol = 20');
|
|
realm.write(() => {
|
|
results.update('intCol', 10);
|
|
});
|
|
TestCase.assertEqual(results.length, 0);
|
|
TestCase.assertEqual(realm.objects('NullableBasicTypesObject').filtered('intCol = 10').length, 5);
|
|
|
|
// update should work on a sorted result set
|
|
results = realm.objects('NullableBasicTypesObject').filtered('intCol == 10').sorted('intCol');
|
|
realm.write(() => {
|
|
results.update('intCol', 20);
|
|
});
|
|
TestCase.assertEqual(results.length, 0);
|
|
TestCase.assertEqual(realm.objects('NullableBasicTypesObject').filtered('intCol = 20').length, 5);
|
|
|
|
// update should work on a result snapshot
|
|
results = realm.objects('NullableBasicTypesObject').filtered('intCol == 20').snapshot();
|
|
realm.write(() => {
|
|
results.update('intCol', 10);
|
|
});
|
|
TestCase.assertEqual(results.length, 5); // snapshot length should not change
|
|
TestCase.assertEqual(realm.objects('NullableBasicTypesObject').filtered('intCol = 10').length, 5);
|
|
|
|
realm.close();
|
|
},
|
|
|
|
testResultsUpdateDataTypes: function() {
|
|
const N = 5;
|
|
|
|
var realm = new Realm({schema: [schemas.NullableBasicTypes]});
|
|
realm.write(() => {
|
|
for(var i = 0; i < N; i++) {
|
|
realm.create('NullableBasicTypesObject', {
|
|
boolCol: false,
|
|
stringCol: 'hello',
|
|
intCol: 10,
|
|
floatCol: 10.0,
|
|
doubleCol: 10.0,
|
|
dateCol: new Date(10)
|
|
});
|
|
}
|
|
});
|
|
|
|
const testCases = [
|
|
// col name, initial filter, initial filter pre-update count, initial filter post-update count, updated value, updated filter, updated filter post-update count
|
|
[ 'boolCol', 'boolCol = false', N, 0, true, 'boolCol = true', N ],
|
|
[ 'stringCol', 'stringCol = "hello"', N, 0, 'world', 'stringCol = "world"', N ],
|
|
[ 'intCol', 'intCol = 10', N, 0, 20, 'intCol = 20', N ],
|
|
[ 'floatCol', 'floatCol = 10.0', N, 0, 20.0, 'floatCol = 20.0', N ],
|
|
[ 'doubleCol', 'doubleCol = 10.0', N, 0, 20.0, 'doubleCol = 20.0', N ],
|
|
];
|
|
|
|
testCases.forEach(function(testCase) {
|
|
var results = realm.objects('NullableBasicTypesObject').filtered(testCase[1]);
|
|
TestCase.assertEqual(results.length, testCase[2]);
|
|
|
|
realm.write(() => {
|
|
results.update(testCase[0], testCase[4]);
|
|
});
|
|
|
|
TestCase.assertEqual(results.length, testCase[3]);
|
|
|
|
results = realm.objects('NullableBasicTypesObject').filtered(testCase[5]);
|
|
TestCase.assertEqual(results.length, testCase[6]);
|
|
});
|
|
|
|
realm.close();
|
|
},
|
|
|
|
testResultUpdateDateColumn: function() {
|
|
const N = 5;
|
|
|
|
var realm = new Realm({schema: [schemas.NullableBasicTypes]});
|
|
|
|
// date column
|
|
realm.write(() => {
|
|
for(var i = 0; i < N; i++) {
|
|
realm.create('NullableBasicTypesObject', {
|
|
dateCol: new Date(1000)
|
|
});
|
|
}
|
|
});
|
|
|
|
var results = realm.objects('NullableBasicTypesObject').filtered('dateCol = $0', new Date(1000));
|
|
TestCase.assertEqual(results.length, N);
|
|
|
|
realm.write(() => {
|
|
results.update('dateCol', new Date(2000));
|
|
});
|
|
|
|
TestCase.assertEqual(results.length, 0);
|
|
results = realm.objects('NullableBasicTypesObject').filtered('dateCol = $0', new Date(2000));
|
|
TestCase.assertEqual(results.length, N);
|
|
|
|
realm.close();
|
|
},
|
|
|
|
testResultsUpdateDataColumn: function() {
|
|
const N = 5;
|
|
|
|
var RANDOM_DATA = new Uint8Array([
|
|
0xd8, 0x21, 0xd6, 0xe8, 0x00, 0x57, 0xbc, 0xb2, 0x6a, 0x15, 0x77, 0x30, 0xac, 0x77, 0x96, 0xd9,
|
|
0x67, 0x1e, 0x40, 0xa7, 0x6d, 0x52, 0x83, 0xda, 0x07, 0x29, 0x9c, 0x70, 0x38, 0x48, 0x4e, 0xff,
|
|
]);
|
|
|
|
var realm = new Realm({schema: [schemas.NullableBasicTypes]});
|
|
|
|
// date column
|
|
realm.write(() => {
|
|
for(var i = 0; i < N; i++) {
|
|
realm.create('NullableBasicTypesObject', {
|
|
dataCol: null
|
|
});
|
|
}
|
|
});
|
|
|
|
var results = realm.objects('NullableBasicTypesObject');
|
|
TestCase.assertEqual(results.length, N);
|
|
|
|
realm.write(() => {
|
|
results.update('dataCol', RANDOM_DATA);
|
|
});
|
|
|
|
for(var i = 0; i < results.length; i++) {
|
|
TestCase.assertArraysEqual(new Uint8Array(results[i].dataCol), RANDOM_DATA);
|
|
}
|
|
|
|
realm.close();
|
|
},
|
|
|
|
testResultsUpdateEmpty() {
|
|
var realm = new Realm({schema: [schemas.NullableBasicTypes]});
|
|
|
|
var emptyResults = realm.objects('NullableBasicTypesObject').filtered('stringCol = "hello"');
|
|
TestCase.assertEqual(emptyResults.length, 0);
|
|
|
|
realm.write(() => {
|
|
emptyResults.update('stringCol', 'no-op');
|
|
});
|
|
|
|
TestCase.assertEqual(emptyResults.length, 0);
|
|
TestCase.assertEqual(realm.objects('NullableBasicTypesObject').filtered('stringCol = "no-op"').length, 0);
|
|
|
|
realm.close();
|
|
},
|
|
|
|
testResultsUpdateInvalidated() {
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
realm.write(function() {
|
|
for (var i = 10; i > 0; i--) {
|
|
realm.create('TestObject', [i]);
|
|
}
|
|
});
|
|
|
|
var resultsVariants = [
|
|
realm.objects('TestObject'),
|
|
realm.objects('TestObject').filtered('doubleCol > 1'),
|
|
realm.objects('TestObject').filtered('doubleCol > 1').sorted('doubleCol'),
|
|
realm.objects('TestObject').filtered('doubleCol > 1').snapshot()
|
|
];
|
|
|
|
// test isValid
|
|
resultsVariants.forEach(function(objects) {
|
|
TestCase.assertEqual(objects.isValid(), true);
|
|
});
|
|
|
|
// close and test update
|
|
realm.close();
|
|
realm = new Realm({
|
|
schemaVersion: 1,
|
|
schema: [schemas.TestObject, schemas.BasicTypes]
|
|
});
|
|
|
|
resultsVariants.forEach(function(objects) {
|
|
TestCase.assertEqual(objects.isValid(), false);
|
|
TestCase.assertThrows(function() { objects.update('doubleCol', 42); });
|
|
});
|
|
},
|
|
|
|
testResultsUpdateWrongProperty() {
|
|
var realm = new Realm({schema: [schemas.NullableBasicTypes]});
|
|
|
|
const N = 5;
|
|
realm.write(() => {
|
|
for(var i = 0; i < N; i++) {
|
|
realm.create('NullableBasicTypesObject', {
|
|
stringCol: 'hello'
|
|
});
|
|
}
|
|
});
|
|
|
|
var results = realm.objects('NullableBasicTypesObject').filtered('stringCol = "hello"');
|
|
TestCase.assertEqual(results.length, N);
|
|
|
|
TestCase.assertThrows(function() {
|
|
realm.write(() => {
|
|
results.update('unknownCol', 'world');
|
|
});
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
|
results.update('stringCol', 'world');
|
|
});
|
|
|
|
realm.close();
|
|
}
|
|
};
|