mirror of
https://github.com/status-im/realm-js.git
synced 2025-01-19 02:53:51 +00:00
9e0a9a3bd3
* Add support for linkingObjects * Test linkingObjects * Borrow names helper from list tests * include computed properties when serializing the schema for the RN debugger * add API docs * review comments * Expose admin users to JS (#1100) The JS binding used to conflate `SyncUser::is_admin()` with the user being created by calling `Realm.Sync.User.adminToken()`, but now that we expose a user’s role on the server under `is_admin()` this supposition is no longer correct. #1097 attempted to fix one such case, but fixing it only uncovered another: in `UserClass<T>::all_users()`. I’ve gone through all the callsites of `SyncUser::is_admin()` to make sure they don’t assume an admin token user. * [1.8.3] Bump version * add linkingObjects method to Realm.Object * changelog
107 lines
3.2 KiB
JavaScript
107 lines
3.2 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 TESTS = {
|
||
ListTests: require('./list-tests'),
|
||
LinkingObjectsTests: require('./linkingobjects-tests'),
|
||
ObjectTests: require('./object-tests'),
|
||
RealmTests: require('./realm-tests'),
|
||
ResultsTests: require('./results-tests'),
|
||
QueryTests: require('./query-tests'),
|
||
MigrationTests: require('./migration-tests')
|
||
};
|
||
|
||
// encryption is not supported on windows
|
||
if (!(typeof process === 'object' && process.platform === 'win32')) {
|
||
TESTS.EncryptionTests = require('./encryption-tests');
|
||
}
|
||
|
||
// If sync is enabled, run the sync tests
|
||
if (Realm.Sync) {
|
||
TESTS.UserTests = require('./user-tests');
|
||
TESTS.SessionTests = require('./session-tests');
|
||
}
|
||
|
||
function node_require(module) { return require(module); }
|
||
|
||
// If on node, run the async tests
|
||
if (typeof process === 'object' && process + '' === '[object process]') {
|
||
TESTS.AsyncTests = node_require('./async-tests');
|
||
}
|
||
|
||
var SPECIAL_METHODS = {
|
||
beforeEach: true,
|
||
afterEach: true,
|
||
};
|
||
|
||
exports.getTestNames = function() {
|
||
var testNames = {};
|
||
|
||
for (var suiteName in TESTS) {
|
||
var testSuite = TESTS[suiteName];
|
||
|
||
testNames[suiteName] = Object.keys(testSuite).filter(function(testName) {
|
||
return !(testName in SPECIAL_METHODS) && typeof testSuite[testName] == 'function';
|
||
});
|
||
}
|
||
|
||
return testNames;
|
||
};
|
||
|
||
exports.registerTests = function(tests) {
|
||
for (var suiteName in tests) {
|
||
TESTS[suiteName] = tests[suiteName];
|
||
}
|
||
};
|
||
|
||
exports.runTest = function(suiteName, testName) {
|
||
var testSuite = TESTS[suiteName];
|
||
var testMethod = testSuite && testSuite[testName];
|
||
|
||
if (testMethod) {
|
||
// Start fresh in case of a crash in a previous run.
|
||
Realm.clearTestState();
|
||
console.log("Starting test " + testName);
|
||
var promise;
|
||
try {
|
||
promise = testMethod.call(testSuite);
|
||
|
||
// If the test returns a promise, then clear state on success or failure.
|
||
if (promise) {
|
||
promise.then(
|
||
function() { Realm.clearTestState(); },
|
||
function() { Realm.clearTestState(); }
|
||
);
|
||
}
|
||
|
||
return promise;
|
||
} finally {
|
||
// Synchronously clear state if the test is not async.
|
||
if (!promise) {
|
||
Realm.clearTestState();
|
||
}
|
||
}
|
||
} else if (!testSuite || !(testName in SPECIAL_METHODS)) {
|
||
throw new Error('Missing test: ' + suiteName + '.' + testName);
|
||
}
|
||
};
|