2016-02-18 19:59:34 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
////////////////////////////////////////////////////////////////////////////
|
2015-08-14 15:18:49 +00:00
|
|
|
|
2015-08-13 16:12:48 +00:00
|
|
|
'use strict';
|
|
|
|
|
2015-10-08 23:19:19 +00:00
|
|
|
var Realm = require('realm');
|
2015-10-06 07:57:35 +00:00
|
|
|
var TestCase = require('./asserts');
|
|
|
|
var schemas = require('./schemas');
|
|
|
|
|
2016-05-20 22:54:20 +00:00
|
|
|
module.exports = {
|
2016-02-28 21:07:05 +00:00
|
|
|
testResultsConstructor: function() {
|
|
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
|
|
var objects = realm.objects('TestObject');
|
|
|
|
|
|
|
|
TestCase.assertTrue(objects instanceof Realm.Results);
|
2016-03-09 07:47:08 +00:00
|
|
|
TestCase.assertTrue(objects instanceof Realm.Collection);
|
2016-02-28 21:07:05 +00:00
|
|
|
|
|
|
|
TestCase.assertThrows(function() {
|
|
|
|
new Realm.Results();
|
|
|
|
});
|
2016-05-09 23:15:10 +00:00
|
|
|
|
|
|
|
TestCase.assertEqual(typeof Realm.Results, 'function');
|
|
|
|
TestCase.assertTrue(Realm.Results instanceof Function);
|
2016-02-28 21:07:05 +00:00
|
|
|
},
|
|
|
|
|
2015-08-13 16:12:48 +00:00
|
|
|
testResultsLength: function() {
|
2015-10-06 07:57:35 +00:00
|
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
2015-08-13 16:12:48 +00:00
|
|
|
var objects = realm.objects('TestObject');
|
|
|
|
TestCase.assertEqual(objects.length, 0);
|
|
|
|
|
|
|
|
realm.write(function() {
|
2015-11-02 20:02:53 +00:00
|
|
|
realm.create('TestObject', {doubleCol: 1});
|
2015-08-13 16:12:48 +00:00
|
|
|
TestCase.assertEqual(objects.length, 1);
|
|
|
|
});
|
|
|
|
TestCase.assertEqual(objects.length, 1);
|
|
|
|
},
|
2016-02-28 21:07:05 +00:00
|
|
|
|
2015-08-13 16:12:48 +00:00
|
|
|
testResultsSubscript: function() {
|
2015-10-06 07:57:35 +00:00
|
|
|
var realm = new Realm({schema: [schemas.PersonObject]});
|
2016-04-19 23:03:18 +00:00
|
|
|
TestCase.assertEqual(realm.objects('PersonObject')[0], undefined);
|
2016-04-27 21:01:01 +00:00
|
|
|
|
2015-08-13 16:12:48 +00:00
|
|
|
realm.write(function() {
|
2015-11-02 20:02:53 +00:00
|
|
|
realm.create('PersonObject', {name: 'name1', age: 1});
|
|
|
|
realm.create('PersonObject', {name: 'name2', age: 2});
|
2015-08-13 16:12:48 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
var people = realm.objects('PersonObject');
|
|
|
|
TestCase.assertEqual(people[0].age, 1);
|
|
|
|
TestCase.assertEqual(people[1].age, 2);
|
2015-10-12 22:35:13 +00:00
|
|
|
TestCase.assertEqual(people[2], undefined);
|
|
|
|
TestCase.assertEqual(people[-1], undefined);
|
2015-10-06 07:57:35 +00:00
|
|
|
TestCase.assertTrue(Object.getPrototypeOf(people[0]) === schemas.PersonObject.prototype);
|
2015-10-21 22:17:55 +00:00
|
|
|
TestCase.assertTrue(people[0] instanceof schemas.PersonObject);
|
2015-08-13 16:12:48 +00:00
|
|
|
},
|
2016-02-28 21:07:05 +00:00
|
|
|
|
2015-10-21 22:25:15 +00:00
|
|
|
testResultsReadonly: function() {
|
|
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
|
|
|
var objects = realm.objects('TestObject');
|
|
|
|
|
|
|
|
realm.write(function() {
|
2015-11-02 20:02:53 +00:00
|
|
|
realm.create('TestObject', {doubleCol: 1});
|
2015-10-21 22:25:15 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
TestCase.assertThrows(function() {
|
2015-11-02 20:02:53 +00:00
|
|
|
objects[-1] = {doubleCol: 0};
|
2015-10-21 22:25:15 +00:00
|
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
2015-11-02 20:02:53 +00:00
|
|
|
objects[0] = {doubleCol: 0};
|
2015-10-21 22:25:15 +00:00
|
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
2015-11-02 20:02:53 +00:00
|
|
|
objects[1] = {doubleCol: 0};
|
2015-10-21 22:25:15 +00:00
|
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
|
|
|
objects.length = 0;
|
|
|
|
});
|
|
|
|
},
|
2016-02-28 21:07:05 +00:00
|
|
|
|
2015-08-13 16:12:48 +00:00
|
|
|
testResultsInvalidProperty: function() {
|
2015-10-06 07:57:35 +00:00
|
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
2015-08-13 16:12:48 +00:00
|
|
|
var objects = realm.objects('TestObject');
|
|
|
|
TestCase.assertEqual(undefined, objects.ablasdf);
|
|
|
|
},
|
2016-02-28 21:07:05 +00:00
|
|
|
|
2015-09-01 23:23:42 +00:00
|
|
|
testResultsInvalidObjectType: function() {
|
2015-10-06 07:57:35 +00:00
|
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
2015-09-01 23:23:42 +00:00
|
|
|
TestCase.assertThrows(function() {
|
2016-05-20 23:33:16 +00:00
|
|
|
realm.objects('NotTestObject');
|
2015-09-01 23:23:42 +00:00
|
|
|
});
|
|
|
|
},
|
2016-02-28 21:07:05 +00:00
|
|
|
|
2015-08-14 17:47:56 +00:00
|
|
|
testResultsEnumerate: function() {
|
2015-10-06 07:57:35 +00:00
|
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
2015-08-13 16:12:48 +00:00
|
|
|
var objects = realm.objects('TestObject');
|
2016-05-20 23:33:16 +00:00
|
|
|
var index;
|
2015-11-02 20:02:53 +00:00
|
|
|
|
2016-05-20 23:33:16 +00:00
|
|
|
for (index in objects) {
|
2015-08-13 16:12:48 +00:00
|
|
|
TestCase.assertTrue(false, "No objects should have been enumerated");
|
|
|
|
}
|
|
|
|
|
|
|
|
realm.write(function() {
|
2015-11-02 20:02:53 +00:00
|
|
|
realm.create('TestObject', {doubleCol: 1});
|
2015-08-13 16:12:48 +00:00
|
|
|
TestCase.assertEqual(objects.length, 1);
|
|
|
|
});
|
|
|
|
|
|
|
|
var count = 0;
|
2015-10-21 22:21:17 +00:00
|
|
|
var keys = Object.keys(objects);
|
2016-05-20 23:33:16 +00:00
|
|
|
for (index in objects) {
|
2015-10-21 22:21:17 +00:00
|
|
|
TestCase.assertEqual(count++, +index);
|
|
|
|
TestCase.assertEqual(keys[index], index);
|
2016-04-27 21:01:01 +00:00
|
|
|
}
|
2015-10-21 22:21:17 +00:00
|
|
|
|
|
|
|
TestCase.assertEqual(count, 1);
|
|
|
|
TestCase.assertEqual(keys.length, 1);
|
2015-08-13 16:12:48 +00:00
|
|
|
},
|
2016-02-28 21:07:05 +00:00
|
|
|
|
2016-02-18 04:06:42 +00:00
|
|
|
testResultsFiltered: function() {
|
|
|
|
var realm = new Realm({schema: [schemas.PersonObject, schemas.DefaultValues, schemas.TestObject]});
|
2016-06-09 20:59:49 +00:00
|
|
|
|
2016-02-18 04:06:42 +00:00
|
|
|
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);
|
2016-02-18 04:09:39 +00:00
|
|
|
TestCase.assertEqual(realm.objects('PersonObject').filtered('age > 10').filtered('age < 13').length, 3);
|
|
|
|
|
2016-02-18 04:06:42 +00:00
|
|
|
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);
|
2016-06-09 20:59:49 +00:00
|
|
|
|
2016-02-18 04:06:42 +00:00
|
|
|
TestCase.assertThrows(function() {
|
|
|
|
realm.objects('PersonObject').filtered('age > $2 && age < $0', 13, 10)
|
|
|
|
});
|
2016-06-09 20:59:49 +00:00
|
|
|
TestCase.assertThrows(function() {
|
|
|
|
realm.objects('PersonObject').filtered("invalidQuery");
|
|
|
|
});
|
2016-02-18 04:06:42 +00:00
|
|
|
|
|
|
|
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);
|
2016-06-09 20:59:49 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
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});
|
|
|
|
});
|
2016-02-18 04:51:03 +00:00
|
|
|
|
|
|
|
TestCase.assertThrows(function() {
|
2016-06-09 20:59:49 +00:00
|
|
|
realm.objects('LinkTypesObject').filtered('objectCol = $0', object);
|
2016-02-18 04:51:03 +00:00
|
|
|
});
|
2016-02-18 04:06:42 +00:00
|
|
|
},
|
2016-02-28 21:07:05 +00:00
|
|
|
|
2016-02-18 21:41:11 +00:00
|
|
|
testResultsSorted: function() {
|
2016-01-13 10:40:26 +00:00
|
|
|
var realm = new Realm({schema: [schemas.IntPrimary]});
|
|
|
|
var objects = realm.objects('IntPrimaryObject');
|
2015-11-02 20:02:53 +00:00
|
|
|
|
2015-09-03 22:46:31 +00:00
|
|
|
realm.write(function() {
|
2016-01-13 10:40:26 +00:00
|
|
|
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'});
|
|
|
|
});
|
|
|
|
|
2016-05-20 23:33:16 +00:00
|
|
|
var primaries = function(results) {
|
2016-02-29 05:40:27 +00:00
|
|
|
return results.map(function(object) {
|
2016-01-13 10:40:26 +00:00
|
|
|
return object.primaryCol;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2017-09-21 17:12:10 +00:00
|
|
|
objects = objects.sorted([]);
|
|
|
|
TestCase.assertArraysEqual(primaries(objects), [2, 3, 1, 4, 0]);
|
|
|
|
|
2016-02-18 20:47:18 +00:00
|
|
|
objects = objects.sorted('primaryCol');
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertArraysEqual(primaries(objects), [0, 1, 2, 3, 4]);
|
|
|
|
|
2016-02-18 20:47:18 +00:00
|
|
|
objects = objects.sorted('primaryCol', true);
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertArraysEqual(primaries(objects), [4, 3, 2, 1, 0]);
|
|
|
|
|
2016-02-18 20:47:18 +00:00
|
|
|
objects = objects.sorted(['primaryCol', 'valueCol']);
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertArraysEqual(primaries(objects), [0, 1, 2, 3, 4]);
|
|
|
|
|
2016-02-18 20:47:18 +00:00
|
|
|
objects = objects.sorted([['primaryCol', true], ['valueCol', true]]);
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertArraysEqual(primaries(objects), [4, 3, 2, 1, 0]);
|
|
|
|
|
2016-02-18 20:47:18 +00:00
|
|
|
objects = objects.sorted([['primaryCol', false], 'valueCol']);
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertArraysEqual(primaries(objects), [0, 1, 2, 3, 4]);
|
|
|
|
|
2016-02-18 20:47:18 +00:00
|
|
|
objects = objects.sorted(['valueCol', 'primaryCol']);
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertArraysEqual(primaries(objects), [2, 3, 1, 0, 4]);
|
|
|
|
|
2016-02-18 20:47:18 +00:00
|
|
|
objects = objects.sorted([['valueCol', false], ['primaryCol', true]]);
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertArraysEqual(primaries(objects), [3, 2, 1, 4, 0]);
|
|
|
|
|
2016-02-18 20:47:18 +00:00
|
|
|
objects = objects.sorted([['valueCol', true], ['primaryCol', false]]);
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertArraysEqual(primaries(objects), [0, 4, 1, 2, 3]);
|
|
|
|
|
2016-02-18 20:47:18 +00:00
|
|
|
objects = objects.sorted([['valueCol', true], ['primaryCol', true]]);
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertArraysEqual(primaries(objects), [4, 0, 1, 3, 2]);
|
|
|
|
|
2016-02-18 20:55:54 +00:00
|
|
|
TestCase.assertThrows(function() {
|
|
|
|
objects.sorted();
|
|
|
|
});
|
2016-01-13 10:40:26 +00:00
|
|
|
TestCase.assertThrows(function() {
|
2016-02-18 20:47:18 +00:00
|
|
|
objects.sorted(1);
|
2016-01-13 10:40:26 +00:00
|
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
2016-02-18 20:47:18 +00:00
|
|
|
objects.sorted([1]);
|
2016-01-13 10:40:26 +00:00
|
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
2016-02-18 20:47:18 +00:00
|
|
|
objects.sorted('fish');
|
2016-01-13 10:40:26 +00:00
|
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
2016-02-18 20:47:18 +00:00
|
|
|
objects.sorted(['valueCol', 'fish']);
|
|
|
|
});
|
|
|
|
TestCase.assertThrows(function() {
|
|
|
|
objects.sorted(['valueCol', 'primaryCol'], true);
|
2016-01-13 10:40:26 +00:00
|
|
|
});
|
2015-09-03 22:46:31 +00:00
|
|
|
},
|
2016-03-04 15:55:05 +00:00
|
|
|
|
|
|
|
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()]);
|
|
|
|
});
|
|
|
|
|
2016-03-04 15:58:25 +00:00
|
|
|
var numberProps = ['intCol', 'floatCol', 'doubleCol', 'stringCol'];
|
2016-03-04 15:55:05 +00:00
|
|
|
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');
|
2016-04-27 21:01:01 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
testResultsInvalidation: function() {
|
2017-09-11 21:57:31 +00:00
|
|
|
let realm = new Realm({schema: [schemas.TestObject]});
|
2016-05-16 23:01:14 +00:00
|
|
|
realm.write(function() {
|
|
|
|
for (var i = 10; i > 0; i--) {
|
|
|
|
realm.create('TestObject', [i]);
|
|
|
|
}
|
|
|
|
});
|
2016-04-27 21:01:01 +00:00
|
|
|
|
2016-05-16 23:01:14 +00:00
|
|
|
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()
|
|
|
|
];
|
2016-04-27 21:01:01 +00:00
|
|
|
|
2016-05-16 23:01:14 +00:00
|
|
|
// test isValid
|
|
|
|
resultsVariants.forEach(function(objects) {
|
|
|
|
TestCase.assertEqual(objects.isValid(), true);
|
|
|
|
});
|
|
|
|
|
|
|
|
// close and test invalidated accessors
|
|
|
|
realm.close();
|
2016-04-27 21:01:01 +00:00
|
|
|
realm = new Realm({
|
|
|
|
schemaVersion: 1,
|
2017-09-11 21:57:31 +00:00
|
|
|
schema: [schemas.TestObject, schemas.DateObject]
|
2016-04-27 21:01:01 +00:00
|
|
|
});
|
|
|
|
|
2016-05-16 23:01:14 +00:00
|
|
|
resultsVariants.forEach(function(objects) {
|
|
|
|
TestCase.assertEqual(objects.isValid(), false);
|
2016-04-27 21:01:01 +00:00
|
|
|
TestCase.assertThrows(function() { objects[0]; });
|
|
|
|
TestCase.assertThrows(function() { objects.filtered('doubleCol < 42'); });
|
|
|
|
TestCase.assertThrows(function() { objects.sorted('doubleCol', true); });
|
|
|
|
TestCase.assertThrows(function() { objects.snapshot(); });
|
|
|
|
});
|
2016-05-16 23:01:14 +00:00
|
|
|
},
|
2016-05-20 20:42:17 +00:00
|
|
|
|
|
|
|
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);
|
|
|
|
});
|
|
|
|
|
2016-05-24 17:23:36 +00:00
|
|
|
realm.write(function() {
|
|
|
|
var objects = createTestObjects(10);
|
|
|
|
realm.deleteAll();
|
|
|
|
|
|
|
|
var snapshot = objects.snapshot();
|
|
|
|
TestCase.assertEqual(objects.length, 0);
|
|
|
|
TestCase.assertEqual(snapshot.length, 0);
|
|
|
|
});
|
|
|
|
|
2016-05-20 20:42:17 +00:00
|
|
|
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);
|
|
|
|
});
|
2016-05-24 17:23:36 +00:00
|
|
|
|
|
|
|
realm.write(function() {
|
|
|
|
var objects = createTestObjects(10);
|
|
|
|
realm.delete(objects);
|
|
|
|
|
|
|
|
var snapshot = objects.snapshot();
|
|
|
|
TestCase.assertEqual(objects.length, 0);
|
|
|
|
TestCase.assertEqual(snapshot.length, 0);
|
|
|
|
});
|
2017-01-31 13:07:29 +00:00
|
|
|
},
|
2017-09-07 18:28:24 +00:00
|
|
|
|
2017-06-26 11:43:49 +00:00
|
|
|
testResultsFindIndexOfObject: function() {
|
|
|
|
var realm = new Realm({schema: [schemas.TestObject]});
|
2017-09-07 18:28:24 +00:00
|
|
|
|
2017-06-26 11:43:49 +00:00
|
|
|
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});
|
|
|
|
});
|
2017-09-07 18:28:24 +00:00
|
|
|
|
2017-06-26 11:43:49 +00:00
|
|
|
// 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);
|
2017-09-07 18:28:24 +00:00
|
|
|
|
2017-06-26 11:43:49 +00:00
|
|
|
// 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);
|
2017-09-07 18:28:24 +00:00
|
|
|
|
2017-06-26 11:43:49 +00:00
|
|
|
// 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);
|
|
|
|
});
|
|
|
|
},
|
2017-01-31 13:07:29 +00:00
|
|
|
|
|
|
|
testAddListener: function() {
|
2017-09-19 22:54:10 +00:00
|
|
|
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;
|
|
|
|
}
|
2017-01-31 13:07:29 +00:00
|
|
|
|
2017-09-07 18:28:24 +00:00
|
|
|
const realm = new Realm({ schema: [schemas.TestObject] });
|
|
|
|
realm.write(() => {
|
|
|
|
realm.create('TestObject', { doubleCol: 1 });
|
|
|
|
realm.create('TestObject', { doubleCol: 2 });
|
|
|
|
realm.create('TestObject', { doubleCol: 3 });
|
|
|
|
});
|
2017-01-31 13:07:29 +00:00
|
|
|
|
2017-09-07 18:28:24 +00:00
|
|
|
let resolve, first = true;
|
|
|
|
return new Promise((r, _reject) => {
|
|
|
|
resolve = r;
|
2017-01-31 13:07:29 +00:00
|
|
|
realm.objects('TestObject').addListener((testObjects, changes) => {
|
2017-09-07 18:28:24 +00:00
|
|
|
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;
|
2017-01-31 13:07:29 +00:00
|
|
|
resolve();
|
|
|
|
});
|
2017-09-07 18:28:24 +00:00
|
|
|
}).then(() => {
|
|
|
|
return new Promise((r, _reject) => {
|
|
|
|
realm.write(() => {
|
|
|
|
realm.create('TestObject', { doubleCol: 1 });
|
|
|
|
});
|
|
|
|
resolve = r;
|
2017-01-31 13:07:29 +00:00
|
|
|
});
|
2017-09-29 11:23:37 +00:00
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
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);
|
2017-09-07 18:28:24 +00:00
|
|
|
});
|
2017-09-29 11:23:37 +00:00
|
|
|
|
|
|
|
// 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')
|
|
|
|
});
|
2017-10-02 21:15:19 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
testIterator: function() {
|
|
|
|
var realm = new Realm({ schema: [ schemas.TestObject ]});
|
|
|
|
realm.write(() => {
|
|
|
|
realm.create('TestObject', { doubleCol: 2 });
|
|
|
|
realm.create('TestObject', { doubleCol: 3 });
|
|
|
|
});
|
2017-09-29 11:23:37 +00:00
|
|
|
|
2017-10-02 21:15:19 +00:00
|
|
|
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);
|
|
|
|
},
|
2016-05-20 22:54:20 +00:00
|
|
|
};
|