Merge pull request #1674 from strongloop/eslint/use-const-not-var
Refactor: migrate from "var" to "const"
This commit is contained in:
commit
bd5fd07d27
|
@ -4,6 +4,9 @@
|
|||
"ecmaVersion": 2017
|
||||
},
|
||||
"rules": {
|
||||
// TODO(bajtos) move these two rules to eslint-config-loopback
|
||||
"no-var": "error",
|
||||
"prefer-const": "error",
|
||||
"max-len": ["error", 110, 4, {
|
||||
"ignoreComments": true,
|
||||
"ignoreUrls": true,
|
||||
|
|
|
@ -5,16 +5,16 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var DataSource = require('../../loopback-datasource-juggler').DataSource;
|
||||
var ModelBuilder = require('../../loopback-datasource-juggler').ModelBuilder;
|
||||
var introspectType = require('../lib/introspection')(ModelBuilder);
|
||||
const DataSource = require('../../loopback-datasource-juggler').DataSource;
|
||||
const ModelBuilder = require('../../loopback-datasource-juggler').ModelBuilder;
|
||||
const introspectType = require('../lib/introspection')(ModelBuilder);
|
||||
|
||||
var ds = new DataSource('memory');
|
||||
const ds = new DataSource('memory');
|
||||
|
||||
// Create a open model that doesn't require a schema
|
||||
var Application = ds.createModel('Schemaless', {}, {strict: false});
|
||||
const Application = ds.createModel('Schemaless', {}, {strict: false});
|
||||
|
||||
var application = {
|
||||
const application = {
|
||||
owner: 'rfeng',
|
||||
name: 'MyApp1',
|
||||
description: 'My first app',
|
||||
|
@ -47,7 +47,7 @@ Application.create(application, function(err, app1) {
|
|||
});
|
||||
|
||||
// Instance JSON document
|
||||
var user = {
|
||||
const user = {
|
||||
name: 'Joe',
|
||||
age: 30,
|
||||
birthday: new Date(),
|
||||
|
@ -68,13 +68,13 @@ var user = {
|
|||
};
|
||||
|
||||
// Introspect the JSON document to generate a schema
|
||||
var schema = introspectType(user);
|
||||
const schema = introspectType(user);
|
||||
|
||||
// Create a model for the generated schema
|
||||
var User = ds.createModel('User', schema, {idInjection: true});
|
||||
const User = ds.createModel('User', schema, {idInjection: true});
|
||||
|
||||
// Use the model for CRUD
|
||||
var obj = new User(user);
|
||||
const obj = new User(user);
|
||||
|
||||
console.log(obj.toObject());
|
||||
|
||||
|
|
|
@ -5,10 +5,10 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var ModelBuilder = require('../../loopback-datasource-juggler').ModelBuilder;
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const ModelBuilder = require('../../loopback-datasource-juggler').ModelBuilder;
|
||||
const modelBuilder = new ModelBuilder();
|
||||
// define models
|
||||
var Post = modelBuilder.define('Post', {
|
||||
const Post = modelBuilder.define('Post', {
|
||||
title: {type: String, length: 255},
|
||||
content: {type: ModelBuilder.Text},
|
||||
date: {type: Date, default: function() {
|
||||
|
@ -19,7 +19,7 @@ var Post = modelBuilder.define('Post', {
|
|||
});
|
||||
|
||||
// simpler way to describe model
|
||||
var User = modelBuilder.define('User', {
|
||||
const User = modelBuilder.define('User', {
|
||||
name: String,
|
||||
bio: ModelBuilder.Text,
|
||||
approved: Boolean,
|
||||
|
@ -27,14 +27,14 @@ var User = modelBuilder.define('User', {
|
|||
age: Number,
|
||||
});
|
||||
|
||||
var Group = modelBuilder.define('Group', {group: String});
|
||||
const Group = modelBuilder.define('Group', {group: String});
|
||||
|
||||
// define any custom method
|
||||
User.prototype.getNameAndAge = function() {
|
||||
return this.name + ', ' + this.age;
|
||||
};
|
||||
|
||||
var user = new User({name: 'Joe'});
|
||||
let user = new User({name: 'Joe'});
|
||||
console.log(user);
|
||||
|
||||
console.log(modelBuilder.models);
|
||||
|
|
|
@ -5,12 +5,12 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var DataSource = require('../../loopback-datasource-juggler').DataSource;
|
||||
var ModelBuilder = require('../../loopback-datasource-juggler').ModelBuilder;
|
||||
var ds = new DataSource('memory');
|
||||
const DataSource = require('../../loopback-datasource-juggler').DataSource;
|
||||
const ModelBuilder = require('../../loopback-datasource-juggler').ModelBuilder;
|
||||
const ds = new DataSource('memory');
|
||||
|
||||
// define models
|
||||
var Post = ds.define('Post', {
|
||||
const Post = ds.define('Post', {
|
||||
title: {type: String, length: 255},
|
||||
content: {type: DataSource.Text},
|
||||
date: {type: Date, default: function() {
|
||||
|
@ -21,7 +21,7 @@ var Post = ds.define('Post', {
|
|||
});
|
||||
|
||||
// simplier way to describe model
|
||||
var User = ds.define('User', {
|
||||
const User = ds.define('User', {
|
||||
name: String,
|
||||
bio: DataSource.Text,
|
||||
approved: Boolean,
|
||||
|
@ -29,14 +29,14 @@ var User = ds.define('User', {
|
|||
age: Number,
|
||||
});
|
||||
|
||||
var Group = ds.define('Group', {name: String});
|
||||
const Group = ds.define('Group', {name: String});
|
||||
|
||||
// define any custom method
|
||||
User.prototype.getNameAndAge = function() {
|
||||
return this.name + ', ' + this.age;
|
||||
};
|
||||
|
||||
var user = new User({name: 'Joe'});
|
||||
const user = new User({name: 'Joe'});
|
||||
console.log(user);
|
||||
|
||||
// console.log(ds.models);
|
||||
|
@ -58,10 +58,10 @@ Post.belongsTo(User, {as: 'author', foreignKey: 'userId'});
|
|||
|
||||
User.hasAndBelongsToMany('groups');
|
||||
|
||||
var user2 = new User({name: 'Smith', age: 14});
|
||||
const user2 = new User({name: 'Smith', age: 14});
|
||||
user2.save(function(err) {
|
||||
console.log(user2);
|
||||
var post = user2.posts.build({title: 'Hello world'});
|
||||
const post = user2.posts.build({title: 'Hello world'});
|
||||
post.save(function(err, data) {
|
||||
console.log(err ? err : data);
|
||||
});
|
||||
|
@ -77,7 +77,7 @@ User.create({name: 'Jeff', age: 12}, function(err, data) {
|
|||
return;
|
||||
}
|
||||
console.log(data);
|
||||
var post = data.posts.build({title: 'My Post'});
|
||||
const post = data.posts.build({title: 'My Post'});
|
||||
console.log(post);
|
||||
});
|
||||
|
||||
|
@ -90,8 +90,8 @@ User.minors(function(err, kids) {
|
|||
console.log('Kids: ', kids);
|
||||
});
|
||||
|
||||
var Article = ds.define('Article', {title: String});
|
||||
var Tag = ds.define('Tag', {name: String});
|
||||
const Article = ds.define('Article', {title: String});
|
||||
const Tag = ds.define('Tag', {name: String});
|
||||
Article.hasAndBelongsToMany('tags');
|
||||
|
||||
Article.create(function(e, article) {
|
||||
|
@ -105,7 +105,7 @@ Article.create(function(e, article) {
|
|||
});
|
||||
|
||||
// should be able to attach a data source to an existing model
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
const Color = modelBuilder.define('Color', {
|
||||
name: String,
|
||||
|
|
|
@ -5,10 +5,10 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var jdb = require('../index');
|
||||
const jdb = require('../index');
|
||||
|
||||
var User, Post, Passport, City, Street, Building;
|
||||
var nbSchemaRequests = 0;
|
||||
let User, Post, Passport, City, Street, Building;
|
||||
const nbSchemaRequests = 0;
|
||||
|
||||
setup(function() {
|
||||
Passport.find({include: 'owner'}, function(err, passports) {
|
||||
|
@ -35,7 +35,7 @@ setup(function() {
|
|||
});
|
||||
|
||||
function setup(done) {
|
||||
var db = new jdb.DataSource({connector: 'memory'});
|
||||
const db = new jdb.DataSource({connector: 'memory'});
|
||||
City = db.define('City');
|
||||
Street = db.define('Street');
|
||||
Building = db.define('Building');
|
||||
|
@ -56,9 +56,9 @@ function setup(done) {
|
|||
Post.belongsTo('author', {model: User, foreignKey: 'userId'});
|
||||
|
||||
db.automigrate(function() {
|
||||
var createdUsers = [];
|
||||
var createdPassports = [];
|
||||
var createdPosts = [];
|
||||
let createdUsers = [];
|
||||
let createdPassports = [];
|
||||
let createdPosts = [];
|
||||
createUsers();
|
||||
function createUsers() {
|
||||
clearAndCreate(
|
||||
|
@ -112,12 +112,12 @@ function setup(done) {
|
|||
}
|
||||
|
||||
function clearAndCreate(model, data, callback) {
|
||||
var createdItems = [];
|
||||
const createdItems = [];
|
||||
model.destroyAll(function() {
|
||||
nextItem(null, null);
|
||||
});
|
||||
|
||||
var itemIndex = 0;
|
||||
let itemIndex = 0;
|
||||
|
||||
function nextItem(err, lastItem) {
|
||||
if (lastItem !== null) {
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var path = require('path'),
|
||||
const path = require('path'),
|
||||
fs = require('fs'),
|
||||
DataSource = require('../lib/datasource').DataSource;
|
||||
|
||||
|
@ -21,12 +21,12 @@ function loadSchemasSync(schemaFile, dataSource) {
|
|||
}
|
||||
|
||||
// Read the dataSource JSON file
|
||||
var schemas = JSON.parse(fs.readFileSync(schemaFile));
|
||||
const schemas = JSON.parse(fs.readFileSync(schemaFile));
|
||||
|
||||
return dataSource.buildModels(schemas);
|
||||
}
|
||||
|
||||
var models = loadSchemasSync(path.join(__dirname, 'jdb-schemas.json'));
|
||||
let models = loadSchemasSync(path.join(__dirname, 'jdb-schemas.json'));
|
||||
|
||||
for (const s in models) {
|
||||
const m = models[s];
|
||||
|
|
|
@ -5,11 +5,11 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var ModelBuilder = require('../../loopback-datasource-juggler').ModelBuilder;
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const ModelBuilder = require('../../loopback-datasource-juggler').ModelBuilder;
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
// simplier way to describe model
|
||||
var User = modelBuilder.define('User', {
|
||||
const User = modelBuilder.define('User', {
|
||||
name: String,
|
||||
bio: ModelBuilder.Text,
|
||||
approved: Boolean,
|
||||
|
@ -31,7 +31,7 @@ var User = modelBuilder.define('User', {
|
|||
friends: [String],
|
||||
});
|
||||
|
||||
var user = new User({
|
||||
const user = new User({
|
||||
name: 'Joe',
|
||||
age: 20,
|
||||
address: {street: '123 Main St', 'city': 'San Jose', state: 'CA'},
|
||||
|
|
|
@ -5,22 +5,22 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var DataSource = require('../index').DataSource;
|
||||
var ds = new DataSource('memory');
|
||||
const DataSource = require('../index').DataSource;
|
||||
const ds = new DataSource('memory');
|
||||
|
||||
var Order = ds.createModel('Order', {
|
||||
const Order = ds.createModel('Order', {
|
||||
items: [String],
|
||||
orderDate: Date,
|
||||
qty: Number,
|
||||
});
|
||||
|
||||
var Customer = ds.createModel('Customer', {
|
||||
const Customer = ds.createModel('Customer', {
|
||||
name: String,
|
||||
});
|
||||
|
||||
Order.belongsTo(Customer);
|
||||
|
||||
var order1, order2, order3;
|
||||
let order1, order2, order3;
|
||||
|
||||
Customer.create({name: 'John'}, function(err, customer) {
|
||||
Order.create({customerId: customer.id, orderDate: new Date(), items: ['Book']}, function(err, order) {
|
||||
|
@ -42,7 +42,7 @@ Customer.create({name: 'John'}, function(err, customer) {
|
|||
});
|
||||
});
|
||||
|
||||
var customer3 = order.customer.build({name: 'Tom'});
|
||||
const customer3 = order.customer.build({name: 'Tom'});
|
||||
console.log('Customer 3', customer3);
|
||||
});
|
||||
});
|
||||
|
@ -67,15 +67,15 @@ Customer.create({name: 'Ray'}, function(err, customer) {
|
|||
});
|
||||
});
|
||||
|
||||
var Physician = ds.createModel('Physician', {
|
||||
const Physician = ds.createModel('Physician', {
|
||||
name: String,
|
||||
});
|
||||
|
||||
var Patient = ds.createModel('Patient', {
|
||||
const Patient = ds.createModel('Patient', {
|
||||
name: String,
|
||||
});
|
||||
|
||||
var Appointment = ds.createModel('Appointment', {
|
||||
const Appointment = ds.createModel('Appointment', {
|
||||
physicianId: Number,
|
||||
patientId: Number,
|
||||
appointmentDate: Date,
|
||||
|
@ -102,7 +102,7 @@ Physician.create({name: 'Dr John'}, function(err, physician1) {
|
|||
patient1.physicians(console.log);
|
||||
|
||||
// Build an appointment?
|
||||
var patient3 = patient1.physicians.build({name: 'Dr X'});
|
||||
const patient3 = patient1.physicians.build({name: 'Dr X'});
|
||||
console.log('Physician 3: ', patient3, patient3.constructor.modelName);
|
||||
|
||||
// Create a physician?
|
||||
|
@ -118,11 +118,11 @@ Physician.create({name: 'Dr John'}, function(err, physician1) {
|
|||
});
|
||||
});
|
||||
|
||||
var Assembly = ds.createModel('Assembly', {
|
||||
const Assembly = ds.createModel('Assembly', {
|
||||
name: String,
|
||||
});
|
||||
|
||||
var Part = ds.createModel('Part', {
|
||||
const Part = ds.createModel('Part', {
|
||||
partNumber: String,
|
||||
});
|
||||
|
||||
|
@ -137,7 +137,7 @@ Assembly.create({name: 'car'}, function(err, assembly) {
|
|||
});
|
||||
|
||||
// Build an part?
|
||||
var part3 = assembly.parts.build({partNumber: 'door'});
|
||||
const part3 = assembly.parts.build({partNumber: 'door'});
|
||||
console.log('Part3: ', part3, part3.constructor.modelName);
|
||||
|
||||
// Create a part?
|
||||
|
|
4
index.js
4
index.js
|
@ -4,7 +4,7 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var SG = require('strong-globalize');
|
||||
const SG = require('strong-globalize');
|
||||
SG.SetRootDir(__dirname);
|
||||
|
||||
exports.ModelBuilder = exports.LDL = require('./lib/model-builder.js').ModelBuilder;
|
||||
|
@ -17,7 +17,7 @@ Object.defineProperty(exports, 'version', {
|
|||
get: function() { return require('./package.json').version; },
|
||||
});
|
||||
|
||||
var commonTest = './test/common_test';
|
||||
const commonTest = './test/common_test';
|
||||
Object.defineProperty(exports, 'test', {
|
||||
get: function() { return require(commonTest); },
|
||||
});
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
// A lightweight alternative to "depd" that works in the browser
|
||||
module.exports = function depd(namespace) {
|
||||
var warned = {};
|
||||
const warned = {};
|
||||
return function deprecate(message) {
|
||||
if (warned[message]) return;
|
||||
warned[message] = true;
|
||||
|
|
|
@ -1,15 +1,15 @@
|
|||
'use strict';
|
||||
|
||||
var g = require('strong-globalize')();
|
||||
const g = require('strong-globalize')();
|
||||
|
||||
var assert = require('assert');
|
||||
var Connector = require('loopback-connector').Connector;
|
||||
var debug = require('debug')('loopback:connector:kv-memory');
|
||||
var minimatch = require('minimatch');
|
||||
var util = require('util');
|
||||
const assert = require('assert');
|
||||
const Connector = require('loopback-connector').Connector;
|
||||
const debug = require('debug')('loopback:connector:kv-memory');
|
||||
const minimatch = require('minimatch');
|
||||
const util = require('util');
|
||||
|
||||
exports.initialize = function initializeDataSource(dataSource, cb) {
|
||||
var settings = dataSource.settings;
|
||||
const settings = dataSource.settings;
|
||||
dataSource.connector = new KeyValueMemoryConnector(settings, dataSource);
|
||||
if (cb) process.nextTick(cb);
|
||||
};
|
||||
|
@ -33,14 +33,13 @@ KeyValueMemoryConnector.prototype._setupRegularCleanup = function() {
|
|||
// in order to release memory. Note that GET operation checks
|
||||
// key expiration too, the scheduled cleanup is merely a performance
|
||||
// optimization.
|
||||
var self = this;
|
||||
var timer = this._cleanupTimer = setInterval(
|
||||
function() {
|
||||
if (self && self._removeExpiredItems) {
|
||||
self._removeExpiredItems();
|
||||
this._cleanupTimer = setInterval(
|
||||
() => {
|
||||
if (this && this._removeExpiredItems) {
|
||||
this._removeExpiredItems();
|
||||
} else {
|
||||
// The datasource/connector was destroyed - cancel the timer
|
||||
clearInterval(timer);
|
||||
clearInterval(this._cleanupTimer);
|
||||
}
|
||||
},
|
||||
1000
|
||||
|
@ -50,9 +49,9 @@ KeyValueMemoryConnector.prototype._setupRegularCleanup = function() {
|
|||
|
||||
KeyValueMemoryConnector._removeExpiredItems = function() {
|
||||
debug('Running scheduled cleanup of expired items.');
|
||||
for (var modelName in this._store) {
|
||||
var modelStore = this._store[modelName];
|
||||
for (var key in modelStore) {
|
||||
for (const modelName in this._store) {
|
||||
const modelStore = this._store[modelName];
|
||||
for (const key in modelStore) {
|
||||
if (modelStore[key].isExpired()) {
|
||||
debug('Removing expired key', key);
|
||||
delete modelStore[key];
|
||||
|
@ -69,8 +68,8 @@ KeyValueMemoryConnector.prototype._getStoreForModel = function(modelName) {
|
|||
};
|
||||
|
||||
KeyValueMemoryConnector.prototype._removeIfExpired = function(modelName, key) {
|
||||
var store = this._getStoreForModel(modelName);
|
||||
var item = store[key];
|
||||
const store = this._getStoreForModel(modelName);
|
||||
let item = store[key];
|
||||
if (item && item.isExpired()) {
|
||||
debug('Removing expired key', key);
|
||||
delete store[key];
|
||||
|
@ -84,9 +83,9 @@ KeyValueMemoryConnector.prototype.get =
|
|||
function(modelName, key, options, callback) {
|
||||
this._removeIfExpired(modelName, key);
|
||||
|
||||
var store = this._getStoreForModel(modelName);
|
||||
var item = store[key];
|
||||
var value = item ? item.value : null;
|
||||
const store = this._getStoreForModel(modelName);
|
||||
const item = store[key];
|
||||
let value = item ? item.value : null;
|
||||
debug('GET %j %j -> %s', modelName, key, value);
|
||||
|
||||
if (/^buffer:/.test(value)) {
|
||||
|
@ -104,7 +103,7 @@ function(modelName, key, options, callback) {
|
|||
|
||||
KeyValueMemoryConnector.prototype.set =
|
||||
function(modelName, key, value, options, callback) {
|
||||
var store = this._getStoreForModel(modelName);
|
||||
const store = this._getStoreForModel(modelName);
|
||||
if (Buffer.isBuffer(value)) {
|
||||
value = 'buffer:' + value.toString('base64');
|
||||
} else if (value instanceof Date) {
|
||||
|
@ -123,11 +122,11 @@ KeyValueMemoryConnector.prototype.expire =
|
|||
function(modelName, key, ttl, options, callback) {
|
||||
this._removeIfExpired(modelName, key);
|
||||
|
||||
var store = this._getStoreForModel(modelName);
|
||||
const store = this._getStoreForModel(modelName);
|
||||
|
||||
if (!(key in store)) {
|
||||
return process.nextTick(function() {
|
||||
var err = new Error(g.f('Cannot expire unknown key %j', key));
|
||||
const err = new Error(g.f('Cannot expire unknown key %j', key));
|
||||
err.statusCode = 404;
|
||||
callback(err);
|
||||
});
|
||||
|
@ -142,18 +141,18 @@ KeyValueMemoryConnector.prototype.ttl =
|
|||
function(modelName, key, options, callback) {
|
||||
this._removeIfExpired(modelName, key);
|
||||
|
||||
var store = this._getStoreForModel(modelName);
|
||||
const store = this._getStoreForModel(modelName);
|
||||
|
||||
// key is unknown
|
||||
if (!(key in store)) {
|
||||
return process.nextTick(function() {
|
||||
var err = new Error(g.f('Cannot get TTL for unknown key %j', key));
|
||||
const err = new Error(g.f('Cannot get TTL for unknown key %j', key));
|
||||
err.statusCode = 404;
|
||||
callback(err);
|
||||
});
|
||||
}
|
||||
|
||||
var ttl = store[key].getTtl();
|
||||
const ttl = store[key].getTtl();
|
||||
debug('TTL %j %j -> %s', modelName, key, ttl);
|
||||
|
||||
process.nextTick(function() {
|
||||
|
@ -163,20 +162,20 @@ function(modelName, key, options, callback) {
|
|||
|
||||
KeyValueMemoryConnector.prototype.iterateKeys =
|
||||
function(modelName, filter, options, callback) {
|
||||
var store = this._getStoreForModel(modelName);
|
||||
var self = this;
|
||||
var checkFilter = createMatcher(filter.match);
|
||||
const store = this._getStoreForModel(modelName);
|
||||
const self = this;
|
||||
const checkFilter = createMatcher(filter.match);
|
||||
|
||||
var keys = Object.keys(store).filter(function(key) {
|
||||
const keys = Object.keys(store).filter(function(key) {
|
||||
return !self._removeIfExpired(modelName, key) && checkFilter(key);
|
||||
});
|
||||
|
||||
debug('ITERATE KEYS %j -> %s keys', modelName, keys.length);
|
||||
|
||||
var ix = 0;
|
||||
let ix = 0;
|
||||
return {
|
||||
next: function(cb) {
|
||||
var value = ix < keys.length ? keys[ix++] : undefined;
|
||||
const value = ix < keys.length ? keys[ix++] : undefined;
|
||||
setImmediate(function() { cb(null, value); });
|
||||
},
|
||||
};
|
||||
|
@ -203,15 +202,15 @@ KeyValueMemoryConnector.prototype.disconnect = function(callback) {
|
|||
|
||||
KeyValueMemoryConnector.prototype.delete =
|
||||
function(modelName, key, options, callback) {
|
||||
var store = this._getStoreForModel(modelName);
|
||||
const store = this._getStoreForModel(modelName);
|
||||
delete store[key];
|
||||
callback();
|
||||
};
|
||||
|
||||
KeyValueMemoryConnector.prototype.deleteAll =
|
||||
function(modelName, options, callback) {
|
||||
var modelStore = this._getStoreForModel(modelName);
|
||||
for (var key in modelStore)
|
||||
const modelStore = this._getStoreForModel(modelName);
|
||||
for (const key in modelStore)
|
||||
delete modelStore[key];
|
||||
callback();
|
||||
};
|
||||
|
|
|
@ -6,14 +6,14 @@
|
|||
'use strict';
|
||||
|
||||
/* global window:false */
|
||||
var g = require('strong-globalize')();
|
||||
var util = require('util');
|
||||
var Connector = require('loopback-connector').Connector;
|
||||
var geo = require('../geo');
|
||||
var utils = require('../utils');
|
||||
var fs = require('fs');
|
||||
var async = require('async');
|
||||
var debug = require('debug')('loopback:connector:memory');
|
||||
const g = require('strong-globalize')();
|
||||
const util = require('util');
|
||||
const Connector = require('loopback-connector').Connector;
|
||||
const geo = require('../geo');
|
||||
const utils = require('../utils');
|
||||
const fs = require('fs');
|
||||
const async = require('async');
|
||||
const debug = require('debug')('loopback:connector:memory');
|
||||
|
||||
/**
|
||||
* Initialize the Memory connector against the given data source
|
||||
|
@ -82,7 +82,7 @@ function deserialize(dbObj) {
|
|||
}
|
||||
|
||||
Memory.prototype.getCollection = function(model) {
|
||||
var modelClass = this._models[model];
|
||||
const modelClass = this._models[model];
|
||||
if (modelClass && modelClass.settings.memory) {
|
||||
model = modelClass.settings.memory.collection || model;
|
||||
}
|
||||
|
@ -111,15 +111,15 @@ Memory.prototype.collectionSeq = function(model, val) {
|
|||
* @returns {*} The file operation queue
|
||||
*/
|
||||
Memory.prototype.setupFileQueue = function() {
|
||||
var self = this;
|
||||
const self = this;
|
||||
if (!this.fileQueue) {
|
||||
// Create a queue for writes
|
||||
this.fileQueue = async.queue(function(task, done) {
|
||||
var callback = task.callback || function() {};
|
||||
var file = self.settings.file;
|
||||
const callback = task.callback || function() {};
|
||||
const file = self.settings.file;
|
||||
if (task.operation === 'write') {
|
||||
// Flush out the models/ids
|
||||
var data = JSON.stringify({
|
||||
const data = JSON.stringify({
|
||||
ids: self.ids,
|
||||
models: self.cache,
|
||||
}, null, ' ');
|
||||
|
@ -130,7 +130,7 @@ Memory.prototype.setupFileQueue = function() {
|
|||
callback(err, task.data);
|
||||
});
|
||||
} else if (task.operation === 'read') {
|
||||
debug('Reading cache from %s: %s', file, data);
|
||||
debug('Reading cache from %s', file);
|
||||
fs.readFile(file, {
|
||||
encoding: 'utf8',
|
||||
flag: 'r',
|
||||
|
@ -147,7 +147,7 @@ Memory.prototype.setupFileQueue = function() {
|
|||
}
|
||||
});
|
||||
} else {
|
||||
var err = new Error('Unknown type of task');
|
||||
const err = new Error('Unknown type of task');
|
||||
done(err);
|
||||
callback(err);
|
||||
}
|
||||
|
@ -176,8 +176,8 @@ Memory.prototype.parseAndLoad = function(data, callback) {
|
|||
};
|
||||
|
||||
Memory.prototype.loadFromFile = function(callback) {
|
||||
var hasLocalStorage = typeof window !== 'undefined' && window.localStorage;
|
||||
var localStorage = hasLocalStorage && this.settings.localStorage;
|
||||
const hasLocalStorage = typeof window !== 'undefined' && window.localStorage;
|
||||
const localStorage = hasLocalStorage && this.settings.localStorage;
|
||||
|
||||
if (this.settings.file) {
|
||||
debug('Queueing read %s', this.settings.file);
|
||||
|
@ -186,7 +186,7 @@ Memory.prototype.loadFromFile = function(callback) {
|
|||
callback: callback,
|
||||
});
|
||||
} else if (localStorage) {
|
||||
var data = window.localStorage.getItem(localStorage);
|
||||
let data = window.localStorage.getItem(localStorage);
|
||||
data = data || '{}';
|
||||
this.parseAndLoad(data, callback);
|
||||
} else {
|
||||
|
@ -199,9 +199,9 @@ Memory.prototype.loadFromFile = function(callback) {
|
|||
* @param {Function} callback
|
||||
*/
|
||||
Memory.prototype.saveToFile = function(result, callback) {
|
||||
var file = this.settings.file;
|
||||
var hasLocalStorage = typeof window !== 'undefined' && window.localStorage;
|
||||
var localStorage = hasLocalStorage && this.settings.localStorage;
|
||||
const file = this.settings.file;
|
||||
const hasLocalStorage = typeof window !== 'undefined' && window.localStorage;
|
||||
const localStorage = hasLocalStorage && this.settings.localStorage;
|
||||
if (file) {
|
||||
debug('Queueing write %s', this.settings.file);
|
||||
// Enqueue the write
|
||||
|
@ -212,7 +212,7 @@ Memory.prototype.saveToFile = function(result, callback) {
|
|||
});
|
||||
} else if (localStorage) {
|
||||
// Flush out the models/ids
|
||||
var data = JSON.stringify({
|
||||
const data = JSON.stringify({
|
||||
ids: this.ids,
|
||||
models: this.cache,
|
||||
}, null, ' ');
|
||||
|
@ -229,26 +229,26 @@ Memory.prototype.saveToFile = function(result, callback) {
|
|||
|
||||
Memory.prototype.define = function defineModel(definition) {
|
||||
this.constructor.super_.prototype.define.apply(this, [].slice.call(arguments));
|
||||
var m = definition.model.modelName;
|
||||
const m = definition.model.modelName;
|
||||
if (!this.collection(m)) this.initCollection(m);
|
||||
};
|
||||
|
||||
Memory.prototype._createSync = function(model, data, fn) {
|
||||
// FIXME: [rfeng] We need to generate unique ids based on the id type
|
||||
// FIXME: [rfeng] We don't support composite ids yet
|
||||
var currentId = this.collectionSeq(model);
|
||||
let currentId = this.collectionSeq(model);
|
||||
if (currentId === undefined) { // First time
|
||||
currentId = this.collectionSeq(model, 1);
|
||||
}
|
||||
var id = this.getIdValue(model, data) || currentId;
|
||||
let id = this.getIdValue(model, data) || currentId;
|
||||
if (id > currentId) {
|
||||
// If the id is passed in and the value is greater than the current id
|
||||
currentId = id;
|
||||
}
|
||||
this.collectionSeq(model, Number(currentId) + 1);
|
||||
|
||||
var props = this._models[model].properties;
|
||||
var idName = this.idName(model);
|
||||
const props = this._models[model].properties;
|
||||
const idName = this.idName(model);
|
||||
id = (props[idName] && props[idName].type && props[idName].type(id)) || id;
|
||||
this.setIdValue(model, data, id);
|
||||
if (!this.collection(model)) {
|
||||
|
@ -256,7 +256,7 @@ Memory.prototype._createSync = function(model, data, fn) {
|
|||
}
|
||||
|
||||
if (this.collection(model)[id]) {
|
||||
var error = new Error(g.f('Duplicate entry for %s.%s', model, idName));
|
||||
const error = new Error(g.f('Duplicate entry for %s.%s', model, idName));
|
||||
error.statusCode = error.status = 409;
|
||||
return fn(error);
|
||||
}
|
||||
|
@ -266,7 +266,7 @@ Memory.prototype._createSync = function(model, data, fn) {
|
|||
};
|
||||
|
||||
Memory.prototype.create = function create(model, data, options, callback) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
this._createSync(model, data, function(err, id) {
|
||||
if (err) {
|
||||
return process.nextTick(function() {
|
||||
|
@ -278,7 +278,7 @@ Memory.prototype.create = function create(model, data, options, callback) {
|
|||
};
|
||||
|
||||
Memory.prototype.updateOrCreate = function(model, data, options, callback) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
this.exists(model, self.getIdValue(model, data), options, function(err, exists) {
|
||||
if (exists) {
|
||||
self.save(model, data, options, function(err, data) {
|
||||
|
@ -295,10 +295,10 @@ Memory.prototype.updateOrCreate = function(model, data, options, callback) {
|
|||
|
||||
Memory.prototype.patchOrCreateWithWhere =
|
||||
Memory.prototype.upsertWithWhere = function(model, where, data, options, callback) {
|
||||
var self = this;
|
||||
var primaryKey = this.idName(model);
|
||||
var filter = {where: where};
|
||||
var nodes = self._findAllSkippingIncludes(model, filter);
|
||||
const self = this;
|
||||
const primaryKey = this.idName(model);
|
||||
const filter = {where: where};
|
||||
const nodes = self._findAllSkippingIncludes(model, filter);
|
||||
if (nodes.length === 0) {
|
||||
return self._createSync(model, data, function(err, id) {
|
||||
if (err) return process.nextTick(function() { callback(err); });
|
||||
|
@ -309,13 +309,13 @@ Memory.prototype.upsertWithWhere = function(model, where, data, options, callbac
|
|||
});
|
||||
}
|
||||
if (nodes.length === 1) {
|
||||
var primaryKeyValue = nodes[0][primaryKey];
|
||||
const primaryKeyValue = nodes[0][primaryKey];
|
||||
self.updateAttributes(model, primaryKeyValue, data, options, function(err, data) {
|
||||
callback(err, data, {isNewInstance: false});
|
||||
});
|
||||
} else {
|
||||
process.nextTick(function() {
|
||||
var error = new Error('There are multiple instances found.' +
|
||||
const error = new Error('There are multiple instances found.' +
|
||||
'Upsert Operation will not be performed!');
|
||||
error.statusCode = 400;
|
||||
callback(error);
|
||||
|
@ -324,9 +324,9 @@ Memory.prototype.upsertWithWhere = function(model, where, data, options, callbac
|
|||
};
|
||||
|
||||
Memory.prototype.findOrCreate = function(model, filter, data, options, callback) {
|
||||
var self = this;
|
||||
var nodes = self._findAllSkippingIncludes(model, filter);
|
||||
var found = nodes[0];
|
||||
const self = this;
|
||||
const nodes = self._findAllSkippingIncludes(model, filter);
|
||||
const found = nodes[0];
|
||||
|
||||
if (!found) {
|
||||
// Calling _createSync to update the collection in a sync way and to guarantee to create it in the same turn of even loop
|
||||
|
@ -354,10 +354,10 @@ Memory.prototype.findOrCreate = function(model, filter, data, options, callback)
|
|||
};
|
||||
|
||||
Memory.prototype.save = function save(model, data, options, callback) {
|
||||
var self = this;
|
||||
var id = this.getIdValue(model, data);
|
||||
var cachedModels = this.collection(model);
|
||||
var modelData = cachedModels && this.collection(model)[id];
|
||||
const self = this;
|
||||
const id = this.getIdValue(model, data);
|
||||
const cachedModels = this.collection(model);
|
||||
let modelData = cachedModels && this.collection(model)[id];
|
||||
modelData = modelData && deserialize(modelData);
|
||||
if (modelData) {
|
||||
data = merge(modelData, data);
|
||||
|
@ -381,7 +381,7 @@ Memory.prototype.find = function find(model, id, options, callback) {
|
|||
};
|
||||
|
||||
Memory.prototype.destroy = function destroy(model, id, options, callback) {
|
||||
var exists = this.collection(model)[id];
|
||||
const exists = this.collection(model)[id];
|
||||
delete this.collection(model)[id];
|
||||
this.saveToFile({count: exists ? 1 : 0}, callback);
|
||||
};
|
||||
|
@ -389,9 +389,9 @@ Memory.prototype.destroy = function destroy(model, id, options, callback) {
|
|||
Memory.prototype.fromDb = function(model, data) {
|
||||
if (!data) return null;
|
||||
data = deserialize(data);
|
||||
var props = this._models[model].properties;
|
||||
for (var key in data) {
|
||||
var val = data[key];
|
||||
const props = this._models[model].properties;
|
||||
for (const key in data) {
|
||||
let val = data[key];
|
||||
if (val === undefined || val === null) {
|
||||
continue;
|
||||
}
|
||||
|
@ -417,9 +417,9 @@ function getValue(obj, path) {
|
|||
if (obj == null) {
|
||||
return undefined;
|
||||
}
|
||||
var keys = path.split('.');
|
||||
var val = obj;
|
||||
for (var i = 0, n = keys.length; i < n; i++) {
|
||||
const keys = path.split('.');
|
||||
let val = obj;
|
||||
for (let i = 0, n = keys.length; i < n; i++) {
|
||||
val = val[keys[i]];
|
||||
if (val == null) {
|
||||
return val;
|
||||
|
@ -429,26 +429,26 @@ function getValue(obj, path) {
|
|||
}
|
||||
|
||||
Memory.prototype._findAllSkippingIncludes = function(model, filter) {
|
||||
var nodes = Object.keys(this.collection(model)).map(function(key) {
|
||||
let nodes = Object.keys(this.collection(model)).map(function(key) {
|
||||
return this.fromDb(model, this.collection(model)[key]);
|
||||
}.bind(this));
|
||||
|
||||
if (filter) {
|
||||
if (!filter.order) {
|
||||
var idNames = this.idNames(model);
|
||||
const idNames = this.idNames(model);
|
||||
if (idNames && idNames.length) {
|
||||
filter.order = idNames;
|
||||
}
|
||||
}
|
||||
// do we need some sorting?
|
||||
if (filter.order) {
|
||||
var orders = filter.order;
|
||||
let orders = filter.order;
|
||||
if (typeof filter.order === 'string') {
|
||||
orders = [filter.order];
|
||||
}
|
||||
orders.forEach(function(key, i) {
|
||||
var reverse = 1;
|
||||
var m = key.match(/\s+(A|DE)SC$/i);
|
||||
let reverse = 1;
|
||||
const m = key.match(/\s+(A|DE)SC$/i);
|
||||
if (m) {
|
||||
key = key.replace(/\s+(A|DE)SC/i, '');
|
||||
if (m[1].toLowerCase() === 'de') reverse = -1;
|
||||
|
@ -458,7 +458,7 @@ Memory.prototype._findAllSkippingIncludes = function(model, filter) {
|
|||
nodes = nodes.sort(sorting.bind(orders));
|
||||
}
|
||||
|
||||
var nearFilter = geo.nearFilter(filter.where);
|
||||
const nearFilter = geo.nearFilter(filter.where);
|
||||
|
||||
// geo sorting
|
||||
if (nearFilter) {
|
||||
|
@ -475,18 +475,18 @@ Memory.prototype._findAllSkippingIncludes = function(model, filter) {
|
|||
}
|
||||
|
||||
// limit/skip
|
||||
var skip = filter.skip || filter.offset || 0;
|
||||
var limit = filter.limit || nodes.length;
|
||||
const skip = filter.skip || filter.offset || 0;
|
||||
const limit = filter.limit || nodes.length;
|
||||
nodes = nodes.slice(skip, skip + limit);
|
||||
}
|
||||
return nodes;
|
||||
|
||||
function sorting(a, b) {
|
||||
var undefinedA, undefinedB;
|
||||
let undefinedA, undefinedB;
|
||||
|
||||
for (var i = 0, l = this.length; i < l; i++) {
|
||||
var aVal = getValue(a, this[i].key);
|
||||
var bVal = getValue(b, this[i].key);
|
||||
for (let i = 0, l = this.length; i < l; i++) {
|
||||
const aVal = getValue(a, this[i].key);
|
||||
const bVal = getValue(b, this[i].key);
|
||||
undefinedB = bVal === undefined && aVal !== undefined;
|
||||
undefinedA = aVal === undefined && bVal !== undefined;
|
||||
|
||||
|
@ -502,8 +502,8 @@ Memory.prototype._findAllSkippingIncludes = function(model, filter) {
|
|||
};
|
||||
|
||||
Memory.prototype.all = function all(model, filter, options, callback) {
|
||||
var self = this;
|
||||
var nodes = self._findAllSkippingIncludes(model, filter);
|
||||
const self = this;
|
||||
const nodes = self._findAllSkippingIncludes(model, filter);
|
||||
|
||||
process.nextTick(function() {
|
||||
if (filter && filter.include) {
|
||||
|
@ -515,11 +515,11 @@ Memory.prototype.all = function all(model, filter, options, callback) {
|
|||
};
|
||||
|
||||
function applyFilter(filter) {
|
||||
var where = filter.where;
|
||||
const where = filter.where;
|
||||
if (typeof where === 'function') {
|
||||
return where;
|
||||
}
|
||||
var keys = Object.keys(where);
|
||||
const keys = Object.keys(where);
|
||||
return function(obj) {
|
||||
return keys.every(function(key) {
|
||||
if (key === 'and' || key === 'or') {
|
||||
|
@ -537,18 +537,18 @@ function applyFilter(filter) {
|
|||
}
|
||||
}
|
||||
|
||||
var value = getValue(obj, key);
|
||||
const value = getValue(obj, key);
|
||||
// Support referencesMany and other embedded relations
|
||||
// Also support array types. Mongo, possibly PostgreSQL
|
||||
if (Array.isArray(value)) {
|
||||
var matcher = where[key];
|
||||
const matcher = where[key];
|
||||
// The following condition is for the case where we are querying with
|
||||
// a neq filter, and when the value is an empty array ([]).
|
||||
if (matcher.neq !== undefined && value.length <= 0) {
|
||||
return true;
|
||||
}
|
||||
return value.some(function(v, i) {
|
||||
var filter = {where: {}};
|
||||
const filter = {where: {}};
|
||||
filter.where[i] = matcher;
|
||||
return applyFilter(filter)(value);
|
||||
});
|
||||
|
@ -560,11 +560,11 @@ function applyFilter(filter) {
|
|||
|
||||
// If we have a composed key a.b and b would resolve to a property of an object inside an array
|
||||
// then, we attempt to emulate mongo db matching. Helps for embedded relations
|
||||
var dotIndex = key.indexOf('.');
|
||||
var subValue = obj[key.substring(0, dotIndex)];
|
||||
const dotIndex = key.indexOf('.');
|
||||
const subValue = obj[key.substring(0, dotIndex)];
|
||||
if (dotIndex !== -1) {
|
||||
var subFilter = {where: {}};
|
||||
var subKey = key.substring(dotIndex + 1);
|
||||
const subFilter = {where: {}};
|
||||
const subKey = key.substring(dotIndex + 1);
|
||||
subFilter.where[subKey] = where[key];
|
||||
if (Array.isArray(subValue)) {
|
||||
return subValue.some(applyFilter(subFilter));
|
||||
|
@ -581,12 +581,12 @@ function applyFilter(filter) {
|
|||
if (pattern instanceof RegExp) {
|
||||
return pattern;
|
||||
}
|
||||
var regex = '';
|
||||
let regex = '';
|
||||
// Escaping user input to be treated as a literal string within a regular expression
|
||||
// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Writing_a_Regular_Expression_Pattern
|
||||
pattern = pattern.replace(/([.*+?^=!:${}()|\[\]\/\\])/g, '\\$1');
|
||||
for (var i = 0, n = pattern.length; i < n; i++) {
|
||||
var char = pattern.charAt(i);
|
||||
for (let i = 0, n = pattern.length; i < n; i++) {
|
||||
const char = pattern.charAt(i);
|
||||
if (char === '\\') {
|
||||
i++; // Skip to next char
|
||||
if (i < n) {
|
||||
|
@ -627,7 +627,7 @@ function applyFilter(filter) {
|
|||
return true;
|
||||
}
|
||||
|
||||
var i;
|
||||
let i;
|
||||
if (example.inq) {
|
||||
// if (!value) return false;
|
||||
for (i = 0; i < example.inq.length; i++) {
|
||||
|
@ -657,7 +657,7 @@ function applyFilter(filter) {
|
|||
}
|
||||
|
||||
if (example.like || example.nlike || example.ilike || example.nilike) {
|
||||
var like = example.like || example.nlike || example.ilike || example.nilike;
|
||||
let like = example.like || example.nlike || example.ilike || example.nilike;
|
||||
if (typeof like === 'string') {
|
||||
like = toRegExp(like);
|
||||
}
|
||||
|
@ -709,7 +709,7 @@ function applyFilter(filter) {
|
|||
return val1 - val2;
|
||||
}
|
||||
if (val1 instanceof Date) {
|
||||
var result = val1 - val2;
|
||||
const result = val1 - val2;
|
||||
return result;
|
||||
}
|
||||
// Return NaN if we don't know how to compare
|
||||
|
@ -734,9 +734,9 @@ function applyFilter(filter) {
|
|||
}
|
||||
|
||||
Memory.prototype.destroyAll = function destroyAll(model, where, options, callback) {
|
||||
var cache = this.collection(model);
|
||||
var filter = null;
|
||||
var count = 0;
|
||||
const cache = this.collection(model);
|
||||
let filter = null;
|
||||
let count = 0;
|
||||
if (where) {
|
||||
filter = applyFilter({where: where});
|
||||
Object.keys(cache).forEach(function(id) {
|
||||
|
@ -753,10 +753,10 @@ Memory.prototype.destroyAll = function destroyAll(model, where, options, callbac
|
|||
};
|
||||
|
||||
Memory.prototype.count = function count(model, where, options, callback) {
|
||||
var cache = this.collection(model);
|
||||
var data = Object.keys(cache);
|
||||
const cache = this.collection(model);
|
||||
let data = Object.keys(cache);
|
||||
if (where) {
|
||||
var filter = {where: where};
|
||||
const filter = {where: where};
|
||||
data = data.map(function(id) {
|
||||
return this.fromDb(model, cache[id]);
|
||||
}.bind(this));
|
||||
|
@ -769,16 +769,16 @@ Memory.prototype.count = function count(model, where, options, callback) {
|
|||
|
||||
Memory.prototype.update =
|
||||
Memory.prototype.updateAll = function updateAll(model, where, data, options, cb) {
|
||||
var self = this;
|
||||
var cache = this.collection(model);
|
||||
var filter = null;
|
||||
const self = this;
|
||||
const cache = this.collection(model);
|
||||
let filter = null;
|
||||
where = where || {};
|
||||
filter = applyFilter({where: where});
|
||||
|
||||
var ids = Object.keys(cache);
|
||||
var count = 0;
|
||||
const ids = Object.keys(cache);
|
||||
let count = 0;
|
||||
async.each(ids, function(id, done) {
|
||||
var inst = self.fromDb(model, cache[id]);
|
||||
const inst = self.fromDb(model, cache[id]);
|
||||
if (!filter || filter(inst)) {
|
||||
count++;
|
||||
// The id value from the cache is string
|
||||
|
@ -796,7 +796,7 @@ Memory.prototype.update =
|
|||
|
||||
Memory.prototype.updateAttributes = function updateAttributes(model, id, data, options, cb) {
|
||||
if (!id) {
|
||||
var err = new Error(g.f('You must provide an {{id}} when updating attributes!'));
|
||||
const err = new Error(g.f('You must provide an {{id}} when updating attributes!'));
|
||||
if (cb) {
|
||||
return cb(err);
|
||||
} else {
|
||||
|
@ -809,40 +809,40 @@ Memory.prototype.updateAttributes = function updateAttributes(model, id, data, o
|
|||
|
||||
this.setIdValue(model, data, id);
|
||||
|
||||
var cachedModels = this.collection(model);
|
||||
var modelData = cachedModels && this.collection(model)[id];
|
||||
const cachedModels = this.collection(model);
|
||||
const modelData = cachedModels && this.collection(model)[id];
|
||||
|
||||
if (modelData) {
|
||||
this.save(model, data, options, cb);
|
||||
} else {
|
||||
var msg = g.f('Could not update attributes. {{Object}} with {{id}} %s does not exist!', id);
|
||||
var error = new Error(msg);
|
||||
const msg = g.f('Could not update attributes. {{Object}} with {{id}} %s does not exist!', id);
|
||||
const error = new Error(msg);
|
||||
error.statusCode = error.status = 404;
|
||||
cb(error);
|
||||
}
|
||||
};
|
||||
|
||||
Memory.prototype.replaceById = function(model, id, data, options, cb) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
if (!id) {
|
||||
var err = new Error(g.f('You must provide an {{id}} when replacing!'));
|
||||
const err = new Error(g.f('You must provide an {{id}} when replacing!'));
|
||||
return process.nextTick(function() { cb(err); });
|
||||
}
|
||||
// Do not modify the data object passed in arguments
|
||||
data = Object.create(data);
|
||||
this.setIdValue(model, data, id);
|
||||
var cachedModels = this.collection(model);
|
||||
var modelData = cachedModels && this.collection(model)[id];
|
||||
const cachedModels = this.collection(model);
|
||||
const modelData = cachedModels && this.collection(model)[id];
|
||||
if (!modelData) {
|
||||
var msg = 'Could not replace. Object with id ' + id + ' does not exist!';
|
||||
var error = new Error(msg);
|
||||
const msg = 'Could not replace. Object with id ' + id + ' does not exist!';
|
||||
const error = new Error(msg);
|
||||
error.statusCode = error.status = 404;
|
||||
return process.nextTick(function() { cb(error); });
|
||||
}
|
||||
|
||||
var newModelData = {};
|
||||
for (var key in data) {
|
||||
var val = data[key];
|
||||
const newModelData = {};
|
||||
for (const key in data) {
|
||||
const val = data[key];
|
||||
if (typeof val === 'function') {
|
||||
continue; // Skip methods
|
||||
}
|
||||
|
@ -856,13 +856,13 @@ Memory.prototype.replaceById = function(model, id, data, options, cb) {
|
|||
};
|
||||
|
||||
Memory.prototype.replaceOrCreate = function(model, data, options, callback) {
|
||||
var self = this;
|
||||
var idName = self.idNames(model)[0];
|
||||
var idValue = self.getIdValue(model, data);
|
||||
var filter = {where: {}};
|
||||
const self = this;
|
||||
const idName = self.idNames(model)[0];
|
||||
const idValue = self.getIdValue(model, data);
|
||||
const filter = {where: {}};
|
||||
filter.where[idName] = idValue;
|
||||
var nodes = self._findAllSkippingIncludes(model, filter);
|
||||
var found = nodes[0];
|
||||
const nodes = self._findAllSkippingIncludes(model, filter);
|
||||
const found = nodes[0];
|
||||
|
||||
if (!found) {
|
||||
// Calling _createSync to update the collection in a sync way and
|
||||
|
@ -875,7 +875,7 @@ Memory.prototype.replaceOrCreate = function(model, data, options, callback) {
|
|||
});
|
||||
});
|
||||
}
|
||||
var id = self.getIdValue(model, data);
|
||||
const id = self.getIdValue(model, data);
|
||||
self.collection(model)[id] = serialize(data);
|
||||
self.saveToFile(data, function(err) {
|
||||
callback(err, self.fromDb(model, data), {isNewInstance: false});
|
||||
|
@ -896,7 +896,7 @@ Memory.prototype.buildNearFilter = function(filter) {
|
|||
};
|
||||
|
||||
Memory.prototype.automigrate = function(models, cb) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
|
||||
if ((!cb) && ('function' === typeof models)) {
|
||||
cb = models;
|
||||
|
@ -912,7 +912,7 @@ Memory.prototype.automigrate = function(models, cb) {
|
|||
return process.nextTick(cb);
|
||||
}
|
||||
|
||||
var invalidModels = models.filter(function(m) {
|
||||
const invalidModels = models.filter(function(m) {
|
||||
return !(m in self._models);
|
||||
});
|
||||
|
||||
|
@ -935,8 +935,8 @@ function merge(base, update) {
|
|||
}
|
||||
// We cannot use Object.keys(update) if the update is an instance of the model
|
||||
// class as the properties are defined at the ModelClass.prototype level
|
||||
for (var key in update) {
|
||||
var val = update[key];
|
||||
for (const key in update) {
|
||||
const val = update[key];
|
||||
if (typeof val === 'function') {
|
||||
continue; // Skip methods
|
||||
}
|
||||
|
|
|
@ -5,11 +5,11 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var g = require('strong-globalize')();
|
||||
var util = require('util');
|
||||
var Connector = require('loopback-connector').Connector;
|
||||
var utils = require('../utils');
|
||||
var crypto = require('crypto');
|
||||
const g = require('strong-globalize')();
|
||||
const util = require('util');
|
||||
const Connector = require('loopback-connector').Connector;
|
||||
const utils = require('../utils');
|
||||
const crypto = require('crypto');
|
||||
|
||||
/**
|
||||
* Initialize the Transient connector against the given data source
|
||||
|
@ -59,8 +59,8 @@ Transient.prototype.connect = function(callback) {
|
|||
};
|
||||
|
||||
Transient.prototype.generateId = function(model, data, idName) {
|
||||
var idType;
|
||||
var props = this._models[model].properties;
|
||||
let idType;
|
||||
const props = this._models[model].properties;
|
||||
if (idName) idType = props[idName] && props[idName].type;
|
||||
idType = idType || this.getDefaultIdType();
|
||||
if (idType === Number) {
|
||||
|
@ -89,10 +89,11 @@ Transient.prototype.count = function count(model, callback, where) {
|
|||
};
|
||||
|
||||
Transient.prototype.create = function create(model, data, callback) {
|
||||
var props = this._models[model].properties;
|
||||
var idName = this.idName(model);
|
||||
const props = this._models[model].properties;
|
||||
const idName = this.idName(model);
|
||||
let id = undefined;
|
||||
if (idName && props[idName]) {
|
||||
var id = this.getIdValue(model, data) || this.generateId(model, data, idName);
|
||||
id = this.getIdValue(model, data) || this.generateId(model, data, idName);
|
||||
id = (props[idName] && props[idName].type && props[idName].type(id)) || id;
|
||||
this.setIdValue(model, data, id);
|
||||
}
|
||||
|
@ -105,13 +106,13 @@ Transient.prototype.save = function save(model, data, callback) {
|
|||
|
||||
Transient.prototype.update =
|
||||
Transient.prototype.updateAll = function updateAll(model, where, data, cb) {
|
||||
var count = 0;
|
||||
const count = 0;
|
||||
this.flush('update', {count: count}, cb);
|
||||
};
|
||||
|
||||
Transient.prototype.updateAttributes = function updateAttributes(model, id, data, cb) {
|
||||
if (!id) {
|
||||
var err = new Error(g.f('You must provide an {{id}} when updating attributes!'));
|
||||
const err = new Error(g.f('You must provide an {{id}} when updating attributes!'));
|
||||
if (cb) {
|
||||
return cb(err);
|
||||
} else {
|
||||
|
|
536
lib/dao.js
536
lib/dao.js
File diff suppressed because it is too large
Load Diff
|
@ -10,30 +10,30 @@
|
|||
/*!
|
||||
* Module dependencies
|
||||
*/
|
||||
var ModelBuilder = require('./model-builder.js').ModelBuilder;
|
||||
var ModelDefinition = require('./model-definition.js');
|
||||
var RelationDefinition = require('./relation-definition.js');
|
||||
var OberserverMixin = require('./observer');
|
||||
var jutil = require('./jutil');
|
||||
var utils = require('./utils');
|
||||
var ModelBaseClass = require('./model.js');
|
||||
var DataAccessObject = require('./dao.js');
|
||||
var defineScope = require('./scope.js').defineScope;
|
||||
var EventEmitter = require('events').EventEmitter;
|
||||
var util = require('util');
|
||||
var assert = require('assert');
|
||||
var async = require('async');
|
||||
var traverse = require('traverse');
|
||||
var g = require('strong-globalize')();
|
||||
var juggler = require('..');
|
||||
var deprecated = require('depd')('loopback-datasource-juggler');
|
||||
var Transaction = require('loopback-connector').Transaction;
|
||||
const ModelBuilder = require('./model-builder.js').ModelBuilder;
|
||||
const ModelDefinition = require('./model-definition.js');
|
||||
const RelationDefinition = require('./relation-definition.js');
|
||||
const OberserverMixin = require('./observer');
|
||||
const jutil = require('./jutil');
|
||||
const utils = require('./utils');
|
||||
const ModelBaseClass = require('./model.js');
|
||||
const DataAccessObject = require('./dao.js');
|
||||
const defineScope = require('./scope.js').defineScope;
|
||||
const EventEmitter = require('events').EventEmitter;
|
||||
const util = require('util');
|
||||
const assert = require('assert');
|
||||
const async = require('async');
|
||||
const traverse = require('traverse');
|
||||
const g = require('strong-globalize')();
|
||||
const juggler = require('..');
|
||||
const deprecated = require('depd')('loopback-datasource-juggler');
|
||||
const Transaction = require('loopback-connector').Transaction;
|
||||
|
||||
if (process.env.DEBUG === 'loopback') {
|
||||
// For back-compatibility
|
||||
process.env.DEBUG = 'loopback:*';
|
||||
}
|
||||
var debug = require('debug')('loopback:datasource');
|
||||
const debug = require('debug')('loopback:datasource');
|
||||
|
||||
/*!
|
||||
* Export public API
|
||||
|
@ -43,7 +43,7 @@ exports.DataSource = DataSource;
|
|||
/*!
|
||||
* Helpers
|
||||
*/
|
||||
var slice = Array.prototype.slice;
|
||||
const slice = Array.prototype.slice;
|
||||
|
||||
/**
|
||||
* LoopBack models can manipulate data via the DataSource object.
|
||||
|
@ -140,16 +140,16 @@ function DataSource(name, settings, modelBuilder) {
|
|||
this._setupConnector();
|
||||
|
||||
// connector
|
||||
var connector = this.connector;
|
||||
const connector = this.connector;
|
||||
|
||||
// DataAccessObject - connector defined or supply the default
|
||||
var dao = (connector && connector.DataAccessObject) || this.constructor.DataAccessObject;
|
||||
const dao = (connector && connector.DataAccessObject) || this.constructor.DataAccessObject;
|
||||
this.DataAccessObject = function() {
|
||||
};
|
||||
|
||||
// define DataAccessObject methods
|
||||
Object.keys(dao).forEach(function(name) {
|
||||
var fn = dao[name];
|
||||
const fn = dao[name];
|
||||
this.DataAccessObject[name] = fn;
|
||||
|
||||
if (typeof fn === 'function') {
|
||||
|
@ -166,7 +166,7 @@ function DataSource(name, settings, modelBuilder) {
|
|||
|
||||
// define DataAccessObject.prototype methods
|
||||
Object.keys(dao.prototype || []).forEach(function(name) {
|
||||
var fn = dao.prototype[name];
|
||||
const fn = dao.prototype[name];
|
||||
this.DataAccessObject.prototype[name] = fn;
|
||||
if (typeof fn === 'function') {
|
||||
this.defineOperation(name, {
|
||||
|
@ -199,14 +199,14 @@ DataSource.prototype._setupConnector = function() {
|
|||
// Set up the dataSource if the connector doesn't do so
|
||||
this.connector.dataSource = this;
|
||||
}
|
||||
var dataSource = this;
|
||||
const dataSource = this;
|
||||
this.connector.log = function(query, start) {
|
||||
dataSource.log(query, start);
|
||||
};
|
||||
|
||||
this.connector.logger = function(query) {
|
||||
var t1 = Date.now();
|
||||
var log = this.log;
|
||||
const t1 = Date.now();
|
||||
const log = this.log;
|
||||
return function(q) {
|
||||
log(q || query, t1);
|
||||
};
|
||||
|
@ -218,7 +218,7 @@ DataSource.prototype._setupConnector = function() {
|
|||
|
||||
// List possible connector module names
|
||||
function connectorModuleNames(name) {
|
||||
var names = []; // Check the name as is
|
||||
const names = []; // Check the name as is
|
||||
if (!name.match(/^\//)) {
|
||||
names.push('./connectors/' + name); // Check built-in connectors
|
||||
if (name.indexOf('loopback-connector-') !== 0) {
|
||||
|
@ -235,13 +235,13 @@ function connectorModuleNames(name) {
|
|||
|
||||
// testable with DI
|
||||
function tryModules(names, loader) {
|
||||
var mod;
|
||||
let mod;
|
||||
loader = loader || require;
|
||||
for (var m = 0; m < names.length; m++) {
|
||||
for (let m = 0; m < names.length; m++) {
|
||||
try {
|
||||
mod = loader(names[m]);
|
||||
} catch (e) {
|
||||
var notFound = e.code === 'MODULE_NOT_FOUND' &&
|
||||
const notFound = e.code === 'MODULE_NOT_FOUND' &&
|
||||
e.message && e.message.indexOf(names[m]) > 0;
|
||||
|
||||
if (notFound) {
|
||||
|
@ -266,9 +266,9 @@ function tryModules(names, loader) {
|
|||
* @private
|
||||
*/
|
||||
DataSource._resolveConnector = function(name, loader) {
|
||||
var names = connectorModuleNames(name);
|
||||
var connector = tryModules(names, loader);
|
||||
var error = null;
|
||||
const names = connectorModuleNames(name);
|
||||
const connector = tryModules(names, loader);
|
||||
let error = null;
|
||||
if (!connector) {
|
||||
error = g.f('\nWARNING: {{LoopBack}} connector "%s" is not installed ' +
|
||||
'as any of the following modules:\n\n %s\n\nTo fix, run:\n\n {{npm install %s --save}}\n',
|
||||
|
@ -290,7 +290,7 @@ DataSource._resolveConnector = function(name, loader) {
|
|||
*/
|
||||
DataSource.prototype.connect = function(callback) {
|
||||
callback = callback || utils.createPromiseCallback();
|
||||
var self = this;
|
||||
const self = this;
|
||||
if (this.connected) {
|
||||
// The data source is already connected, return immediately
|
||||
process.nextTick(callback);
|
||||
|
@ -317,7 +317,7 @@ DataSource.prototype.connect = function(callback) {
|
|||
this.connector.connect(function(err, result) {
|
||||
self.connecting = false;
|
||||
if (!err) self.connected = true;
|
||||
var cbs = self.pendingConnectCallbacks;
|
||||
const cbs = self.pendingConnectCallbacks;
|
||||
self.pendingConnectCallbacks = [];
|
||||
if (!err) {
|
||||
self.emit('connected');
|
||||
|
@ -362,8 +362,8 @@ DataSource.prototype.connect = function(callback) {
|
|||
* @private
|
||||
*/
|
||||
DataSource.prototype.setup = function(dsName, settings) {
|
||||
var dataSource = this;
|
||||
var connector;
|
||||
const dataSource = this;
|
||||
let connector;
|
||||
|
||||
// First argument is an `object`
|
||||
if (dsName && typeof dsName === 'object') {
|
||||
|
@ -424,7 +424,7 @@ DataSource.prototype.setup = function(dsName, settings) {
|
|||
|
||||
this.name = dsName || (typeof this.settings.name === 'string' && this.settings.name);
|
||||
|
||||
var connectorName;
|
||||
let connectorName;
|
||||
if (typeof connector === 'string') {
|
||||
// Connector needs to be resolved by name
|
||||
connectorName = connector;
|
||||
|
@ -441,7 +441,7 @@ DataSource.prototype.setup = function(dsName, settings) {
|
|||
|
||||
if ((!connector) && connectorName) {
|
||||
// The connector has not been resolved
|
||||
var result = DataSource._resolveConnector(connectorName);
|
||||
const result = DataSource._resolveConnector(connectorName);
|
||||
connector = result.connector;
|
||||
if (!connector) {
|
||||
console.error(result.error);
|
||||
|
@ -451,7 +451,7 @@ DataSource.prototype.setup = function(dsName, settings) {
|
|||
}
|
||||
|
||||
if (connector) {
|
||||
var postInit = function postInit(err, result) {
|
||||
const postInit = function postInit(err, result) {
|
||||
this._setupConnector();
|
||||
// we have an connector now?
|
||||
if (!this.connector) {
|
||||
|
@ -532,7 +532,7 @@ function isModelDataSourceAttached(model) {
|
|||
*/
|
||||
DataSource.prototype.defineScopes = function(modelClass, scopes) {
|
||||
if (scopes) {
|
||||
for (var s in scopes) {
|
||||
for (const s in scopes) {
|
||||
defineScope(modelClass, modelClass, s, scopes[s], {}, scopes[s].options);
|
||||
}
|
||||
}
|
||||
|
@ -547,16 +547,16 @@ DataSource.prototype.defineScopes = function(modelClass, scopes) {
|
|||
* object definitions.
|
||||
*/
|
||||
DataSource.prototype.defineRelations = function(modelClass, relations) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
|
||||
// Wait for target/through models to be attached before setting up the relation
|
||||
var deferRelationSetup = function(relationName, relation, targetModel, throughModel) {
|
||||
const deferRelationSetup = function(relationName, relation, targetModel, throughModel) {
|
||||
if (!isModelDataSourceAttached(targetModel)) {
|
||||
targetModel.once('dataAccessConfigured', function(targetModel) {
|
||||
// Check if the through model doesn't exist or resolved
|
||||
if (!throughModel || isModelDataSourceAttached(throughModel)) {
|
||||
// The target model is resolved
|
||||
var params = traverse(relation).clone();
|
||||
const params = traverse(relation).clone();
|
||||
params.as = relationName;
|
||||
params.model = targetModel;
|
||||
if (throughModel) {
|
||||
|
@ -572,7 +572,7 @@ DataSource.prototype.defineRelations = function(modelClass, relations) {
|
|||
throughModel.once('dataAccessConfigured', function(throughModel) {
|
||||
if (isModelDataSourceAttached(targetModel)) {
|
||||
// The target model is resolved
|
||||
var params = traverse(relation).clone();
|
||||
const params = traverse(relation).clone();
|
||||
params.as = relationName;
|
||||
params.model = targetModel;
|
||||
params.through = throughModel;
|
||||
|
@ -585,8 +585,8 @@ DataSource.prototype.defineRelations = function(modelClass, relations) {
|
|||
// Set up the relations
|
||||
if (relations) {
|
||||
Object.keys(relations).forEach(function(relationName) {
|
||||
var targetModel;
|
||||
var r = relations[relationName];
|
||||
let targetModel;
|
||||
const r = relations[relationName];
|
||||
|
||||
validateRelation(relationName, r);
|
||||
|
||||
|
@ -594,7 +594,7 @@ DataSource.prototype.defineRelations = function(modelClass, relations) {
|
|||
targetModel = isModelClass(r.model) ? r.model : self.getModel(r.model, true);
|
||||
}
|
||||
|
||||
var throughModel = null;
|
||||
let throughModel = null;
|
||||
if (r.through) {
|
||||
throughModel = isModelClass(r.through) ? r.through : self.getModel(r.through, true);
|
||||
}
|
||||
|
@ -605,7 +605,7 @@ DataSource.prototype.defineRelations = function(modelClass, relations) {
|
|||
deferRelationSetup(relationName, r, targetModel, throughModel);
|
||||
} else {
|
||||
// The target model is resolved
|
||||
var params = traverse(r).clone();
|
||||
const params = traverse(r).clone();
|
||||
params.as = relationName;
|
||||
params.model = targetModel;
|
||||
if (throughModel) {
|
||||
|
@ -618,9 +618,9 @@ DataSource.prototype.defineRelations = function(modelClass, relations) {
|
|||
};
|
||||
|
||||
function validateRelation(relationName, relation) {
|
||||
var rn = relationName;
|
||||
var r = relation;
|
||||
var msg, code;
|
||||
const rn = relationName;
|
||||
const r = relation;
|
||||
let msg, code;
|
||||
|
||||
assert(DataSource.relationTypes.indexOf(r.type) !== -1, 'Invalid relation type: ' + r.type);
|
||||
assert(isValidRelationName(rn), 'Invalid relation name: ' + rn);
|
||||
|
@ -668,7 +668,7 @@ function validateRelation(relationName, relation) {
|
|||
}
|
||||
|
||||
if (msg) {
|
||||
var error = new Error(msg);
|
||||
const error = new Error(msg);
|
||||
error.details = {code: code, rType: r.type, rName: rn};
|
||||
throw error;
|
||||
}
|
||||
|
@ -683,7 +683,7 @@ function validateRelation(relationName, relation) {
|
|||
}
|
||||
|
||||
function isValidRelationName(relationName) {
|
||||
var invalidRelationNames = ['trigger'];
|
||||
const invalidRelationNames = ['trigger'];
|
||||
return invalidRelationNames.indexOf(relationName) === -1;
|
||||
}
|
||||
|
||||
|
@ -697,11 +697,11 @@ function isValidRelationName(relationName) {
|
|||
DataSource.prototype.setupDataAccess = function(modelClass, settings) {
|
||||
if (this.connector) {
|
||||
// Check if the id property should be generated
|
||||
var idName = modelClass.definition.idName();
|
||||
var idProp = modelClass.definition.rawProperties[idName];
|
||||
const idName = modelClass.definition.idName();
|
||||
const idProp = modelClass.definition.rawProperties[idName];
|
||||
if (idProp && idProp.generated && this.connector.getDefaultIdType) {
|
||||
// Set the default id type from connector's ability
|
||||
var idType = this.connector.getDefaultIdType() || String;
|
||||
const idType = this.connector.getDefaultIdType() || String;
|
||||
idProp.type = idType;
|
||||
modelClass.definition.rawProperties[idName].type = idType;
|
||||
modelClass.definition.properties[idName].type = idType;
|
||||
|
@ -720,7 +720,7 @@ DataSource.prototype.setupDataAccess = function(modelClass, settings) {
|
|||
this.mixin(modelClass);
|
||||
|
||||
// define relations from LDL (options.relations)
|
||||
var relations = settings.relationships || settings.relations;
|
||||
const relations = settings.relationships || settings.relations;
|
||||
this.defineRelations(modelClass, relations);
|
||||
|
||||
// Emit the dataAccessConfigured event to indicate all the methods for data
|
||||
|
@ -728,7 +728,7 @@ DataSource.prototype.setupDataAccess = function(modelClass, settings) {
|
|||
modelClass.emit('dataAccessConfigured', modelClass);
|
||||
|
||||
// define scopes from LDL (options.relations)
|
||||
var scopes = settings.scopes || {};
|
||||
const scopes = settings.scopes || {};
|
||||
this.defineScopes(modelClass, scopes);
|
||||
};
|
||||
|
||||
|
@ -783,7 +783,7 @@ DataSource.prototype.setupDataAccess = function(modelClass, settings) {
|
|||
|
||||
DataSource.prototype.createModel =
|
||||
DataSource.prototype.define = function defineClass(className, properties, settings) {
|
||||
var args = slice.call(arguments);
|
||||
const args = slice.call(arguments);
|
||||
|
||||
if (!className) {
|
||||
throw new Error(g.f('Class name required'));
|
||||
|
@ -810,7 +810,7 @@ DataSource.prototype.define = function defineClass(className, properties, settin
|
|||
}
|
||||
}
|
||||
|
||||
var modelClass = this.modelBuilder.define(className, properties, settings);
|
||||
const modelClass = this.modelBuilder.define(className, properties, settings);
|
||||
modelClass.dataSource = this;
|
||||
|
||||
if (settings.unresolved) {
|
||||
|
@ -841,16 +841,16 @@ DataSource.prototype.deleteModelByName = function(modelName) {
|
|||
*/
|
||||
|
||||
DataSource.prototype.mixin = function(ModelCtor) {
|
||||
var ops = this.operations();
|
||||
var DAO = this.DataAccessObject;
|
||||
const ops = this.operations();
|
||||
const DAO = this.DataAccessObject;
|
||||
|
||||
// mixin DAO
|
||||
jutil.mixin(ModelCtor, DAO, {proxyFunctions: true, override: true});
|
||||
|
||||
// decorate operations as alias functions
|
||||
Object.keys(ops).forEach(function(name) {
|
||||
var op = ops[name];
|
||||
var scope;
|
||||
const op = ops[name];
|
||||
let scope;
|
||||
|
||||
if (op.enabled) {
|
||||
scope = op.prototype ? ModelCtor.prototype : ModelCtor;
|
||||
|
@ -908,8 +908,8 @@ DataSource.prototype.getModelDefinition = function(name) {
|
|||
* no subtype.
|
||||
*/
|
||||
DataSource.prototype.getTypes = function() {
|
||||
var getTypes = this.connector && this.connector.getTypes;
|
||||
var types = getTypes && getTypes() || [];
|
||||
const getTypes = this.connector && this.connector.getTypes;
|
||||
let types = getTypes && getTypes() || [];
|
||||
if (typeof types === 'string') {
|
||||
types = types.split(/[\s,\/]+/);
|
||||
}
|
||||
|
@ -922,10 +922,10 @@ DataSource.prototype.getTypes = function() {
|
|||
* @returns {Boolean} true if all types are supported by the data source
|
||||
*/
|
||||
DataSource.prototype.supportTypes = function(types) {
|
||||
var supportedTypes = this.getTypes();
|
||||
const supportedTypes = this.getTypes();
|
||||
if (Array.isArray(types)) {
|
||||
// Check each of the types
|
||||
for (var i = 0; i < types.length; i++) {
|
||||
for (let i = 0; i < types.length; i++) {
|
||||
if (supportedTypes.indexOf(types[i]) === -1) {
|
||||
// Not supported
|
||||
return false;
|
||||
|
@ -983,7 +983,7 @@ DataSource.prototype.attach = function(modelClass) {
|
|||
DataSource.prototype.defineProperty = function(model, prop, params) {
|
||||
this.modelBuilder.defineProperty(model, prop, params);
|
||||
|
||||
var resolvedProp = this.getModelDefinition(model).properties[prop];
|
||||
const resolvedProp = this.getModelDefinition(model).properties[prop];
|
||||
if (this.connector && this.connector.defineProperty) {
|
||||
this.connector.defineProperty(model, prop, resolvedProp);
|
||||
}
|
||||
|
@ -1024,7 +1024,7 @@ DataSource.prototype.automigrate = function(models, cb) {
|
|||
models = [models];
|
||||
}
|
||||
|
||||
var attachedModels = this.connector._models;
|
||||
const attachedModels = this.connector._models;
|
||||
|
||||
if (attachedModels && typeof attachedModels === 'object') {
|
||||
models = models || Object.keys(attachedModels);
|
||||
|
@ -1034,7 +1034,7 @@ DataSource.prototype.automigrate = function(models, cb) {
|
|||
return cb.promise;
|
||||
}
|
||||
|
||||
var invalidModels = models.filter(function(m) {
|
||||
const invalidModels = models.filter(function(m) {
|
||||
return !(m in attachedModels);
|
||||
});
|
||||
|
||||
|
@ -1085,7 +1085,7 @@ DataSource.prototype.autoupdate = function(models, cb) {
|
|||
models = [models];
|
||||
}
|
||||
|
||||
var attachedModels = this.connector._models;
|
||||
const attachedModels = this.connector._models;
|
||||
|
||||
if (attachedModels && typeof attachedModels === 'object') {
|
||||
models = models || Object.keys(attachedModels);
|
||||
|
@ -1095,7 +1095,7 @@ DataSource.prototype.autoupdate = function(models, cb) {
|
|||
return cb.promise;
|
||||
}
|
||||
|
||||
var invalidModels = models.filter(function(m) {
|
||||
const invalidModels = models.filter(function(m) {
|
||||
return !(m in attachedModels);
|
||||
});
|
||||
|
||||
|
@ -1406,10 +1406,10 @@ function fromDBName(dbName, camelCase) {
|
|||
if (!dbName) {
|
||||
return dbName;
|
||||
}
|
||||
var parts = dbName.split(/-|_/);
|
||||
const parts = dbName.split(/-|_/);
|
||||
parts[0] = camelCase ? parts[0].toLowerCase() : capitalize(parts[0]);
|
||||
|
||||
for (var i = 1; i < parts.length; i++) {
|
||||
for (let i = 1; i < parts.length; i++) {
|
||||
parts[i] = capitalize(parts[i]);
|
||||
}
|
||||
return parts.join('');
|
||||
|
@ -1492,7 +1492,7 @@ DataSource.prototype.discoverSchema = function(tableName, options, cb) {
|
|||
cb && cb(err, schemas);
|
||||
return;
|
||||
}
|
||||
for (var s in schemas) {
|
||||
for (const s in schemas) {
|
||||
cb && cb(null, schemas[s]);
|
||||
return;
|
||||
}
|
||||
|
@ -1522,10 +1522,10 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
|
||||
cb = cb || utils.createPromiseCallback();
|
||||
|
||||
var self = this;
|
||||
var dbType = this.connector.name;
|
||||
const self = this;
|
||||
const dbType = this.connector.name;
|
||||
|
||||
var nameMapper;
|
||||
let nameMapper;
|
||||
if (options.nameMapper === null) {
|
||||
// No mapping
|
||||
nameMapper = function(type, name) {
|
||||
|
@ -1553,11 +1553,11 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
return cb.promise;
|
||||
}
|
||||
|
||||
var tasks = [
|
||||
const tasks = [
|
||||
this.discoverModelProperties.bind(this, tableName, options),
|
||||
this.discoverPrimaryKeys.bind(this, tableName, options)];
|
||||
|
||||
var followingRelations = options.associations || options.relations;
|
||||
const followingRelations = options.associations || options.relations;
|
||||
if (followingRelations) {
|
||||
tasks.push(this.discoverForeignKeys.bind(this, tableName, options));
|
||||
}
|
||||
|
@ -1568,15 +1568,15 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
return cb.promise;
|
||||
}
|
||||
|
||||
var columns = results[0];
|
||||
const columns = results[0];
|
||||
if (!columns || columns.length === 0) {
|
||||
cb(new Error(g.f('Table \'%s\' does not exist.', tableName)));
|
||||
return cb.promise;
|
||||
}
|
||||
|
||||
// Handle primary keys
|
||||
var primaryKeys = results[1] || [];
|
||||
var pks = {};
|
||||
const primaryKeys = results[1] || [];
|
||||
const pks = {};
|
||||
primaryKeys.forEach(function(pk) {
|
||||
pks[pk.columnName] = pk.keySeq;
|
||||
});
|
||||
|
@ -1585,7 +1585,7 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
debug('Primary keys: ', pks);
|
||||
}
|
||||
|
||||
var schema = {
|
||||
const schema = {
|
||||
name: nameMapper('table', tableName),
|
||||
options: {
|
||||
idInjection: false, // DO NOT add id property
|
||||
|
@ -1599,7 +1599,7 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
};
|
||||
|
||||
columns.forEach(function(item) {
|
||||
var propName = nameMapper('column', item.columnName);
|
||||
const propName = nameMapper('column', item.columnName);
|
||||
schema.properties[propName] = {
|
||||
type: item.type,
|
||||
required: (item.nullable === 'N' || item.nullable === 'NO' ||
|
||||
|
@ -1612,7 +1612,7 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
if (pks[item.columnName]) {
|
||||
schema.properties[propName].id = pks[item.columnName];
|
||||
}
|
||||
var dbSpecific = schema.properties[propName][dbType] = {
|
||||
const dbSpecific = schema.properties[propName][dbType] = {
|
||||
columnName: item.columnName,
|
||||
dataType: item.dataType,
|
||||
dataLength: item.dataLength,
|
||||
|
@ -1622,7 +1622,7 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
};
|
||||
// merge connector-specific properties
|
||||
if (item[dbType]) {
|
||||
for (var k in item[dbType]) {
|
||||
for (const k in item[dbType]) {
|
||||
dbSpecific[k] = item[dbType][k];
|
||||
}
|
||||
}
|
||||
|
@ -1630,7 +1630,7 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
|
||||
// Add current modelName to the visited tables
|
||||
options.visited = options.visited || {};
|
||||
var schemaKey = columns[0].owner + '.' + tableName;
|
||||
const schemaKey = columns[0].owner + '.' + tableName;
|
||||
if (!options.visited.hasOwnProperty(schemaKey)) {
|
||||
if (self.settings.debug) {
|
||||
debug('Adding schema for ' + schemaKey);
|
||||
|
@ -1638,13 +1638,13 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
options.visited[schemaKey] = schema;
|
||||
}
|
||||
|
||||
var otherTables = {};
|
||||
const otherTables = {};
|
||||
if (followingRelations) {
|
||||
// Handle foreign keys
|
||||
var fks = {};
|
||||
var foreignKeys = results[2] || [];
|
||||
const fks = {};
|
||||
const foreignKeys = results[2] || [];
|
||||
foreignKeys.forEach(function(fk) {
|
||||
var fkInfo = {
|
||||
const fkInfo = {
|
||||
keySeq: fk.keySeq,
|
||||
owner: fk.pkOwner,
|
||||
tableName: fk.pkTableName,
|
||||
|
@ -1663,14 +1663,14 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
|
||||
schema.options.relations = {};
|
||||
foreignKeys.forEach(function(fk) {
|
||||
var propName = nameMapper('fk', (fk.fkName || fk.pkTableName));
|
||||
const propName = nameMapper('fk', (fk.fkName || fk.pkTableName));
|
||||
schema.options.relations[propName] = {
|
||||
model: nameMapper('table', fk.pkTableName),
|
||||
type: 'belongsTo',
|
||||
foreignKey: nameMapper('column', fk.fkColumnName),
|
||||
};
|
||||
|
||||
var key = fk.pkOwner + '.' + fk.pkTableName;
|
||||
const key = fk.pkOwner + '.' + fk.pkTableName;
|
||||
if (!options.visited.hasOwnProperty(key) && !otherTables.hasOwnProperty(key)) {
|
||||
otherTables[key] = {owner: fk.pkOwner, tableName: fk.pkTableName};
|
||||
}
|
||||
|
@ -1680,13 +1680,13 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
if (Object.keys(otherTables).length === 0) {
|
||||
cb(null, options.visited);
|
||||
} else {
|
||||
var moreTasks = [];
|
||||
for (var t in otherTables) {
|
||||
const moreTasks = [];
|
||||
for (const t in otherTables) {
|
||||
if (self.settings.debug) {
|
||||
debug('Discovering related schema for ' + schemaKey);
|
||||
}
|
||||
var newOptions = {};
|
||||
for (var key in options) {
|
||||
const newOptions = {};
|
||||
for (const key in options) {
|
||||
newOptions[key] = options[key];
|
||||
}
|
||||
newOptions.owner = otherTables[t].owner;
|
||||
|
@ -1694,7 +1694,7 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
moreTasks.push(DataSource.prototype.discoverSchemas.bind(self, otherTables[t].tableName, newOptions));
|
||||
}
|
||||
async.parallel(moreTasks, function(err, results) {
|
||||
var result = results && results[0];
|
||||
const result = results && results[0];
|
||||
cb(err, result);
|
||||
});
|
||||
}
|
||||
|
@ -1715,15 +1715,15 @@ DataSource.prototype.discoverSchemas = function(tableName, options, cb) {
|
|||
* @returns {Array<Object>} An array of schema definition objects.
|
||||
*/
|
||||
DataSource.prototype.discoverSchemasSync = function(modelName, options) {
|
||||
var self = this;
|
||||
var dbType = this.connector.name;
|
||||
const self = this;
|
||||
const dbType = this.connector.name;
|
||||
|
||||
var columns = this.discoverModelPropertiesSync(modelName, options);
|
||||
const columns = this.discoverModelPropertiesSync(modelName, options);
|
||||
if (!columns || columns.length === 0) {
|
||||
return [];
|
||||
}
|
||||
|
||||
var nameMapper = options.nameMapper || function mapName(type, name) {
|
||||
const nameMapper = options.nameMapper || function mapName(type, name) {
|
||||
if (type === 'table' || type === 'model') {
|
||||
return fromDBName(name, false);
|
||||
} else {
|
||||
|
@ -1732,8 +1732,8 @@ DataSource.prototype.discoverSchemasSync = function(modelName, options) {
|
|||
};
|
||||
|
||||
// Handle primary keys
|
||||
var primaryKeys = this.discoverPrimaryKeysSync(modelName, options);
|
||||
var pks = {};
|
||||
const primaryKeys = this.discoverPrimaryKeysSync(modelName, options);
|
||||
const pks = {};
|
||||
primaryKeys.forEach(function(pk) {
|
||||
pks[pk.columnName] = pk.keySeq;
|
||||
});
|
||||
|
@ -1742,7 +1742,7 @@ DataSource.prototype.discoverSchemasSync = function(modelName, options) {
|
|||
debug('Primary keys: ', pks);
|
||||
}
|
||||
|
||||
var schema = {
|
||||
const schema = {
|
||||
name: nameMapper('table', modelName),
|
||||
options: {
|
||||
idInjection: false, // DO NOT add id property
|
||||
|
@ -1756,9 +1756,9 @@ DataSource.prototype.discoverSchemasSync = function(modelName, options) {
|
|||
};
|
||||
|
||||
columns.forEach(function(item) {
|
||||
var i = item;
|
||||
const i = item;
|
||||
|
||||
var propName = nameMapper('column', item.columnName);
|
||||
const propName = nameMapper('column', item.columnName);
|
||||
schema.properties[propName] = {
|
||||
type: item.type,
|
||||
required: (item.nullable === 'N'),
|
||||
|
@ -1782,7 +1782,7 @@ DataSource.prototype.discoverSchemasSync = function(modelName, options) {
|
|||
|
||||
// Add current modelName to the visited tables
|
||||
options.visited = options.visited || {};
|
||||
var schemaKey = columns[0].owner + '.' + modelName;
|
||||
const schemaKey = columns[0].owner + '.' + modelName;
|
||||
if (!options.visited.hasOwnProperty(schemaKey)) {
|
||||
if (self.settings.debug) {
|
||||
debug('Adding schema for ' + schemaKey);
|
||||
|
@ -1790,14 +1790,14 @@ DataSource.prototype.discoverSchemasSync = function(modelName, options) {
|
|||
options.visited[schemaKey] = schema;
|
||||
}
|
||||
|
||||
var otherTables = {};
|
||||
var followingRelations = options.associations || options.relations;
|
||||
const otherTables = {};
|
||||
const followingRelations = options.associations || options.relations;
|
||||
if (followingRelations) {
|
||||
// Handle foreign keys
|
||||
var fks = {};
|
||||
var foreignKeys = this.discoverForeignKeysSync(modelName, options);
|
||||
const fks = {};
|
||||
const foreignKeys = this.discoverForeignKeysSync(modelName, options);
|
||||
foreignKeys.forEach(function(fk) {
|
||||
var fkInfo = {
|
||||
const fkInfo = {
|
||||
keySeq: fk.keySeq,
|
||||
owner: fk.pkOwner,
|
||||
tableName: fk.pkTableName,
|
||||
|
@ -1816,14 +1816,14 @@ DataSource.prototype.discoverSchemasSync = function(modelName, options) {
|
|||
|
||||
schema.options.relations = {};
|
||||
foreignKeys.forEach(function(fk) {
|
||||
var propName = nameMapper('column', fk.pkTableName);
|
||||
const propName = nameMapper('column', fk.pkTableName);
|
||||
schema.options.relations[propName] = {
|
||||
model: nameMapper('table', fk.pkTableName),
|
||||
type: 'belongsTo',
|
||||
foreignKey: nameMapper('column', fk.fkColumnName),
|
||||
};
|
||||
|
||||
var key = fk.pkOwner + '.' + fk.pkTableName;
|
||||
const key = fk.pkOwner + '.' + fk.pkTableName;
|
||||
if (!options.visited.hasOwnProperty(key) && !otherTables.hasOwnProperty(key)) {
|
||||
otherTables[key] = {owner: fk.pkOwner, tableName: fk.pkTableName};
|
||||
}
|
||||
|
@ -1833,13 +1833,13 @@ DataSource.prototype.discoverSchemasSync = function(modelName, options) {
|
|||
if (Object.keys(otherTables).length === 0) {
|
||||
return options.visited;
|
||||
} else {
|
||||
var moreTasks = [];
|
||||
for (var t in otherTables) {
|
||||
const moreTasks = [];
|
||||
for (const t in otherTables) {
|
||||
if (self.settings.debug) {
|
||||
debug('Discovering related schema for ' + schemaKey);
|
||||
}
|
||||
var newOptions = {};
|
||||
for (var key in options) {
|
||||
const newOptions = {};
|
||||
for (const key in options) {
|
||||
newOptions[key] = options[key];
|
||||
}
|
||||
newOptions.owner = otherTables[t].owner;
|
||||
|
@ -1863,7 +1863,7 @@ DataSource.prototype.discoverSchemasSync = function(modelName, options) {
|
|||
* constructors, keyed by model name
|
||||
*/
|
||||
DataSource.prototype.discoverAndBuildModels = function(modelName, options, cb) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
options = options || {};
|
||||
this.discoverSchemas(modelName, options, function(err, schemas) {
|
||||
if (err) {
|
||||
|
@ -1871,9 +1871,9 @@ DataSource.prototype.discoverAndBuildModels = function(modelName, options, cb) {
|
|||
return;
|
||||
}
|
||||
|
||||
var schemaList = [];
|
||||
for (var s in schemas) {
|
||||
var schema = schemas[s];
|
||||
const schemaList = [];
|
||||
for (const s in schemas) {
|
||||
const schema = schemas[s];
|
||||
if (options.base) {
|
||||
schema.options = schema.options || {};
|
||||
schema.options.base = options.base;
|
||||
|
@ -1881,7 +1881,7 @@ DataSource.prototype.discoverAndBuildModels = function(modelName, options, cb) {
|
|||
schemaList.push(schema);
|
||||
}
|
||||
|
||||
var models = self.modelBuilder.buildModels(schemaList,
|
||||
const models = self.modelBuilder.buildModels(schemaList,
|
||||
self.createModel.bind(self));
|
||||
|
||||
cb && cb(err, models);
|
||||
|
@ -1905,11 +1905,11 @@ DataSource.prototype.discoverAndBuildModels = function(modelName, options, cb) {
|
|||
*/
|
||||
DataSource.prototype.discoverAndBuildModelsSync = function(modelName, options) {
|
||||
options = options || {};
|
||||
var schemas = this.discoverSchemasSync(modelName, options);
|
||||
const schemas = this.discoverSchemasSync(modelName, options);
|
||||
|
||||
var schemaList = [];
|
||||
for (var s in schemas) {
|
||||
var schema = schemas[s];
|
||||
const schemaList = [];
|
||||
for (const s in schemas) {
|
||||
const schema = schemas[s];
|
||||
if (options.base) {
|
||||
schema.options = schema.options || {};
|
||||
schema.options.base = options.base;
|
||||
|
@ -1917,7 +1917,7 @@ DataSource.prototype.discoverAndBuildModelsSync = function(modelName, options) {
|
|||
schemaList.push(schema);
|
||||
}
|
||||
|
||||
var models = this.modelBuilder.buildModels(schemaList,
|
||||
const models = this.modelBuilder.buildModels(schemaList,
|
||||
this.createModel.bind(this));
|
||||
|
||||
return models;
|
||||
|
@ -1932,7 +1932,7 @@ DataSource.prototype.discoverAndBuildModelsSync = function(modelName, options) {
|
|||
*/
|
||||
DataSource.prototype.buildModelFromInstance = function(name, json, options) {
|
||||
// Introspect the JSON document to generate a schema
|
||||
var schema = ModelBuilder.introspect(json);
|
||||
const schema = ModelBuilder.introspect(json);
|
||||
|
||||
// Create a model for the generated schema
|
||||
return this.createModel(name, schema, options);
|
||||
|
@ -2063,8 +2063,8 @@ DataSource.prototype.idNames = function(modelName) {
|
|||
* @returns {Object} The id property definition
|
||||
*/
|
||||
DataSource.prototype.idProperty = function(modelName) {
|
||||
var def = this.getModelDefinition(modelName);
|
||||
var idProps = def && def.ids();
|
||||
const def = this.getModelDefinition(modelName);
|
||||
const idProps = def && def.ids();
|
||||
return idProps && idProps[0] && idProps[0].property;
|
||||
};
|
||||
|
||||
|
@ -2076,13 +2076,13 @@ DataSource.prototype.idProperty = function(modelName) {
|
|||
* @param {String} pkName (optional) primary key used for foreignKey
|
||||
*/
|
||||
DataSource.prototype.defineForeignKey = function defineForeignKey(className, key, foreignClassName, pkName) {
|
||||
var pkType = null;
|
||||
var foreignModel = this.getModelDefinition(foreignClassName);
|
||||
let pkType = null;
|
||||
const foreignModel = this.getModelDefinition(foreignClassName);
|
||||
pkName = pkName || foreignModel && foreignModel.idName();
|
||||
if (pkName) {
|
||||
pkType = foreignModel.properties[pkName].type;
|
||||
}
|
||||
var model = this.getModelDefinition(className);
|
||||
const model = this.getModelDefinition(className);
|
||||
if (model.properties[key]) {
|
||||
if (pkType) {
|
||||
// Reset the type of the foreign key
|
||||
|
@ -2091,8 +2091,8 @@ DataSource.prototype.defineForeignKey = function defineForeignKey(className, key
|
|||
return;
|
||||
}
|
||||
|
||||
var fkDef = {type: pkType};
|
||||
var foreignMeta = this.columnMetadata(foreignClassName, pkName);
|
||||
const fkDef = {type: pkType};
|
||||
const foreignMeta = this.columnMetadata(foreignClassName, pkName);
|
||||
if (foreignMeta && (foreignMeta.dataType || foreignMeta.dataLength)) {
|
||||
fkDef[this.connector.name] = {};
|
||||
if (foreignMeta.dataType) {
|
||||
|
@ -2103,7 +2103,7 @@ DataSource.prototype.defineForeignKey = function defineForeignKey(className, key
|
|||
}
|
||||
}
|
||||
if (this.connector.defineForeignKey) {
|
||||
var cb = function(err, keyType) {
|
||||
const cb = function(err, keyType) {
|
||||
if (err) throw err;
|
||||
fkDef.type = keyType || pkType;
|
||||
// Add the foreign key property to the data source _models
|
||||
|
@ -2130,7 +2130,7 @@ DataSource.prototype.defineForeignKey = function defineForeignKey(className, key
|
|||
*/
|
||||
DataSource.prototype.disconnect = function disconnect(cb) {
|
||||
cb = cb || utils.createPromiseCallback();
|
||||
var self = this;
|
||||
const self = this;
|
||||
if (this.connected && (typeof this.connector.disconnect === 'function')) {
|
||||
this.connector.disconnect(function(err, result) {
|
||||
self.connected = false;
|
||||
|
@ -2153,10 +2153,10 @@ DataSource.prototype.disconnect = function disconnect(cb) {
|
|||
* @private
|
||||
*/
|
||||
DataSource.prototype.copyModel = function copyModel(Master) {
|
||||
var dataSource = this;
|
||||
var className = Master.modelName;
|
||||
var md = Master.modelBuilder.getModelDefinition(className);
|
||||
var Slave = function SlaveModel() {
|
||||
const dataSource = this;
|
||||
const className = Master.modelName;
|
||||
const md = Master.modelBuilder.getModelDefinition(className);
|
||||
const Slave = function SlaveModel() {
|
||||
Master.apply(this, [].slice.call(arguments));
|
||||
};
|
||||
|
||||
|
@ -2234,10 +2234,10 @@ DataSource.prototype.transaction = function(execute, options, cb) {
|
|||
options = options || {};
|
||||
}
|
||||
|
||||
var dataSource = this;
|
||||
var transaction = new EventEmitter();
|
||||
const dataSource = this;
|
||||
const transaction = new EventEmitter();
|
||||
|
||||
for (var p in dataSource) {
|
||||
for (const p in dataSource) {
|
||||
transaction[p] = dataSource[p];
|
||||
}
|
||||
|
||||
|
@ -2252,8 +2252,8 @@ DataSource.prototype.transaction = function(execute, options, cb) {
|
|||
};
|
||||
|
||||
// Create a blank pool for the slave models bound to this transaction.
|
||||
var modelBuilder = new ModelBuilder();
|
||||
var slaveModels = modelBuilder.models;
|
||||
const modelBuilder = new ModelBuilder();
|
||||
const slaveModels = modelBuilder.models;
|
||||
transaction.modelBuilder = modelBuilder;
|
||||
transaction.models = slaveModels;
|
||||
transaction.definitions = modelBuilder.definitions;
|
||||
|
@ -2261,7 +2261,7 @@ DataSource.prototype.transaction = function(execute, options, cb) {
|
|||
// For performance reasons, use a getter per model and only call copyModel()
|
||||
// for the models that are actually used. These getters are then replaced
|
||||
// with the actual values on first use.
|
||||
var masterModels = dataSource.modelBuilder.models;
|
||||
const masterModels = dataSource.modelBuilder.models;
|
||||
Object.keys(masterModels).forEach(function(name) {
|
||||
Object.defineProperty(slaveModels, name, {
|
||||
enumerable: true,
|
||||
|
@ -2275,7 +2275,7 @@ DataSource.prototype.transaction = function(execute, options, cb) {
|
|||
});
|
||||
});
|
||||
|
||||
var done = function(err) {
|
||||
let done = function(err) {
|
||||
if (err) {
|
||||
transaction.rollback(function(error) {
|
||||
cb(err || error);
|
||||
|
@ -2292,7 +2292,7 @@ DataSource.prototype.transaction = function(execute, options, cb) {
|
|||
if (execute) {
|
||||
cb = cb || utils.createPromiseCallback();
|
||||
try {
|
||||
var result = execute(slaveModels, done);
|
||||
const result = execute(slaveModels, done);
|
||||
if (result && typeof result.then === 'function') {
|
||||
result.then(function() { done(); }, done);
|
||||
}
|
||||
|
@ -2347,7 +2347,7 @@ DataSource.prototype.transaction = function(execute, options, cb) {
|
|||
return transaction;
|
||||
}
|
||||
|
||||
var connector = dataSource.connector;
|
||||
const connector = dataSource.connector;
|
||||
if (connector.transaction) {
|
||||
// Create a transient or memory source transaction.
|
||||
transaction.connector = connector.transaction();
|
||||
|
@ -2385,7 +2385,7 @@ DataSource.prototype.transaction = function(execute, options, cb) {
|
|||
*/
|
||||
|
||||
DataSource.prototype.enableRemote = function(operation) {
|
||||
var op = this.getOperation(operation);
|
||||
const op = this.getOperation(operation);
|
||||
if (op) {
|
||||
op.remoteEnabled = true;
|
||||
} else {
|
||||
|
@ -2414,7 +2414,7 @@ DataSource.prototype.enableRemote = function(operation) {
|
|||
*/
|
||||
|
||||
DataSource.prototype.disableRemote = function(operation) {
|
||||
var op = this.getOperation(operation);
|
||||
const op = this.getOperation(operation);
|
||||
if (op) {
|
||||
op.remoteEnabled = false;
|
||||
} else {
|
||||
|
@ -2428,11 +2428,11 @@ DataSource.prototype.disableRemote = function(operation) {
|
|||
*/
|
||||
|
||||
DataSource.prototype.getOperation = function(operation) {
|
||||
var ops = this.operations();
|
||||
var opKeys = Object.keys(ops);
|
||||
const ops = this.operations();
|
||||
const opKeys = Object.keys(ops);
|
||||
|
||||
for (var i = 0; i < opKeys.length; i++) {
|
||||
var op = ops[opKeys[i]];
|
||||
for (let i = 0; i < opKeys.length; i++) {
|
||||
const op = ops[opKeys[i]];
|
||||
|
||||
if (op.name === operation) {
|
||||
return op;
|
||||
|
@ -2500,7 +2500,7 @@ DataSource.prototype.isRelational = function() {
|
|||
*/
|
||||
DataSource.prototype.queueInvocation = DataSource.prototype.ready =
|
||||
function(obj, args) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
debug('Datasource %s: connected=%s connecting=%s', this.name,
|
||||
this.connected, this.connecting);
|
||||
if (this.connected) {
|
||||
|
@ -2508,10 +2508,10 @@ function(obj, args) {
|
|||
return false;
|
||||
}
|
||||
|
||||
var method = args.callee;
|
||||
const method = args.callee;
|
||||
// Set up a callback after the connection is established to continue the method call
|
||||
|
||||
var onConnected = null, onError = null, timeoutHandle = null;
|
||||
let onConnected = null, onError = null, timeoutHandle = null;
|
||||
onConnected = function() {
|
||||
debug('Datasource %s is now connected - executing method %s', self.name, method.name);
|
||||
// Remove the error handler
|
||||
|
@ -2519,12 +2519,12 @@ function(obj, args) {
|
|||
if (timeoutHandle) {
|
||||
clearTimeout(timeoutHandle);
|
||||
}
|
||||
var params = [].slice.call(args);
|
||||
const params = [].slice.call(args);
|
||||
try {
|
||||
method.apply(obj, params);
|
||||
} catch (err) {
|
||||
// Catch the exception and report it via callback
|
||||
var cb = params.pop();
|
||||
const cb = params.pop();
|
||||
if (typeof cb === 'function') {
|
||||
process.nextTick(function() {
|
||||
cb(err);
|
||||
|
@ -2541,8 +2541,8 @@ function(obj, args) {
|
|||
if (timeoutHandle) {
|
||||
clearTimeout(timeoutHandle);
|
||||
}
|
||||
var params = [].slice.call(args);
|
||||
var cb = params.pop();
|
||||
const params = [].slice.call(args);
|
||||
const cb = params.pop();
|
||||
if (typeof cb === 'function') {
|
||||
process.nextTick(function() {
|
||||
cb(err);
|
||||
|
@ -2553,15 +2553,15 @@ function(obj, args) {
|
|||
this.once('error', onError);
|
||||
|
||||
// Set up a timeout to cancel the invocation
|
||||
var timeout = this.settings.connectionTimeout || 5000;
|
||||
const timeout = this.settings.connectionTimeout || 5000;
|
||||
timeoutHandle = setTimeout(function() {
|
||||
debug('Datasource %s fails to connect due to timeout - aborting method %s',
|
||||
self.name, method.name);
|
||||
self.connecting = false;
|
||||
self.removeListener('error', onError);
|
||||
self.removeListener('connected', onConnected);
|
||||
var params = [].slice.call(args);
|
||||
var cb = params.pop();
|
||||
const params = [].slice.call(args);
|
||||
const cb = params.pop();
|
||||
if (typeof cb === 'function') {
|
||||
cb(new Error(g.f('Timeout in connecting after %s ms', timeout)));
|
||||
}
|
||||
|
@ -2580,14 +2580,14 @@ function(obj, args) {
|
|||
*/
|
||||
DataSource.prototype.ping = function(cb) {
|
||||
cb = cb || utils.createPromiseCallback();
|
||||
var self = this;
|
||||
const self = this;
|
||||
if (self.connector.ping) {
|
||||
this.connector.ping(cb);
|
||||
} else if (self.connector.discoverModelProperties) {
|
||||
self.discoverModelProperties('dummy', {}, cb);
|
||||
} else {
|
||||
process.nextTick(function() {
|
||||
var err = self.connected ? null : new Error(g.f('Not connected'));
|
||||
const err = self.connected ? null : new Error(g.f('Not connected'));
|
||||
cb(err);
|
||||
});
|
||||
}
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var inspect = require('util').inspect;
|
||||
const inspect = require('util').inspect;
|
||||
|
||||
module.exports = DateString;
|
||||
|
||||
|
@ -60,7 +60,7 @@ function DateString(value) {
|
|||
Object.defineProperty(this, 'when', {
|
||||
get: () => { return this._when; },
|
||||
set: (val) => {
|
||||
var d = new Date(val);
|
||||
const d = new Date(val);
|
||||
if (isNaN(d.getTime())) {
|
||||
throw new Error('Invalid date');
|
||||
} else {
|
||||
|
|
60
lib/geo.js
60
lib/geo.js
|
@ -5,13 +5,17 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
const assert = require('assert');
|
||||
|
||||
/*!
|
||||
* Get a near filter from a given where object. For connector use only.
|
||||
*/
|
||||
|
||||
exports.nearFilter = function nearFilter(where) {
|
||||
const nearResults = [];
|
||||
nearSearch(where);
|
||||
return (!nearResults.length ? false : nearResults);
|
||||
|
||||
function nearSearch(clause, parentKeys) {
|
||||
if (typeof clause !== 'object') {
|
||||
return false;
|
||||
|
@ -22,12 +26,12 @@ exports.nearFilter = function nearFilter(where) {
|
|||
if (typeof clause[clauseKey] !== 'object' || !clause[clauseKey]) return;
|
||||
if (Array.isArray(clause[clauseKey])) {
|
||||
clause[clauseKey].forEach(function(el, index) {
|
||||
var ret = nearSearch(el, parentKeys.concat(clauseKey).concat(index));
|
||||
const ret = nearSearch(el, parentKeys.concat(clauseKey).concat(index));
|
||||
if (ret) return ret;
|
||||
});
|
||||
} else {
|
||||
if (clause[clauseKey].hasOwnProperty('near')) {
|
||||
var result = clause[clauseKey];
|
||||
const result = clause[clauseKey];
|
||||
nearResults.push({
|
||||
near: result.near,
|
||||
maxDistance: result.maxDistance,
|
||||
|
@ -41,10 +45,6 @@ exports.nearFilter = function nearFilter(where) {
|
|||
}
|
||||
});
|
||||
}
|
||||
var nearResults = [];
|
||||
nearSearch(where);
|
||||
|
||||
return (!nearResults.length ? false : nearResults);
|
||||
};
|
||||
|
||||
/*!
|
||||
|
@ -68,19 +68,19 @@ exports.nearFilter = function nearFilter(where) {
|
|||
*/
|
||||
|
||||
exports.filter = function(rawResults, filters) {
|
||||
var distances = {};
|
||||
var results = [];
|
||||
const distances = {};
|
||||
const results = [];
|
||||
|
||||
filters.forEach(function(filter) {
|
||||
var origin = filter.near;
|
||||
var max = filter.maxDistance > 0 ? filter.maxDistance : false;
|
||||
var min = filter.minDistance > 0 ? filter.minDistance : false;
|
||||
var unit = filter.unit;
|
||||
var key = filter.key;
|
||||
const origin = filter.near;
|
||||
const max = filter.maxDistance > 0 ? filter.maxDistance : false;
|
||||
const min = filter.minDistance > 0 ? filter.minDistance : false;
|
||||
const unit = filter.unit;
|
||||
const key = filter.key;
|
||||
|
||||
// create distance index
|
||||
rawResults.forEach(function(result) {
|
||||
var loc = result[key];
|
||||
let loc = result[key];
|
||||
|
||||
// filter out results without locations
|
||||
if (!loc) return;
|
||||
|
@ -90,7 +90,7 @@ exports.filter = function(rawResults, filters) {
|
|||
if (typeof loc.lat !== 'number') return;
|
||||
if (typeof loc.lng !== 'number') return;
|
||||
|
||||
var d = GeoPoint.distanceBetween(origin, loc, {type: unit});
|
||||
const d = GeoPoint.distanceBetween(origin, loc, {type: unit});
|
||||
|
||||
// filter result if distance is either < minDistance or > maxDistance
|
||||
if ((min && d < min) || (max && d > max)) return;
|
||||
|
@ -100,12 +100,12 @@ exports.filter = function(rawResults, filters) {
|
|||
});
|
||||
|
||||
results.sort(function(resA, resB) {
|
||||
var a = resA[key];
|
||||
var b = resB[key];
|
||||
const a = resA[key];
|
||||
const b = resB[key];
|
||||
|
||||
if (a && b) {
|
||||
var da = distances[resA.id];
|
||||
var db = distances[resB.id];
|
||||
const da = distances[resA.id];
|
||||
const db = distances[resB.id];
|
||||
|
||||
if (db === da) return 0;
|
||||
return da > db ? 1 : -1;
|
||||
|
@ -231,11 +231,11 @@ GeoPoint.distanceBetween = function distanceBetween(a, b, options) {
|
|||
b = GeoPoint(b);
|
||||
}
|
||||
|
||||
var x1 = a.lat;
|
||||
var y1 = a.lng;
|
||||
const x1 = a.lat;
|
||||
const y1 = a.lng;
|
||||
|
||||
var x2 = b.lat;
|
||||
var y2 = b.lng;
|
||||
const x2 = b.lat;
|
||||
const y2 = b.lng;
|
||||
|
||||
return geoDistance(x1, y1, x2, y2, options);
|
||||
};
|
||||
|
@ -283,13 +283,13 @@ GeoPoint.prototype.toString = function() {
|
|||
*/
|
||||
|
||||
// factor to convert degrees to radians
|
||||
var DEG2RAD = 0.01745329252;
|
||||
const DEG2RAD = 0.01745329252;
|
||||
|
||||
// factor to convert radians degrees to degrees
|
||||
var RAD2DEG = 57.29577951308;
|
||||
const RAD2DEG = 57.29577951308;
|
||||
|
||||
// radius of the earth
|
||||
var EARTH_RADIUS = {
|
||||
const EARTH_RADIUS = {
|
||||
kilometers: 6370.99056,
|
||||
meters: 6370990.56,
|
||||
miles: 3958.75,
|
||||
|
@ -299,7 +299,7 @@ var EARTH_RADIUS = {
|
|||
};
|
||||
|
||||
function geoDistance(x1, y1, x2, y2, options) {
|
||||
var type = (options && options.type) || 'miles';
|
||||
const type = (options && options.type) || 'miles';
|
||||
|
||||
// Convert to radians
|
||||
x1 = x1 * DEG2RAD;
|
||||
|
@ -309,11 +309,11 @@ function geoDistance(x1, y1, x2, y2, options) {
|
|||
|
||||
// use the haversine formula to calculate distance for any 2 points on a sphere.
|
||||
// ref http://en.wikipedia.org/wiki/Haversine_formula
|
||||
var haversine = function(a) {
|
||||
const haversine = function(a) {
|
||||
return Math.pow(Math.sin(a / 2.0), 2);
|
||||
};
|
||||
|
||||
var f = Math.sqrt(haversine(x2 - x1) + Math.cos(x2) * Math.cos(x1) * haversine(y2 - y1));
|
||||
const f = Math.sqrt(haversine(x2 - x1) + Math.cos(x2) * Math.cos(x1) * haversine(y2 - y1));
|
||||
|
||||
return 2 * Math.asin(f) * EARTH_RADIUS[type];
|
||||
}
|
||||
|
|
16
lib/hooks.js
16
lib/hooks.js
|
@ -5,8 +5,8 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var deprecated = require('depd')('loopback-datasource-juggler');
|
||||
var g = require('strong-globalize')();
|
||||
const deprecated = require('depd')('loopback-datasource-juggler');
|
||||
const g = require('strong-globalize')();
|
||||
|
||||
/*!
|
||||
* Module exports
|
||||
|
@ -48,16 +48,16 @@ Hookable.afterDestroy = null;
|
|||
* @param {Function} callback
|
||||
*/
|
||||
Hookable.prototype.trigger = function trigger(actionName, work, data, callback) {
|
||||
var capitalizedName = capitalize(actionName);
|
||||
var beforeHook = this.constructor['before' + capitalizedName] ||
|
||||
const capitalizedName = capitalize(actionName);
|
||||
let beforeHook = this.constructor['before' + capitalizedName] ||
|
||||
this.constructor['pre' + capitalizedName];
|
||||
var afterHook = this.constructor['after' + capitalizedName] ||
|
||||
let afterHook = this.constructor['after' + capitalizedName] ||
|
||||
this.constructor['post' + capitalizedName];
|
||||
if (actionName === 'validate') {
|
||||
beforeHook = beforeHook || this.constructor.beforeValidation;
|
||||
afterHook = afterHook || this.constructor.afterValidation;
|
||||
}
|
||||
var inst = this;
|
||||
const inst = this;
|
||||
|
||||
if (actionName !== 'initialize') {
|
||||
if (beforeHook)
|
||||
|
@ -100,11 +100,11 @@ function capitalize(string) {
|
|||
}
|
||||
|
||||
function deprecateHook(ctor, prefixes, capitalizedName) {
|
||||
var candidateNames = prefixes.map(function(p) { return p + capitalizedName; });
|
||||
const candidateNames = prefixes.map(function(p) { return p + capitalizedName; });
|
||||
if (capitalizedName === 'Validate')
|
||||
candidateNames.push(prefixes[0] + 'Validation');
|
||||
|
||||
var hookName = candidateNames.filter(function(hook) { return !!ctor[hook]; })[0];
|
||||
let hookName = candidateNames.filter(function(hook) { return !!ctor[hook]; })[0];
|
||||
if (!hookName) return; // just to be sure, this should never happen
|
||||
if (ctor.modelName) hookName = ctor.modelName + '.' + hookName;
|
||||
deprecated(g.f('Model hook "%s" is deprecated, ' +
|
||||
|
|
244
lib/include.js
244
lib/include.js
|
@ -5,16 +5,16 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var async = require('async');
|
||||
var g = require('strong-globalize')();
|
||||
var utils = require('./utils');
|
||||
var List = require('./list');
|
||||
var includeUtils = require('./include_utils');
|
||||
var isPlainObject = utils.isPlainObject;
|
||||
var defineCachedRelations = utils.defineCachedRelations;
|
||||
var uniq = utils.uniq;
|
||||
var idName = utils.idName;
|
||||
var debug = require('debug')('loopback:include');
|
||||
const async = require('async');
|
||||
const g = require('strong-globalize')();
|
||||
const utils = require('./utils');
|
||||
const List = require('./list');
|
||||
const includeUtils = require('./include_utils');
|
||||
const isPlainObject = utils.isPlainObject;
|
||||
const defineCachedRelations = utils.defineCachedRelations;
|
||||
const uniq = utils.uniq;
|
||||
const idName = utils.idName;
|
||||
const debug = require('debug')('loopback:include');
|
||||
|
||||
/*!
|
||||
* Normalize the include to be an array
|
||||
|
@ -22,19 +22,19 @@ var debug = require('debug')('loopback:include');
|
|||
* @returns {*}
|
||||
*/
|
||||
function normalizeInclude(include) {
|
||||
var newInclude;
|
||||
let newInclude;
|
||||
if (typeof include === 'string') {
|
||||
return [include];
|
||||
} else if (isPlainObject(include)) {
|
||||
// Build an array of key/value pairs
|
||||
newInclude = [];
|
||||
var rel = include.rel || include.relation;
|
||||
var obj = {};
|
||||
const rel = include.rel || include.relation;
|
||||
const obj = {};
|
||||
if (typeof rel === 'string') {
|
||||
obj[rel] = new IncludeScope(include.scope);
|
||||
newInclude.push(obj);
|
||||
} else {
|
||||
for (var key in include) {
|
||||
for (const key in include) {
|
||||
obj[key] = include[key];
|
||||
newInclude.push(obj);
|
||||
}
|
||||
|
@ -42,8 +42,8 @@ function normalizeInclude(include) {
|
|||
return newInclude;
|
||||
} else if (Array.isArray(include)) {
|
||||
newInclude = [];
|
||||
for (var i = 0, n = include.length; i < n; i++) {
|
||||
var subIncludes = normalizeInclude(include[i]);
|
||||
for (let i = 0, n = include.length; i < n; i++) {
|
||||
const subIncludes = normalizeInclude(include[i]);
|
||||
newInclude = newInclude.concat(subIncludes);
|
||||
}
|
||||
return newInclude;
|
||||
|
@ -80,8 +80,8 @@ function lookupModel(models, modelName) {
|
|||
if (models[modelName]) {
|
||||
return models[modelName];
|
||||
}
|
||||
var lookupClassName = modelName.toLowerCase();
|
||||
for (var name in models) {
|
||||
const lookupClassName = modelName.toLowerCase();
|
||||
for (const name in models) {
|
||||
if (name.toLowerCase() === lookupClassName) {
|
||||
return models[name];
|
||||
}
|
||||
|
@ -161,7 +161,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
cb = options;
|
||||
options = {};
|
||||
}
|
||||
var self = this;
|
||||
const self = this;
|
||||
|
||||
if (!include || (Array.isArray(include) && include.length === 0) ||
|
||||
(Array.isArray(objects) && objects.length === 0) ||
|
||||
|
@ -176,7 +176,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
debug('include: %j', include);
|
||||
|
||||
// Find the limit of items for `inq`
|
||||
var inqLimit = 256;
|
||||
let inqLimit = 256;
|
||||
if (self.dataSource && self.dataSource.settings &&
|
||||
self.dataSource.settings.inqLimit) {
|
||||
inqLimit = self.dataSource.settings.inqLimit;
|
||||
|
@ -212,13 +212,13 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
return cb(e);
|
||||
}
|
||||
|
||||
var foreignKeys = [];
|
||||
let foreignKeys = [];
|
||||
if (filter.where[fkName]) {
|
||||
foreignKeys = filter.where[fkName].inq;
|
||||
} else if (filter.where.and) {
|
||||
// The inq can be embedded inside 'and: []'. No or: [] is needed as
|
||||
// include only uses and. We only deal with the generated inq for include.
|
||||
for (var j in filter.where.and) {
|
||||
for (const j in filter.where.and) {
|
||||
if (filter.where.and[j][fkName] &&
|
||||
Array.isArray(filter.where.and[j][fkName].inq)) {
|
||||
foreignKeys = filter.where.and[j][fkName].inq;
|
||||
|
@ -233,7 +233,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
// Force the find to be performed per FK to honor the pagination
|
||||
pageSize = 1;
|
||||
}
|
||||
var size = foreignKeys.length;
|
||||
const size = foreignKeys.length;
|
||||
if (size > inqLimit && pageSize <= 0) {
|
||||
pageSize = inqLimit;
|
||||
}
|
||||
|
@ -241,29 +241,29 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
return model.find(filter, options, cb);
|
||||
}
|
||||
|
||||
var listOfFKs = [];
|
||||
let listOfFKs = [];
|
||||
|
||||
for (var i = 0; i < size; i += pageSize) {
|
||||
var end = i + pageSize;
|
||||
for (let i = 0; i < size; i += pageSize) {
|
||||
let end = i + pageSize;
|
||||
if (end > size) {
|
||||
end = size;
|
||||
}
|
||||
listOfFKs.push(foreignKeys.slice(i, end));
|
||||
}
|
||||
|
||||
var items = [];
|
||||
let items = [];
|
||||
// Optimization: no need to resolve keys that are an empty array
|
||||
listOfFKs = listOfFKs.filter(function(keys) {
|
||||
return keys.length > 0;
|
||||
});
|
||||
async.each(listOfFKs, function(foreignKeys, done) {
|
||||
var newFilter = {};
|
||||
for (var f in filter) {
|
||||
const newFilter = {};
|
||||
for (const f in filter) {
|
||||
newFilter[f] = filter[f];
|
||||
}
|
||||
if (filter.where) {
|
||||
newFilter.where = {};
|
||||
for (var w in filter.where) {
|
||||
for (const w in filter.where) {
|
||||
newFilter.where[w] = filter.where[w];
|
||||
}
|
||||
}
|
||||
|
@ -282,10 +282,10 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
}
|
||||
|
||||
function processIncludeItem(objs, include, options, cb) {
|
||||
var relations = self.relations;
|
||||
const relations = self.relations;
|
||||
|
||||
var relationName;
|
||||
var subInclude = null, scope = null;
|
||||
let relationName;
|
||||
let subInclude = null, scope = null;
|
||||
|
||||
if (isPlainObject(include)) {
|
||||
relationName = Object.keys(include)[0];
|
||||
|
@ -304,13 +304,13 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
subInclude = null;
|
||||
}
|
||||
|
||||
var relation = relations[relationName];
|
||||
const relation = relations[relationName];
|
||||
if (!relation) {
|
||||
cb(new Error(g.f('Relation "%s" is not defined for %s model', relationName, self.modelName)));
|
||||
return;
|
||||
}
|
||||
debug('Relation: %j', relation);
|
||||
var polymorphic = relation.polymorphic;
|
||||
const polymorphic = relation.polymorphic;
|
||||
// if (polymorphic && !polymorphic.discriminator) {
|
||||
// cb(new Error('Relation "' + relationName + '" is polymorphic but ' +
|
||||
// 'discriminator is not present'));
|
||||
|
@ -330,15 +330,15 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
return cb();
|
||||
}
|
||||
// prepare filter and fields for making DB Call
|
||||
var filter = (scope && scope.conditions()) || {};
|
||||
const filter = (scope && scope.conditions()) || {};
|
||||
if ((relation.multiple || relation.type === 'belongsTo') && scope) {
|
||||
var includeScope = {};
|
||||
const includeScope = {};
|
||||
// make sure not to miss any fields for sub includes
|
||||
if (filter.fields && Array.isArray(subInclude) &&
|
||||
relation.modelTo.relations) {
|
||||
includeScope.fields = [];
|
||||
subInclude.forEach(function(name) {
|
||||
var rel = relation.modelTo.relations[name];
|
||||
const rel = relation.modelTo.relations[name];
|
||||
if (rel && rel.type === 'belongsTo') {
|
||||
includeScope.fields.push(rel.keyFrom);
|
||||
}
|
||||
|
@ -349,7 +349,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
// Let's add a placeholder where query
|
||||
filter.where = filter.where || {};
|
||||
// if fields are specified, make sure target foreign key is present
|
||||
var fields = filter.fields;
|
||||
let fields = filter.fields;
|
||||
if (typeof fields === 'string') {
|
||||
// transform string into array containing this string
|
||||
filter.fields = fields = [fields];
|
||||
|
@ -405,14 +405,14 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
* @param callback
|
||||
*/
|
||||
function includeHasManyThrough(callback) {
|
||||
var sourceIds = [];
|
||||
const sourceIds = [];
|
||||
// Map for Indexing objects by their id for faster retrieval
|
||||
var objIdMap = {};
|
||||
for (var i = 0; i < objs.length; i++) {
|
||||
var obj = objs[i];
|
||||
const objIdMap = {};
|
||||
for (let i = 0; i < objs.length; i++) {
|
||||
const obj = objs[i];
|
||||
// one-to-many: foreign key reference is modelTo -> modelFrom.
|
||||
// use modelFrom.keyFrom in where filter later
|
||||
var sourceId = obj[relation.keyFrom];
|
||||
const sourceId = obj[relation.keyFrom];
|
||||
if (sourceId) {
|
||||
sourceIds.push(sourceId);
|
||||
objIdMap[sourceId.toString()] = obj;
|
||||
|
@ -423,7 +423,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
}
|
||||
// default filters are not applicable on through model. should be applied
|
||||
// on modelTo later in 2nd DB call.
|
||||
var throughFilter = {
|
||||
const throughFilter = {
|
||||
where: {},
|
||||
};
|
||||
throughFilter.where[relation.keyTo] = {
|
||||
|
@ -451,25 +451,25 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
return callback(err);
|
||||
}
|
||||
// start preparing for 2nd DB call.
|
||||
var targetIds = [];
|
||||
var targetObjsMap = {};
|
||||
for (var i = 0; i < throughObjs.length; i++) {
|
||||
var throughObj = throughObjs[i];
|
||||
var targetId = throughObj[relation.keyThrough];
|
||||
const targetIds = [];
|
||||
const targetObjsMap = {};
|
||||
for (let i = 0; i < throughObjs.length; i++) {
|
||||
const throughObj = throughObjs[i];
|
||||
const targetId = throughObj[relation.keyThrough];
|
||||
if (targetId) {
|
||||
// save targetIds for 2nd DB Call
|
||||
targetIds.push(targetId);
|
||||
var sourceObj = objIdMap[throughObj[relation.keyTo]];
|
||||
var targetIdStr = targetId.toString();
|
||||
const sourceObj = objIdMap[throughObj[relation.keyTo]];
|
||||
const targetIdStr = targetId.toString();
|
||||
// Since targetId can be duplicates, multiple source objs are put
|
||||
// into buckets.
|
||||
var objList = targetObjsMap[targetIdStr] =
|
||||
const objList = targetObjsMap[targetIdStr] =
|
||||
targetObjsMap[targetIdStr] || [];
|
||||
objList.push(sourceObj);
|
||||
}
|
||||
}
|
||||
// Polymorphic relation does not have idKey of modelTo. Find it manually
|
||||
var modelToIdName = idName(relation.modelTo);
|
||||
const modelToIdName = idName(relation.modelTo);
|
||||
filter.where[modelToIdName] = {
|
||||
inq: uniq(targetIds),
|
||||
};
|
||||
|
@ -490,7 +490,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
var tasks = [];
|
||||
const tasks = [];
|
||||
// simultaneously process subIncludes. Call it first as it is an async
|
||||
// process.
|
||||
if (subInclude && targets) {
|
||||
|
@ -503,13 +503,15 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
function targetLinkingTask(next) {
|
||||
async.each(targets, linkManyToMany, next);
|
||||
function linkManyToMany(target, next) {
|
||||
var targetId = target[modelToIdName];
|
||||
const targetId = target[modelToIdName];
|
||||
if (!targetId) {
|
||||
var err = new Error(g.f('LinkManyToMany received target that doesn\'t contain required "%s"',
|
||||
modelToIdName));
|
||||
const err = new Error(g.f(
|
||||
'LinkManyToMany received target that doesn\'t contain required "%s"',
|
||||
modelToIdName
|
||||
));
|
||||
return next(err);
|
||||
}
|
||||
var objList = targetObjsMap[targetId.toString()];
|
||||
const objList = targetObjsMap[targetId.toString()];
|
||||
async.each(objList, function(obj, next) {
|
||||
if (!obj) return next();
|
||||
obj.__cachedRelations[relationName].push(target);
|
||||
|
@ -528,15 +530,15 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
* @param callback
|
||||
*/
|
||||
function includeReferencesMany(callback) {
|
||||
var modelToIdName = idName(relation.modelTo);
|
||||
var allTargetIds = [];
|
||||
const modelToIdName = idName(relation.modelTo);
|
||||
let allTargetIds = [];
|
||||
// Map for Indexing objects by their id for faster retrieval
|
||||
var targetObjsMap = {};
|
||||
for (var i = 0; i < objs.length; i++) {
|
||||
var obj = objs[i];
|
||||
const targetObjsMap = {};
|
||||
for (let i = 0; i < objs.length; i++) {
|
||||
const obj = objs[i];
|
||||
// one-to-many: foreign key reference is modelTo -> modelFrom.
|
||||
// use modelFrom.keyFrom in where filter later
|
||||
var targetIds = obj[relation.keyFrom];
|
||||
let targetIds = obj[relation.keyFrom];
|
||||
if (targetIds) {
|
||||
if (typeof targetIds === 'string') {
|
||||
// For relational DBs, the array is stored as stringified json
|
||||
|
@ -546,10 +548,10 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
// referencesMany has multiple targetIds per obj. We need to concat
|
||||
// them into allTargetIds before DB Call
|
||||
allTargetIds = allTargetIds.concat(targetIds);
|
||||
for (var j = 0; j < targetIds.length; j++) {
|
||||
var targetId = targetIds[j];
|
||||
var targetIdStr = targetId.toString();
|
||||
var objList = targetObjsMap[targetIdStr] =
|
||||
for (let j = 0; j < targetIds.length; j++) {
|
||||
const targetId = targetIds[j];
|
||||
const targetIdStr = targetId.toString();
|
||||
const objList = targetObjsMap[targetIdStr] =
|
||||
targetObjsMap[targetIdStr] || [];
|
||||
objList.push(obj);
|
||||
}
|
||||
|
@ -577,7 +579,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
var tasks = [];
|
||||
const tasks = [];
|
||||
// simultaneously process subIncludes
|
||||
if (subInclude && targets) {
|
||||
tasks.push(function subIncludesTask(next) {
|
||||
|
@ -590,7 +592,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
function targetLinkingTask(next) {
|
||||
async.each(targets, linkManyToMany, next);
|
||||
function linkManyToMany(target, next) {
|
||||
var objList = targetObjsMap[target[relation.keyTo].toString()];
|
||||
const objList = targetObjsMap[target[relation.keyTo].toString()];
|
||||
async.each(objList, function(obj, next) {
|
||||
if (!obj) return next();
|
||||
obj.__cachedRelations[relationName].push(target);
|
||||
|
@ -609,7 +611,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
*/
|
||||
function includeHasManySimple(callback) {
|
||||
// Map for Indexing objects by their id for faster retrieval
|
||||
var objIdMap2 = includeUtils.buildOneToOneIdentityMapWithOrigKeys(objs, relation.keyFrom);
|
||||
const objIdMap2 = includeUtils.buildOneToOneIdentityMapWithOrigKeys(objs, relation.keyFrom);
|
||||
|
||||
filter.where[relation.keyTo] = {
|
||||
inq: uniq(objIdMap2.getKeys()),
|
||||
|
@ -624,7 +626,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
var targetsIdMap = includeUtils.buildOneToManyIdentityMapWithOrigKeys(targets, relation.keyTo);
|
||||
const targetsIdMap = includeUtils.buildOneToManyIdentityMapWithOrigKeys(targets, relation.keyTo);
|
||||
includeUtils.join(objIdMap2, targetsIdMap, function(obj1, valueToMergeIn) {
|
||||
defineCachedRelations(obj1);
|
||||
obj1.__cachedRelations[relationName] = valueToMergeIn;
|
||||
|
@ -639,14 +641,14 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
* @param callback
|
||||
*/
|
||||
function includeHasMany(callback) {
|
||||
var sourceIds = [];
|
||||
const sourceIds = [];
|
||||
// Map for Indexing objects by their id for faster retrieval
|
||||
var objIdMap = {};
|
||||
for (var i = 0; i < objs.length; i++) {
|
||||
var obj = objs[i];
|
||||
const objIdMap = {};
|
||||
for (let i = 0; i < objs.length; i++) {
|
||||
const obj = objs[i];
|
||||
// one-to-many: foreign key reference is modelTo -> modelFrom.
|
||||
// use modelFrom.keyFrom in where filter later
|
||||
var sourceId = obj[relation.keyFrom];
|
||||
const sourceId = obj[relation.keyFrom];
|
||||
if (sourceId) {
|
||||
sourceIds.push(sourceId);
|
||||
objIdMap[sourceId.toString()] = obj;
|
||||
|
@ -674,7 +676,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
var tasks = [];
|
||||
const tasks = [];
|
||||
// simultaneously process subIncludes
|
||||
if (subInclude && targets) {
|
||||
tasks.push(function subIncludesTask(next) {
|
||||
|
@ -693,9 +695,9 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
async.each(targets, linkManyToOne, next);
|
||||
function linkManyToOne(target, next) {
|
||||
// fix for bug in hasMany with referencesMany
|
||||
var targetIds = [].concat(target[relation.keyTo]);
|
||||
const targetIds = [].concat(target[relation.keyTo]);
|
||||
async.each(targetIds, function(targetId, next) {
|
||||
var obj = objIdMap[targetId.toString()];
|
||||
const obj = objIdMap[targetId.toString()];
|
||||
if (!obj) return next();
|
||||
obj.__cachedRelations[relationName].push(target);
|
||||
processTargetObj(obj, next);
|
||||
|
@ -704,7 +706,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
return next(err);
|
||||
}
|
||||
|
||||
var objsWithEmptyRelation = objs.filter(function(obj) {
|
||||
const objsWithEmptyRelation = objs.filter(function(obj) {
|
||||
return obj.__cachedRelations[relationName].length === 0;
|
||||
});
|
||||
async.each(objsWithEmptyRelation, function(obj, next) {
|
||||
|
@ -725,22 +727,22 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
* @param callback
|
||||
*/
|
||||
function includePolymorphicBelongsTo(callback) {
|
||||
var targetIdsByType = {};
|
||||
const targetIdsByType = {};
|
||||
// Map for Indexing objects by their type and targetId for faster retrieval
|
||||
var targetObjMapByType = {};
|
||||
for (var i = 0; i < objs.length; i++) {
|
||||
var obj = objs[i];
|
||||
var discriminator = polymorphic.discriminator;
|
||||
var modelType = obj[discriminator];
|
||||
const targetObjMapByType = {};
|
||||
for (let i = 0; i < objs.length; i++) {
|
||||
const obj = objs[i];
|
||||
const discriminator = polymorphic.discriminator;
|
||||
const modelType = obj[discriminator];
|
||||
if (modelType) {
|
||||
targetIdsByType[modelType] = targetIdsByType[modelType] || [];
|
||||
targetObjMapByType[modelType] = targetObjMapByType[modelType] || {};
|
||||
var targetIds = targetIdsByType[modelType];
|
||||
var targetObjsMap = targetObjMapByType[modelType];
|
||||
var targetId = obj[relation.keyFrom];
|
||||
const targetIds = targetIdsByType[modelType];
|
||||
const targetObjsMap = targetObjMapByType[modelType];
|
||||
const targetId = obj[relation.keyFrom];
|
||||
if (targetId) {
|
||||
targetIds.push(targetId);
|
||||
var targetIdStr = targetId.toString();
|
||||
const targetIdStr = targetId.toString();
|
||||
targetObjsMap[targetIdStr] = targetObjsMap[targetIdStr] || [];
|
||||
// Is belongsTo. Multiple objects can have the same
|
||||
// targetId and therefore map value is an array
|
||||
|
@ -758,13 +760,13 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
* @param callback
|
||||
*/
|
||||
function processPolymorphicType(modelType, callback) {
|
||||
var typeFilter = {where: {}};
|
||||
const typeFilter = {where: {}};
|
||||
utils.mergeQuery(typeFilter, filter);
|
||||
var targetIds = targetIdsByType[modelType];
|
||||
const targetIds = targetIdsByType[modelType];
|
||||
typeFilter.where[relation.keyTo] = {
|
||||
inq: uniq(targetIds),
|
||||
};
|
||||
var Model = lookupModel(relation.modelFrom.dataSource.modelBuilder.
|
||||
const Model = lookupModel(relation.modelFrom.dataSource.modelBuilder.
|
||||
models, modelType);
|
||||
if (!Model) {
|
||||
callback(new Error(g.f('Discriminator type %s specified but no model exists with such name',
|
||||
|
@ -786,7 +788,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
var tasks = [];
|
||||
const tasks = [];
|
||||
|
||||
// simultaneously process subIncludes
|
||||
if (subInclude && targets) {
|
||||
|
@ -797,10 +799,10 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
// process each target object
|
||||
tasks.push(targetLinkingTask);
|
||||
function targetLinkingTask(next) {
|
||||
var targetObjsMap = targetObjMapByType[modelType];
|
||||
const targetObjsMap = targetObjMapByType[modelType];
|
||||
async.each(targets, linkOneToMany, next);
|
||||
function linkOneToMany(target, next) {
|
||||
var objList = targetObjsMap[target[relation.keyTo].toString()];
|
||||
const objList = targetObjsMap[target[relation.keyTo].toString()];
|
||||
async.each(objList, function(obj, next) {
|
||||
if (!obj) return next();
|
||||
obj.__cachedRelations[relationName] = target;
|
||||
|
@ -819,14 +821,14 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
* @param callback
|
||||
*/
|
||||
function includePolymorphicHasOne(callback) {
|
||||
var sourceIds = [];
|
||||
const sourceIds = [];
|
||||
// Map for Indexing objects by their id for faster retrieval
|
||||
var objIdMap = {};
|
||||
for (var i = 0; i < objs.length; i++) {
|
||||
var obj = objs[i];
|
||||
const objIdMap = {};
|
||||
for (let i = 0; i < objs.length; i++) {
|
||||
const obj = objs[i];
|
||||
// one-to-one: foreign key reference is modelTo -> modelFrom.
|
||||
// use modelFrom.keyFrom in where filter later
|
||||
var sourceId = obj[relation.keyFrom];
|
||||
const sourceId = obj[relation.keyFrom];
|
||||
if (sourceId) {
|
||||
sourceIds.push(sourceId);
|
||||
objIdMap[sourceId.toString()] = obj;
|
||||
|
@ -853,7 +855,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
var tasks = [];
|
||||
const tasks = [];
|
||||
// simultaneously process subIncludes
|
||||
if (subInclude && targets) {
|
||||
tasks.push(function subIncludesTask(next) {
|
||||
|
@ -865,9 +867,9 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
function targetLinkingTask(next) {
|
||||
async.each(targets, linkOneToOne, next);
|
||||
function linkOneToOne(target, next) {
|
||||
var sourceId = target[relation.keyTo];
|
||||
const sourceId = target[relation.keyTo];
|
||||
if (!sourceId) return next();
|
||||
var obj = objIdMap[sourceId.toString()];
|
||||
const obj = objIdMap[sourceId.toString()];
|
||||
if (!obj) return next();
|
||||
obj.__cachedRelations[relationName] = target;
|
||||
processTargetObj(obj, next);
|
||||
|
@ -883,10 +885,10 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
* @param callback
|
||||
*/
|
||||
function includeOneToOne(callback) {
|
||||
var targetIds = [];
|
||||
var objTargetIdMap = {};
|
||||
for (var i = 0; i < objs.length; i++) {
|
||||
var obj = objs[i];
|
||||
const targetIds = [];
|
||||
const objTargetIdMap = {};
|
||||
for (let i = 0; i < objs.length; i++) {
|
||||
const obj = objs[i];
|
||||
if (relation.type === 'belongsTo') {
|
||||
if (obj[relation.keyFrom] == null) {
|
||||
defineCachedRelations(obj);
|
||||
|
@ -895,10 +897,10 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
continue;
|
||||
}
|
||||
}
|
||||
var targetId = obj[relation.keyFrom];
|
||||
const targetId = obj[relation.keyFrom];
|
||||
if (targetId) {
|
||||
targetIds.push(targetId);
|
||||
var targetIdStr = targetId.toString();
|
||||
const targetIdStr = targetId.toString();
|
||||
objTargetIdMap[targetIdStr] = objTargetIdMap[targetIdStr] || [];
|
||||
objTargetIdMap[targetIdStr].push(obj);
|
||||
} else {
|
||||
|
@ -925,7 +927,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
var tasks = [];
|
||||
const tasks = [];
|
||||
// simultaneously process subIncludes
|
||||
if (subInclude && targets) {
|
||||
tasks.push(function subIncludesTask(next) {
|
||||
|
@ -937,8 +939,8 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
function targetLinkingTask(next) {
|
||||
async.each(targets, linkOneToMany, next);
|
||||
function linkOneToMany(target, next) {
|
||||
var targetId = target[relation.keyTo];
|
||||
var objList = objTargetIdMap[targetId.toString()];
|
||||
const targetId = target[relation.keyTo];
|
||||
const objList = objTargetIdMap[targetId.toString()];
|
||||
async.each(objList, function(obj, next) {
|
||||
if (!obj) return next();
|
||||
obj.__cachedRelations[relationName] = target;
|
||||
|
@ -973,7 +975,7 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
* @returns {*}
|
||||
*/
|
||||
function processTargetObj(obj, callback) {
|
||||
var isInst = obj instanceof self;
|
||||
const isInst = obj instanceof self;
|
||||
|
||||
// Calling the relation method on the instance
|
||||
if (relation.type === 'belongsTo') {
|
||||
|
@ -1015,21 +1017,21 @@ Inclusion.include = function(objects, include, options, cb) {
|
|||
callback);
|
||||
}
|
||||
|
||||
var inst = (obj instanceof self) ? obj : new self(obj);
|
||||
const inst = (obj instanceof self) ? obj : new self(obj);
|
||||
|
||||
// If related objects are not cached by include Handlers, directly call
|
||||
// related accessor function even though it is not very efficient
|
||||
var related; // relation accessor function
|
||||
let related; // relation accessor function
|
||||
|
||||
if ((relation.multiple || relation.type === 'belongsTo') && scope) {
|
||||
var includeScope = {};
|
||||
var filter = scope.conditions();
|
||||
const includeScope = {};
|
||||
const filter = scope.conditions();
|
||||
|
||||
// make sure not to miss any fields for sub includes
|
||||
if (filter.fields && Array.isArray(subInclude) && relation.modelTo.relations) {
|
||||
includeScope.fields = [];
|
||||
subInclude.forEach(function(name) {
|
||||
var rel = relation.modelTo.relations[name];
|
||||
const rel = relation.modelTo.relations[name];
|
||||
if (rel && rel.type === 'belongsTo') {
|
||||
includeScope.fields.push(rel.keyFrom);
|
||||
}
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var g = require('strong-globalize')();
|
||||
const g = require('strong-globalize')();
|
||||
|
||||
module.exports.buildOneToOneIdentityMapWithOrigKeys = buildOneToOneIdentityMapWithOrigKeys;
|
||||
module.exports.buildOneToManyIdentityMapWithOrigKeys = buildOneToManyIdentityMapWithOrigKeys;
|
||||
|
@ -15,7 +15,7 @@ module.exports.KVMap = KVMap;
|
|||
const util = require('util');
|
||||
|
||||
function getId(obj, idName) {
|
||||
var id = obj && obj[idName];
|
||||
const id = obj && obj[idName];
|
||||
if (id == null) {
|
||||
const msg = g.f('ID property "%s" is missing for included item: %j. ' +
|
||||
'Please make sure `fields` include "%s" if it\'s present in the `filter`',
|
||||
|
@ -35,21 +35,21 @@ function getId(obj, idName) {
|
|||
* @returns {} object where keys are ids and values are objects itself
|
||||
*/
|
||||
function buildOneToOneIdentityMapWithOrigKeys(objs, idName) {
|
||||
var kvMap = new KVMap();
|
||||
for (var i = 0; i < objs.length; i++) {
|
||||
var obj = objs[i];
|
||||
var id = getId(obj, idName);
|
||||
const kvMap = new KVMap();
|
||||
for (let i = 0; i < objs.length; i++) {
|
||||
const obj = objs[i];
|
||||
const id = getId(obj, idName);
|
||||
kvMap.set(id, obj);
|
||||
}
|
||||
return kvMap;
|
||||
}
|
||||
|
||||
function buildOneToManyIdentityMapWithOrigKeys(objs, idName) {
|
||||
var kvMap = new KVMap();
|
||||
for (var i = 0; i < objs.length; i++) {
|
||||
var obj = objs[i];
|
||||
var id = getId(obj, idName);
|
||||
var value = kvMap.get(id) || [];
|
||||
const kvMap = new KVMap();
|
||||
for (let i = 0; i < objs.length; i++) {
|
||||
const obj = objs[i];
|
||||
const id = getId(obj, idName);
|
||||
const value = kvMap.get(id) || [];
|
||||
value.push(obj);
|
||||
kvMap.set(id, value);
|
||||
}
|
||||
|
@ -64,11 +64,11 @@ function buildOneToManyIdentityMapWithOrigKeys(objs, idName) {
|
|||
* @param mergeF function(obj, objectsToMergeIn)
|
||||
*/
|
||||
function join(oneToOneIdMap, oneToManyIdMap, mergeF) {
|
||||
var ids = oneToOneIdMap.getKeys();
|
||||
for (var i = 0; i < ids.length; i++) {
|
||||
var id = ids[i];
|
||||
var obj = oneToOneIdMap.get(id);
|
||||
var objectsToMergeIn = oneToManyIdMap.get(id) || [];
|
||||
const ids = oneToOneIdMap.getKeys();
|
||||
for (let i = 0; i < ids.length; i++) {
|
||||
const id = ids[i];
|
||||
const obj = oneToOneIdMap.get(id);
|
||||
const objectsToMergeIn = oneToManyIdMap.get(id) || [];
|
||||
mergeF(obj, objectsToMergeIn);
|
||||
}
|
||||
}
|
||||
|
@ -79,20 +79,20 @@ function join(oneToOneIdMap, oneToManyIdMap, mergeF) {
|
|||
* @constructor
|
||||
*/
|
||||
function KVMap() {
|
||||
var _originalKeyFieldName = 'originalKey';
|
||||
var _valueKeyFieldName = 'value';
|
||||
var _dict = {};
|
||||
var keyToString = function(key) { return key.toString(); };
|
||||
var mapImpl = {
|
||||
const _originalKeyFieldName = 'originalKey';
|
||||
const _valueKeyFieldName = 'value';
|
||||
const _dict = {};
|
||||
const keyToString = function(key) { return key.toString(); };
|
||||
const mapImpl = {
|
||||
set: function(key, value) {
|
||||
var recordObj = {};
|
||||
const recordObj = {};
|
||||
recordObj[_originalKeyFieldName] = key;
|
||||
recordObj[_valueKeyFieldName] = value;
|
||||
_dict[keyToString(key)] = recordObj;
|
||||
return true;
|
||||
},
|
||||
get: function(key) {
|
||||
var storeObj = _dict[keyToString(key)];
|
||||
const storeObj = _dict[keyToString(key)];
|
||||
if (storeObj) {
|
||||
return storeObj[_valueKeyFieldName];
|
||||
} else {
|
||||
|
@ -104,12 +104,12 @@ function KVMap() {
|
|||
return true;
|
||||
},
|
||||
exist: function(key) {
|
||||
var result = _dict.hasOwnProperty(keyToString(key));
|
||||
const result = _dict.hasOwnProperty(keyToString(key));
|
||||
return result;
|
||||
},
|
||||
getKeys: function() {
|
||||
var result = [];
|
||||
for (var key in _dict) {
|
||||
const result = [];
|
||||
for (const key in _dict) {
|
||||
result.push(_dict[key][_originalKeyFieldName]);
|
||||
}
|
||||
return result;
|
||||
|
|
|
@ -13,14 +13,14 @@ module.exports = function getIntrospector(ModelBuilder) {
|
|||
}
|
||||
|
||||
// Check registered schemaTypes
|
||||
for (var t in ModelBuilder.schemaTypes) {
|
||||
var st = ModelBuilder.schemaTypes[t];
|
||||
for (const t in ModelBuilder.schemaTypes) {
|
||||
const st = ModelBuilder.schemaTypes[t];
|
||||
if (st !== Object && st !== Array && (value instanceof st)) {
|
||||
return t;
|
||||
}
|
||||
}
|
||||
|
||||
var type = typeof value;
|
||||
const type = typeof value;
|
||||
if (type === 'string' || type === 'number' || type === 'boolean') {
|
||||
return type;
|
||||
}
|
||||
|
@ -29,9 +29,9 @@ module.exports = function getIntrospector(ModelBuilder) {
|
|||
return 'date';
|
||||
}
|
||||
|
||||
var itemType;
|
||||
let itemType;
|
||||
if (Array.isArray(value)) {
|
||||
for (var i = 0; i < value.length; i++) {
|
||||
for (let i = 0; i < value.length; i++) {
|
||||
if (value[i] === null || value[i] === undefined) {
|
||||
continue;
|
||||
}
|
||||
|
@ -47,8 +47,8 @@ module.exports = function getIntrospector(ModelBuilder) {
|
|||
return value.constructor.name;
|
||||
}
|
||||
|
||||
var properties = {};
|
||||
for (var p in value) {
|
||||
const properties = {};
|
||||
for (const p in value) {
|
||||
itemType = introspectType(value[p]);
|
||||
if (itemType) {
|
||||
properties[p] = itemType;
|
||||
|
|
22
lib/jutil.js
22
lib/jutil.js
|
@ -5,7 +5,7 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var util = require('util');
|
||||
const util = require('util');
|
||||
|
||||
/**
|
||||
*
|
||||
|
@ -24,7 +24,7 @@ exports.inherits = function(newClass, baseClass, options) {
|
|||
Object.keys(baseClass).forEach(function(classProp) {
|
||||
if (classProp !== 'super_' && (!newClass.hasOwnProperty(classProp) ||
|
||||
options.override)) {
|
||||
var pd = Object.getOwnPropertyDescriptor(baseClass, classProp);
|
||||
const pd = Object.getOwnPropertyDescriptor(baseClass, classProp);
|
||||
Object.defineProperty(newClass, classProp, pd);
|
||||
}
|
||||
});
|
||||
|
@ -75,13 +75,13 @@ exports.mixin = function(newClass, mixinClass, options) {
|
|||
|
||||
function mixInto(sourceScope, targetScope, options) {
|
||||
Object.keys(sourceScope).forEach(function(propertyName) {
|
||||
var targetPropertyExists = targetScope.hasOwnProperty(propertyName);
|
||||
var sourceProperty = Object.getOwnPropertyDescriptor(sourceScope, propertyName);
|
||||
var targetProperty = targetPropertyExists && Object.getOwnPropertyDescriptor(targetScope, propertyName);
|
||||
var sourceIsFunc = typeof sourceProperty.value === 'function';
|
||||
var isFunc = targetPropertyExists && typeof targetProperty.value === 'function';
|
||||
var isDelegate = isFunc && targetProperty.value._delegate;
|
||||
var shouldOverride = options.override || !targetPropertyExists || isDelegate;
|
||||
const targetPropertyExists = targetScope.hasOwnProperty(propertyName);
|
||||
const sourceProperty = Object.getOwnPropertyDescriptor(sourceScope, propertyName);
|
||||
const targetProperty = targetPropertyExists && Object.getOwnPropertyDescriptor(targetScope, propertyName);
|
||||
const sourceIsFunc = typeof sourceProperty.value === 'function';
|
||||
const isFunc = targetPropertyExists && typeof targetProperty.value === 'function';
|
||||
const isDelegate = isFunc && targetProperty.value._delegate;
|
||||
const shouldOverride = options.override || !targetPropertyExists || isDelegate;
|
||||
|
||||
if (propertyName == '_mixins') {
|
||||
mergeMixins(sourceScope._mixins, targetScope._mixins);
|
||||
|
@ -96,8 +96,8 @@ function mixInto(sourceScope, targetScope, options) {
|
|||
|
||||
function mergeMixins(source, target) {
|
||||
// hand-written equivalent of lodash.union()
|
||||
for (var ix in source) {
|
||||
var mx = source[ix];
|
||||
for (const ix in source) {
|
||||
const mx = source[ix];
|
||||
if (target.indexOf(mx) === -1)
|
||||
target.push(mx);
|
||||
}
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
var async = require('async');
|
||||
var debug = require('debug')('loopback:kvao:delete-all');
|
||||
var utils = require('../utils');
|
||||
const assert = require('assert');
|
||||
const async = require('async');
|
||||
const debug = require('debug')('loopback:kvao:delete-all');
|
||||
const utils = require('../utils');
|
||||
|
||||
/**
|
||||
* Delete all keys (and values) associated to the current model.
|
||||
|
@ -27,17 +27,17 @@ module.exports = function deleteAll(options, callback) {
|
|||
|
||||
callback = callback || utils.createPromiseCallback();
|
||||
|
||||
var connector = this.getConnector();
|
||||
const connector = this.getConnector();
|
||||
if (typeof connector.deleteAll === 'function') {
|
||||
connector.deleteAll(this.modelName, options, callback);
|
||||
} else if (typeof connector.delete === 'function') {
|
||||
debug('Falling back to unoptimized key-value pair deletion');
|
||||
iterateAndDelete(connector, this.modelName, options, callback);
|
||||
} else {
|
||||
var errMsg = 'Connector does not support key-value pair deletion';
|
||||
const errMsg = 'Connector does not support key-value pair deletion';
|
||||
debug(errMsg);
|
||||
process.nextTick(function() {
|
||||
var err = new Error(errMsg);
|
||||
const err = new Error(errMsg);
|
||||
err.statusCode = 501;
|
||||
callback(err);
|
||||
});
|
||||
|
@ -46,8 +46,8 @@ module.exports = function deleteAll(options, callback) {
|
|||
};
|
||||
|
||||
function iterateAndDelete(connector, modelName, options, callback) {
|
||||
var iter = connector.iterateKeys(modelName, {});
|
||||
var keys = [];
|
||||
const iter = connector.iterateKeys(modelName, {});
|
||||
const keys = [];
|
||||
iter.next(onNextKey);
|
||||
|
||||
function onNextKey(err, key) {
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
var debug = require('debug')('loopback:kvao:delete');
|
||||
var utils = require('../utils');
|
||||
const assert = require('assert');
|
||||
const debug = require('debug')('loopback:kvao:delete');
|
||||
const utils = require('../utils');
|
||||
|
||||
/**
|
||||
* Delete the key-value pair associated to the given key.
|
||||
|
@ -28,14 +28,14 @@ module.exports = function keyValueDelete(key, options, callback) {
|
|||
|
||||
callback = callback || utils.createPromiseCallback();
|
||||
|
||||
var connector = this.getConnector();
|
||||
const connector = this.getConnector();
|
||||
if (typeof connector.delete === 'function') {
|
||||
connector.delete(this.modelName, key, options, callback);
|
||||
} else {
|
||||
var errMsg = 'Connector does not support key-value pair deletion';
|
||||
const errMsg = 'Connector does not support key-value pair deletion';
|
||||
debug(errMsg);
|
||||
process.nextTick(function() {
|
||||
var err = new Error(errMsg);
|
||||
const err = new Error(errMsg);
|
||||
err.statusCode = 501;
|
||||
callback(err);
|
||||
});
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
var utils = require('../utils');
|
||||
const assert = require('assert');
|
||||
const utils = require('../utils');
|
||||
|
||||
/**
|
||||
* Set the TTL (time to live) in ms (milliseconds) for a given key. TTL is the
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
var utils = require('../utils');
|
||||
const assert = require('assert');
|
||||
const utils = require('../utils');
|
||||
|
||||
/**
|
||||
* Return the value associated with a given key.
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
var utils = require('../utils');
|
||||
const assert = require('assert');
|
||||
const utils = require('../utils');
|
||||
|
||||
/**
|
||||
* Asynchronously iterate all keys in the database. Similar to `.keys()` but
|
||||
|
@ -26,7 +26,7 @@ module.exports = function keyValueIterateKeys(filter, options) {
|
|||
assert(typeof filter === 'object', 'filter must be an object');
|
||||
assert(typeof options === 'object', 'options must be an object');
|
||||
|
||||
var iter = this.getConnector().iterateKeys(this.modelName, filter, options);
|
||||
const iter = this.getConnector().iterateKeys(this.modelName, filter, options);
|
||||
// promisify the returned iterator
|
||||
return {
|
||||
next: function(callback) {
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
var utils = require('../utils');
|
||||
const assert = require('assert');
|
||||
const utils = require('../utils');
|
||||
|
||||
/**
|
||||
* Return all keys in the database.
|
||||
|
@ -41,8 +41,8 @@ module.exports = function keyValueKeys(filter, options, callback) {
|
|||
|
||||
callback = callback || utils.createPromiseCallback();
|
||||
|
||||
var iter = this.iterateKeys(filter, options);
|
||||
var keys = [];
|
||||
const iter = this.iterateKeys(filter, options);
|
||||
const keys = [];
|
||||
iter.next(onNextKey);
|
||||
|
||||
function onNextKey(err, key) {
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
var utils = require('../utils');
|
||||
const assert = require('assert');
|
||||
const utils = require('../utils');
|
||||
|
||||
/**
|
||||
* Persist a value and associate it with the given key.
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
var utils = require('../utils');
|
||||
const assert = require('assert');
|
||||
const utils = require('../utils');
|
||||
|
||||
/**
|
||||
* Return the TTL (time to live) for a given key. TTL is the remaining time
|
||||
|
|
18
lib/list.js
18
lib/list.js
|
@ -5,14 +5,14 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var g = require('strong-globalize')();
|
||||
var util = require('util');
|
||||
var Any = require('./types').Types.Any;
|
||||
const g = require('strong-globalize')();
|
||||
const util = require('util');
|
||||
const Any = require('./types').Types.Any;
|
||||
|
||||
module.exports = List;
|
||||
|
||||
function List(items, itemType, parent) {
|
||||
var list = this;
|
||||
const list = this;
|
||||
if (!(list instanceof List)) {
|
||||
return new List(items, itemType, parent);
|
||||
}
|
||||
|
@ -27,7 +27,7 @@ function List(items, itemType, parent) {
|
|||
}
|
||||
}
|
||||
|
||||
var arr = [];
|
||||
const arr = [];
|
||||
arr.__proto__ = List.prototype;
|
||||
|
||||
items = items || [];
|
||||
|
@ -80,16 +80,16 @@ function List(items, itemType, parent) {
|
|||
|
||||
util.inherits(List, Array);
|
||||
|
||||
var _push = List.prototype.push;
|
||||
const _push = List.prototype.push;
|
||||
|
||||
List.prototype.push = function(obj) {
|
||||
var item = this.itemType && (obj instanceof this.itemType) ? obj : this.toItem(obj);
|
||||
const item = this.itemType && (obj instanceof this.itemType) ? obj : this.toItem(obj);
|
||||
_push.call(this, item);
|
||||
return item;
|
||||
};
|
||||
|
||||
List.prototype.toObject = function(onlySchema, removeHidden, removeProtected) {
|
||||
var items = [];
|
||||
const items = [];
|
||||
this.forEach(function(item) {
|
||||
if (item && typeof item === 'object' && item.toObject) {
|
||||
items.push(item.toObject(onlySchema, removeHidden, removeProtected));
|
||||
|
@ -106,7 +106,7 @@ List.prototype.toObject = function(onlySchema, removeHidden, removeProtected) {
|
|||
* Some modules such as `should` checks prototype for comparison
|
||||
*/
|
||||
List.prototype.toArray = function() {
|
||||
var items = [];
|
||||
const items = [];
|
||||
this.forEach(function(item) {
|
||||
items.push(item);
|
||||
});
|
||||
|
|
|
@ -4,9 +4,9 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var debug = require('debug')('loopback:mixin');
|
||||
var assert = require('assert');
|
||||
var DefaultModelBaseClass = require('./model.js');
|
||||
const debug = require('debug')('loopback:mixin');
|
||||
const assert = require('assert');
|
||||
const DefaultModelBaseClass = require('./model.js');
|
||||
|
||||
function isModelClass(cls) {
|
||||
if (!cls) {
|
||||
|
@ -29,7 +29,7 @@ function MixinProvider(modelBuilder) {
|
|||
* @param {Object} options
|
||||
*/
|
||||
MixinProvider.prototype.applyMixin = function applyMixin(modelClass, name, options) {
|
||||
var fn = this.mixins[name];
|
||||
const fn = this.mixins[name];
|
||||
if (typeof fn === 'function') {
|
||||
if (modelClass.dataSource) {
|
||||
fn(modelClass, options || {});
|
||||
|
@ -40,12 +40,12 @@ MixinProvider.prototype.applyMixin = function applyMixin(modelClass, name, optio
|
|||
}
|
||||
} else {
|
||||
// Try model name
|
||||
var model = this.modelBuilder.getModel(name);
|
||||
const model = this.modelBuilder.getModel(name);
|
||||
if (model) {
|
||||
debug('Mixin is resolved to a model: %s', name);
|
||||
modelClass.mixin(model, options);
|
||||
} else {
|
||||
var errMsg = 'Model "' + modelClass.modelName + '" uses unknown mixin: ' + name;
|
||||
const errMsg = 'Model "' + modelClass.modelName + '" uses unknown mixin: ' + name;
|
||||
debug(errMsg);
|
||||
throw new Error(errMsg);
|
||||
}
|
||||
|
|
|
@ -8,24 +8,24 @@
|
|||
* Module dependencies
|
||||
*/
|
||||
|
||||
var g = require('strong-globalize')();
|
||||
var inflection = require('inflection');
|
||||
var EventEmitter = require('events').EventEmitter;
|
||||
var util = require('util');
|
||||
var assert = require('assert');
|
||||
var deprecated = require('depd')('loopback-datasource-juggler');
|
||||
var DefaultModelBaseClass = require('./model.js');
|
||||
var List = require('./list.js');
|
||||
var ModelDefinition = require('./model-definition.js');
|
||||
var deepMerge = require('./utils').deepMerge;
|
||||
var deepMergeProperty = require('./utils').deepMergeProperty;
|
||||
var rankArrayElements = require('./utils').rankArrayElements;
|
||||
var MixinProvider = require('./mixins');
|
||||
const g = require('strong-globalize')();
|
||||
const inflection = require('inflection');
|
||||
const EventEmitter = require('events').EventEmitter;
|
||||
const util = require('util');
|
||||
const assert = require('assert');
|
||||
const deprecated = require('depd')('loopback-datasource-juggler');
|
||||
const DefaultModelBaseClass = require('./model.js');
|
||||
const List = require('./list.js');
|
||||
const ModelDefinition = require('./model-definition.js');
|
||||
const deepMerge = require('./utils').deepMerge;
|
||||
const deepMergeProperty = require('./utils').deepMergeProperty;
|
||||
const rankArrayElements = require('./utils').rankArrayElements;
|
||||
const MixinProvider = require('./mixins');
|
||||
|
||||
// Set up types
|
||||
require('./types')(ModelBuilder);
|
||||
|
||||
var introspect = require('./introspection')(ModelBuilder);
|
||||
const introspect = require('./introspection')(ModelBuilder);
|
||||
|
||||
/*!
|
||||
* Export public API
|
||||
|
@ -35,7 +35,7 @@ exports.ModelBuilder = exports.Schema = ModelBuilder;
|
|||
/*!
|
||||
* Helpers
|
||||
*/
|
||||
var slice = Array.prototype.slice;
|
||||
const slice = Array.prototype.slice;
|
||||
|
||||
/**
|
||||
* ModelBuilder - A builder to define data models.
|
||||
|
@ -74,7 +74,7 @@ function isModelClass(cls) {
|
|||
* @returns {ModelClass} The model class
|
||||
*/
|
||||
ModelBuilder.prototype.getModel = function(name, forceCreate) {
|
||||
var model = this.models[name];
|
||||
let model = this.models[name];
|
||||
if (!model && forceCreate) {
|
||||
model = this.define(name, {}, {unresolved: true});
|
||||
}
|
||||
|
@ -120,13 +120,13 @@ ModelBuilder.prototype.getModelDefinition = function(name) {
|
|||
*
|
||||
*/
|
||||
ModelBuilder.prototype.define = function defineClass(className, properties, settings, parent) {
|
||||
var modelBuilder = this;
|
||||
var args = slice.call(arguments);
|
||||
var pluralName = (settings && settings.plural) ||
|
||||
const modelBuilder = this;
|
||||
const args = slice.call(arguments);
|
||||
const pluralName = (settings && settings.plural) ||
|
||||
inflection.pluralize(className);
|
||||
|
||||
var httpOptions = (settings && settings.http) || {};
|
||||
var pathName = httpOptions.path || pluralName;
|
||||
const httpOptions = (settings && settings.http) || {};
|
||||
let pathName = httpOptions.path || pluralName;
|
||||
|
||||
if (!className) {
|
||||
throw new Error(g.f('Class name required'));
|
||||
|
@ -149,8 +149,8 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
}
|
||||
|
||||
// Set up the base model class
|
||||
var ModelBaseClass = parent || this.defaultModelBaseClass;
|
||||
var baseClass = settings.base || settings['super'];
|
||||
let ModelBaseClass = parent || this.defaultModelBaseClass;
|
||||
const baseClass = settings.base || settings['super'];
|
||||
if (baseClass) {
|
||||
// Normalize base model property
|
||||
settings.base = baseClass;
|
||||
|
@ -180,7 +180,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
}
|
||||
|
||||
// Check if there is a unresolved model with the same name
|
||||
var ModelClass = this.models[className];
|
||||
let ModelClass = this.models[className];
|
||||
|
||||
// Create the ModelClass if it doesn't exist or it's resolved (override)
|
||||
// TODO: [rfeng] We need to decide what names to use for built-in models such as User.
|
||||
|
@ -188,11 +188,11 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
ModelClass = createModelClassCtor(className, ModelBaseClass);
|
||||
|
||||
// mix in EventEmitter (don't inherit from)
|
||||
var events = new EventEmitter();
|
||||
const events = new EventEmitter();
|
||||
// The model can have more than 10 listeners for lazy relationship setup
|
||||
// See https://github.com/strongloop/loopback/issues/404
|
||||
events.setMaxListeners(32);
|
||||
for (var f in EventEmitter.prototype) {
|
||||
for (const f in EventEmitter.prototype) {
|
||||
if (typeof EventEmitter.prototype[f] === 'function') {
|
||||
ModelClass[f] = EventEmitter.prototype[f].bind(events);
|
||||
}
|
||||
|
@ -229,7 +229,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
hiddenProperty(ModelClass, '_warned', {});
|
||||
|
||||
// inherit ModelBaseClass static methods
|
||||
for (var i in ModelBaseClass) {
|
||||
for (const i in ModelBaseClass) {
|
||||
// We need to skip properties that are already in the subclass, for example, the event emitter methods
|
||||
if (i !== '_mixins' && !(i in ModelClass)) {
|
||||
ModelClass[i] = ModelBaseClass[i];
|
||||
|
@ -239,7 +239,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
// Load and inject the model classes
|
||||
if (settings.models) {
|
||||
Object.keys(settings.models).forEach(function(m) {
|
||||
var model = settings.models[m];
|
||||
const model = settings.models[m];
|
||||
ModelClass[m] = typeof model === 'string' ? modelBuilder.getModel(model, true) : model;
|
||||
});
|
||||
}
|
||||
|
@ -247,7 +247,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
ModelClass.getter = {};
|
||||
ModelClass.setter = {};
|
||||
|
||||
for (var p in properties) {
|
||||
for (const p in properties) {
|
||||
// e.g excludePropertyList = ['id'] - base properties listed in excludePropertyList will be excluded from the model.
|
||||
// excludeBaseProperties is introduced in SOAP model generation only for now and below logic
|
||||
// handles excludeBaseProperties. Generated SOAP model has base as 'Model' which means 'id' property gets added
|
||||
|
@ -256,7 +256,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
// work either for SOAP generator case since generators use ModelDefinition.create to create property in the model
|
||||
// dynamically, that execution path has strict validation where doesn't accept 'id: false' in a property.
|
||||
// See https://github.com/strongloop/loopback-workspace/issues/486 for some more details.
|
||||
var excludePropertyList = settings['excludeBaseProperties'];
|
||||
const excludePropertyList = settings['excludeBaseProperties'];
|
||||
// Remove properties that reverted by the subclass of the property from excludePropertyList
|
||||
if (properties[p] === null || properties[p] === false ||
|
||||
(excludePropertyList != null && excludePropertyList.indexOf(p) != -1)) {
|
||||
|
@ -276,7 +276,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
}
|
||||
}
|
||||
|
||||
var modelDefinition = new ModelDefinition(this, className, properties, settings);
|
||||
const modelDefinition = new ModelDefinition(this, className, properties, settings);
|
||||
|
||||
this.definitions[className] = modelDefinition;
|
||||
|
||||
|
@ -285,13 +285,13 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
// keep a pointer to settings as models can use it for configuration
|
||||
ModelClass.settings = modelDefinition.settings;
|
||||
|
||||
var idInjection = settings.idInjection;
|
||||
let idInjection = settings.idInjection;
|
||||
if (idInjection !== false) {
|
||||
// Default to true if undefined
|
||||
idInjection = true;
|
||||
}
|
||||
|
||||
var idNames = modelDefinition.idNames();
|
||||
let idNames = modelDefinition.idNames();
|
||||
if (idNames.length > 0) {
|
||||
// id already exists
|
||||
idInjection = false;
|
||||
|
@ -306,11 +306,11 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
idNames = modelDefinition.idNames(); // Reload it after rebuild
|
||||
// Create a virtual property 'id'
|
||||
if (idNames.length === 1) {
|
||||
var idProp = idNames[0];
|
||||
const idProp = idNames[0];
|
||||
if (idProp !== 'id') {
|
||||
Object.defineProperty(ModelClass.prototype, 'id', {
|
||||
get: function() {
|
||||
var idProp = ModelClass.definition.idNames()[0];
|
||||
const idProp = ModelClass.definition.idNames()[0];
|
||||
return this.__data[idProp];
|
||||
},
|
||||
configurable: true,
|
||||
|
@ -321,9 +321,9 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
// Now the id property is an object that consists of multiple keys
|
||||
Object.defineProperty(ModelClass.prototype, 'id', {
|
||||
get: function() {
|
||||
var compositeId = {};
|
||||
var idNames = ModelClass.definition.idNames();
|
||||
for (var i = 0, p; i < idNames.length; i++) {
|
||||
const compositeId = {};
|
||||
const idNames = ModelClass.definition.idNames();
|
||||
for (let i = 0, p; i < idNames.length; i++) {
|
||||
p = idNames[i];
|
||||
compositeId[p] = this.__data[p];
|
||||
}
|
||||
|
@ -336,10 +336,10 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
|
||||
// updateOnly property is added to indicate that this property will appear in
|
||||
// the model for update/updateorcreate operations but and not for create operation.
|
||||
var forceId = ModelClass.settings.forceId;
|
||||
let forceId = ModelClass.settings.forceId;
|
||||
if (idNames.length > 0) {
|
||||
var idName = modelDefinition.idName();
|
||||
idProp = ModelClass.definition.rawProperties[idName];
|
||||
const idName = modelDefinition.idName();
|
||||
const idProp = ModelClass.definition.rawProperties[idName];
|
||||
if (idProp.generated && forceId !== false) {
|
||||
forceId = 'auto';
|
||||
} else if (!idProp.generated && forceId === 'auto') {
|
||||
|
@ -362,9 +362,9 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
|
||||
// A function to loop through the properties
|
||||
ModelClass.forEachProperty = function(cb) {
|
||||
var props = ModelClass.definition.properties;
|
||||
var keys = Object.keys(props);
|
||||
for (var i = 0, n = keys.length; i < n; i++) {
|
||||
const props = ModelClass.definition.properties;
|
||||
const keys = Object.keys(props);
|
||||
for (let i = 0, n = keys.length; i < n; i++) {
|
||||
cb(keys[i], props[keys[i]]);
|
||||
}
|
||||
};
|
||||
|
@ -396,15 +396,15 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
* merged with base model settings.
|
||||
*/
|
||||
ModelClass.extend = function(className, subClassProperties, subClassSettings) {
|
||||
var baseClassProperties = ModelClass.definition.properties;
|
||||
var baseClassSettings = ModelClass.definition.settings;
|
||||
const baseClassProperties = ModelClass.definition.properties;
|
||||
const baseClassSettings = ModelClass.definition.settings;
|
||||
|
||||
subClassProperties = subClassProperties || {};
|
||||
subClassSettings = subClassSettings || {};
|
||||
|
||||
// Check if subclass redefines the ids
|
||||
var idFound = false;
|
||||
for (var k in subClassProperties) {
|
||||
let idFound = false;
|
||||
for (const k in subClassProperties) {
|
||||
if (subClassProperties[k] && subClassProperties[k].id) {
|
||||
idFound = true;
|
||||
break;
|
||||
|
@ -412,17 +412,17 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
}
|
||||
|
||||
// Merging the properties
|
||||
var keys = Object.keys(baseClassProperties);
|
||||
for (var i = 0, n = keys.length; i < n; i++) {
|
||||
var key = keys[i];
|
||||
const keys = Object.keys(baseClassProperties);
|
||||
for (let i = 0, n = keys.length; i < n; i++) {
|
||||
const key = keys[i];
|
||||
|
||||
if (idFound && baseClassProperties[key].id) {
|
||||
// don't inherit id properties
|
||||
continue;
|
||||
}
|
||||
if (subClassProperties[key] === undefined) {
|
||||
var baseProp = baseClassProperties[key];
|
||||
var basePropCopy = baseProp;
|
||||
const baseProp = baseClassProperties[key];
|
||||
let basePropCopy = baseProp;
|
||||
if (baseProp && typeof baseProp === 'object') {
|
||||
// Deep clone the base properties
|
||||
basePropCopy = deepMerge(baseProp);
|
||||
|
@ -432,8 +432,8 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
}
|
||||
|
||||
// Merging the settings
|
||||
var originalSubclassSettings = subClassSettings;
|
||||
let mergePolicy = ModelClass.getMergePolicy(subClassSettings);
|
||||
const originalSubclassSettings = subClassSettings;
|
||||
const mergePolicy = ModelClass.getMergePolicy(subClassSettings);
|
||||
subClassSettings = mergeSettings(baseClassSettings, subClassSettings, mergePolicy);
|
||||
|
||||
// Ensure 'base' is not inherited. Note we don't have to delete 'super'
|
||||
|
@ -444,7 +444,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
}
|
||||
|
||||
// Define the subclass
|
||||
var subClass = modelBuilder.define(className, subClassProperties, subClassSettings, ModelClass);
|
||||
const subClass = modelBuilder.define(className, subClassProperties, subClassSettings, ModelClass);
|
||||
|
||||
// Calling the setup function
|
||||
if (typeof subClass.setup === 'function') {
|
||||
|
@ -492,7 +492,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
*/
|
||||
function mergeSettings(baseClassSettings, subClassSettings, mergePolicy) {
|
||||
// deep clone base class settings
|
||||
let mergedSettings = deepMerge(baseClassSettings);
|
||||
const mergedSettings = deepMerge(baseClassSettings);
|
||||
|
||||
Object.keys(baseClassSettings).forEach(function(key) {
|
||||
// rank base class settings arrays elements where required
|
||||
|
@ -545,15 +545,15 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
* @param {String} propertyName Name of the property.
|
||||
*/
|
||||
ModelClass.registerProperty = function(propertyName) {
|
||||
var properties = modelDefinition.build();
|
||||
var prop = properties[propertyName];
|
||||
var DataType = prop.type;
|
||||
const properties = modelDefinition.build();
|
||||
const prop = properties[propertyName];
|
||||
const DataType = prop.type;
|
||||
if (!DataType) {
|
||||
throw new Error(g.f('Invalid type for property %s', propertyName));
|
||||
}
|
||||
|
||||
if (prop.required) {
|
||||
var requiredOptions = typeof prop.required === 'object' ? prop.required : undefined;
|
||||
const requiredOptions = typeof prop.required === 'object' ? prop.required : undefined;
|
||||
ModelClass.validatesPresenceOf(propertyName, requiredOptions);
|
||||
}
|
||||
if (DataType === Date) ModelClass.validatesDateOf(propertyName);
|
||||
|
@ -567,7 +567,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
}
|
||||
},
|
||||
set: function(value) {
|
||||
var DataType = ModelClass.definition.properties[propertyName].type;
|
||||
let DataType = ModelClass.definition.properties[propertyName].type;
|
||||
if (Array.isArray(DataType) || DataType === Array) {
|
||||
DataType = List;
|
||||
} else if (DataType === Date) {
|
||||
|
@ -578,7 +578,7 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
DataType = modelBuilder.resolveType(DataType);
|
||||
}
|
||||
|
||||
var persistUndefinedAsNull = ModelClass.definition.settings.persistUndefinedAsNull;
|
||||
const persistUndefinedAsNull = ModelClass.definition.settings.persistUndefinedAsNull;
|
||||
if (value === undefined && persistUndefinedAsNull) {
|
||||
value = null;
|
||||
}
|
||||
|
@ -621,20 +621,20 @@ ModelBuilder.prototype.define = function defineClass(className, properties, sett
|
|||
});
|
||||
};
|
||||
|
||||
var props = ModelClass.definition.properties;
|
||||
var keys = Object.keys(props);
|
||||
var size = keys.length;
|
||||
for (i = 0; i < size; i++) {
|
||||
var propertyName = keys[i];
|
||||
const props = ModelClass.definition.properties;
|
||||
let keys = Object.keys(props);
|
||||
let size = keys.length;
|
||||
for (let i = 0; i < size; i++) {
|
||||
const propertyName = keys[i];
|
||||
ModelClass.registerProperty(propertyName);
|
||||
}
|
||||
|
||||
var mixinSettings = settings.mixins || {};
|
||||
const mixinSettings = settings.mixins || {};
|
||||
keys = Object.keys(mixinSettings);
|
||||
size = keys.length;
|
||||
for (i = 0; i < size; i++) {
|
||||
var name = keys[i];
|
||||
var mixin = mixinSettings[name];
|
||||
for (let i = 0; i < size; i++) {
|
||||
const name = keys[i];
|
||||
let mixin = mixinSettings[name];
|
||||
if (mixin === true) {
|
||||
mixin = {};
|
||||
}
|
||||
|
@ -696,7 +696,7 @@ function createModelClassCtor(name, ModelBaseClass) {
|
|||
// DataType for Date
|
||||
function DateType(arg) {
|
||||
if (arg === null) return null;
|
||||
var d = new Date(arg);
|
||||
const d = new Date(arg);
|
||||
return d;
|
||||
}
|
||||
|
||||
|
@ -770,19 +770,19 @@ ModelBuilder.prototype.defineValueType = function(type, aliases) {
|
|||
* @property {Boolean} index True if the property is an index; false otherwise.
|
||||
*/
|
||||
ModelBuilder.prototype.extendModel = function(model, props) {
|
||||
var t = this;
|
||||
var keys = Object.keys(props);
|
||||
for (var i = 0; i < keys.length; i++) {
|
||||
var definition = props[keys[i]];
|
||||
const t = this;
|
||||
const keys = Object.keys(props);
|
||||
for (let i = 0; i < keys.length; i++) {
|
||||
const definition = props[keys[i]];
|
||||
t.defineProperty(model, keys[i], definition);
|
||||
}
|
||||
};
|
||||
|
||||
ModelBuilder.prototype.copyModel = function copyModel(Master) {
|
||||
var modelBuilder = this;
|
||||
var className = Master.modelName;
|
||||
var md = Master.modelBuilder.definitions[className];
|
||||
var Slave = function SlaveModel() {
|
||||
const modelBuilder = this;
|
||||
const className = Master.modelName;
|
||||
const md = Master.modelBuilder.definitions[className];
|
||||
const Slave = function SlaveModel() {
|
||||
Master.apply(this, [].slice.call(arguments));
|
||||
};
|
||||
|
||||
|
@ -858,7 +858,7 @@ ModelBuilder.prototype.resolveType = function(type) {
|
|||
}
|
||||
if (Array.isArray(type) && type.length > 0) {
|
||||
// For array types, the first item should be the type string
|
||||
var itemType = this.resolveType(type[0]);
|
||||
const itemType = this.resolveType(type[0]);
|
||||
if (typeof itemType === 'function') {
|
||||
return [itemType];
|
||||
} else {
|
||||
|
@ -866,7 +866,7 @@ ModelBuilder.prototype.resolveType = function(type) {
|
|||
}
|
||||
}
|
||||
if (typeof type === 'string') {
|
||||
var schemaType = ModelBuilder.schemaTypes[type.toLowerCase()] || this.models[type];
|
||||
const schemaType = ModelBuilder.schemaTypes[type.toLowerCase()] || this.models[type];
|
||||
if (schemaType) {
|
||||
return schemaType;
|
||||
} else {
|
||||
|
@ -906,7 +906,7 @@ ModelBuilder.prototype.resolveType = function(type) {
|
|||
* model name.
|
||||
*/
|
||||
ModelBuilder.prototype.buildModels = function(schemas, createModel) {
|
||||
var models = {};
|
||||
const models = {};
|
||||
|
||||
// Normalize the schemas to be an array of the schema objects {name: <name>, properties: {}, options: {}}
|
||||
if (!Array.isArray(schemas)) {
|
||||
|
@ -925,25 +925,22 @@ ModelBuilder.prototype.buildModels = function(schemas, createModel) {
|
|||
}
|
||||
}
|
||||
|
||||
var relations = [];
|
||||
for (var s = 0, n = schemas.length; s < n; s++) {
|
||||
var name = this.getSchemaName(schemas[s].name);
|
||||
let relations = [];
|
||||
for (let s = 0, n = schemas.length; s < n; s++) {
|
||||
const name = this.getSchemaName(schemas[s].name);
|
||||
schemas[s].name = name;
|
||||
var model;
|
||||
if (typeof createModel === 'function') {
|
||||
model = createModel(schemas[s].name, schemas[s].properties, schemas[s].options);
|
||||
} else {
|
||||
model = this.define(schemas[s].name, schemas[s].properties, schemas[s].options);
|
||||
}
|
||||
const model = typeof createModel === 'function' ?
|
||||
createModel(schemas[s].name, schemas[s].properties, schemas[s].options) :
|
||||
this.define(schemas[s].name, schemas[s].properties, schemas[s].options);
|
||||
models[name] = model;
|
||||
relations = relations.concat(model.definition.relations);
|
||||
}
|
||||
|
||||
// Connect the models based on the relations
|
||||
for (var i = 0; i < relations.length; i++) {
|
||||
var relation = relations[i];
|
||||
var sourceModel = models[relation.source];
|
||||
var targetModel = models[relation.target];
|
||||
for (let i = 0; i < relations.length; i++) {
|
||||
const relation = relations[i];
|
||||
const sourceModel = models[relation.source];
|
||||
const targetModel = models[relation.target];
|
||||
if (sourceModel && targetModel) {
|
||||
if (typeof sourceModel[relation.type] === 'function') {
|
||||
sourceModel[relation.type](targetModel, {as: relation.as});
|
||||
|
@ -962,7 +959,7 @@ ModelBuilder.prototype.buildModels = function(schemas, createModel) {
|
|||
*/
|
||||
ModelBuilder.prototype.buildModelFromInstance = function(name, json, options) {
|
||||
// Introspect the JSON document to generate a schema
|
||||
var schema = introspect(json);
|
||||
const schema = introspect(json);
|
||||
|
||||
// Create a model for the generated schema
|
||||
return this.define(name, schema, options);
|
||||
|
|
|
@ -4,12 +4,12 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var assert = require('assert');
|
||||
var util = require('util');
|
||||
var EventEmitter = require('events').EventEmitter;
|
||||
var traverse = require('traverse');
|
||||
var ModelBaseClass = require('./model');
|
||||
var ModelBuilder = require('./model-builder');
|
||||
const assert = require('assert');
|
||||
const util = require('util');
|
||||
const EventEmitter = require('events').EventEmitter;
|
||||
const traverse = require('traverse');
|
||||
const ModelBaseClass = require('./model');
|
||||
const ModelBuilder = require('./model-builder');
|
||||
|
||||
/**
|
||||
* Model definition
|
||||
|
@ -35,7 +35,7 @@ function ModelDefinition(modelBuilder, name, properties, settings) {
|
|||
assert(name, 'name is missing');
|
||||
|
||||
if (arguments.length === 2 && typeof name === 'object') {
|
||||
var schema = name;
|
||||
const schema = name;
|
||||
this.name = schema.name;
|
||||
this.rawProperties = schema.properties || {}; // Keep the raw property definitions
|
||||
this.settings = schema.settings || {};
|
||||
|
@ -60,7 +60,7 @@ require('./types')(ModelDefinition);
|
|||
* @param {String} connectorType The connector type, such as 'oracle' or 'mongodb'
|
||||
*/
|
||||
ModelDefinition.prototype.tableName = function(connectorType) {
|
||||
var settings = this.settings;
|
||||
const settings = this.settings;
|
||||
if (settings[connectorType]) {
|
||||
return settings[connectorType].table || settings[connectorType].tableName || this.name;
|
||||
} else {
|
||||
|
@ -79,7 +79,7 @@ ModelDefinition.prototype.columnName = function(connectorType, propertyName) {
|
|||
return propertyName;
|
||||
}
|
||||
this.build();
|
||||
var property = this.properties[propertyName];
|
||||
const property = this.properties[propertyName];
|
||||
if (property && property[connectorType]) {
|
||||
return property[connectorType].column || property[connectorType].columnName || propertyName;
|
||||
} else {
|
||||
|
@ -98,7 +98,7 @@ ModelDefinition.prototype.columnMetadata = function(connectorType, propertyName)
|
|||
return propertyName;
|
||||
}
|
||||
this.build();
|
||||
var property = this.properties[propertyName];
|
||||
const property = this.properties[propertyName];
|
||||
if (property && property[connectorType]) {
|
||||
return property[connectorType];
|
||||
} else {
|
||||
|
@ -113,9 +113,9 @@ ModelDefinition.prototype.columnMetadata = function(connectorType, propertyName)
|
|||
*/
|
||||
ModelDefinition.prototype.columnNames = function(connectorType) {
|
||||
this.build();
|
||||
var props = this.properties;
|
||||
var cols = [];
|
||||
for (var p in props) {
|
||||
const props = this.properties;
|
||||
const cols = [];
|
||||
for (const p in props) {
|
||||
if (props[p][connectorType]) {
|
||||
cols.push(props[p][connectorType].column || props[p][connectorType].columnName || p);
|
||||
} else {
|
||||
|
@ -133,11 +133,11 @@ ModelDefinition.prototype.ids = function() {
|
|||
if (this._ids) {
|
||||
return this._ids;
|
||||
}
|
||||
var ids = [];
|
||||
const ids = [];
|
||||
this.build();
|
||||
var props = this.properties;
|
||||
for (var key in props) {
|
||||
var id = props[key].id;
|
||||
const props = this.properties;
|
||||
for (const key in props) {
|
||||
let id = props[key].id;
|
||||
if (!id) {
|
||||
continue;
|
||||
}
|
||||
|
@ -167,7 +167,7 @@ ModelDefinition.prototype.idColumnName = function(connectorType) {
|
|||
* @returns {String} property name for ID
|
||||
*/
|
||||
ModelDefinition.prototype.idName = function() {
|
||||
var id = this.ids()[0];
|
||||
const id = this.ids()[0];
|
||||
if (this.properties.id && this.properties.id.id) {
|
||||
return 'id';
|
||||
} else {
|
||||
|
@ -180,8 +180,8 @@ ModelDefinition.prototype.idName = function() {
|
|||
* @returns {String[]} property names for IDs
|
||||
*/
|
||||
ModelDefinition.prototype.idNames = function() {
|
||||
var ids = this.ids();
|
||||
var names = ids.map(function(id) {
|
||||
const ids = this.ids();
|
||||
const names = ids.map(function(id) {
|
||||
return id.name;
|
||||
});
|
||||
return names;
|
||||
|
@ -193,13 +193,13 @@ ModelDefinition.prototype.idNames = function() {
|
|||
*/
|
||||
ModelDefinition.prototype.indexes = function() {
|
||||
this.build();
|
||||
var indexes = {};
|
||||
const indexes = {};
|
||||
if (this.settings.indexes) {
|
||||
for (var i in this.settings.indexes) {
|
||||
for (const i in this.settings.indexes) {
|
||||
indexes[i] = this.settings.indexes[i];
|
||||
}
|
||||
}
|
||||
for (var p in this.properties) {
|
||||
for (const p in this.properties) {
|
||||
if (this.properties[p].index) {
|
||||
indexes[p + '_index'] = this.properties[p].index;
|
||||
}
|
||||
|
@ -222,9 +222,9 @@ ModelDefinition.prototype.build = function(forceRebuild) {
|
|||
return this.properties;
|
||||
}
|
||||
this.properties = {};
|
||||
for (var p in this.rawProperties) {
|
||||
var prop = this.rawProperties[p];
|
||||
var type = this.modelBuilder.resolveType(prop);
|
||||
for (const p in this.rawProperties) {
|
||||
const prop = this.rawProperties[p];
|
||||
const type = this.modelBuilder.resolveType(prop);
|
||||
if (typeof type === 'string') {
|
||||
this.relations.push({
|
||||
source: this.name,
|
||||
|
@ -233,11 +233,11 @@ ModelDefinition.prototype.build = function(forceRebuild) {
|
|||
as: p,
|
||||
});
|
||||
} else {
|
||||
var typeDef = {
|
||||
const typeDef = {
|
||||
type: type,
|
||||
};
|
||||
if (typeof prop === 'object' && prop !== null) {
|
||||
for (var a in prop) {
|
||||
for (const a in prop) {
|
||||
// Skip the type property but don't delete it Model.extend() shares same instances of the properties from the base class
|
||||
if (a !== 'type') {
|
||||
typeDef[a] = prop[a];
|
||||
|
@ -274,14 +274,14 @@ ModelDefinition.prototype.toJSON = function(forceRebuild) {
|
|||
if (this.json) {
|
||||
return this.json;
|
||||
}
|
||||
var json = {
|
||||
const json = {
|
||||
name: this.name,
|
||||
properties: {},
|
||||
settings: this.settings,
|
||||
};
|
||||
this.build(forceRebuild);
|
||||
|
||||
var mapper = function(val) {
|
||||
const mapper = function(val) {
|
||||
if (val === undefined || val === null) {
|
||||
return val;
|
||||
}
|
||||
|
@ -302,7 +302,7 @@ ModelDefinition.prototype.toJSON = function(forceRebuild) {
|
|||
return val;
|
||||
}
|
||||
};
|
||||
for (var p in this.properties) {
|
||||
for (const p in this.properties) {
|
||||
json.properties[p] = traverse(this.properties[p]).map(mapper);
|
||||
}
|
||||
this.json = json;
|
||||
|
|
|
@ -12,12 +12,12 @@ module.exports = ModelUtils;
|
|||
/*!
|
||||
* Module dependencies
|
||||
*/
|
||||
var g = require('strong-globalize')();
|
||||
var geo = require('./geo');
|
||||
var utils = require('./utils');
|
||||
var fieldsToArray = utils.fieldsToArray;
|
||||
var sanitizeQueryOrData = utils.sanitizeQuery;
|
||||
var BaseModel = require('./model');
|
||||
const g = require('strong-globalize')();
|
||||
const geo = require('./geo');
|
||||
const utils = require('./utils');
|
||||
const fieldsToArray = utils.fieldsToArray;
|
||||
const sanitizeQueryOrData = utils.sanitizeQuery;
|
||||
const BaseModel = require('./model');
|
||||
|
||||
/**
|
||||
* A mixin to contain utility methods for DataAccessObject
|
||||
|
@ -48,10 +48,10 @@ ModelUtils._allowExtendedOperators = function(options) {
|
|||
*/
|
||||
ModelUtils._getSetting = function(key, options) {
|
||||
// Check method level options
|
||||
var val = options && options[key];
|
||||
let val = options && options[key];
|
||||
if (val !== undefined) return val;
|
||||
// Check for settings in model
|
||||
var m = this.definition;
|
||||
const m = this.definition;
|
||||
if (m && m.settings) {
|
||||
val = m.settings[key];
|
||||
if (val !== undefined) {
|
||||
|
@ -61,7 +61,7 @@ ModelUtils._getSetting = function(key, options) {
|
|||
}
|
||||
|
||||
// Check for settings in connector
|
||||
var ds = this.getDataSource();
|
||||
const ds = this.getDataSource();
|
||||
if (ds && ds.settings) {
|
||||
return ds.settings[key];
|
||||
}
|
||||
|
@ -69,7 +69,7 @@ ModelUtils._getSetting = function(key, options) {
|
|||
return undefined;
|
||||
};
|
||||
|
||||
var operators = {
|
||||
const operators = {
|
||||
eq: '=',
|
||||
gt: '>',
|
||||
gte: '>=',
|
||||
|
@ -98,15 +98,15 @@ ModelUtils._normalize = function(filter, options) {
|
|||
if (!filter) {
|
||||
return undefined;
|
||||
}
|
||||
var err = null;
|
||||
let err = null;
|
||||
if ((typeof filter !== 'object') || Array.isArray(filter)) {
|
||||
err = new Error(g.f('The query filter %j is not an {{object}}', filter));
|
||||
err.statusCode = 400;
|
||||
throw err;
|
||||
}
|
||||
if (filter.limit || filter.skip || filter.offset) {
|
||||
var limit = Number(filter.limit || 100);
|
||||
var offset = Number(filter.skip || filter.offset || 0);
|
||||
const limit = Number(filter.limit || 100);
|
||||
const offset = Number(filter.skip || filter.offset || 0);
|
||||
if (isNaN(limit) || limit <= 0 || Math.ceil(limit) !== limit) {
|
||||
err = new Error(g.f('The {{limit}} parameter %j is not valid',
|
||||
filter.limit));
|
||||
|
@ -125,24 +125,24 @@ ModelUtils._normalize = function(filter, options) {
|
|||
}
|
||||
|
||||
if (filter.order) {
|
||||
var order = filter.order;
|
||||
let order = filter.order;
|
||||
if (!Array.isArray(order)) {
|
||||
order = [order];
|
||||
}
|
||||
var fields = [];
|
||||
for (var i = 0, m = order.length; i < m; i++) {
|
||||
const fields = [];
|
||||
for (let i = 0, m = order.length; i < m; i++) {
|
||||
if (typeof order[i] === 'string') {
|
||||
// Normalize 'f1 ASC, f2 DESC, f3' to ['f1 ASC', 'f2 DESC', 'f3']
|
||||
var tokens = order[i].split(/(?:\s*,\s*)+/);
|
||||
for (var t = 0, n = tokens.length; t < n; t++) {
|
||||
var token = tokens[t];
|
||||
const tokens = order[i].split(/(?:\s*,\s*)+/);
|
||||
for (let t = 0, n = tokens.length; t < n; t++) {
|
||||
let token = tokens[t];
|
||||
if (token.length === 0) {
|
||||
// Skip empty token
|
||||
continue;
|
||||
}
|
||||
var parts = token.split(/\s+/);
|
||||
const parts = token.split(/\s+/);
|
||||
if (parts.length >= 2) {
|
||||
var dir = parts[1].toUpperCase();
|
||||
const dir = parts[1].toUpperCase();
|
||||
if (dir === 'ASC' || dir === 'DESC') {
|
||||
token = parts[0] + ' ' + dir;
|
||||
} else {
|
||||
|
@ -178,7 +178,7 @@ ModelUtils._normalize = function(filter, options) {
|
|||
};
|
||||
|
||||
function DateType(arg) {
|
||||
var d = new Date(arg);
|
||||
const d = new Date(arg);
|
||||
if (isNaN(d.getTime())) {
|
||||
throw new Error(g.f('Invalid date: %s', arg));
|
||||
}
|
||||
|
@ -203,7 +203,7 @@ function BooleanType(arg) {
|
|||
}
|
||||
|
||||
function NumberType(val) {
|
||||
var num = Number(val);
|
||||
const num = Number(val);
|
||||
return !isNaN(num) ? num : val;
|
||||
}
|
||||
|
||||
|
@ -217,14 +217,14 @@ function coerceArray(val) {
|
|||
}
|
||||
|
||||
// It is an object, check if empty
|
||||
var props = Object.keys(val);
|
||||
const props = Object.keys(val);
|
||||
|
||||
if (props.length === 0) {
|
||||
throw new Error(g.f('Value is an empty {{object}}'));
|
||||
}
|
||||
|
||||
var arrayVal = new Array(props.length);
|
||||
for (var i = 0; i < arrayVal.length; ++i) {
|
||||
const arrayVal = new Array(props.length);
|
||||
for (let i = 0; i < arrayVal.length; ++i) {
|
||||
if (!val.hasOwnProperty(i)) {
|
||||
throw new Error(g.f('Value is not an {{array}} or {{object}} with sequential numeric indices'));
|
||||
}
|
||||
|
@ -244,8 +244,8 @@ function _normalizeAsArray(result) {
|
|||
} else {
|
||||
// See https://github.com/strongloop/loopback-datasource-juggler/issues/1646
|
||||
// `ModelBaseClass` normalize the properties to an object such as `{secret: true}`
|
||||
var keys = [];
|
||||
for (var k in result) {
|
||||
const keys = [];
|
||||
for (const k in result) {
|
||||
if (result[k]) keys.push(k);
|
||||
}
|
||||
return keys;
|
||||
|
@ -256,8 +256,8 @@ function _normalizeAsArray(result) {
|
|||
* Get an array of hidden property names
|
||||
*/
|
||||
ModelUtils._getHiddenProperties = function() {
|
||||
var settings = this.definition.settings || {};
|
||||
var result = settings.hiddenProperties || settings.hidden || [];
|
||||
const settings = this.definition.settings || {};
|
||||
const result = settings.hiddenProperties || settings.hidden || [];
|
||||
return _normalizeAsArray(result);
|
||||
};
|
||||
|
||||
|
@ -265,8 +265,8 @@ ModelUtils._getHiddenProperties = function() {
|
|||
* Get an array of protected property names
|
||||
*/
|
||||
ModelUtils._getProtectedProperties = function() {
|
||||
var settings = this.definition.settings || {};
|
||||
var result = settings.protectedProperties || settings.protected || [];
|
||||
const settings = this.definition.settings || {};
|
||||
const result = settings.protectedProperties || settings.protected || [];
|
||||
return _normalizeAsArray(result);
|
||||
};
|
||||
|
||||
|
@ -276,7 +276,7 @@ ModelUtils._getProtectedProperties = function() {
|
|||
ModelUtils._getMaxDepthOfQuery = function(options, defaultValue) {
|
||||
options = options || {};
|
||||
// See https://github.com/strongloop/loopback-datasource-juggler/issues/1651
|
||||
var maxDepth = this._getSetting('maxDepthOfQuery', options);
|
||||
let maxDepth = this._getSetting('maxDepthOfQuery', options);
|
||||
if (maxDepth == null) {
|
||||
maxDepth = defaultValue || 32;
|
||||
}
|
||||
|
@ -289,7 +289,7 @@ ModelUtils._getMaxDepthOfQuery = function(options, defaultValue) {
|
|||
ModelUtils._getMaxDepthOfData = function(options, defaultValue) {
|
||||
options = options || {};
|
||||
// See https://github.com/strongloop/loopback-datasource-juggler/issues/1651
|
||||
var maxDepth = this._getSetting('maxDepthOfData', options);
|
||||
let maxDepth = this._getSetting('maxDepthOfData', options);
|
||||
if (maxDepth == null) {
|
||||
maxDepth = defaultValue || 64;
|
||||
}
|
||||
|
@ -300,7 +300,7 @@ ModelUtils._getMaxDepthOfData = function(options, defaultValue) {
|
|||
* Get the prohibitHiddenPropertiesInQuery flag
|
||||
*/
|
||||
ModelUtils._getProhibitHiddenPropertiesInQuery = function(options, defaultValue) {
|
||||
var flag = this._getSetting('prohibitHiddenPropertiesInQuery', options);
|
||||
const flag = this._getSetting('prohibitHiddenPropertiesInQuery', options);
|
||||
if (flag == null) return !!defaultValue;
|
||||
return !!flag;
|
||||
};
|
||||
|
@ -312,14 +312,14 @@ ModelUtils._sanitizeQuery = function(query, options) {
|
|||
options = options || {};
|
||||
|
||||
// Get settings to normalize `undefined` values
|
||||
var normalizeUndefinedInQuery = this._getSetting('normalizeUndefinedInQuery', options);
|
||||
const normalizeUndefinedInQuery = this._getSetting('normalizeUndefinedInQuery', options);
|
||||
// Get setting to prohibit hidden/protected properties in query
|
||||
var prohibitHiddenPropertiesInQuery = this._getProhibitHiddenPropertiesInQuery(options);
|
||||
const prohibitHiddenPropertiesInQuery = this._getProhibitHiddenPropertiesInQuery(options);
|
||||
|
||||
// See https://github.com/strongloop/loopback-datasource-juggler/issues/1651
|
||||
var maxDepthOfQuery = this._getMaxDepthOfQuery(options);
|
||||
const maxDepthOfQuery = this._getMaxDepthOfQuery(options);
|
||||
|
||||
var prohibitedKeys = [];
|
||||
let prohibitedKeys = [];
|
||||
// Check violation of keys
|
||||
if (prohibitHiddenPropertiesInQuery) {
|
||||
prohibitedKeys = this._getHiddenProperties();
|
||||
|
@ -355,24 +355,24 @@ ModelUtils._sanitizeData = function(data, options) {
|
|||
* @private
|
||||
*/
|
||||
ModelUtils._coerce = function(where, options) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
if (where == null) {
|
||||
return where;
|
||||
}
|
||||
options = options || {};
|
||||
|
||||
var err;
|
||||
let err;
|
||||
if (typeof where !== 'object' || Array.isArray(where)) {
|
||||
err = new Error(g.f('The where clause %j is not an {{object}}', where));
|
||||
err.statusCode = 400;
|
||||
throw err;
|
||||
}
|
||||
|
||||
var props = self.definition.properties;
|
||||
for (var p in where) {
|
||||
const props = self.definition.properties;
|
||||
for (const p in where) {
|
||||
// Handle logical operators
|
||||
if (p === 'and' || p === 'or' || p === 'nor') {
|
||||
var clauses = where[p];
|
||||
let clauses = where[p];
|
||||
try {
|
||||
clauses = coerceArray(clauses);
|
||||
} catch (e) {
|
||||
|
@ -381,13 +381,13 @@ ModelUtils._coerce = function(where, options) {
|
|||
throw err;
|
||||
}
|
||||
|
||||
for (var k = 0; k < clauses.length; k++) {
|
||||
for (let k = 0; k < clauses.length; k++) {
|
||||
self._coerce(clauses[k], options);
|
||||
}
|
||||
|
||||
continue;
|
||||
}
|
||||
var DataType = props[p] && props[p].type;
|
||||
let DataType = props[p] && props[p].type;
|
||||
if (!DataType) {
|
||||
continue;
|
||||
}
|
||||
|
@ -424,15 +424,15 @@ ModelUtils._coerce = function(where, options) {
|
|||
continue;
|
||||
}
|
||||
|
||||
var val = where[p];
|
||||
let val = where[p];
|
||||
if (val === null || val === undefined) {
|
||||
continue;
|
||||
}
|
||||
// Check there is an operator
|
||||
var operator = null;
|
||||
var exp = val;
|
||||
let operator = null;
|
||||
const exp = val;
|
||||
if (val.constructor === Object) {
|
||||
for (var op in operators) {
|
||||
for (const op in operators) {
|
||||
if (op in val) {
|
||||
val = val[op];
|
||||
operator = op;
|
||||
|
@ -493,10 +493,10 @@ ModelUtils._coerce = function(where, options) {
|
|||
// NOOP when not coercable into an array.
|
||||
}
|
||||
|
||||
var allowExtendedOperators = self._allowExtendedOperators(options);
|
||||
const allowExtendedOperators = self._allowExtendedOperators(options);
|
||||
// Coerce the array items
|
||||
if (Array.isArray(val)) {
|
||||
for (var i = 0; i < val.length; i++) {
|
||||
for (let i = 0; i < val.length; i++) {
|
||||
if (val[i] !== null && val[i] !== undefined) {
|
||||
if (!(val[i] instanceof RegExp)) {
|
||||
val[i] = DataType(val[i]);
|
||||
|
@ -517,7 +517,7 @@ ModelUtils._coerce = function(where, options) {
|
|||
// Do not coerce object values when extended operators are allowed
|
||||
} else {
|
||||
if (!allowExtendedOperators) {
|
||||
var extendedOperators = Object.keys(val).filter(function(k) {
|
||||
const extendedOperators = Object.keys(val).filter(function(k) {
|
||||
return k[0] === '$';
|
||||
});
|
||||
if (extendedOperators.length) {
|
||||
|
@ -538,7 +538,7 @@ ModelUtils._coerce = function(where, options) {
|
|||
}
|
||||
// Rebuild {property: {operator: value}}
|
||||
if (operator && operator !== 'eq') {
|
||||
var value = {};
|
||||
const value = {};
|
||||
value[operator] = val;
|
||||
if (exp.options) {
|
||||
// Keep options for operators
|
||||
|
|
132
lib/model.js
132
lib/model.js
|
@ -16,22 +16,22 @@ module.exports = ModelBaseClass;
|
|||
* Module dependencies
|
||||
*/
|
||||
|
||||
var g = require('strong-globalize')();
|
||||
var util = require('util');
|
||||
var jutil = require('./jutil');
|
||||
var List = require('./list');
|
||||
var DataAccessUtils = require('./model-utils');
|
||||
var Observer = require('./observer');
|
||||
var Hookable = require('./hooks');
|
||||
var validations = require('./validations');
|
||||
var _extend = util._extend;
|
||||
var utils = require('./utils');
|
||||
var fieldsToArray = utils.fieldsToArray;
|
||||
var uuid = require('uuid');
|
||||
var shortid = require('shortid');
|
||||
const g = require('strong-globalize')();
|
||||
const util = require('util');
|
||||
const jutil = require('./jutil');
|
||||
const List = require('./list');
|
||||
const DataAccessUtils = require('./model-utils');
|
||||
const Observer = require('./observer');
|
||||
const Hookable = require('./hooks');
|
||||
const validations = require('./validations');
|
||||
const _extend = util._extend;
|
||||
const utils = require('./utils');
|
||||
const fieldsToArray = utils.fieldsToArray;
|
||||
const uuid = require('uuid');
|
||||
const shortid = require('shortid');
|
||||
|
||||
// Set up an object for quick lookup
|
||||
var BASE_TYPES = {
|
||||
const BASE_TYPES = {
|
||||
'String': true,
|
||||
'Boolean': true,
|
||||
'Number': true,
|
||||
|
@ -73,8 +73,8 @@ function ModelBaseClass(data, options) {
|
|||
* @private
|
||||
*/
|
||||
ModelBaseClass.prototype._initProperties = function(data, options) {
|
||||
var self = this;
|
||||
var ctor = this.constructor;
|
||||
const self = this;
|
||||
const ctor = this.constructor;
|
||||
|
||||
if (typeof data !== 'undefined' && data !== null && data.constructor &&
|
||||
typeof (data.constructor) !== 'function') {
|
||||
|
@ -85,7 +85,7 @@ ModelBaseClass.prototype._initProperties = function(data, options) {
|
|||
// Convert the data to be plain object to avoid pollutions
|
||||
data = data.toObject(false);
|
||||
}
|
||||
var properties = _extend({}, ctor.definition.properties);
|
||||
const properties = _extend({}, ctor.definition.properties);
|
||||
data = data || {};
|
||||
|
||||
if (typeof ctor.applyProperties === 'function') {
|
||||
|
@ -93,9 +93,9 @@ ModelBaseClass.prototype._initProperties = function(data, options) {
|
|||
}
|
||||
|
||||
options = options || {};
|
||||
var applySetters = options.applySetters;
|
||||
var applyDefaultValues = options.applyDefaultValues;
|
||||
var strict = options.strict;
|
||||
const applySetters = options.applySetters;
|
||||
const applyDefaultValues = options.applyDefaultValues;
|
||||
let strict = options.strict;
|
||||
|
||||
if (strict === undefined) {
|
||||
strict = ctor.definition.settings.strict;
|
||||
|
@ -105,7 +105,7 @@ ModelBaseClass.prototype._initProperties = function(data, options) {
|
|||
'{{`Validation Error`}} for unknown properties,', ctor.modelName);
|
||||
}
|
||||
|
||||
var persistUndefinedAsNull = ctor.definition.settings.persistUndefinedAsNull;
|
||||
const persistUndefinedAsNull = ctor.definition.settings.persistUndefinedAsNull;
|
||||
|
||||
if (ctor.hideInternalProperties) {
|
||||
// Object.defineProperty() is expensive. We only try to make the internal
|
||||
|
@ -177,7 +177,7 @@ ModelBaseClass.prototype._initProperties = function(data, options) {
|
|||
this.__cachedRelations = data.__cachedRelations;
|
||||
}
|
||||
|
||||
var keys = Object.keys(data);
|
||||
let keys = Object.keys(data);
|
||||
|
||||
if (Array.isArray(options.fields)) {
|
||||
keys = keys.filter(function(k) {
|
||||
|
@ -185,9 +185,9 @@ ModelBaseClass.prototype._initProperties = function(data, options) {
|
|||
});
|
||||
}
|
||||
|
||||
var size = keys.length;
|
||||
var p, propVal;
|
||||
for (var k = 0; k < size; k++) {
|
||||
let size = keys.length;
|
||||
let p, propVal;
|
||||
for (let k = 0; k < size; k++) {
|
||||
p = keys[k];
|
||||
propVal = data[p];
|
||||
if (typeof propVal === 'function') {
|
||||
|
@ -206,14 +206,14 @@ ModelBaseClass.prototype._initProperties = function(data, options) {
|
|||
self.__data[p] = propVal;
|
||||
}
|
||||
} else if (ctor.relations[p]) {
|
||||
var relationType = ctor.relations[p].type;
|
||||
const relationType = ctor.relations[p].type;
|
||||
|
||||
var modelTo;
|
||||
let modelTo;
|
||||
if (!properties[p]) {
|
||||
modelTo = ctor.relations[p].modelTo || ModelBaseClass;
|
||||
var multiple = ctor.relations[p].multiple;
|
||||
var typeName = multiple ? 'Array' : modelTo.modelName;
|
||||
var propType = multiple ? [modelTo] : modelTo;
|
||||
const multiple = ctor.relations[p].multiple;
|
||||
const typeName = multiple ? 'Array' : modelTo.modelName;
|
||||
const propType = multiple ? [modelTo] : modelTo;
|
||||
properties[p] = {name: typeName, type: propType};
|
||||
/* Issue #1252
|
||||
this.setStrict(false);
|
||||
|
@ -226,7 +226,7 @@ ModelBaseClass.prototype._initProperties = function(data, options) {
|
|||
self.__data[ctor.relations[p].keyFrom] = propVal[ctor.relations[p].keyTo];
|
||||
|
||||
if (ctor.relations[p].options.embedsProperties) {
|
||||
var fields = fieldsToArray(ctor.relations[p].properties,
|
||||
const fields = fieldsToArray(ctor.relations[p].properties,
|
||||
modelTo.definition.properties, modelTo.settings.strict);
|
||||
if (!~fields.indexOf(ctor.relations[p].keyTo)) {
|
||||
fields.push(ctor.relations[p].keyTo);
|
||||
|
@ -272,14 +272,14 @@ ModelBaseClass.prototype._initProperties = function(data, options) {
|
|||
|
||||
size = keys.length;
|
||||
|
||||
for (k = 0; k < size; k++) {
|
||||
for (let k = 0; k < size; k++) {
|
||||
p = keys[k];
|
||||
propVal = self.__data[p];
|
||||
var type = properties[p].type;
|
||||
const type = properties[p].type;
|
||||
|
||||
// Set default values
|
||||
if (applyDefaultValues && propVal === undefined) {
|
||||
var def = properties[p]['default'];
|
||||
let def = properties[p]['default'];
|
||||
if (def !== undefined) {
|
||||
if (typeof def === 'function') {
|
||||
if (def === Date) {
|
||||
|
@ -301,7 +301,7 @@ ModelBaseClass.prototype._initProperties = function(data, options) {
|
|||
|
||||
// Set default value using a named function
|
||||
if (applyDefaultValues && propVal === undefined) {
|
||||
var defn = properties[p].defaultFn;
|
||||
const defn = properties[p].defaultFn;
|
||||
switch (defn) {
|
||||
case undefined:
|
||||
break;
|
||||
|
@ -381,7 +381,7 @@ ModelBaseClass.defineProperty = function(prop, params) {
|
|||
* @returns {String} Name of property type
|
||||
*/
|
||||
ModelBaseClass.getPropertyType = function(propName) {
|
||||
var prop = this.definition.properties[propName];
|
||||
const prop = this.definition.properties[propName];
|
||||
if (!prop) {
|
||||
// The property is not part of the definition
|
||||
return null;
|
||||
|
@ -421,7 +421,7 @@ ModelBaseClass.toString = function() {
|
|||
*/
|
||||
ModelBaseClass.prototype.toObject = function(onlySchema, removeHidden, removeProtected) {
|
||||
if (typeof onlySchema === 'object' && onlySchema != null) {
|
||||
var options = onlySchema;
|
||||
const options = onlySchema;
|
||||
onlySchema = options.onlySchema;
|
||||
removeHidden = options.removeHidden;
|
||||
removeProtected = options.removeProtected;
|
||||
|
@ -429,24 +429,24 @@ ModelBaseClass.prototype.toObject = function(onlySchema, removeHidden, removePro
|
|||
if (onlySchema === undefined) {
|
||||
onlySchema = true;
|
||||
}
|
||||
var data = {};
|
||||
var self = this;
|
||||
var Model = this.constructor;
|
||||
const data = {};
|
||||
const self = this;
|
||||
const Model = this.constructor;
|
||||
|
||||
// if it is already an Object
|
||||
if (Model === Object) {
|
||||
return self;
|
||||
}
|
||||
|
||||
var strict = this.__strict;
|
||||
var schemaLess = (strict === false) || !onlySchema;
|
||||
var persistUndefinedAsNull = Model.definition.settings.persistUndefinedAsNull;
|
||||
const strict = this.__strict;
|
||||
const schemaLess = (strict === false) || !onlySchema;
|
||||
const persistUndefinedAsNull = Model.definition.settings.persistUndefinedAsNull;
|
||||
|
||||
var props = Model.definition.properties;
|
||||
var keys = Object.keys(props);
|
||||
var propertyName, val;
|
||||
const props = Model.definition.properties;
|
||||
let keys = Object.keys(props);
|
||||
let propertyName, val;
|
||||
|
||||
for (var i = 0; i < keys.length; i++) {
|
||||
for (let i = 0; i < keys.length; i++) {
|
||||
propertyName = keys[i];
|
||||
val = self[propertyName];
|
||||
|
||||
|
@ -482,8 +482,8 @@ ModelBaseClass.prototype.toObject = function(onlySchema, removeHidden, removePro
|
|||
// If the property is not declared in the model definition, no setter will be
|
||||
// triggered to add it to __data
|
||||
keys = Object.keys(self);
|
||||
var size = keys.length;
|
||||
for (i = 0; i < size; i++) {
|
||||
let size = keys.length;
|
||||
for (let i = 0; i < size; i++) {
|
||||
propertyName = keys[i];
|
||||
if (props[propertyName]) {
|
||||
continue;
|
||||
|
@ -517,7 +517,7 @@ ModelBaseClass.prototype.toObject = function(onlySchema, removeHidden, removePro
|
|||
// Now continue to check __data
|
||||
keys = Object.keys(self.__data);
|
||||
size = keys.length;
|
||||
for (i = 0; i < size; i++) {
|
||||
for (let i = 0; i < size; i++) {
|
||||
propertyName = keys[i];
|
||||
if (propertyName.indexOf('__') === 0) {
|
||||
continue;
|
||||
|
@ -529,7 +529,7 @@ ModelBaseClass.prototype.toObject = function(onlySchema, removeHidden, removePro
|
|||
if (removeProtected && Model.isProtectedProperty(propertyName)) {
|
||||
continue;
|
||||
}
|
||||
var ownVal = self[propertyName];
|
||||
const ownVal = self[propertyName];
|
||||
// The ownVal can be a relation function
|
||||
val = (ownVal !== undefined && (typeof ownVal !== 'function')) ? ownVal : self.__data[propertyName];
|
||||
if (typeof val === 'function') {
|
||||
|
@ -555,9 +555,9 @@ ModelBaseClass.prototype.toObject = function(onlySchema, removeHidden, removePro
|
|||
* @param {string[]} arr An array of strings
|
||||
*/
|
||||
function asObjectMap(arr) {
|
||||
var obj = {};
|
||||
const obj = {};
|
||||
if (Array.isArray(arr)) {
|
||||
for (var i = 0; i < arr.length; i++) {
|
||||
for (let i = 0; i < arr.length; i++) {
|
||||
obj[arr[i]] = true;
|
||||
}
|
||||
return obj;
|
||||
|
@ -570,8 +570,8 @@ function asObjectMap(arr) {
|
|||
* @returns {Boolean} true or false if protected or not.
|
||||
*/
|
||||
ModelBaseClass.isProtectedProperty = function(propertyName) {
|
||||
var settings = (this.definition && this.definition.settings) || {};
|
||||
var protectedProperties = settings.protectedProperties || settings.protected;
|
||||
const settings = (this.definition && this.definition.settings) || {};
|
||||
const protectedProperties = settings.protectedProperties || settings.protected;
|
||||
settings.protectedProperties = asObjectMap(protectedProperties);
|
||||
return settings.protectedProperties[propertyName];
|
||||
};
|
||||
|
@ -582,8 +582,8 @@ ModelBaseClass.isProtectedProperty = function(propertyName) {
|
|||
* @returns {Boolean} true or false if hidden or not.
|
||||
*/
|
||||
ModelBaseClass.isHiddenProperty = function(propertyName) {
|
||||
var settings = (this.definition && this.definition.settings) || {};
|
||||
var hiddenProperties = settings.hiddenProperties || settings.hidden;
|
||||
const settings = (this.definition && this.definition.settings) || {};
|
||||
const hiddenProperties = settings.hiddenProperties || settings.hidden;
|
||||
settings.hiddenProperties = asObjectMap(hiddenProperties);
|
||||
return settings.hiddenProperties[propertyName];
|
||||
};
|
||||
|
@ -593,7 +593,7 @@ ModelBaseClass.prototype.toJSON = function() {
|
|||
};
|
||||
|
||||
ModelBaseClass.prototype.fromObject = function(obj) {
|
||||
for (var key in obj) {
|
||||
for (const key in obj) {
|
||||
this[key] = obj[key];
|
||||
}
|
||||
};
|
||||
|
@ -604,8 +604,8 @@ ModelBaseClass.prototype.fromObject = function(obj) {
|
|||
* initial state.
|
||||
*/
|
||||
ModelBaseClass.prototype.reset = function() {
|
||||
var obj = this;
|
||||
for (var k in obj) {
|
||||
const obj = this;
|
||||
for (const k in obj) {
|
||||
if (k !== 'id' && !obj.constructor.dataSource.definitions[obj.constructor.modelName].properties[k]) {
|
||||
delete obj[k];
|
||||
}
|
||||
|
@ -615,11 +615,11 @@ ModelBaseClass.prototype.reset = function() {
|
|||
// Node v0.11+ allows custom inspect functions to return an object
|
||||
// instead of string. That way options like `showHidden` and `colors`
|
||||
// can be preserved.
|
||||
var versionParts = process.versions && process.versions.node ?
|
||||
const versionParts = process.versions && process.versions.node ?
|
||||
process.versions.node.split(/\./g).map(function(v) { return +v; }) :
|
||||
[1, 0, 0]; // browserify ships 1.0-compatible version of util.inspect
|
||||
|
||||
var INSPECT_SUPPORTS_OBJECT_RETVAL =
|
||||
const INSPECT_SUPPORTS_OBJECT_RETVAL =
|
||||
versionParts[0] > 0 ||
|
||||
versionParts[1] > 11 ||
|
||||
(versionParts[0] === 11 && versionParts[1] >= 14);
|
||||
|
@ -648,8 +648,8 @@ ModelBaseClass.mixin = function(anotherClass, options) {
|
|||
this.modelBuilder.mixins.applyMixin(this, anotherClass, options);
|
||||
} else {
|
||||
if (anotherClass.prototype instanceof ModelBaseClass) {
|
||||
var props = anotherClass.definition.properties;
|
||||
for (var i in props) {
|
||||
const props = anotherClass.definition.properties;
|
||||
for (const i in props) {
|
||||
if (this.definition.properties[i]) {
|
||||
continue;
|
||||
}
|
||||
|
@ -780,7 +780,7 @@ ModelBaseClass.getMergePolicy = function(options) {
|
|||
// + fix for description arrays that should not be merged
|
||||
// + fix for relations that should patch matching relations
|
||||
// + ranking of ACLs
|
||||
var mergePolicy = {
|
||||
let mergePolicy = {
|
||||
description: {replace: true}, // string or array
|
||||
properties: {patch: true}, // object
|
||||
hidden: {replace: false}, // array
|
||||
|
@ -789,7 +789,7 @@ ModelBaseClass.getMergePolicy = function(options) {
|
|||
acls: {rank: true}, // array
|
||||
};
|
||||
|
||||
var config = (options || {}).configureModelMerge;
|
||||
const config = (options || {}).configureModelMerge;
|
||||
|
||||
if (config === true) {
|
||||
// NOTE: recommended merge policy from datasource-juggler v3.6.2
|
||||
|
|
|
@ -4,8 +4,8 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var async = require('async');
|
||||
var utils = require('./utils');
|
||||
const async = require('async');
|
||||
const utils = require('./utils');
|
||||
|
||||
module.exports = ObserverMixin;
|
||||
|
||||
|
@ -74,7 +74,7 @@ ObserverMixin.observe = function(operation, listener) {
|
|||
ObserverMixin.removeObserver = function(operation, listener) {
|
||||
if (!(this._observers && this._observers[operation])) return;
|
||||
|
||||
var index = this._observers[operation].indexOf(listener);
|
||||
const index = this._observers[operation].indexOf(listener);
|
||||
if (index !== -1) {
|
||||
return this._observers[operation].splice(index, 1);
|
||||
}
|
||||
|
@ -127,7 +127,7 @@ ObserverMixin.clearObservers = function(operation) {
|
|||
* have finished.
|
||||
*/
|
||||
ObserverMixin.notifyObserversOf = function(operation, context, callback) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
if (!callback) callback = utils.createPromiseCallback();
|
||||
|
||||
function createNotifier(op) {
|
||||
|
@ -141,14 +141,14 @@ ObserverMixin.notifyObserversOf = function(operation, context, callback) {
|
|||
}
|
||||
|
||||
if (Array.isArray(operation)) {
|
||||
var tasks = [];
|
||||
for (var i = 0, n = operation.length; i < n; i++) {
|
||||
const tasks = [];
|
||||
for (let i = 0, n = operation.length; i < n; i++) {
|
||||
tasks.push(createNotifier(operation[i]));
|
||||
}
|
||||
return async.waterfall(tasks, callback);
|
||||
}
|
||||
|
||||
var observers = this._observers && this._observers[operation];
|
||||
const observers = this._observers && this._observers[operation];
|
||||
|
||||
this._notifyBaseObservers(operation, context, function doNotify(err) {
|
||||
if (err) return callback(err, context);
|
||||
|
@ -157,7 +157,7 @@ ObserverMixin.notifyObserversOf = function(operation, context, callback) {
|
|||
async.eachSeries(
|
||||
observers,
|
||||
function notifySingleObserver(fn, next) {
|
||||
var retval = fn(context, next);
|
||||
const retval = fn(context, next);
|
||||
if (retval && typeof retval.then === 'function') {
|
||||
retval.then(
|
||||
function() { next(); return null; },
|
||||
|
@ -217,7 +217,7 @@ ObserverMixin._notifyBaseObservers = function(operation, context, callback) {
|
|||
* @returns {*}
|
||||
*/
|
||||
ObserverMixin.notifyObserversAround = function(operation, context, fn, callback) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
context = context || {};
|
||||
// Add callback to the context object so that an observer can skip other
|
||||
// ones by calling the callback function directly and not calling next
|
||||
|
@ -230,23 +230,23 @@ ObserverMixin.notifyObserversAround = function(operation, context, fn, callback)
|
|||
if (err) return callback(err);
|
||||
|
||||
function cbForWork(err) {
|
||||
var args = [].slice.call(arguments, 0);
|
||||
const args = [].slice.call(arguments, 0);
|
||||
if (err) return callback.apply(null, args);
|
||||
// Find the list of params from the callback in addition to err
|
||||
var returnedArgs = args.slice(1);
|
||||
const returnedArgs = args.slice(1);
|
||||
// Set up the array of results
|
||||
context.results = returnedArgs;
|
||||
// Notify after observers
|
||||
self.notifyObserversOf('after ' + operation, context,
|
||||
function(err, context) {
|
||||
if (err) return callback(err, context);
|
||||
var results = returnedArgs;
|
||||
let results = returnedArgs;
|
||||
if (context && Array.isArray(context.results)) {
|
||||
// Pickup the results from context
|
||||
results = context.results;
|
||||
}
|
||||
// Build the list of params for final callback
|
||||
var args = [err].concat(results);
|
||||
const args = [err].concat(results);
|
||||
callback.apply(null, args);
|
||||
});
|
||||
}
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -7,8 +7,8 @@
|
|||
/*!
|
||||
* Dependencies
|
||||
*/
|
||||
var relation = require('./relation-definition');
|
||||
var RelationDefinition = relation.RelationDefinition;
|
||||
const relation = require('./relation-definition');
|
||||
const RelationDefinition = relation.RelationDefinition;
|
||||
|
||||
module.exports = RelationMixin;
|
||||
|
||||
|
|
137
lib/scope.js
137
lib/scope.js
|
@ -4,17 +4,17 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var _ = require('lodash');
|
||||
var i8n = require('inflection');
|
||||
var g = require('strong-globalize')();
|
||||
var utils = require('./utils');
|
||||
var defineCachedRelations = utils.defineCachedRelations;
|
||||
var setScopeValuesFromWhere = utils.setScopeValuesFromWhere;
|
||||
var mergeQuery = utils.mergeQuery;
|
||||
var DefaultModelBaseClass = require('./model.js');
|
||||
var collectTargetIds = utils.collectTargetIds;
|
||||
var idName = utils.idName;
|
||||
var deprecated = require('depd')('loopback-datasource-juggler');
|
||||
const _ = require('lodash');
|
||||
const i8n = require('inflection');
|
||||
const g = require('strong-globalize')();
|
||||
const utils = require('./utils');
|
||||
const defineCachedRelations = utils.defineCachedRelations;
|
||||
const setScopeValuesFromWhere = utils.setScopeValuesFromWhere;
|
||||
const mergeQuery = utils.mergeQuery;
|
||||
const DefaultModelBaseClass = require('./model.js');
|
||||
const collectTargetIds = utils.collectTargetIds;
|
||||
const idName = utils.idName;
|
||||
const deprecated = require('depd')('loopback-datasource-juggler');
|
||||
|
||||
/**
|
||||
* Module exports
|
||||
|
@ -32,14 +32,14 @@ function ScopeDefinition(definition) {
|
|||
}
|
||||
|
||||
ScopeDefinition.prototype.targetModel = function(receiver) {
|
||||
var modelTo;
|
||||
let modelTo;
|
||||
if (typeof this.options.modelTo === 'function') {
|
||||
modelTo = this.options.modelTo.call(this, receiver) || this.modelTo;
|
||||
} else {
|
||||
modelTo = this.modelTo;
|
||||
}
|
||||
if (!(modelTo.prototype instanceof DefaultModelBaseClass)) {
|
||||
var msg = 'Invalid target model for scope `';
|
||||
let msg = 'Invalid target model for scope `';
|
||||
msg += (this.isStatic ? this.modelFrom : this.modelFrom.constructor).modelName;
|
||||
msg += this.isStatic ? '.' : '.prototype.';
|
||||
msg += this.name + '`.';
|
||||
|
@ -58,12 +58,12 @@ ScopeDefinition.prototype.targetModel = function(receiver) {
|
|||
* @returns {*}
|
||||
*/
|
||||
ScopeDefinition.prototype.related = function(receiver, scopeParams, condOrRefresh, options, cb) {
|
||||
var name = this.name;
|
||||
var self = receiver;
|
||||
const name = this.name;
|
||||
const self = receiver;
|
||||
|
||||
var actualCond = {};
|
||||
var actualRefresh = false;
|
||||
var saveOnCache = receiver instanceof DefaultModelBaseClass;
|
||||
let actualCond = {};
|
||||
let actualRefresh = false;
|
||||
let saveOnCache = receiver instanceof DefaultModelBaseClass;
|
||||
if (typeof condOrRefresh === 'function' &&
|
||||
options === undefined && cb === undefined) {
|
||||
// related(receiver, scopeParams, cb)
|
||||
|
@ -90,19 +90,20 @@ ScopeDefinition.prototype.related = function(receiver, scopeParams, condOrRefres
|
|||
actualRefresh;
|
||||
if (refreshIsNeeded) {
|
||||
// It either doesn't hit the cache or refresh is required
|
||||
var params = mergeQuery(actualCond, scopeParams, {nestedInclude: true});
|
||||
var targetModel = this.targetModel(receiver);
|
||||
const params = mergeQuery(actualCond, scopeParams, {nestedInclude: true});
|
||||
const targetModel = this.targetModel(receiver);
|
||||
|
||||
// If there is a through model
|
||||
// run another query to apply filter on relatedModel(targetModel)
|
||||
// see github.com/strongloop/loopback-datasource-juggler/issues/166
|
||||
var scopeOnRelatedModel = params.collect &&
|
||||
const scopeOnRelatedModel = params.collect &&
|
||||
params.include.scope !== null &&
|
||||
typeof params.include.scope === 'object';
|
||||
let filter, queryRelated;
|
||||
if (scopeOnRelatedModel) {
|
||||
var filter = params.include;
|
||||
filter = params.include;
|
||||
// The filter applied on relatedModel
|
||||
var queryRelated = filter.scope;
|
||||
queryRelated = filter.scope;
|
||||
delete params.include.scope;
|
||||
}
|
||||
|
||||
|
@ -113,18 +114,18 @@ ScopeDefinition.prototype.related = function(receiver, scopeParams, condOrRefres
|
|||
}
|
||||
|
||||
if (scopeOnRelatedModel === true) {
|
||||
var relatedModel = targetModel.relations[filter.relation].modelTo;
|
||||
var IdKey = idName(relatedModel);
|
||||
const relatedModel = targetModel.relations[filter.relation].modelTo;
|
||||
const IdKey = idName(relatedModel);
|
||||
|
||||
// return {inq: [1,2,3]}}
|
||||
var smartMerge = function(idCollection, qWhere) {
|
||||
const smartMerge = function(idCollection, qWhere) {
|
||||
if (!qWhere[IdKey]) return idCollection;
|
||||
var merged = {};
|
||||
let merged = {};
|
||||
|
||||
var idsA = idCollection.inq;
|
||||
var idsB = qWhere[IdKey].inq ? qWhere[IdKey].inq : [qWhere[IdKey]];
|
||||
const idsA = idCollection.inq;
|
||||
const idsB = qWhere[IdKey].inq ? qWhere[IdKey].inq : [qWhere[IdKey]];
|
||||
|
||||
var intersect = _.intersectionWith(idsA, idsB, _.isEqual);
|
||||
const intersect = _.intersectionWith(idsA, idsB, _.isEqual);
|
||||
if (intersect.length === 1) merged = intersect[0];
|
||||
if (intersect.length > 1) merged = {inq: intersect};
|
||||
|
||||
|
@ -133,7 +134,7 @@ ScopeDefinition.prototype.related = function(receiver, scopeParams, condOrRefres
|
|||
|
||||
if (queryRelated.where !== undefined) {
|
||||
// Merge queryRelated filter and targetId filter
|
||||
var IdKeyCondition = {};
|
||||
const IdKeyCondition = {};
|
||||
IdKeyCondition[IdKey] = smartMerge(collectTargetIds(data, IdKey),
|
||||
queryRelated.where);
|
||||
|
||||
|
@ -141,7 +142,7 @@ ScopeDefinition.prototype.related = function(receiver, scopeParams, condOrRefres
|
|||
// return empty result
|
||||
if (_.isObject(IdKeyCondition[IdKey]) && _.isEmpty(IdKeyCondition[IdKey])) return cb(null, []);
|
||||
|
||||
var mergedWhere = {
|
||||
const mergedWhere = {
|
||||
and: [
|
||||
IdKeyCondition,
|
||||
_.omit(queryRelated.where, IdKey),
|
||||
|
@ -201,8 +202,8 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
|
||||
options = options || {};
|
||||
// Check if the cls is the class itself or its prototype
|
||||
var isStatic = (typeof cls === 'function') || options.isStatic || false;
|
||||
var definition = new ScopeDefinition({
|
||||
const isStatic = (typeof cls === 'function') || options.isStatic || false;
|
||||
const definition = new ScopeDefinition({
|
||||
isStatic: isStatic,
|
||||
modelFrom: cls,
|
||||
modelTo: targetClass,
|
||||
|
@ -236,10 +237,10 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
*
|
||||
*/
|
||||
get: function() {
|
||||
var targetModel = definition.targetModel(this);
|
||||
var self = this;
|
||||
const targetModel = definition.targetModel(this);
|
||||
const self = this;
|
||||
|
||||
var f = function(condOrRefresh, options, cb) {
|
||||
const f = function(condOrRefresh, options, cb) {
|
||||
if (arguments.length === 0) {
|
||||
if (typeof f.value === 'function') {
|
||||
return f.value(self);
|
||||
|
@ -312,7 +313,7 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
f.findOne = findOne;
|
||||
f.count = count;
|
||||
|
||||
for (var i in definition.methods) {
|
||||
for (const i in definition.methods) {
|
||||
f[i] = definition.methods[i].bind(self);
|
||||
}
|
||||
|
||||
|
@ -336,52 +337,52 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
});
|
||||
|
||||
// Wrap the property into a function for remoting
|
||||
var fn = function() {
|
||||
const fn = function() {
|
||||
// primaryObject.scopeName, such as user.accounts
|
||||
var f = this[name];
|
||||
const f = this[name];
|
||||
// set receiver to be the scope property whose value is a function
|
||||
f.apply(this[name], arguments);
|
||||
};
|
||||
|
||||
cls['__get__' + name] = fn;
|
||||
|
||||
var fnCreate = function() {
|
||||
var f = this[name].create;
|
||||
const fnCreate = function() {
|
||||
const f = this[name].create;
|
||||
f.apply(this[name], arguments);
|
||||
};
|
||||
|
||||
cls['__create__' + name] = fnCreate;
|
||||
|
||||
var fnDelete = function() {
|
||||
var f = this[name].destroyAll;
|
||||
const fnDelete = function() {
|
||||
const f = this[name].destroyAll;
|
||||
f.apply(this[name], arguments);
|
||||
};
|
||||
|
||||
cls['__delete__' + name] = fnDelete;
|
||||
|
||||
var fnUpdate = function() {
|
||||
var f = this[name].updateAll;
|
||||
const fnUpdate = function() {
|
||||
const f = this[name].updateAll;
|
||||
f.apply(this[name], arguments);
|
||||
};
|
||||
|
||||
cls['__update__' + name] = fnUpdate;
|
||||
|
||||
var fnFindById = function(cb) {
|
||||
var f = this[name].findById;
|
||||
const fnFindById = function(cb) {
|
||||
const f = this[name].findById;
|
||||
f.apply(this[name], arguments);
|
||||
};
|
||||
|
||||
cls['__findById__' + name] = fnFindById;
|
||||
|
||||
var fnFindOne = function(cb) {
|
||||
var f = this[name].findOne;
|
||||
const fnFindOne = function(cb) {
|
||||
const f = this[name].findOne;
|
||||
f.apply(this[name], arguments);
|
||||
};
|
||||
|
||||
cls['__findOne__' + name] = fnFindOne;
|
||||
|
||||
var fnCount = function(cb) {
|
||||
var f = this[name].count;
|
||||
const fnCount = function(cb) {
|
||||
const f = this[name].count;
|
||||
f.apply(this[name], arguments);
|
||||
};
|
||||
|
||||
|
@ -391,8 +392,8 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
function build(data) {
|
||||
data = data || {};
|
||||
// Find all fixed property values for the scope
|
||||
var targetModel = definition.targetModel(this._receiver);
|
||||
var where = (this._scope && this._scope.where) || {};
|
||||
const targetModel = definition.targetModel(this._receiver);
|
||||
const where = (this._scope && this._scope.where) || {};
|
||||
setScopeValuesFromWhere(data, where, targetModel);
|
||||
return new targetModel(data);
|
||||
}
|
||||
|
@ -430,9 +431,9 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
}
|
||||
options = options || {};
|
||||
|
||||
var targetModel = definition.targetModel(this._receiver);
|
||||
var scoped = (this._scope && this._scope.where) || {};
|
||||
var filter = mergeQuery({where: scoped}, {where: where || {}});
|
||||
const targetModel = definition.targetModel(this._receiver);
|
||||
const scoped = (this._scope && this._scope.where) || {};
|
||||
const filter = mergeQuery({where: scoped}, {where: where || {}});
|
||||
return targetModel.destroyAll(filter.where, options, cb);
|
||||
}
|
||||
|
||||
|
@ -450,9 +451,9 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
options = {};
|
||||
}
|
||||
options = options || {};
|
||||
var targetModel = definition.targetModel(this._receiver);
|
||||
var scoped = (this._scope && this._scope.where) || {};
|
||||
var filter = mergeQuery({where: scoped}, {where: where || {}});
|
||||
const targetModel = definition.targetModel(this._receiver);
|
||||
const scoped = (this._scope && this._scope.where) || {};
|
||||
const filter = mergeQuery({where: scoped}, {where: where || {}});
|
||||
return targetModel.updateAll(filter.where, data, options, cb);
|
||||
}
|
||||
|
||||
|
@ -478,9 +479,9 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
|
||||
options = options || {};
|
||||
filter = filter || {};
|
||||
var targetModel = definition.targetModel(this._receiver);
|
||||
var idName = targetModel.definition.idName();
|
||||
var query = {where: {}};
|
||||
const targetModel = definition.targetModel(this._receiver);
|
||||
const idName = targetModel.definition.idName();
|
||||
let query = {where: {}};
|
||||
query.where[idName] = id;
|
||||
query = mergeQuery(query, filter);
|
||||
return this.findOne(query, options, cb);
|
||||
|
@ -498,8 +499,8 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
options = {};
|
||||
}
|
||||
options = options || {};
|
||||
var targetModel = definition.targetModel(this._receiver);
|
||||
var scoped = (this._scope && this._scope.where) || {};
|
||||
const targetModel = definition.targetModel(this._receiver);
|
||||
const scoped = (this._scope && this._scope.where) || {};
|
||||
filter = mergeQuery({where: scoped}, filter || {});
|
||||
return targetModel.findOne(filter, options, cb);
|
||||
}
|
||||
|
@ -516,9 +517,9 @@ function defineScope(cls, targetClass, name, params, methods, options) {
|
|||
}
|
||||
options = options || {};
|
||||
|
||||
var targetModel = definition.targetModel(this._receiver);
|
||||
var scoped = (this._scope && this._scope.where) || {};
|
||||
var filter = mergeQuery({where: scoped}, {where: where || {}});
|
||||
const targetModel = definition.targetModel(this._receiver);
|
||||
const scoped = (this._scope && this._scope.where) || {};
|
||||
const filter = mergeQuery({where: scoped}, {where: where || {}});
|
||||
return targetModel.count(filter.where, options, cb);
|
||||
}
|
||||
|
||||
|
|
|
@ -4,14 +4,14 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var g = require('strong-globalize')();
|
||||
var debug = require('debug')('loopback:connector:transaction');
|
||||
var uuid = require('uuid');
|
||||
var utils = require('./utils');
|
||||
var jutil = require('./jutil');
|
||||
var ObserverMixin = require('./observer');
|
||||
const g = require('strong-globalize')();
|
||||
const debug = require('debug')('loopback:connector:transaction');
|
||||
const uuid = require('uuid');
|
||||
const utils = require('./utils');
|
||||
const jutil = require('./jutil');
|
||||
const ObserverMixin = require('./observer');
|
||||
|
||||
var Transaction = require('loopback-connector').Transaction;
|
||||
const Transaction = require('loopback-connector').Transaction;
|
||||
|
||||
module.exports = TransactionMixin;
|
||||
|
||||
|
@ -73,7 +73,7 @@ function TransactionMixin() {
|
|||
TransactionMixin.beginTransaction = function(options, cb) {
|
||||
cb = cb || utils.createPromiseCallback();
|
||||
if (Transaction) {
|
||||
var connector = this.getConnector();
|
||||
const connector = this.getConnector();
|
||||
Transaction.begin(connector, options, function(err, transaction) {
|
||||
if (err) return cb(err);
|
||||
// NOTE(lehni) As part of the process of moving the handling of
|
||||
|
@ -87,7 +87,7 @@ TransactionMixin.beginTransaction = function(options, cb) {
|
|||
}
|
||||
if (options.timeout && !transaction.timeout) {
|
||||
transaction.timeout = setTimeout(function() {
|
||||
var context = {
|
||||
const context = {
|
||||
transaction: transaction,
|
||||
operation: 'timeout',
|
||||
};
|
||||
|
@ -105,7 +105,7 @@ TransactionMixin.beginTransaction = function(options, cb) {
|
|||
});
|
||||
} else {
|
||||
process.nextTick(function() {
|
||||
var err = new Error(g.f('{{Transaction}} is not supported'));
|
||||
const err = new Error(g.f('{{Transaction}} is not supported'));
|
||||
cb(err);
|
||||
});
|
||||
}
|
||||
|
@ -136,7 +136,7 @@ if (Transaction) {
|
|||
Transaction.prototype.commit = function(cb) {
|
||||
cb = cb || utils.createPromiseCallback();
|
||||
if (this.ensureActive(cb)) {
|
||||
var context = {
|
||||
const context = {
|
||||
transaction: this,
|
||||
operation: 'commit',
|
||||
};
|
||||
|
@ -175,7 +175,7 @@ if (Transaction) {
|
|||
Transaction.prototype.rollback = function(cb) {
|
||||
cb = cb || utils.createPromiseCallback();
|
||||
if (this.ensureActive(cb)) {
|
||||
var context = {
|
||||
const context = {
|
||||
transaction: this,
|
||||
operation: 'rollback',
|
||||
};
|
||||
|
|
10
lib/types.js
10
lib/types.js
|
@ -4,7 +4,7 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var Types = {};
|
||||
const Types = {};
|
||||
/**
|
||||
* Schema types
|
||||
*/
|
||||
|
@ -40,10 +40,10 @@ Types.Any.prototype.toObject = Types.Any.prototype.toJSON = function() {
|
|||
};
|
||||
|
||||
module.exports = function(modelTypes) {
|
||||
var DateString = require('./date-string');
|
||||
var GeoPoint = require('./geo').GeoPoint;
|
||||
const DateString = require('./date-string');
|
||||
const GeoPoint = require('./geo').GeoPoint;
|
||||
|
||||
for (var t in Types) {
|
||||
for (const t in Types) {
|
||||
modelTypes[t] = Types[t];
|
||||
}
|
||||
|
||||
|
@ -51,7 +51,7 @@ module.exports = function(modelTypes) {
|
|||
modelTypes.registerType = function(type, names) {
|
||||
names = names || [];
|
||||
names = names.concat([type.name]);
|
||||
for (var n = 0; n < names.length; n++) {
|
||||
for (let n = 0; n < names.length; n++) {
|
||||
this.schemaTypes[names[n].toLowerCase()] = type;
|
||||
}
|
||||
};
|
||||
|
|
150
lib/utils.js
150
lib/utils.js
|
@ -28,10 +28,10 @@ exports.idName = idName;
|
|||
exports.rankArrayElements = rankArrayElements;
|
||||
exports.idsHaveDuplicates = idsHaveDuplicates;
|
||||
|
||||
var g = require('strong-globalize')();
|
||||
var traverse = require('traverse');
|
||||
var assert = require('assert');
|
||||
var debug = require('debug')('loopback:juggler:utils');
|
||||
const g = require('strong-globalize')();
|
||||
const traverse = require('traverse');
|
||||
const assert = require('assert');
|
||||
const debug = require('debug')('loopback:juggler:utils');
|
||||
|
||||
function safeRequire(module) {
|
||||
try {
|
||||
|
@ -52,17 +52,17 @@ function safeRequire(module) {
|
|||
* @param {Object} The where clause
|
||||
*/
|
||||
function setScopeValuesFromWhere(data, where, targetModel) {
|
||||
for (var i in where) {
|
||||
for (const i in where) {
|
||||
if (i === 'and') {
|
||||
// Find fixed property values from each subclauses
|
||||
for (var w = 0, n = where[i].length; w < n; w++) {
|
||||
for (let w = 0, n = where[i].length; w < n; w++) {
|
||||
setScopeValuesFromWhere(data, where[i][w], targetModel);
|
||||
}
|
||||
continue;
|
||||
}
|
||||
var prop = targetModel.definition.properties[i];
|
||||
const prop = targetModel.definition.properties[i];
|
||||
if (prop) {
|
||||
var val = where[i];
|
||||
const val = where[i];
|
||||
if (typeof val !== 'object' || val instanceof prop.type ||
|
||||
prop.type.name === 'ObjectID' || // MongoDB key
|
||||
prop.type.name === 'uuidFromString') { // C*
|
||||
|
@ -82,26 +82,26 @@ function setScopeValuesFromWhere(data, where, targetModel) {
|
|||
* @returns {Object}
|
||||
*/
|
||||
function mergeIncludes(destination, source) {
|
||||
var destArray = convertToArray(destination);
|
||||
var sourceArray = convertToArray(source);
|
||||
const destArray = convertToArray(destination);
|
||||
const sourceArray = convertToArray(source);
|
||||
if (destArray.length === 0) {
|
||||
return sourceArray;
|
||||
}
|
||||
if (sourceArray.length === 0) {
|
||||
return destArray;
|
||||
}
|
||||
var relationNames = [];
|
||||
var resultArray = [];
|
||||
for (var j in sourceArray) {
|
||||
var sourceEntry = sourceArray[j];
|
||||
var sourceEntryRelationName = (typeof (sourceEntry.rel || sourceEntry.relation) === 'string') ?
|
||||
const relationNames = [];
|
||||
const resultArray = [];
|
||||
for (const j in sourceArray) {
|
||||
const sourceEntry = sourceArray[j];
|
||||
const sourceEntryRelationName = (typeof (sourceEntry.rel || sourceEntry.relation) === 'string') ?
|
||||
sourceEntry.relation : Object.keys(sourceEntry)[0];
|
||||
relationNames.push(sourceEntryRelationName);
|
||||
resultArray.push(sourceEntry);
|
||||
}
|
||||
for (var i in destArray) {
|
||||
var destEntry = destArray[i];
|
||||
var destEntryRelationName = (typeof (destEntry.rel || destEntry.relation) === 'string') ?
|
||||
for (const i in destArray) {
|
||||
const destEntry = destArray[i];
|
||||
const destEntryRelationName = (typeof (destEntry.rel || destEntry.relation) === 'string') ?
|
||||
destEntry.relation : Object.keys(destEntry)[0];
|
||||
if (relationNames.indexOf(destEntryRelationName) === -1) {
|
||||
resultArray.push(destEntry);
|
||||
|
@ -129,17 +129,17 @@ function convertToArray(include) {
|
|||
return [include];
|
||||
}
|
||||
// Build an array of key/value pairs
|
||||
var newInclude = [];
|
||||
for (var key in include) {
|
||||
const newInclude = [];
|
||||
for (const key in include) {
|
||||
const obj = {};
|
||||
obj[key] = include[key];
|
||||
newInclude.push(obj);
|
||||
}
|
||||
return newInclude;
|
||||
} else if (Array.isArray(include)) {
|
||||
var normalized = [];
|
||||
for (var i in include) {
|
||||
var includeEntry = include[i];
|
||||
const normalized = [];
|
||||
for (const i in include) {
|
||||
const includeEntry = include[i];
|
||||
if (typeof includeEntry === 'string') {
|
||||
const obj = {};
|
||||
obj[includeEntry] = true;
|
||||
|
@ -185,7 +185,7 @@ function mergeQuery(base, update, spec) {
|
|||
// specify nestedInclude=true to force nesting of inclusions on scoped
|
||||
// queries. e.g. In physician.patients.find({include: 'address'}),
|
||||
// inclusion should be on patient model, not on physician model.
|
||||
var saved = base.include;
|
||||
const saved = base.include;
|
||||
base.include = {};
|
||||
base.include[update.include] = saved;
|
||||
} else {
|
||||
|
@ -217,7 +217,7 @@ function mergeQuery(base, update, spec) {
|
|||
base.limit = update.limit;
|
||||
}
|
||||
|
||||
var skip = spec.skip !== false && spec.offset !== false;
|
||||
const skip = spec.skip !== false && spec.offset !== false;
|
||||
|
||||
if (skip && update.skip !== undefined) {
|
||||
base.skip = update.skip;
|
||||
|
@ -241,8 +241,8 @@ function fieldsToArray(fields, properties, excludeUnknown) {
|
|||
if (!fields) return;
|
||||
|
||||
// include all properties by default
|
||||
var result = properties;
|
||||
var i, n;
|
||||
let result = properties;
|
||||
let i, n;
|
||||
|
||||
if (typeof fields === 'string') {
|
||||
result = [fields];
|
||||
|
@ -251,13 +251,13 @@ function fieldsToArray(fields, properties, excludeUnknown) {
|
|||
result = fields;
|
||||
} else if ('object' === typeof fields) {
|
||||
// { field1: boolean, field2: boolean ... }
|
||||
var included = [];
|
||||
var excluded = [];
|
||||
var keys = Object.keys(fields);
|
||||
const included = [];
|
||||
const excluded = [];
|
||||
const keys = Object.keys(fields);
|
||||
if (!keys.length) return;
|
||||
|
||||
for (i = 0, n = keys.length; i < n; i++) {
|
||||
var k = keys[i];
|
||||
const k = keys[i];
|
||||
if (fields[k]) {
|
||||
included.push(k);
|
||||
} else if ((k in fields) && !fields[k]) {
|
||||
|
@ -268,13 +268,13 @@ function fieldsToArray(fields, properties, excludeUnknown) {
|
|||
result = included;
|
||||
} else if (excluded.length > 0) {
|
||||
for (i = 0, n = excluded.length; i < n; i++) {
|
||||
var index = result.indexOf(excluded[i]);
|
||||
const index = result.indexOf(excluded[i]);
|
||||
if (index !== -1) result.splice(index, 1); // only when existing field excluded
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
var fieldArray = [];
|
||||
let fieldArray = [];
|
||||
if (excludeUnknown) {
|
||||
for (i = 0, n = result.length; i < n; i++) {
|
||||
if (properties.indexOf(result[i]) !== -1) {
|
||||
|
@ -290,10 +290,10 @@ function fieldsToArray(fields, properties, excludeUnknown) {
|
|||
function selectFields(fields) {
|
||||
// map function
|
||||
return function(obj) {
|
||||
var result = {};
|
||||
var key;
|
||||
const result = {};
|
||||
let key;
|
||||
|
||||
for (var i = 0; i < fields.length; i++) {
|
||||
for (let i = 0; i < fields.length; i++) {
|
||||
key = fields[i];
|
||||
|
||||
result[key] = obj[key];
|
||||
|
@ -307,7 +307,7 @@ function isProhibited(key, prohibitedKeys) {
|
|||
if (typeof key !== 'string') {
|
||||
return false;
|
||||
}
|
||||
for (var k of prohibitedKeys) {
|
||||
for (const k of prohibitedKeys) {
|
||||
if (k === key) return true;
|
||||
// x.secret, secret.y, or x.secret.y
|
||||
if (key.split('.').indexOf(k) !== -1) return true;
|
||||
|
@ -416,8 +416,8 @@ function parseSettings(urlStr) {
|
|||
if (!urlStr) {
|
||||
return {};
|
||||
}
|
||||
var uri = url.parse(urlStr, false);
|
||||
var settings = {};
|
||||
const uri = url.parse(urlStr, false);
|
||||
const settings = {};
|
||||
settings.connector = uri.protocol && uri.protocol.split(':')[0]; // Remove the trailing :
|
||||
settings.host = settings.hostname = uri.hostname;
|
||||
settings.port = uri.port && Number(uri.port); // port is a string
|
||||
|
@ -426,8 +426,8 @@ function parseSettings(urlStr) {
|
|||
settings.database = uri.pathname && uri.pathname.split('/')[1]; // remove the leading /
|
||||
settings.url = urlStr;
|
||||
if (uri.query) {
|
||||
var params = qs.parse(uri.query);
|
||||
for (var p in params) {
|
||||
const params = qs.parse(uri.query);
|
||||
for (const p in params) {
|
||||
settings[p] = params[p];
|
||||
}
|
||||
}
|
||||
|
@ -451,8 +451,8 @@ function parseSettings(urlStr) {
|
|||
*/
|
||||
function deepMerge(base, extras) {
|
||||
// deepMerge allows undefined extras to allow deep cloning of arrays
|
||||
var array = Array.isArray(base) && (Array.isArray(extras) || !extras);
|
||||
var dst = array && [] || {};
|
||||
const array = Array.isArray(base) && (Array.isArray(extras) || !extras);
|
||||
let dst = array && [] || {};
|
||||
|
||||
if (array) {
|
||||
// extras or base is an array
|
||||
|
@ -480,7 +480,7 @@ function deepMerge(base, extras) {
|
|||
if (extras != null && typeof extras === 'object') {
|
||||
// extras is an object {}
|
||||
Object.keys(extras).forEach(function(key) {
|
||||
var extra = extras[key];
|
||||
const extra = extras[key];
|
||||
if (extra == null || typeof extra !== 'object') {
|
||||
// extra item value is null, undefined or not an object
|
||||
dst[key] = extra;
|
||||
|
@ -511,8 +511,8 @@ function deepMerge(base, extras) {
|
|||
* @returns {Object} The merged property
|
||||
*/
|
||||
function deepMergeProperty(base, extras) {
|
||||
let mergedObject = deepMerge({key: base}, {key: extras});
|
||||
let mergedProperty = mergedObject.key;
|
||||
const mergedObject = deepMerge({key: base}, {key: extras});
|
||||
const mergedProperty = mergedObject.key;
|
||||
return mergedProperty;
|
||||
}
|
||||
|
||||
|
@ -583,26 +583,26 @@ function sortObjectsByIds(idName, ids, objects, strict) {
|
|||
return (typeof id === 'object') ? String(id) : id;
|
||||
});
|
||||
|
||||
var indexOf = function(x) {
|
||||
var isObj = (typeof x[idName] === 'object'); // ObjectID
|
||||
var id = isObj ? String(x[idName]) : x[idName];
|
||||
const indexOf = function(x) {
|
||||
const isObj = (typeof x[idName] === 'object'); // ObjectID
|
||||
const id = isObj ? String(x[idName]) : x[idName];
|
||||
return ids.indexOf(id);
|
||||
};
|
||||
|
||||
var heading = [];
|
||||
var tailing = [];
|
||||
const heading = [];
|
||||
const tailing = [];
|
||||
|
||||
objects.forEach(function(x) {
|
||||
if (typeof x === 'object') {
|
||||
var idx = indexOf(x);
|
||||
const idx = indexOf(x);
|
||||
if (strict && idx === -1) return;
|
||||
idx === -1 ? tailing.push(x) : heading.push(x);
|
||||
}
|
||||
});
|
||||
|
||||
heading.sort(function(x, y) {
|
||||
var a = indexOf(x);
|
||||
var b = indexOf(y);
|
||||
const a = indexOf(x);
|
||||
const b = indexOf(y);
|
||||
if (a === -1 || b === -1) return 1; // last
|
||||
if (a === b) return 0;
|
||||
if (a > b) return 1;
|
||||
|
@ -613,8 +613,8 @@ function sortObjectsByIds(idName, ids, objects, strict) {
|
|||
}
|
||||
|
||||
function createPromiseCallback() {
|
||||
var cb;
|
||||
var promise = new Promise(function(resolve, reject) {
|
||||
let cb;
|
||||
const promise = new Promise(function(resolve, reject) {
|
||||
cb = function(err, data) {
|
||||
if (err) return reject(err);
|
||||
return resolve(data);
|
||||
|
@ -636,15 +636,15 @@ function isBsonType(value) {
|
|||
* @returns {Array} an array with unique items
|
||||
*/
|
||||
function uniq(a) {
|
||||
var uniqArray = [];
|
||||
const uniqArray = [];
|
||||
if (!a) {
|
||||
return uniqArray;
|
||||
}
|
||||
assert(Array.isArray(a), 'array argument is required');
|
||||
var comparableA = a.map(
|
||||
const comparableA = a.map(
|
||||
item => isBsonType(item) ? item.toString() : item
|
||||
);
|
||||
for (var i = 0, n = comparableA.length; i < n; i++) {
|
||||
for (let i = 0, n = comparableA.length; i < n; i++) {
|
||||
if (comparableA.indexOf(comparableA[i]) === i) {
|
||||
uniqArray.push(a[i]);
|
||||
}
|
||||
|
@ -658,8 +658,8 @@ function uniq(a) {
|
|||
* @returns {Object} A RegExp object
|
||||
*/
|
||||
function toRegExp(regex) {
|
||||
var isString = typeof regex === 'string';
|
||||
var isRegExp = regex instanceof RegExp;
|
||||
const isString = typeof regex === 'string';
|
||||
const isRegExp = regex instanceof RegExp;
|
||||
|
||||
if (!(isString || isRegExp))
|
||||
return new Error(g.f('Invalid argument, must be a string, {{regex}} literal, or ' +
|
||||
|
@ -672,20 +672,20 @@ function toRegExp(regex) {
|
|||
return new RegExp(regex);
|
||||
|
||||
// only accept i, g, or m as valid regex flags
|
||||
var flags = regex.split('/').pop().split('');
|
||||
var validFlags = ['i', 'g', 'm'];
|
||||
var invalidFlags = [];
|
||||
const flags = regex.split('/').pop().split('');
|
||||
const validFlags = ['i', 'g', 'm'];
|
||||
const invalidFlags = [];
|
||||
flags.forEach(function(flag) {
|
||||
if (validFlags.indexOf(flag) === -1)
|
||||
invalidFlags.push(flag);
|
||||
});
|
||||
|
||||
var hasInvalidFlags = invalidFlags.length > 0;
|
||||
const hasInvalidFlags = invalidFlags.length > 0;
|
||||
if (hasInvalidFlags)
|
||||
return new Error(g.f('Invalid {{regex}} flags: %s', invalidFlags));
|
||||
|
||||
// strip regex delimiter forward slashes
|
||||
var expression = regex.substr(1, regex.lastIndexOf('/') - 1);
|
||||
const expression = regex.substr(1, regex.lastIndexOf('/') - 1);
|
||||
return new RegExp(expression, flags.join(''));
|
||||
}
|
||||
|
||||
|
@ -723,7 +723,7 @@ function findIndexOf(arr, target, isEqual) {
|
|||
return arr.indexOf(target);
|
||||
}
|
||||
|
||||
for (var i = 0; i < arr.length; i++) {
|
||||
for (let i = 0; i < arr.length; i++) {
|
||||
if (isEqual(arr[i], target)) { return i; }
|
||||
}
|
||||
|
||||
|
@ -737,12 +737,12 @@ function findIndexOf(arr, target, isEqual) {
|
|||
* @returns {Object} The object that queries targetIds
|
||||
*/
|
||||
function collectTargetIds(targetData, idPropertyName) {
|
||||
var targetIds = [];
|
||||
for (var i = 0; i < targetData.length; i++) {
|
||||
var targetId = targetData[i][idPropertyName];
|
||||
const targetIds = [];
|
||||
for (let i = 0; i < targetData.length; i++) {
|
||||
const targetId = targetData[i][idPropertyName];
|
||||
targetIds.push(targetId);
|
||||
}
|
||||
var IdQuery = {
|
||||
const IdQuery = {
|
||||
inq: uniq(targetIds),
|
||||
};
|
||||
return IdQuery;
|
||||
|
@ -765,12 +765,12 @@ function idName(m) {
|
|||
*/
|
||||
function idsHaveDuplicates(ids) {
|
||||
// use Set if available and all ids are of string or number type
|
||||
var hasDuplicates = undefined;
|
||||
var i, j;
|
||||
let hasDuplicates = undefined;
|
||||
let i, j;
|
||||
if (typeof Set === 'function') {
|
||||
var uniqueIds = new Set();
|
||||
const uniqueIds = new Set();
|
||||
for (i = 0; i < ids.length; ++i) {
|
||||
var idType = typeof ids[i];
|
||||
const idType = typeof ids[i];
|
||||
if (idType === 'string' || idType === 'number') {
|
||||
if (uniqueIds.has(ids[i])) {
|
||||
hasDuplicates = true;
|
||||
|
|
|
@ -5,9 +5,9 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var g = require('strong-globalize')();
|
||||
var util = require('util');
|
||||
var extend = util._extend;
|
||||
const g = require('strong-globalize')();
|
||||
const util = require('util');
|
||||
const extend = util._extend;
|
||||
|
||||
/*!
|
||||
* Module exports
|
||||
|
@ -307,7 +307,7 @@ function validateAbsence(attr, conf, err, options) {
|
|||
function validateLength(attr, conf, err, options) {
|
||||
if (nullCheck.call(this, attr, conf, err)) return;
|
||||
|
||||
var len = this[attr].length;
|
||||
const len = this[attr].length;
|
||||
if (conf.min && len < conf.min) {
|
||||
err('min');
|
||||
}
|
||||
|
@ -362,7 +362,7 @@ function validateFormat(attr, conf, err, options) {
|
|||
if (nullCheck.call(this, attr, conf, err)) return;
|
||||
|
||||
if (typeof this[attr] === 'string' || typeof this[attr] === 'number') {
|
||||
let regex = new RegExp(conf['with']);
|
||||
const regex = new RegExp(conf['with']);
|
||||
if (!regex.test(this[attr])) {
|
||||
err();
|
||||
}
|
||||
|
@ -397,7 +397,7 @@ function escapeStringRegexp(str) {
|
|||
if (typeof str !== 'string') {
|
||||
throw new TypeError('Expected a string');
|
||||
}
|
||||
var matchOperatorsRe = /[|\\{}()[\]^$+*?.]/g;
|
||||
const matchOperatorsRe = /[|\\{}()[\]^$+*?.]/g;
|
||||
return str.replace(matchOperatorsRe, '\\$&');
|
||||
}
|
||||
|
||||
|
@ -412,7 +412,7 @@ function validateUniqueness(attr, conf, err, options, done) {
|
|||
if (blank(this[attr])) {
|
||||
return process.nextTick(done);
|
||||
}
|
||||
var cond = {where: {}};
|
||||
const cond = {where: {}};
|
||||
|
||||
if (conf && conf.ignoreCase) {
|
||||
cond.where[attr] = new RegExp('^' + escapeStringRegexp(this[attr]) + '$', 'i');
|
||||
|
@ -422,14 +422,14 @@ function validateUniqueness(attr, conf, err, options, done) {
|
|||
|
||||
if (conf && conf.scopedTo) {
|
||||
conf.scopedTo.forEach(function(k) {
|
||||
var val = this[k];
|
||||
const val = this[k];
|
||||
if (val !== undefined)
|
||||
cond.where[k] = this[k];
|
||||
}, this);
|
||||
}
|
||||
|
||||
var idName = this.constructor.definition.idName();
|
||||
var isNewRecord = this.isNewRecord();
|
||||
const idName = this.constructor.definition.idName();
|
||||
const isNewRecord = this.isNewRecord();
|
||||
this.constructor.find(cond, options, function(error, found) {
|
||||
if (error) {
|
||||
err(error);
|
||||
|
@ -452,11 +452,11 @@ function validateUniqueness(attr, conf, err, options, done) {
|
|||
function validateDate(attr, conf, err) {
|
||||
if (this[attr] === null || this[attr] === undefined) return;
|
||||
|
||||
var date = new Date(this[attr]);
|
||||
const date = new Date(this[attr]);
|
||||
if (isNaN(date.getTime())) return err();
|
||||
}
|
||||
|
||||
var validators = {
|
||||
const validators = {
|
||||
presence: validatePresence,
|
||||
absence: validateAbsence,
|
||||
length: validateLength,
|
||||
|
@ -471,7 +471,7 @@ var validators = {
|
|||
|
||||
function getConfigurator(name, opts) {
|
||||
return function() {
|
||||
var args = Array.prototype.slice.call(arguments);
|
||||
const args = Array.prototype.slice.call(arguments);
|
||||
args[1] = args[1] || {};
|
||||
configure(this, name, args, opts);
|
||||
};
|
||||
|
@ -513,10 +513,11 @@ function getConfigurator(name, opts) {
|
|||
*/
|
||||
Validatable.prototype.isValid = function(callback, data, options) {
|
||||
options = options || {};
|
||||
var valid = true, inst = this, wait = 0, async = false;
|
||||
var validations = this.constructor.validations;
|
||||
let valid = true, wait = 0, async = false;
|
||||
const inst = this;
|
||||
const validations = this.constructor.validations;
|
||||
|
||||
var reportDiscardedProperties = this.__strict &&
|
||||
const reportDiscardedProperties = this.__strict &&
|
||||
this.__unknownProperties && this.__unknownProperties.length;
|
||||
|
||||
// exit with success when no errors
|
||||
|
@ -539,13 +540,13 @@ Validatable.prototype.isValid = function(callback, data, options) {
|
|||
});
|
||||
|
||||
this.trigger('validate', function(validationsDone) {
|
||||
var inst = this,
|
||||
asyncFail = false;
|
||||
const inst = this;
|
||||
let asyncFail = false;
|
||||
|
||||
var attrs = Object.keys(validations || {});
|
||||
const attrs = Object.keys(validations || {});
|
||||
|
||||
attrs.forEach(function(attr) {
|
||||
var attrValidations = validations[attr] || [];
|
||||
const attrValidations = validations[attr] || [];
|
||||
attrValidations.forEach(function(v) {
|
||||
if (v.options && v.options.async) {
|
||||
async = true;
|
||||
|
@ -562,10 +563,10 @@ Validatable.prototype.isValid = function(callback, data, options) {
|
|||
});
|
||||
|
||||
if (reportDiscardedProperties) {
|
||||
for (var ix in inst.__unknownProperties) {
|
||||
var key = inst.__unknownProperties[ix];
|
||||
var code = 'unknown-property';
|
||||
var msg = defaultMessages[code];
|
||||
for (const ix in inst.__unknownProperties) {
|
||||
const key = inst.__unknownProperties[ix];
|
||||
const code = 'unknown-property';
|
||||
const msg = defaultMessages[code];
|
||||
inst.errors.add(key, msg, code);
|
||||
valid = false;
|
||||
}
|
||||
|
@ -611,7 +612,7 @@ function cleanErrors(inst) {
|
|||
}
|
||||
|
||||
function validationFailed(inst, attr, conf, options, cb) {
|
||||
var opts = conf.options || {};
|
||||
const opts = conf.options || {};
|
||||
|
||||
if (typeof options === 'function') {
|
||||
cb = options;
|
||||
|
@ -628,13 +629,13 @@ function validationFailed(inst, attr, conf, options, cb) {
|
|||
return false;
|
||||
}
|
||||
|
||||
var fail = false;
|
||||
var validator = validators[conf.validation];
|
||||
var validatorArguments = [];
|
||||
let fail = false;
|
||||
const validator = validators[conf.validation];
|
||||
const validatorArguments = [];
|
||||
validatorArguments.push(attr);
|
||||
validatorArguments.push(conf);
|
||||
validatorArguments.push(function onerror(kind) {
|
||||
var message, code = conf.code || conf.validation;
|
||||
let message, code = conf.code || conf.validation;
|
||||
if (conf.message) {
|
||||
message = conf.message;
|
||||
}
|
||||
|
@ -669,7 +670,7 @@ function validationFailed(inst, attr, conf, options, cb) {
|
|||
}
|
||||
|
||||
function skipValidation(inst, conf, kind) {
|
||||
var doValidate = true;
|
||||
let doValidate = true;
|
||||
if (typeof conf[kind] === 'function') {
|
||||
doValidate = conf[kind].call(inst);
|
||||
if (kind === 'unless') doValidate = !doValidate;
|
||||
|
@ -687,7 +688,7 @@ function skipValidation(inst, conf, kind) {
|
|||
return !doValidate;
|
||||
}
|
||||
|
||||
var defaultMessages = {
|
||||
const defaultMessages = {
|
||||
presence: 'can\'t be blank',
|
||||
absence: 'can\'t be set',
|
||||
'unknown-property': 'is not defined in the model',
|
||||
|
@ -764,7 +765,7 @@ function configure(cls, validation, args, opts) {
|
|||
});
|
||||
}
|
||||
args = [].slice.call(args);
|
||||
var conf;
|
||||
let conf;
|
||||
if (typeof args[args.length - 1] === 'object') {
|
||||
conf = args.pop();
|
||||
} else {
|
||||
|
@ -776,7 +777,7 @@ function configure(cls, validation, args, opts) {
|
|||
conf.validation = validation;
|
||||
args.forEach(function(attr) {
|
||||
if (typeof attr === 'string') {
|
||||
var validation = extend({}, conf);
|
||||
const validation = extend({}, conf);
|
||||
validation.options = opts || {};
|
||||
cls.validations[attr] = cls.validations[attr] || [];
|
||||
cls.validations[attr].push(validation);
|
||||
|
@ -803,7 +804,7 @@ Errors.prototype.add = function(field, message, code) {
|
|||
};
|
||||
|
||||
function ErrorCodes(messages) {
|
||||
var c = this;
|
||||
const c = this;
|
||||
Object.keys(messages).forEach(function(field) {
|
||||
c[field] = messages[field].codes;
|
||||
});
|
||||
|
@ -866,7 +867,7 @@ function ValidationError(obj) {
|
|||
|
||||
this.name = 'ValidationError';
|
||||
|
||||
var context = obj && obj.constructor && obj.constructor.modelName;
|
||||
const context = obj && obj.constructor && obj.constructor.modelName;
|
||||
this.message = g.f(
|
||||
'The %s instance is not valid. Details: %s.',
|
||||
context ? '`' + context + '`' : 'model',
|
||||
|
@ -894,20 +895,20 @@ function ValidationError(obj) {
|
|||
|
||||
util.inherits(ValidationError, Error);
|
||||
|
||||
var errorHasStackProperty = !!(new Error).stack;
|
||||
const errorHasStackProperty = !!(new Error).stack;
|
||||
|
||||
ValidationError.maxPropertyStringLength = 32;
|
||||
|
||||
function formatErrors(errors, propertyValues) {
|
||||
var DELIM = '; ';
|
||||
const DELIM = '; ';
|
||||
errors = errors || {};
|
||||
return Object.getOwnPropertyNames(errors)
|
||||
.filter(function(propertyName) {
|
||||
return Array.isArray(errors[propertyName]);
|
||||
})
|
||||
.map(function(propertyName) {
|
||||
var messages = errors[propertyName];
|
||||
var propertyValue = propertyValues[propertyName];
|
||||
const messages = errors[propertyName];
|
||||
const propertyValue = propertyValues[propertyName];
|
||||
return messages.map(function(msg) {
|
||||
return formatPropertyError(propertyName, propertyValue, msg);
|
||||
}).join(DELIM);
|
||||
|
@ -916,8 +917,8 @@ function formatErrors(errors, propertyValues) {
|
|||
}
|
||||
|
||||
function formatPropertyError(propertyName, propertyValue, errorMessage) {
|
||||
var formattedValue;
|
||||
var valueType = typeof propertyValue;
|
||||
let formattedValue;
|
||||
const valueType = typeof propertyValue;
|
||||
if (valueType === 'string') {
|
||||
formattedValue = JSON.stringify(truncatePropertyString(propertyValue));
|
||||
} else if (propertyValue instanceof Date) {
|
||||
|
@ -939,13 +940,13 @@ function formatPropertyError(propertyName, propertyValue, errorMessage) {
|
|||
}
|
||||
|
||||
function truncatePropertyString(value) {
|
||||
var len = ValidationError.maxPropertyStringLength;
|
||||
let len = ValidationError.maxPropertyStringLength;
|
||||
if (value.length <= len) return value;
|
||||
|
||||
// preserve few last characters like `}` or `]`, but no more than 3
|
||||
// this way the last `} ]` in the array of objects is included in the message
|
||||
var tail;
|
||||
var m = value.match(/([ \t})\]]+)$/);
|
||||
let tail;
|
||||
const m = value.match(/([ \t})\]]+)$/);
|
||||
if (m) {
|
||||
tail = m[1].slice(-3);
|
||||
len -= tail.length;
|
||||
|
|
|
@ -12,30 +12,30 @@
|
|||
* $ open hooks.hml
|
||||
*
|
||||
*/
|
||||
var Promise = global.Promise = require('bluebird');
|
||||
var DataSource = require('../').DataSource;
|
||||
var Memory = require('../lib/connectors/memory').Memory;
|
||||
const Promise = global.Promise = require('bluebird');
|
||||
const DataSource = require('../').DataSource;
|
||||
const Memory = require('../lib/connectors/memory').Memory;
|
||||
|
||||
var HOOK_NAMES = [
|
||||
const HOOK_NAMES = [
|
||||
'access',
|
||||
'before save', 'persist', 'loaded', 'after save',
|
||||
'before delete', 'after delete',
|
||||
];
|
||||
|
||||
var dataSources = [
|
||||
const dataSources = [
|
||||
createOptimizedDataSource(),
|
||||
createUnoptimizedDataSource(),
|
||||
];
|
||||
|
||||
var observedContexts = [];
|
||||
var lastId = 0;
|
||||
const observedContexts = [];
|
||||
let lastId = 0;
|
||||
|
||||
Promise.onPossiblyUnhandledRejection(function(err) {
|
||||
console.error('POSSIBLY UNHANDLED REJECTION', err.stack);
|
||||
});
|
||||
|
||||
/* eslint-disable camelcase */
|
||||
var operations = [
|
||||
const operations = [
|
||||
function find(ds) {
|
||||
return ds.TestModel.find({where: {id: '1'}});
|
||||
},
|
||||
|
@ -112,7 +112,7 @@ var operations = [
|
|||
];
|
||||
/* eslint-enable camelcase */
|
||||
|
||||
var p = setupTestModels();
|
||||
let p = setupTestModels();
|
||||
operations.forEach(function(op) {
|
||||
p = p.then(runner(op));
|
||||
});
|
||||
|
@ -120,13 +120,13 @@ operations.forEach(function(op) {
|
|||
p.then(report, function(err) { console.error(err.stack); });
|
||||
|
||||
function createOptimizedDataSource() {
|
||||
var ds = new DataSource({connector: Memory});
|
||||
const ds = new DataSource({connector: Memory});
|
||||
ds.name = 'Optimized';
|
||||
return ds;
|
||||
}
|
||||
|
||||
function createUnoptimizedDataSource() {
|
||||
var ds = new DataSource({connector: Memory});
|
||||
const ds = new DataSource({connector: Memory});
|
||||
ds.name = 'Unoptimized';
|
||||
|
||||
// disable optimized methods
|
||||
|
@ -139,7 +139,7 @@ function createUnoptimizedDataSource() {
|
|||
|
||||
function setupTestModels() {
|
||||
dataSources.forEach(function setupOnDataSource(ds) {
|
||||
var TestModel = ds.TestModel = ds.createModel('TestModel', {
|
||||
const TestModel = ds.TestModel = ds.createModel('TestModel', {
|
||||
id: {type: String, id: true, default: uid},
|
||||
name: {type: String, required: true},
|
||||
extra: {type: String, required: false},
|
||||
|
@ -155,7 +155,7 @@ function uid() {
|
|||
|
||||
function runner(fn) {
|
||||
return function() {
|
||||
var res = Promise.resolve();
|
||||
let res = Promise.resolve();
|
||||
dataSources.forEach(function(ds) {
|
||||
res = res.then(function() {
|
||||
return resetStorage(ds);
|
||||
|
@ -173,7 +173,7 @@ function runner(fn) {
|
|||
}
|
||||
|
||||
function resetStorage(ds) {
|
||||
var TestModel = ds.TestModel;
|
||||
const TestModel = ds.TestModel;
|
||||
HOOK_NAMES.forEach(function(hook) {
|
||||
TestModel.clearObservers(hook);
|
||||
});
|
||||
|
@ -192,7 +192,7 @@ function resetStorage(ds) {
|
|||
.then(function() {
|
||||
HOOK_NAMES.forEach(function(hook) {
|
||||
TestModel.observe(hook, function(ctx, next) {
|
||||
var row = observedContexts[observedContexts.length - 1];
|
||||
const row = observedContexts[observedContexts.length - 1];
|
||||
row.hooks[hook] = Object.keys(ctx);
|
||||
next();
|
||||
});
|
||||
|
@ -212,7 +212,7 @@ function report() {
|
|||
// merge rows where Optimized and Unoptimized produce the same context
|
||||
observedContexts.forEach(function(row, ix) {
|
||||
if (!ix) return;
|
||||
var last = observedContexts[ix - 1];
|
||||
const last = observedContexts[ix - 1];
|
||||
if (row.operation != last.operation) return;
|
||||
if (JSON.stringify(row.hooks) !== JSON.stringify(last.hooks)) return;
|
||||
last.merge = true;
|
||||
|
@ -226,11 +226,11 @@ function report() {
|
|||
|
||||
observedContexts.forEach(function(row) {
|
||||
if (row.skip) return;
|
||||
var caption = row.operation;
|
||||
let caption = row.operation;
|
||||
if (!row.merge) caption += ' (' + row.connector + ')';
|
||||
console.log('<tr><th>' + caption + '</th>');
|
||||
HOOK_NAMES.forEach(function(h) {
|
||||
var text = row.hooks[h] ? row.hooks[h].join('<br/>') : '';
|
||||
const text = row.hooks[h] ? row.hooks[h].join('<br/>') : '';
|
||||
console.log(' <td>' + text + '</td>');
|
||||
});
|
||||
console.log('</tr>');
|
||||
|
|
|
@ -4,12 +4,12 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var should = require('./init.js');
|
||||
const should = require('./init.js');
|
||||
|
||||
var jdb = require('../');
|
||||
var DataSource = jdb.DataSource;
|
||||
const jdb = require('../');
|
||||
const DataSource = jdb.DataSource;
|
||||
|
||||
var ds, Item, Variant;
|
||||
let ds, Item, Variant;
|
||||
describe('Datasource-specific field types for foreign keys', function() {
|
||||
before(function() {
|
||||
ds = new DataSource('memory');
|
||||
|
@ -35,7 +35,7 @@ describe('Datasource-specific field types for foreign keys', function() {
|
|||
});
|
||||
|
||||
it('should create foreign key with database-specific field type', function(done) {
|
||||
var VariantDefinition = ds.getModelDefinition('Variant');
|
||||
const VariantDefinition = ds.getModelDefinition('Variant');
|
||||
should.exist(VariantDefinition);
|
||||
should.exist(VariantDefinition.properties.myProp.memory);
|
||||
should.exist(VariantDefinition.properties.myProp.memory.dataType);
|
||||
|
|
|
@ -60,7 +60,7 @@ describe('allowExtendedOperators', () => {
|
|||
|
||||
all(model, filter, options, callback) {
|
||||
// return the raw "value" query
|
||||
let instanceFound = {
|
||||
const instanceFound = {
|
||||
value: filter.where.value,
|
||||
};
|
||||
callback(null, [instanceFound]);
|
||||
|
|
|
@ -4,18 +4,18 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var ModelBuilder = require('../').ModelBuilder;
|
||||
var should = require('./init');
|
||||
const ModelBuilder = require('../').ModelBuilder;
|
||||
const should = require('./init');
|
||||
|
||||
describe('async observer', function() {
|
||||
var TestModel;
|
||||
let TestModel;
|
||||
beforeEach(function defineTestModel() {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
TestModel = modelBuilder.define('TestModel', {name: String});
|
||||
});
|
||||
|
||||
it('calls registered async observers', function(done) {
|
||||
var notifications = [];
|
||||
const notifications = [];
|
||||
TestModel.observe('before', pushAndNext(notifications, 'before'));
|
||||
TestModel.observe('after', pushAndNext(notifications, 'after'));
|
||||
|
||||
|
@ -32,7 +32,7 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('allows multiple observers for the same operation', function(done) {
|
||||
var notifications = [];
|
||||
const notifications = [];
|
||||
TestModel.observe('event', pushAndNext(notifications, 'one'));
|
||||
TestModel.observe('event', pushAndNext(notifications, 'two'));
|
||||
|
||||
|
@ -44,7 +44,7 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('allows multiple operations to be notified in one call', function(done) {
|
||||
var notifications = [];
|
||||
const notifications = [];
|
||||
TestModel.observe('event1', pushAndNext(notifications, 'one'));
|
||||
TestModel.observe('event2', pushAndNext(notifications, 'two'));
|
||||
|
||||
|
@ -56,10 +56,10 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('inherits observers from base model', function(done) {
|
||||
var notifications = [];
|
||||
const notifications = [];
|
||||
TestModel.observe('event', pushAndNext(notifications, 'base'));
|
||||
|
||||
var Child = TestModel.extend('Child');
|
||||
const Child = TestModel.extend('Child');
|
||||
Child.observe('event', pushAndNext(notifications, 'child'));
|
||||
|
||||
Child.notifyObserversOf('event', {}, function(err) {
|
||||
|
@ -70,11 +70,11 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('allow multiple operations to be notified with base models', function(done) {
|
||||
var notifications = [];
|
||||
const notifications = [];
|
||||
TestModel.observe('event1', pushAndNext(notifications, 'base1'));
|
||||
TestModel.observe('event2', pushAndNext(notifications, 'base2'));
|
||||
|
||||
var Child = TestModel.extend('Child');
|
||||
const Child = TestModel.extend('Child');
|
||||
Child.observe('event1', pushAndNext(notifications, 'child1'));
|
||||
Child.observe('event2', pushAndNext(notifications, 'child2'));
|
||||
|
||||
|
@ -86,10 +86,10 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('does not modify observers in the base model', function(done) {
|
||||
var notifications = [];
|
||||
const notifications = [];
|
||||
TestModel.observe('event', pushAndNext(notifications, 'base'));
|
||||
|
||||
var Child = TestModel.extend('Child');
|
||||
const Child = TestModel.extend('Child');
|
||||
Child.observe('event', pushAndNext(notifications, 'child'));
|
||||
|
||||
TestModel.notifyObserversOf('event', {}, function(err) {
|
||||
|
@ -100,10 +100,10 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('always calls inherited observers', function(done) {
|
||||
var notifications = [];
|
||||
const notifications = [];
|
||||
TestModel.observe('event', pushAndNext(notifications, 'base'));
|
||||
|
||||
var Child = TestModel.extend('Child');
|
||||
const Child = TestModel.extend('Child');
|
||||
// Important: there are no observers on the Child model
|
||||
|
||||
Child.notifyObserversOf('event', {}, function(err) {
|
||||
|
@ -114,7 +114,7 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('can remove observers', function(done) {
|
||||
var notifications = [];
|
||||
const notifications = [];
|
||||
|
||||
function call(ctx, next) {
|
||||
notifications.push('call');
|
||||
|
@ -132,7 +132,7 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('can clear all observers', function(done) {
|
||||
var notifications = [];
|
||||
const notifications = [];
|
||||
|
||||
function call(ctx, next) {
|
||||
notifications.push('call');
|
||||
|
@ -159,7 +159,7 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('passes context to final callback', function(done) {
|
||||
var context = {};
|
||||
const context = {};
|
||||
TestModel.notifyObserversOf('event', context, function(err, ctx) {
|
||||
(ctx || 'null').should.equal(context);
|
||||
done();
|
||||
|
@ -167,7 +167,7 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
describe('notifyObserversAround', function() {
|
||||
var notifications;
|
||||
let notifications;
|
||||
beforeEach(function() {
|
||||
notifications = [];
|
||||
TestModel.observe('before execute',
|
||||
|
@ -177,7 +177,7 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('should notify before/after observers', function(done) {
|
||||
var context = {};
|
||||
const context = {};
|
||||
|
||||
function work(done) {
|
||||
process.nextTick(function() {
|
||||
|
@ -194,7 +194,7 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('should allow work with context', function(done) {
|
||||
var context = {};
|
||||
const context = {};
|
||||
|
||||
function work(context, done) {
|
||||
process.nextTick(function() {
|
||||
|
@ -212,7 +212,7 @@ describe('async observer', function() {
|
|||
|
||||
it('should notify before/after observers with multiple results',
|
||||
function(done) {
|
||||
var context = {};
|
||||
const context = {};
|
||||
|
||||
function work(done) {
|
||||
process.nextTick(function() {
|
||||
|
@ -239,7 +239,7 @@ describe('async observer', function() {
|
|||
TestModel.observe('after invoke',
|
||||
pushAndNext(notifications, 'after invoke'));
|
||||
|
||||
var context = {};
|
||||
const context = {};
|
||||
|
||||
function work(done) {
|
||||
process.nextTick(function() {
|
||||
|
@ -264,7 +264,7 @@ describe('async observer', function() {
|
|||
next();
|
||||
});
|
||||
|
||||
var context = {};
|
||||
const context = {};
|
||||
|
||||
function work(done) {
|
||||
process.nextTick(function() {
|
||||
|
@ -292,7 +292,7 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('handles rejected promise returned by an observer', function(done) {
|
||||
var testError = new Error('expected test error');
|
||||
const testError = new Error('expected test error');
|
||||
TestModel.observe('event', function(ctx) {
|
||||
return Promise.reject(testError);
|
||||
});
|
||||
|
@ -303,8 +303,8 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('returns a promise when no callback is provided', function() {
|
||||
var context = {value: 'a-test-context'};
|
||||
var p = TestModel.notifyObserversOf('event', context);
|
||||
const context = {value: 'a-test-context'};
|
||||
const p = TestModel.notifyObserversOf('event', context);
|
||||
(p !== undefined).should.be.true;
|
||||
return p.then(function(result) {
|
||||
result.should.eql(context);
|
||||
|
@ -312,9 +312,9 @@ describe('async observer', function() {
|
|||
});
|
||||
|
||||
it('returns a rejected promise when no callback is provided', function() {
|
||||
var testError = new Error('expected test error');
|
||||
const testError = new Error('expected test error');
|
||||
TestModel.observe('event', function(ctx, next) { next(testError); });
|
||||
var p = TestModel.notifyObserversOf('event', context);
|
||||
const p = TestModel.notifyObserversOf('event', context);
|
||||
return p.then(
|
||||
function(result) {
|
||||
throw new Error('The promise should have been rejected.');
|
||||
|
|
|
@ -7,16 +7,16 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false, connectorCapabilities:false */
|
||||
var async = require('async');
|
||||
var bdd = require('./helpers/bdd-if');
|
||||
var should = require('./init.js');
|
||||
var uid = require('./helpers/uid-generator');
|
||||
const async = require('async');
|
||||
const bdd = require('./helpers/bdd-if');
|
||||
const should = require('./init.js');
|
||||
const uid = require('./helpers/uid-generator');
|
||||
|
||||
var db, User;
|
||||
let db, User;
|
||||
|
||||
describe('basic-querying', function() {
|
||||
before(function(done) {
|
||||
var userModelDef = {
|
||||
const userModelDef = {
|
||||
seq: {type: Number, index: true},
|
||||
name: {type: String, index: true, sort: true},
|
||||
email: {type: String, index: true},
|
||||
|
@ -71,7 +71,7 @@ describe('basic-querying', function() {
|
|||
});
|
||||
|
||||
it('should query by id: not found', function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 1;
|
||||
const unknownId = uid.fromConnector(db) || 1;
|
||||
User.findById(unknownId, function(err, u) {
|
||||
should.not.exist(u);
|
||||
should.not.exist(err);
|
||||
|
@ -94,10 +94,10 @@ describe('basic-querying', function() {
|
|||
});
|
||||
|
||||
describe('findByIds', function() {
|
||||
var createdUsers;
|
||||
let createdUsers;
|
||||
before(function(done) {
|
||||
db = getSchema();
|
||||
var people = [
|
||||
const people = [
|
||||
{name: 'a', vip: true},
|
||||
{name: 'b', vip: null},
|
||||
{name: 'c'},
|
||||
|
@ -122,7 +122,7 @@ describe('basic-querying', function() {
|
|||
function(err, users) {
|
||||
should.exist(users);
|
||||
should.not.exist(err);
|
||||
var names = users.map(function(u) {
|
||||
const names = users.map(function(u) {
|
||||
return u.name;
|
||||
});
|
||||
names.should.eql(
|
||||
|
@ -142,7 +142,7 @@ describe('basic-querying', function() {
|
|||
{where: {vip: true}}, function(err, users) {
|
||||
should.exist(users);
|
||||
should.not.exist(err);
|
||||
var names = users.map(function(u) {
|
||||
const names = users.map(function(u) {
|
||||
return u.name;
|
||||
});
|
||||
names.should.eql(createdUsers.slice(0, 4).
|
||||
|
@ -283,7 +283,7 @@ describe('basic-querying', function() {
|
|||
User.find({order: 'order DESC'}, function(err, users) {
|
||||
if (err) return done(err);
|
||||
should.exists(users);
|
||||
var order = users.map(function(u) { return u.order; });
|
||||
const order = users.map(function(u) { return u.order; });
|
||||
order.should.eql([6, 5, 4, 3, 2, 1]);
|
||||
done();
|
||||
});
|
||||
|
@ -471,7 +471,7 @@ describe('basic-querying', function() {
|
|||
User.find({where: {name: {'gte': 'Paul McCartney'}}}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
users.should.have.property('length', 4);
|
||||
for (var ix = 0; ix < users.length; ix++) {
|
||||
for (let ix = 0; ix < users.length; ix++) {
|
||||
users[ix].name.should.be.greaterThanOrEqual('Paul McCartney');
|
||||
}
|
||||
done();
|
||||
|
@ -493,7 +493,7 @@ describe('basic-querying', function() {
|
|||
}}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
users.should.have.property('length', 3);
|
||||
for (var ix = 0; ix < users.length; ix++) {
|
||||
for (let ix = 0; ix < users.length; ix++) {
|
||||
users[ix].name.should.be.greaterThan('Paul McCartney');
|
||||
}
|
||||
done();
|
||||
|
@ -506,7 +506,7 @@ describe('basic-querying', function() {
|
|||
}}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
users.should.have.property('length', 2);
|
||||
for (var ix = 0; ix < users.length; ix++) {
|
||||
for (let ix = 0; ix < users.length; ix++) {
|
||||
users[ix].name.should.be.lessThan('Paul McCartney');
|
||||
}
|
||||
done();
|
||||
|
@ -518,7 +518,7 @@ describe('basic-querying', function() {
|
|||
}}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
users.should.have.property('length', 3);
|
||||
for (var ix = 0; ix < users.length; ix++) {
|
||||
for (let ix = 0; ix < users.length; ix++) {
|
||||
users[ix].name.should.be.oneOf(['John Lennon', 'Stuart Sutcliffe', 'Paul McCartney']);
|
||||
users[ix].vip.should.be.true();
|
||||
}
|
||||
|
@ -540,7 +540,7 @@ describe('basic-querying', function() {
|
|||
}}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
users.should.have.property('length', 3);
|
||||
for (var ix = 0; ix < users.length; ix++) {
|
||||
for (let ix = 0; ix < users.length; ix++) {
|
||||
users[ix].name.should.be.oneOf(['John Lennon', 'Stuart Sutcliffe', 'Paul McCartney']);
|
||||
users[ix].vip.should.be.true(users[ix].name + ' should be VIP');
|
||||
}
|
||||
|
@ -553,7 +553,7 @@ describe('basic-querying', function() {
|
|||
}}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
users.should.have.property('length', 2);
|
||||
for (var ix = 0; ix < users.length; ix++) {
|
||||
for (let ix = 0; ix < users.length; ix++) {
|
||||
users[ix].name.should.be.oneOf(['Ringo Starr', 'George Harrison']);
|
||||
users[ix].vip.should.be.false(users[ix].name + ' should not be VIP');
|
||||
}
|
||||
|
@ -578,7 +578,7 @@ describe('basic-querying', function() {
|
|||
});
|
||||
});
|
||||
|
||||
var itWhenIlikeSupported = connectorCapabilities.ilike;
|
||||
const itWhenIlikeSupported = connectorCapabilities.ilike;
|
||||
bdd.describeIf(itWhenIlikeSupported, 'ilike', function() {
|
||||
it('should support "like" that is satisfied',
|
||||
function(done) {
|
||||
|
@ -618,7 +618,7 @@ describe('basic-querying', function() {
|
|||
});
|
||||
});
|
||||
|
||||
var itWhenNilikeSupported = connectorCapabilities.nilike !== false;
|
||||
const itWhenNilikeSupported = connectorCapabilities.nilike !== false;
|
||||
bdd.describeIf(itWhenNilikeSupported, 'nilike', function() {
|
||||
it('should support "nlike" that is satisfied', function(done) {
|
||||
User.find({where: {name: {nlike: 'John'}}},
|
||||
|
@ -783,7 +783,7 @@ describe('basic-querying', function() {
|
|||
});
|
||||
|
||||
it('should only include fields as specified', function(done) {
|
||||
var remaining = 0;
|
||||
let remaining = 0;
|
||||
|
||||
function sample(fields) {
|
||||
return {
|
||||
|
@ -800,7 +800,7 @@ describe('basic-querying', function() {
|
|||
}
|
||||
|
||||
users.forEach(function(user) {
|
||||
var obj = user.toObject();
|
||||
const obj = user.toObject();
|
||||
|
||||
Object.keys(obj)
|
||||
.forEach(function(key) {
|
||||
|
@ -850,13 +850,13 @@ describe('basic-querying', function() {
|
|||
});
|
||||
});
|
||||
|
||||
var describeWhenNestedSupported = connectorCapabilities.nestedProperty;
|
||||
const describeWhenNestedSupported = connectorCapabilities.nestedProperty;
|
||||
bdd.describeIf(describeWhenNestedSupported, 'query with nested property', function() {
|
||||
it('should support nested property in query', function(done) {
|
||||
User.find({where: {'address.city': 'San Jose'}}, function(err, users) {
|
||||
if (err) return done(err);
|
||||
users.length.should.be.equal(1);
|
||||
for (var i = 0; i < users.length; i++) {
|
||||
for (let i = 0; i < users.length; i++) {
|
||||
users[i].address.city.should.be.eql('San Jose');
|
||||
}
|
||||
done();
|
||||
|
@ -867,7 +867,7 @@ describe('basic-querying', function() {
|
|||
User.find({where: {'friends.name': {regexp: /^Ringo/}}}, function(err, users) {
|
||||
if (err) return done(err);
|
||||
users.length.should.be.equal(2);
|
||||
var expectedUsers = ['John Lennon', 'Paul McCartney'];
|
||||
const expectedUsers = ['John Lennon', 'Paul McCartney'];
|
||||
expectedUsers.indexOf(users[0].name).should.not.equal(-1);
|
||||
expectedUsers.indexOf(users[1].name).should.not.equal(-1);
|
||||
done();
|
||||
|
@ -878,7 +878,7 @@ describe('basic-querying', function() {
|
|||
User.find({where: {'address.city': {gt: 'San'}}}, function(err, users) {
|
||||
if (err) return done(err);
|
||||
users.length.should.be.equal(2);
|
||||
for (var i = 0; i < users.length; i++) {
|
||||
for (let i = 0; i < users.length; i++) {
|
||||
users[i].address.state.should.be.eql('CA');
|
||||
}
|
||||
done();
|
||||
|
@ -1015,7 +1015,7 @@ describe('basic-querying', function() {
|
|||
});
|
||||
|
||||
it('should check whether record not exist', function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 42;
|
||||
const unknownId = uid.fromConnector(db) || 42;
|
||||
User.destroyAll(function() {
|
||||
User.exists(unknownId, function(err, exists) {
|
||||
should.not.exist(err);
|
||||
|
@ -1027,7 +1027,7 @@ describe('basic-querying', function() {
|
|||
});
|
||||
|
||||
context('regexp operator', function() {
|
||||
var invalidDataTypes = [0, true, {}, [], Function, null];
|
||||
const invalidDataTypes = [0, true, {}, [], Function, null];
|
||||
|
||||
before(seed);
|
||||
|
||||
|
@ -1046,7 +1046,7 @@ describe('basic-querying', function() {
|
|||
|
||||
// FIXME: This should either be re-enabled or removed.
|
||||
describe.skip('queries', function() {
|
||||
var Todo;
|
||||
let Todo;
|
||||
|
||||
before(function prepDb(done) {
|
||||
db = getSchema();
|
||||
|
@ -1078,7 +1078,7 @@ describe.skip('queries', function() {
|
|||
});
|
||||
|
||||
it('should work for updateOrCreate/upsert', function(done) {
|
||||
var aliases = ['updateOrCreate', 'upsert'];
|
||||
const aliases = ['updateOrCreate', 'upsert'];
|
||||
async.each(aliases, function(alias, cb) {
|
||||
Todo[alias]({content: 'Buy ham'}, function(err) {
|
||||
should.not.exist(err);
|
||||
|
@ -1118,7 +1118,7 @@ describe.skip('queries', function() {
|
|||
it('should work for deleteAll/destroyAll/remove', function(done) {
|
||||
// FIXME: We should add a DAO.delete static method alias for consistency
|
||||
// (DAO.prototype.delete instance method already exists)
|
||||
var aliases = ['deleteAll', 'destroyAll', 'remove'];
|
||||
const aliases = ['deleteAll', 'destroyAll', 'remove'];
|
||||
async.each(aliases, function(alias, cb) {
|
||||
Todo[alias](function(err) {
|
||||
should.not.exist(err);
|
||||
|
@ -1143,7 +1143,7 @@ describe.skip('queries', function() {
|
|||
});
|
||||
|
||||
context('that require an id', function() {
|
||||
var expectedErrMsg = 'Primary key is missing for the Todo model';
|
||||
const expectedErrMsg = 'Primary key is missing for the Todo model';
|
||||
|
||||
it('should return an error for findById', function(done) {
|
||||
Todo.findById(1, function(err) {
|
||||
|
@ -1163,7 +1163,7 @@ describe.skip('queries', function() {
|
|||
|
||||
it('should return an error for deleteById/destroyById/removeById',
|
||||
function(done) {
|
||||
var aliases = ['deleteById', 'destroyById', 'removeById'];
|
||||
const aliases = ['deleteById', 'destroyById', 'removeById'];
|
||||
async.each(aliases, function(alias, cb) {
|
||||
Todo[alias](1, function(err) {
|
||||
should.exist(err);
|
||||
|
@ -1174,7 +1174,7 @@ describe.skip('queries', function() {
|
|||
});
|
||||
|
||||
it('should return an error for instance.save', function(done) {
|
||||
var todo = new Todo();
|
||||
const todo = new Todo();
|
||||
todo.content = 'Buy ham';
|
||||
todo.save(function(err) {
|
||||
should.exist(err);
|
||||
|
@ -1216,7 +1216,7 @@ describe.skip('queries', function() {
|
|||
});
|
||||
|
||||
function seed(done) {
|
||||
var beatles = [
|
||||
const beatles = [
|
||||
{
|
||||
seq: 0,
|
||||
name: 'John Lennon',
|
||||
|
@ -1285,6 +1285,6 @@ function seed(done) {
|
|||
}
|
||||
|
||||
function nextAfterDelay(ctx, next) {
|
||||
var randomTimeoutTrigger = Math.floor(Math.random() * 100);
|
||||
const randomTimeoutTrigger = Math.floor(Math.random() * 100);
|
||||
setTimeout(function() { process.nextTick(next); }, randomTimeoutTrigger);
|
||||
}
|
||||
|
|
|
@ -5,13 +5,13 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var Schema = require('../index').Schema;
|
||||
var Text = Schema.Text;
|
||||
const Schema = require('../index').Schema;
|
||||
const Text = Schema.Text;
|
||||
|
||||
var nbSchemaRequests = 0;
|
||||
let nbSchemaRequests = 0;
|
||||
|
||||
var batch;
|
||||
var schemaName;
|
||||
let batch;
|
||||
let schemaName;
|
||||
|
||||
function it(name, cases) {
|
||||
batch[schemaName][name] = cases;
|
||||
|
@ -27,7 +27,7 @@ module.exports = function testSchema(exportCasesHere, dataSource) {
|
|||
if (dataSource.name.match(/^\/.*\/test\/\.\.$/)) {
|
||||
schemaName = schemaName.split('/').slice(-3).shift();
|
||||
}
|
||||
var start;
|
||||
let start;
|
||||
|
||||
batch['should connect to database'] = function(test) {
|
||||
start = Date.now();
|
||||
|
@ -70,12 +70,12 @@ Object.defineProperty(module.exports, 'skip', {
|
|||
});
|
||||
|
||||
function clearAndCreate(model, data, callback) {
|
||||
var createdItems = [];
|
||||
const createdItems = [];
|
||||
model.destroyAll(function() {
|
||||
nextItem(null, null);
|
||||
});
|
||||
|
||||
var itemIndex = 0;
|
||||
let itemIndex = 0;
|
||||
|
||||
function nextItem(err, lastItem) {
|
||||
if (lastItem !== null) {
|
||||
|
@ -92,9 +92,9 @@ function clearAndCreate(model, data, callback) {
|
|||
|
||||
/* eslint-disable mocha/handle-done-callback */
|
||||
function testOrm(dataSource) {
|
||||
var requestsAreCounted = dataSource.name !== 'mongodb';
|
||||
const requestsAreCounted = dataSource.name !== 'mongodb';
|
||||
|
||||
var Post, User, Passport, Log, Dog;
|
||||
let Post, User, Passport, Log, Dog;
|
||||
|
||||
it('should define class', function(test) {
|
||||
User = dataSource.define('User', {
|
||||
|
@ -123,7 +123,7 @@ function testOrm(dataSource) {
|
|||
extra: Object,
|
||||
});
|
||||
|
||||
var newuser = new User({settings: {hey: 'you'}});
|
||||
const newuser = new User({settings: {hey: 'you'}});
|
||||
test.ok(newuser.settings);
|
||||
|
||||
Post = dataSource.define('Post', {
|
||||
|
@ -177,7 +177,7 @@ function testOrm(dataSource) {
|
|||
Passport.belongsTo(User, {as: 'owner', foreignKey: 'ownerId'});
|
||||
User.hasMany(Passport, {as: 'passports', foreignKey: 'ownerId'});
|
||||
|
||||
var user = new User;
|
||||
const user = new User;
|
||||
|
||||
test.ok(User instanceof Function);
|
||||
|
||||
|
@ -199,7 +199,7 @@ function testOrm(dataSource) {
|
|||
});
|
||||
|
||||
it('should initialize object properly', function(test) {
|
||||
var hw = 'Hello word',
|
||||
const hw = 'Hello word',
|
||||
now = Date.now(),
|
||||
post = new Post({title: hw}),
|
||||
anotherPost = Post({title: 'Resig style constructor'});
|
||||
|
@ -218,7 +218,7 @@ function testOrm(dataSource) {
|
|||
});
|
||||
|
||||
it('should save object', function(test) {
|
||||
var title = 'Initial title', title2 = 'Hello world',
|
||||
const title = 'Initial title', title2 = 'Hello world',
|
||||
date = new Date;
|
||||
|
||||
Post.create({
|
||||
|
@ -234,7 +234,7 @@ function testOrm(dataSource) {
|
|||
test.equal(obj.title, title2);
|
||||
test.ok(!obj.propertyChanged('title'));
|
||||
|
||||
var p = new Post({title: 1});
|
||||
const p = new Post({title: 1});
|
||||
p.title = 2;
|
||||
p.save(function(err, obj) {
|
||||
test.ok(!p.propertyChanged('title'));
|
||||
|
@ -252,7 +252,7 @@ function testOrm(dataSource) {
|
|||
});
|
||||
|
||||
it('should create object with initial data', function(test) {
|
||||
var title = 'Initial title',
|
||||
const title = 'Initial title',
|
||||
date = new Date;
|
||||
|
||||
Post.create({
|
||||
|
@ -301,8 +301,8 @@ function testOrm(dataSource) {
|
|||
*/
|
||||
|
||||
it('should not re-instantiate object on saving', function(test) {
|
||||
var title = 'Initial title';
|
||||
var post = new Post({title: title});
|
||||
const title = 'Initial title';
|
||||
const post = new Post({title: title});
|
||||
post.save(function(err, savedPost) {
|
||||
test.strictEqual(post, savedPost);
|
||||
test.done();
|
||||
|
@ -329,21 +329,21 @@ function testOrm(dataSource) {
|
|||
});
|
||||
|
||||
it('should handle virtual attributes', function(test) {
|
||||
var salt = 's0m3s3cr3t5a1t';
|
||||
const salt = 's0m3s3cr3t5a1t';
|
||||
|
||||
User.setter.passwd = function(password) {
|
||||
this._passwd = calcHash(password, salt);
|
||||
};
|
||||
|
||||
function calcHash(pass, salt) {
|
||||
var crypto = require('crypto');
|
||||
var hash = crypto.createHash('sha256');
|
||||
const crypto = require('crypto');
|
||||
const hash = crypto.createHash('sha256');
|
||||
hash.update(pass);
|
||||
hash.update(salt);
|
||||
return hash.digest('base64');
|
||||
}
|
||||
|
||||
var u = new User;
|
||||
const u = new User;
|
||||
u.passwd = 's3cr3t';
|
||||
test.equal(u.passwd, calcHash('s3cr3t', salt));
|
||||
test.done();
|
||||
|
@ -380,7 +380,7 @@ function testOrm(dataSource) {
|
|||
});
|
||||
});
|
||||
|
||||
var countOfposts, countOfpostsFiltered;
|
||||
let countOfposts, countOfpostsFiltered;
|
||||
it('should fetch collection', function(test) {
|
||||
Post.all(function(err, posts) {
|
||||
countOfposts = posts.length;
|
||||
|
@ -394,7 +394,7 @@ function testOrm(dataSource) {
|
|||
});
|
||||
|
||||
it('should find records filtered with multiple attributes', function(test) {
|
||||
var d = new Date;
|
||||
const d = new Date;
|
||||
Post.create({title: 'title', content: 'content', published: true, date: d}, function(err, post) {
|
||||
Post.all({where: {title: 'title', date: d, published: true}}, function(err, res) {
|
||||
test.equals(res.length, 1, 'Filtering Posts returns one post');
|
||||
|
@ -485,8 +485,8 @@ function testOrm(dataSource) {
|
|||
// Finding one post with an existing author associated
|
||||
Post.all(function(err, posts) {
|
||||
// We try to get the first post with a userId != NULL
|
||||
for (var i = 0; i < posts.length; i++) {
|
||||
var post = posts[i];
|
||||
for (let i = 0; i < posts.length; i++) {
|
||||
const post = posts[i];
|
||||
if (post.userId) {
|
||||
// We could get the user with belongs to relationship but it is better if there is no interactions.
|
||||
User.findById(post.userId, function(err, user) {
|
||||
|
@ -495,7 +495,7 @@ function testOrm(dataSource) {
|
|||
// There can't be any concurrency because we are counting requests
|
||||
// We are first testing cases when user has posts
|
||||
user.posts(function(err, data) {
|
||||
var nbInitialRequests = nbSchemaRequests;
|
||||
const nbInitialRequests = nbSchemaRequests;
|
||||
user.posts(function(err, data2) {
|
||||
test.equal(data.length, 2, 'There should be 2 posts.');
|
||||
test.equal(data.length, data2.length, 'Posts should be the same, since we are loading on the same object.');
|
||||
|
@ -514,7 +514,7 @@ function testOrm(dataSource) {
|
|||
|
||||
// We are now testing cases when user doesn't have any post
|
||||
voidUser.posts(function(err, data) {
|
||||
var nbInitialRequests = nbSchemaRequests;
|
||||
const nbInitialRequests = nbSchemaRequests;
|
||||
voidUser.posts(function(err, data2) {
|
||||
test.equal(data.length, 0, 'There shouldn\'t be any posts (1/2).');
|
||||
test.equal(data2.length, 0, 'There shouldn\'t be any posts (2/2).');
|
||||
|
@ -550,13 +550,13 @@ function testOrm(dataSource) {
|
|||
// });
|
||||
|
||||
it('should support scopes', function(test) {
|
||||
var wait = 2;
|
||||
let wait = 2;
|
||||
|
||||
test.ok(Post.scope, 'Scope supported');
|
||||
Post.scope('published', {where: {published: true}});
|
||||
test.ok(typeof Post.published === 'function');
|
||||
test.ok(Post.published._scope.where.published === true);
|
||||
var post = Post.published.build();
|
||||
const post = Post.published.build();
|
||||
test.ok(post.published, 'Can build');
|
||||
test.ok(post.isNewRecord());
|
||||
Post.published.create(function(err, psto) {
|
||||
|
@ -583,14 +583,14 @@ function testOrm(dataSource) {
|
|||
it('should return type of property', function(test) {
|
||||
test.equal(Post.getPropertyType('title'), 'String');
|
||||
test.equal(Post.getPropertyType('content'), 'Text');
|
||||
var p = new Post;
|
||||
const p = new Post;
|
||||
test.equal(p.getPropertyType('title'), 'String');
|
||||
test.equal(p.getPropertyType('content'), 'Text');
|
||||
test.done();
|
||||
});
|
||||
|
||||
it('should handle ORDER clause', function(test) {
|
||||
var titles = [
|
||||
const titles = [
|
||||
{title: 'Title A', subject: 'B'},
|
||||
{title: 'Title Z', subject: 'A'},
|
||||
{title: 'Title M', subject: 'C'},
|
||||
|
@ -598,8 +598,8 @@ function testOrm(dataSource) {
|
|||
{title: 'Title B', subject: 'A'},
|
||||
{title: 'Title C', subject: 'D'},
|
||||
];
|
||||
var isRedis = Post.dataSource.name === 'redis';
|
||||
var dates = isRedis ? [5, 9, 0, 17, 10, 9] : [
|
||||
const isRedis = Post.dataSource.name === 'redis';
|
||||
const dates = isRedis ? [5, 9, 0, 17, 10, 9] : [
|
||||
new Date(1000 * 5),
|
||||
new Date(1000 * 9),
|
||||
new Date(1000 * 0),
|
||||
|
@ -611,7 +611,7 @@ function testOrm(dataSource) {
|
|||
Post.create({title: t.title, subject: t.subject, date: dates[i]}, done);
|
||||
});
|
||||
|
||||
var i = 0, tests = 0;
|
||||
let i = 0, tests = 0;
|
||||
|
||||
function done(err, obj) {
|
||||
if (++i === titles.length) {
|
||||
|
@ -717,7 +717,7 @@ function testOrm(dataSource) {
|
|||
});
|
||||
}
|
||||
|
||||
var fin = 0;
|
||||
let fin = 0;
|
||||
|
||||
function finished() {
|
||||
if (++fin === tests) {
|
||||
|
@ -871,8 +871,8 @@ function testOrm(dataSource) {
|
|||
// });
|
||||
|
||||
it('should handle order clause with direction', function(test) {
|
||||
var wait = 0;
|
||||
var emails = [
|
||||
let wait = 0;
|
||||
const emails = [
|
||||
'john@hcompany.com',
|
||||
'tom@hcompany.com',
|
||||
'admin@hcompany.com',
|
||||
|
@ -887,7 +887,7 @@ function testOrm(dataSource) {
|
|||
User.create({email: email, name: 'Nick'}, done);
|
||||
});
|
||||
});
|
||||
var tests = 2;
|
||||
let tests = 2;
|
||||
|
||||
function done() {
|
||||
process.nextTick(function() {
|
||||
|
@ -900,7 +900,7 @@ function testOrm(dataSource) {
|
|||
|
||||
function doSortTest() {
|
||||
User.all({order: 'email ASC', where: {name: 'Nick'}}, function(err, users) {
|
||||
var _emails = emails.sort();
|
||||
const _emails = emails.sort();
|
||||
users.forEach(function(user, i) {
|
||||
test.equal(_emails[i], user.email, 'ASC sorting');
|
||||
});
|
||||
|
@ -910,7 +910,7 @@ function testOrm(dataSource) {
|
|||
|
||||
function doReverseSortTest() {
|
||||
User.all({order: 'email DESC', where: {name: 'Nick'}}, function(err, users) {
|
||||
var _emails = emails.sort().reverse();
|
||||
const _emails = emails.sort().reverse();
|
||||
users.forEach(function(user, i) {
|
||||
test.equal(_emails[i], user.email, 'DESC sorting');
|
||||
});
|
||||
|
@ -925,7 +925,7 @@ function testOrm(dataSource) {
|
|||
|
||||
it('should return id in find result even after updateAttributes', function(test) {
|
||||
Post.create(function(err, post) {
|
||||
var id = post.id;
|
||||
const id = post.id;
|
||||
test.ok(post.published === false);
|
||||
post.updateAttributes({title: 'hey', published: true}, function() {
|
||||
Post.find(id, function(err, post) {
|
||||
|
@ -938,7 +938,7 @@ function testOrm(dataSource) {
|
|||
});
|
||||
|
||||
it('should handle belongsTo correctly', function(test) {
|
||||
var passport = new Passport({ownerId: 16});
|
||||
const passport = new Passport({ownerId: 16});
|
||||
// sync getter
|
||||
test.equal(passport.owner(), 16);
|
||||
// sync setter
|
||||
|
@ -1017,7 +1017,7 @@ function testOrm(dataSource) {
|
|||
|
||||
if (dataSource.name !== 'mongoose' && dataSource.name !== 'neo4j')
|
||||
it('should update or create record', function(test) {
|
||||
var newData = {
|
||||
const newData = {
|
||||
id: 1,
|
||||
title: 'New title (really new)',
|
||||
content: 'Some example content (updated)',
|
||||
|
@ -1058,7 +1058,7 @@ function testOrm(dataSource) {
|
|||
User.setter.passwd = function(pass) {
|
||||
this._passwd = pass + 'salt';
|
||||
};
|
||||
var u = new User({passwd: 'qwerty'});
|
||||
const u = new User({passwd: 'qwerty'});
|
||||
test.equal(u.passwd, 'qwertysalt');
|
||||
u.save(function(err, user) {
|
||||
User.findById(user.id, function(err, user) {
|
||||
|
@ -1083,10 +1083,10 @@ function testOrm(dataSource) {
|
|||
});
|
||||
|
||||
it('should work with typed and untyped nested collections', function(test) {
|
||||
var post = new Post;
|
||||
var like = post.likes.push({foo: 'bar'});
|
||||
const post = new Post;
|
||||
const like = post.likes.push({foo: 'bar'});
|
||||
test.equal(like.constructor.name, 'ListItem');
|
||||
var related = post.related.push({hello: 'world'});
|
||||
const related = post.related.push({hello: 'world'});
|
||||
test.ok(related.someMethod);
|
||||
post.save(function(err, p) {
|
||||
test.equal(p.likes.nextid, 2);
|
||||
|
@ -1119,7 +1119,7 @@ function testOrm(dataSource) {
|
|||
});
|
||||
|
||||
it('should find or create', function(test) {
|
||||
var email = 'some email ' + Math.random();
|
||||
const email = 'some email ' + Math.random();
|
||||
User.findOrCreate({where: {email: email}}, function(err, u, created) {
|
||||
test.ok(u);
|
||||
test.ok(!u.age);
|
||||
|
|
|
@ -7,9 +7,9 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false */
|
||||
var should = require('./init.js');
|
||||
var async = require('async');
|
||||
var db, User, options, filter;
|
||||
const should = require('./init.js');
|
||||
const async = require('async');
|
||||
let db, User, options, filter;
|
||||
|
||||
describe('crud-with-options', function() {
|
||||
before(function(done) {
|
||||
|
@ -193,7 +193,7 @@ describe('crud-with-options', function() {
|
|||
|
||||
describe('findByIds', function() {
|
||||
before(function(done) {
|
||||
var people = [
|
||||
const people = [
|
||||
{id: 1, name: 'a', vip: true},
|
||||
{id: 2, name: 'b'},
|
||||
{id: 3, name: 'c'},
|
||||
|
@ -213,7 +213,7 @@ describe('crud-with-options', function() {
|
|||
User.findByIds([3, 2, 1], function(err, users) {
|
||||
should.exist(users);
|
||||
should.not.exist(err);
|
||||
var names = users.map(function(u) { return u.name; });
|
||||
const names = users.map(function(u) { return u.name; });
|
||||
names.should.eql(['c', 'b', 'a']);
|
||||
done();
|
||||
});
|
||||
|
@ -225,7 +225,7 @@ describe('crud-with-options', function() {
|
|||
{where: {vip: true}}, options, function(err, users) {
|
||||
should.exist(users);
|
||||
should.not.exist(err);
|
||||
var names = users.map(function(u) {
|
||||
const names = users.map(function(u) {
|
||||
return u.name;
|
||||
});
|
||||
names.should.eql(['d', 'a']);
|
||||
|
@ -407,15 +407,15 @@ describe('crud-with-options', function() {
|
|||
|
||||
describe('save', function() {
|
||||
it('should allow save(options, cb)', function(done) {
|
||||
var options = {foo: 'bar'};
|
||||
var opts;
|
||||
const options = {foo: 'bar'};
|
||||
let opts;
|
||||
|
||||
User.observe('after save', function(ctx, next) {
|
||||
opts = ctx.options;
|
||||
next();
|
||||
});
|
||||
|
||||
var u = new User();
|
||||
const u = new User();
|
||||
u.save(options, function(err) {
|
||||
should.not.exist(err);
|
||||
options.should.equal(opts);
|
||||
|
@ -605,7 +605,7 @@ describe('upsertWithWhere', function() {
|
|||
});
|
||||
|
||||
function seed(done) {
|
||||
var beatles = [
|
||||
const beatles = [
|
||||
{
|
||||
id: 0,
|
||||
seq: 0,
|
||||
|
|
|
@ -5,12 +5,12 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var should = require('./init.js');
|
||||
var DataSource = require('../lib/datasource.js').DataSource;
|
||||
const should = require('./init.js');
|
||||
const DataSource = require('../lib/datasource.js').DataSource;
|
||||
|
||||
describe('DataSource', function() {
|
||||
it('reports helpful error when connector init throws', function() {
|
||||
var throwingConnector = {
|
||||
const throwingConnector = {
|
||||
name: 'loopback-connector-throwing',
|
||||
initialize: function(ds, cb) {
|
||||
throw new Error('expected test error');
|
||||
|
@ -50,7 +50,7 @@ describe('DataSource', function() {
|
|||
* new DataSource(dsName, settings) without settings.name
|
||||
*/
|
||||
it('should retain the name assigned to it', function() {
|
||||
var dataSource = new DataSource('myDataSource', {
|
||||
const dataSource = new DataSource('myDataSource', {
|
||||
connector: 'memory',
|
||||
});
|
||||
|
||||
|
@ -61,7 +61,7 @@ describe('DataSource', function() {
|
|||
* new DataSource(dsName, settings)
|
||||
*/
|
||||
it('should allow the name assigned to it to take precedence over the settings name', function() {
|
||||
var dataSource = new DataSource('myDataSource', {
|
||||
const dataSource = new DataSource('myDataSource', {
|
||||
name: 'defaultDataSource',
|
||||
connector: 'memory',
|
||||
});
|
||||
|
@ -73,7 +73,7 @@ describe('DataSource', function() {
|
|||
* new DataSource(settings) with settings.name
|
||||
*/
|
||||
it('should retain the name from the settings if no name is assigned', function() {
|
||||
var dataSource = new DataSource({
|
||||
const dataSource = new DataSource({
|
||||
name: 'defaultDataSource',
|
||||
connector: 'memory',
|
||||
});
|
||||
|
@ -85,7 +85,7 @@ describe('DataSource', function() {
|
|||
* new DataSource(undefined, settings)
|
||||
*/
|
||||
it('should retain the name from the settings if name is undefined', function() {
|
||||
var dataSource = new DataSource(undefined, {
|
||||
const dataSource = new DataSource(undefined, {
|
||||
name: 'defaultDataSource',
|
||||
connector: 'memory',
|
||||
});
|
||||
|
@ -97,7 +97,7 @@ describe('DataSource', function() {
|
|||
* new DataSource(settings) without settings.name
|
||||
*/
|
||||
it('should use the connector name if no name is provided', function() {
|
||||
var dataSource = new DataSource({
|
||||
const dataSource = new DataSource({
|
||||
connector: 'memory',
|
||||
});
|
||||
|
||||
|
@ -108,14 +108,14 @@ describe('DataSource', function() {
|
|||
* new DataSource(connectorInstance)
|
||||
*/
|
||||
it('should accept resolved connector', function() {
|
||||
var mockConnector = {
|
||||
const mockConnector = {
|
||||
name: 'loopback-connector-mock',
|
||||
initialize: function(ds, cb) {
|
||||
ds.connector = mockConnector;
|
||||
return cb(null);
|
||||
},
|
||||
};
|
||||
var dataSource = new DataSource(mockConnector);
|
||||
const dataSource = new DataSource(mockConnector);
|
||||
|
||||
dataSource.name.should.equal('loopback-connector-mock');
|
||||
dataSource.connector.should.equal(mockConnector);
|
||||
|
@ -125,14 +125,14 @@ describe('DataSource', function() {
|
|||
* new DataSource(dsName, connectorInstance)
|
||||
*/
|
||||
it('should accept dsName and resolved connector', function() {
|
||||
var mockConnector = {
|
||||
const mockConnector = {
|
||||
name: 'loopback-connector-mock',
|
||||
initialize: function(ds, cb) {
|
||||
ds.connector = mockConnector;
|
||||
return cb(null);
|
||||
},
|
||||
};
|
||||
var dataSource = new DataSource('myDataSource', mockConnector);
|
||||
const dataSource = new DataSource('myDataSource', mockConnector);
|
||||
|
||||
dataSource.name.should.equal('myDataSource');
|
||||
dataSource.connector.should.equal(mockConnector);
|
||||
|
@ -142,21 +142,21 @@ describe('DataSource', function() {
|
|||
* new DataSource(connectorInstance, settings)
|
||||
*/
|
||||
it('should accept resolved connector and settings', function() {
|
||||
var mockConnector = {
|
||||
const mockConnector = {
|
||||
name: 'loopback-connector-mock',
|
||||
initialize: function(ds, cb) {
|
||||
ds.connector = mockConnector;
|
||||
return cb(null);
|
||||
},
|
||||
};
|
||||
var dataSource = new DataSource(mockConnector, {name: 'myDataSource'});
|
||||
const dataSource = new DataSource(mockConnector, {name: 'myDataSource'});
|
||||
|
||||
dataSource.name.should.equal('myDataSource');
|
||||
dataSource.connector.should.equal(mockConnector);
|
||||
});
|
||||
|
||||
it('should set states correctly with eager connect', function(done) {
|
||||
var mockConnector = {
|
||||
const mockConnector = {
|
||||
name: 'loopback-connector-mock',
|
||||
initialize: function(ds, cb) {
|
||||
ds.connector = mockConnector;
|
||||
|
@ -169,7 +169,7 @@ describe('DataSource', function() {
|
|||
});
|
||||
},
|
||||
};
|
||||
var dataSource = new DataSource(mockConnector);
|
||||
const dataSource = new DataSource(mockConnector);
|
||||
// DataSource is instantiated
|
||||
// connected: false, connecting: false, initialized: false
|
||||
dataSource.connected.should.be.false();
|
||||
|
@ -211,7 +211,7 @@ describe('DataSource', function() {
|
|||
});
|
||||
|
||||
it('should set states correctly with deferred connect', function(done) {
|
||||
var mockConnector = {
|
||||
const mockConnector = {
|
||||
name: 'loopback-connector-mock',
|
||||
initialize: function(ds, cb) {
|
||||
ds.connector = mockConnector;
|
||||
|
@ -227,7 +227,7 @@ describe('DataSource', function() {
|
|||
});
|
||||
},
|
||||
};
|
||||
var dataSource = new DataSource(mockConnector);
|
||||
const dataSource = new DataSource(mockConnector);
|
||||
// DataSource is instantiated
|
||||
// connected: false, connecting: false, initialized: false
|
||||
dataSource.connected.should.be.false();
|
||||
|
@ -267,7 +267,7 @@ describe('DataSource', function() {
|
|||
});
|
||||
|
||||
it('should set states correctly with lazyConnect = true', function(done) {
|
||||
var mockConnector = {
|
||||
const mockConnector = {
|
||||
name: 'loopback-connector-mock',
|
||||
initialize: function(ds, cb) {
|
||||
ds.connector = mockConnector;
|
||||
|
@ -282,7 +282,7 @@ describe('DataSource', function() {
|
|||
});
|
||||
},
|
||||
};
|
||||
var dataSource = new DataSource(mockConnector, {lazyConnect: true});
|
||||
const dataSource = new DataSource(mockConnector, {lazyConnect: true});
|
||||
// DataSource is instantiated
|
||||
// connected: false, connecting: false, initialized: false
|
||||
dataSource.connected.should.be.false();
|
||||
|
|
|
@ -7,15 +7,15 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false */
|
||||
var should = require('./init.js');
|
||||
const should = require('./init.js');
|
||||
|
||||
var db, Model;
|
||||
let db, Model;
|
||||
|
||||
describe('datatypes', function() {
|
||||
before(function(done) {
|
||||
db = getSchema();
|
||||
var Nested = db.define('Nested', {});
|
||||
var modelTableSchema = {
|
||||
const Nested = db.define('Nested', {});
|
||||
const modelTableSchema = {
|
||||
str: String,
|
||||
date: Date,
|
||||
num: Number,
|
||||
|
@ -30,7 +30,7 @@ describe('datatypes', function() {
|
|||
|
||||
it('should return 400 when property of type array is set to string value',
|
||||
function(done) {
|
||||
var myModel = db.define('myModel', {
|
||||
const myModel = db.define('myModel', {
|
||||
list: {type: ['object']},
|
||||
});
|
||||
|
||||
|
@ -42,7 +42,7 @@ describe('datatypes', function() {
|
|||
|
||||
it('should return 400 when property of type array is set to object value',
|
||||
function(done) {
|
||||
var myModel = db.define('myModel', {
|
||||
const myModel = db.define('myModel', {
|
||||
list: {type: ['object']},
|
||||
});
|
||||
|
||||
|
@ -53,7 +53,8 @@ describe('datatypes', function() {
|
|||
});
|
||||
|
||||
it('should keep types when get read data from db', function(done) {
|
||||
var d = new Date('2015-01-01T12:00:00'), id;
|
||||
const d = new Date('2015-01-01T12:00:00');
|
||||
let id;
|
||||
|
||||
Model.create({
|
||||
str: 'hello', date: d, num: '3', bool: 1, list: ['test'], arr: [1, 'str'],
|
||||
|
@ -101,7 +102,8 @@ describe('datatypes', function() {
|
|||
});
|
||||
|
||||
it('should respect data types when updating attributes', function(done) {
|
||||
var d = new Date, id;
|
||||
const d = new Date;
|
||||
let id;
|
||||
|
||||
Model.create({
|
||||
str: 'hello', date: d, num: '3', bool: 1}, function(err, m) {
|
||||
|
@ -151,7 +153,7 @@ describe('datatypes', function() {
|
|||
});
|
||||
|
||||
it('should not coerce nested objects into ModelConstructor types', function() {
|
||||
var coerced = Model._coerce({nested: {foo: 'bar'}});
|
||||
const coerced = Model._coerce({nested: {foo: 'bar'}});
|
||||
coerced.nested.constructor.name.should.equal('Object');
|
||||
});
|
||||
|
||||
|
@ -176,13 +178,13 @@ describe('datatypes', function() {
|
|||
data: {type: 'string'},
|
||||
});
|
||||
db.automigrate(['HandleNullModel'], function() {
|
||||
let a = new Model(null);
|
||||
const a = new Model(null);
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
describe('model option persistUndefinedAsNull', function() {
|
||||
var TestModel, isStrict;
|
||||
let TestModel, isStrict;
|
||||
before(function(done) {
|
||||
db = getSchema();
|
||||
TestModel = db.define(
|
||||
|
@ -203,7 +205,7 @@ describe('datatypes', function() {
|
|||
});
|
||||
|
||||
it('should set missing optional properties to null', function(done) {
|
||||
var EXPECTED = {desc: null, stars: null};
|
||||
const EXPECTED = {desc: null, stars: null};
|
||||
TestModel.create({name: 'a-test-name'}, function(err, created) {
|
||||
if (err) return done(err);
|
||||
created.should.have.properties(EXPECTED);
|
||||
|
@ -217,8 +219,8 @@ describe('datatypes', function() {
|
|||
});
|
||||
|
||||
it('should convert property value undefined to null', function(done) {
|
||||
var EXPECTED = {desc: null, extra: null};
|
||||
var data = {desc: undefined, extra: undefined};
|
||||
const EXPECTED = {desc: null, extra: null};
|
||||
const data = {desc: undefined, extra: undefined};
|
||||
if (isStrict) {
|
||||
// SQL-based connectors don't support dynamic properties
|
||||
delete EXPECTED.extra;
|
||||
|
@ -238,21 +240,21 @@ describe('datatypes', function() {
|
|||
});
|
||||
|
||||
it('should convert undefined to null in the setter', function() {
|
||||
var inst = new TestModel();
|
||||
const inst = new TestModel();
|
||||
inst.desc = undefined;
|
||||
inst.should.have.property('desc', null);
|
||||
inst.toObject().should.have.property('desc', null);
|
||||
});
|
||||
|
||||
it('should use null in unsetAttribute()', function() {
|
||||
var inst = new TestModel();
|
||||
const inst = new TestModel();
|
||||
inst.unsetAttribute('stars');
|
||||
inst.should.have.property('stars', null);
|
||||
inst.toObject().should.have.property('stars', null);
|
||||
});
|
||||
|
||||
it('should convert undefined to null on save', function(done) {
|
||||
var EXPECTED = {desc: null, stars: null, extra: null, dx: null};
|
||||
const EXPECTED = {desc: null, stars: null, extra: null, dx: null};
|
||||
if (isStrict) {
|
||||
// SQL-based connectors don't support dynamic properties
|
||||
delete EXPECTED.extra;
|
||||
|
@ -298,7 +300,7 @@ describe('datatypes', function() {
|
|||
});
|
||||
|
||||
it('should convert undefined to null in toObject()', function() {
|
||||
var inst = new TestModel();
|
||||
const inst = new TestModel();
|
||||
inst.desc = undefined; // Note: this may be a no-op
|
||||
inst.unsetAttribute('stars');
|
||||
inst.extra = undefined;
|
||||
|
|
|
@ -10,16 +10,16 @@
|
|||
|
||||
require('should');
|
||||
|
||||
var DateString = require('../lib/date-string');
|
||||
var fmt = require('util').format;
|
||||
var inspect = require('util').inspect;
|
||||
var os = require('os');
|
||||
const DateString = require('../lib/date-string');
|
||||
const fmt = require('util').format;
|
||||
const inspect = require('util').inspect;
|
||||
const os = require('os');
|
||||
|
||||
describe('DateString', function() {
|
||||
describe('constructor', function() {
|
||||
it('should support a valid date string', function() {
|
||||
var theDate = '2015-01-01';
|
||||
var date = new DateString(theDate);
|
||||
const theDate = '2015-01-01';
|
||||
const date = new DateString(theDate);
|
||||
date.should.not.eql(null);
|
||||
date.when.should.eql(theDate);
|
||||
date.toString().should.eql(theDate);
|
||||
|
@ -37,16 +37,16 @@ describe('DateString', function() {
|
|||
testInvalidInput('should throw on null input', null, 'Input must be a string');
|
||||
|
||||
it('should update internal date on set', function() {
|
||||
var date = new DateString('2015-01-01');
|
||||
const date = new DateString('2015-01-01');
|
||||
date.when = '2016-01-01';
|
||||
date.when.should.eql('2016-01-01');
|
||||
var d = new Date('2016-01-01');
|
||||
const d = new Date('2016-01-01');
|
||||
// The internal date representation should also be updated!
|
||||
date._date.toString().should.eql(d.toString());
|
||||
});
|
||||
it('should return custom inspect output', function() {
|
||||
var date = new DateString('2015-01-01');
|
||||
var result = inspect(date);
|
||||
const date = new DateString('2015-01-01');
|
||||
const result = inspect(date);
|
||||
result.should.not.eql(null);
|
||||
result.should.eql(fmt('DateString ' + inspect({
|
||||
when: date.when,
|
||||
|
@ -55,24 +55,24 @@ describe('DateString', function() {
|
|||
});
|
||||
|
||||
it('should return JSON output', function() {
|
||||
var date = new DateString('2015-01-01');
|
||||
var result = date.toJSON();
|
||||
const date = new DateString('2015-01-01');
|
||||
const result = date.toJSON();
|
||||
result.should.eql(JSON.stringify({when: date.when}));
|
||||
});
|
||||
|
||||
function testValidInput(msg, val) {
|
||||
it(msg, function() {
|
||||
var theDate = new DateString(val);
|
||||
const theDate = new DateString(val);
|
||||
theDate.when.should.eql(val);
|
||||
var d = new Date(val);
|
||||
const d = new Date(val);
|
||||
theDate._date.toString().should.eql(d.toString());
|
||||
});
|
||||
}
|
||||
|
||||
function testInvalidInput(msg, val, err) {
|
||||
it(msg, () => {
|
||||
var fn = () => {
|
||||
var theDate = new DateString(val);
|
||||
const fn = () => {
|
||||
const theDate = new DateString(val);
|
||||
};
|
||||
fn.should.throw(err);
|
||||
});
|
||||
|
|
|
@ -7,10 +7,10 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false */
|
||||
var should = require('./init.js');
|
||||
var async = require('async');
|
||||
const should = require('./init.js');
|
||||
const async = require('async');
|
||||
|
||||
var db, Category, Product, Tool, Widget, Thing, Person;
|
||||
let db, Category, Product, Tool, Widget, Thing, Person;
|
||||
|
||||
// This test requires a connector that can
|
||||
// handle a custom collection or table name
|
||||
|
@ -18,7 +18,7 @@ var db, Category, Product, Tool, Widget, Thing, Person;
|
|||
// TODO [fabien] add table for pgsql/mysql
|
||||
// TODO [fabien] change model definition - see #293
|
||||
|
||||
var setupProducts = function(ids, done) {
|
||||
const setupProducts = function(ids, done) {
|
||||
async.series([
|
||||
function(next) {
|
||||
Tool.create({name: 'Tool Z'}, function(err, inst) {
|
||||
|
@ -72,7 +72,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
Product.lookupModel = function(data) {
|
||||
var m = this.dataSource.models[data.kind];
|
||||
const m = this.dataSource.models[data.kind];
|
||||
if (m.base === this) return m;
|
||||
return this;
|
||||
};
|
||||
|
@ -104,11 +104,11 @@ describe('default scope', function() {
|
|||
// inst is only valid for instance methods
|
||||
// like save, updateAttributes
|
||||
|
||||
var scopeFn = function(target, inst) {
|
||||
const scopeFn = function(target, inst) {
|
||||
return {where: {kind: this.modelName}};
|
||||
};
|
||||
|
||||
var propertiesFn = function(target, inst) {
|
||||
const propertiesFn = function(target, inst) {
|
||||
return {kind: this.modelName};
|
||||
};
|
||||
|
||||
|
@ -138,14 +138,14 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('manipulation', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
before(function(done) {
|
||||
db.automigrate(done);
|
||||
});
|
||||
|
||||
it('should return a scoped instance', function() {
|
||||
var p = new Tool({name: 'Product A', kind: 'ignored'});
|
||||
const p = new Tool({name: 'Product A', kind: 'ignored'});
|
||||
p.name.should.equal('Product A');
|
||||
p.kind.should.equal('Tool');
|
||||
p.setAttributes({kind: 'ignored'});
|
||||
|
@ -205,7 +205,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
it('should update a scoped instance - updateOrCreate', function(done) {
|
||||
var data = {id: ids.productA, description: 'Anything...', kind: 'ingored'};
|
||||
const data = {id: ids.productA, description: 'Anything...', kind: 'ingored'};
|
||||
Tool.updateOrCreate(data, function(err, p) {
|
||||
should.not.exist(err);
|
||||
p.name.should.equal('Product A');
|
||||
|
@ -217,7 +217,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('findById', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
before(function(done) {
|
||||
db.automigrate(setupProducts.bind(null, ids, done));
|
||||
|
@ -250,7 +250,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('find', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
before(function(done) {
|
||||
db.automigrate(setupProducts.bind(null, ids, done));
|
||||
|
@ -322,7 +322,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('exists', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
before(function(done) {
|
||||
db.automigrate(setupProducts.bind(null, ids, done));
|
||||
|
@ -370,7 +370,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('count', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
before(function(done) {
|
||||
db.automigrate(setupProducts.bind(null, ids, done));
|
||||
|
@ -418,7 +418,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('removeById', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
function isDeleted(id, done) {
|
||||
Product.exists(id, function(err, exists) {
|
||||
|
@ -476,7 +476,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('update', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
before(function(done) {
|
||||
db.automigrate(setupProducts.bind(null, ids, done));
|
||||
|
@ -521,7 +521,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('remove', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
before(function(done) {
|
||||
db.automigrate(setupProducts.bind(null, ids, done));
|
||||
|
@ -593,7 +593,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('scopes', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
before(function(done) {
|
||||
db.automigrate(setupProducts.bind(null, ids, done));
|
||||
|
@ -673,7 +673,7 @@ describe('default scope', function() {
|
|||
products.should.have.length(2);
|
||||
products[0].name.should.equal('Product');
|
||||
products[1].name.should.equal('Product');
|
||||
var kinds = products.map(function(p) { return p.kind; });
|
||||
const kinds = products.map(function(p) { return p.kind; });
|
||||
kinds.sort();
|
||||
kinds.should.eql(['Thing', 'Widget']);
|
||||
done();
|
||||
|
@ -682,7 +682,7 @@ describe('default scope', function() {
|
|||
});
|
||||
|
||||
describe('relations', function() {
|
||||
var ids = {};
|
||||
const ids = {};
|
||||
|
||||
before(function(done) {
|
||||
db.automigrate(done);
|
||||
|
@ -817,7 +817,7 @@ describe('default scope', function() {
|
|||
Person.findById(1, function(err, person) {
|
||||
should.not.exist(err);
|
||||
should.exist(person);
|
||||
var things = person.things();
|
||||
const things = person.things();
|
||||
should.exist(things);
|
||||
things.should.be.an.instanceOf(Array);
|
||||
things.should.have.length(1);
|
||||
|
|
|
@ -7,12 +7,12 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false */
|
||||
var should = require('./init.js');
|
||||
const should = require('./init.js');
|
||||
|
||||
var db = getSchema();
|
||||
const db = getSchema();
|
||||
|
||||
describe('defaults', function() {
|
||||
var Server;
|
||||
let Server;
|
||||
|
||||
before(function() {
|
||||
Server = db.define('Server', {
|
||||
|
@ -23,7 +23,7 @@ describe('defaults', function() {
|
|||
});
|
||||
|
||||
it('should apply defaults on new', function() {
|
||||
var s = new Server;
|
||||
const s = new Server;
|
||||
s.port.should.equal(80);
|
||||
});
|
||||
|
||||
|
|
|
@ -5,17 +5,17 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var jdb = require('../');
|
||||
var DataSource = jdb.DataSource;
|
||||
var should = require('./init.js');
|
||||
const jdb = require('../');
|
||||
const DataSource = jdb.DataSource;
|
||||
const should = require('./init.js');
|
||||
|
||||
describe('Memory connector with mocked discovery', function() {
|
||||
var ds;
|
||||
let ds;
|
||||
|
||||
before(function() {
|
||||
ds = new DataSource({connector: 'memory'});
|
||||
|
||||
var models = [{type: 'table', name: 'CUSTOMER', owner: 'STRONGLOOP'},
|
||||
const models = [{type: 'table', name: 'CUSTOMER', owner: 'STRONGLOOP'},
|
||||
{type: 'table', name: 'INVENTORY', owner: 'STRONGLOOP'},
|
||||
{type: 'table', name: 'LOCATION', owner: 'STRONGLOOP'}];
|
||||
|
||||
|
@ -25,7 +25,7 @@ describe('Memory connector with mocked discovery', function() {
|
|||
});
|
||||
};
|
||||
|
||||
var modelProperties = [{
|
||||
const modelProperties = [{
|
||||
owner: 'STRONGLOOP',
|
||||
tableName: 'INVENTORY',
|
||||
columnName: 'PRODUCT_ID',
|
||||
|
@ -77,7 +77,7 @@ describe('Memory connector with mocked discovery', function() {
|
|||
ds.discoverSchemas('INVENTORY', {}, function(err, schemas) {
|
||||
if (err) return done(err);
|
||||
schemas.should.have.property('STRONGLOOP.INVENTORY');
|
||||
var s = schemas['STRONGLOOP.INVENTORY'];
|
||||
const s = schemas['STRONGLOOP.INVENTORY'];
|
||||
s.name.should.be.eql('Inventory');
|
||||
Object.keys(s.properties).should.be.eql(
|
||||
['productId', 'locationId', 'available', 'total']
|
||||
|
@ -95,7 +95,7 @@ describe('Memory connector with mocked discovery', function() {
|
|||
}, function(err, schemas) {
|
||||
if (err) return done(err);
|
||||
schemas.should.have.property('STRONGLOOP.INVENTORY');
|
||||
var s = schemas['STRONGLOOP.INVENTORY'];
|
||||
const s = schemas['STRONGLOOP.INVENTORY'];
|
||||
s.name.should.be.eql('inventory');
|
||||
Object.keys(s.properties).should.be.eql(
|
||||
['product_id', 'location_id', 'available', 'total']
|
||||
|
@ -109,7 +109,7 @@ describe('Memory connector with mocked discovery', function() {
|
|||
ds.discoverSchemas('INVENTORY', {nameMapper: null}, function(err, schemas) {
|
||||
if (err) return done(err);
|
||||
schemas.should.have.property('STRONGLOOP.INVENTORY');
|
||||
var s = schemas['STRONGLOOP.INVENTORY'];
|
||||
const s = schemas['STRONGLOOP.INVENTORY'];
|
||||
s.name.should.be.eql('INVENTORY');
|
||||
Object.keys(s.properties).should.be.eql(
|
||||
['PRODUCT_ID', 'LOCATION_ID', 'AVAILABLE', 'TOTAL']
|
||||
|
@ -120,7 +120,7 @@ describe('Memory connector with mocked discovery', function() {
|
|||
|
||||
it('should honor connector\'s discoverSchemas implementation',
|
||||
function(done) {
|
||||
var models = {
|
||||
const models = {
|
||||
inventory: {
|
||||
product: {type: 'string'},
|
||||
location: {type: 'string'},
|
||||
|
@ -140,7 +140,7 @@ describe('Memory connector with mocked discovery', function() {
|
|||
|
||||
it('should callback function, passed as options parameter',
|
||||
function(done) {
|
||||
var models = {
|
||||
const models = {
|
||||
inventory: {
|
||||
product: {type: 'string'},
|
||||
location: {type: 'string'},
|
||||
|
@ -152,7 +152,7 @@ describe('Memory connector with mocked discovery', function() {
|
|||
});
|
||||
};
|
||||
|
||||
var options = function(err, schemas) {
|
||||
const options = function(err, schemas) {
|
||||
if (err) return done(err);
|
||||
schemas.should.be.eql(models);
|
||||
done();
|
||||
|
@ -168,7 +168,7 @@ describe('Memory connector with mocked discovery', function() {
|
|||
.then(function(schemas) {
|
||||
schemas.should.have.property('STRONGLOOP.INVENTORY');
|
||||
|
||||
var s = schemas['STRONGLOOP.INVENTORY'];
|
||||
const s = schemas['STRONGLOOP.INVENTORY'];
|
||||
s.name.should.be.eql('Inventory');
|
||||
|
||||
Object.keys(s.properties).should.be.eql(
|
||||
|
@ -182,8 +182,8 @@ describe('Memory connector with mocked discovery', function() {
|
|||
});
|
||||
|
||||
describe('discoverSchema', function() {
|
||||
var models;
|
||||
var schema;
|
||||
let models;
|
||||
let schema;
|
||||
before(function() {
|
||||
schema = {
|
||||
name: 'Inventory',
|
||||
|
@ -265,7 +265,7 @@ describe('Memory connector with mocked discovery', function() {
|
|||
});
|
||||
|
||||
it('should callback function, passed as options parameter', function(done) {
|
||||
var options = function(err, schemas) {
|
||||
const options = function(err, schemas) {
|
||||
if (err) return done(err);
|
||||
schemas.should.be.eql(schema);
|
||||
done();
|
||||
|
@ -288,11 +288,11 @@ describe('Memory connector with mocked discovery', function() {
|
|||
});
|
||||
|
||||
describe('discoverModelDefinitions', function() {
|
||||
var ds;
|
||||
let ds;
|
||||
before(function() {
|
||||
ds = new DataSource({connector: 'memory'});
|
||||
|
||||
var models = [{type: 'table', name: 'CUSTOMER', owner: 'STRONGLOOP'},
|
||||
const models = [{type: 'table', name: 'CUSTOMER', owner: 'STRONGLOOP'},
|
||||
{type: 'table', name: 'INVENTORY', owner: 'STRONGLOOP'},
|
||||
{type: 'table', name: 'LOCATION', owner: 'STRONGLOOP'}];
|
||||
|
||||
|
@ -307,7 +307,7 @@ describe('discoverModelDefinitions', function() {
|
|||
ds.discoverModelDefinitions({}, function(err, schemas) {
|
||||
if (err) return done(err);
|
||||
|
||||
var tableNames = schemas.map(function(s) {
|
||||
const tableNames = schemas.map(function(s) {
|
||||
return s.name;
|
||||
});
|
||||
|
||||
|
@ -319,10 +319,10 @@ describe('discoverModelDefinitions', function() {
|
|||
});
|
||||
|
||||
it('should callback function, passed as options parameter', function(done) {
|
||||
var options = function(err, schemas) {
|
||||
const options = function(err, schemas) {
|
||||
if (err) return done(err);
|
||||
|
||||
var tableNames = schemas.map(function(s) {
|
||||
const tableNames = schemas.map(function(s) {
|
||||
return s.name;
|
||||
});
|
||||
|
||||
|
@ -338,7 +338,7 @@ describe('discoverModelDefinitions', function() {
|
|||
it('should discover model using `discoverModelDefinitions` - promise variant', function(done) {
|
||||
ds.discoverModelDefinitions({})
|
||||
.then(function(schemas) {
|
||||
var tableNames = schemas.map(function(s) {
|
||||
const tableNames = schemas.map(function(s) {
|
||||
return s.name;
|
||||
});
|
||||
|
||||
|
@ -354,8 +354,8 @@ describe('discoverModelDefinitions', function() {
|
|||
});
|
||||
|
||||
describe('discoverModelProperties', function() {
|
||||
var ds;
|
||||
var modelProperties;
|
||||
let ds;
|
||||
let modelProperties;
|
||||
before(function() {
|
||||
ds = new DataSource({connector: 'memory'});
|
||||
|
||||
|
@ -408,7 +408,7 @@ describe('discoverModelProperties', function() {
|
|||
});
|
||||
|
||||
it('should callback function, passed as options parameter', function(done) {
|
||||
var options = function(err, schemas) {
|
||||
const options = function(err, schemas) {
|
||||
if (err) return done(err);
|
||||
|
||||
schemas.should.be.eql(modelProperties);
|
||||
|
@ -440,8 +440,8 @@ describe('discoverModelProperties', function() {
|
|||
});
|
||||
|
||||
describe('discoverPrimaryKeys', function() {
|
||||
var ds;
|
||||
var modelProperties, primaryKeys;
|
||||
let ds;
|
||||
let modelProperties, primaryKeys;
|
||||
before(function() {
|
||||
ds = new DataSource({connector: 'memory'});
|
||||
|
||||
|
@ -478,7 +478,7 @@ describe('discoverPrimaryKeys', function() {
|
|||
});
|
||||
|
||||
it('should callback function, passed as options parameter', function(done) {
|
||||
var options = function(err, modelPrimaryKeys) {
|
||||
const options = function(err, modelPrimaryKeys) {
|
||||
if (err) return done(err);
|
||||
|
||||
modelPrimaryKeys.should.be.eql(primaryKeys);
|
||||
|
@ -500,8 +500,8 @@ describe('discoverPrimaryKeys', function() {
|
|||
});
|
||||
|
||||
describe('discoverForeignKeys', function() {
|
||||
var ds;
|
||||
var modelProperties, foreignKeys;
|
||||
let ds;
|
||||
let modelProperties, foreignKeys;
|
||||
before(function() {
|
||||
ds = new DataSource({connector: 'memory'});
|
||||
|
||||
|
@ -534,7 +534,7 @@ describe('discoverForeignKeys', function() {
|
|||
});
|
||||
|
||||
it('should callback function, passed as options parameter', function(done) {
|
||||
var options = function(err, modelForeignKeys) {
|
||||
const options = function(err, modelForeignKeys) {
|
||||
if (err) return done(err);
|
||||
|
||||
modelForeignKeys.should.be.eql(foreignKeys);
|
||||
|
@ -557,8 +557,8 @@ describe('discoverForeignKeys', function() {
|
|||
});
|
||||
|
||||
describe('discoverExportedForeignKeys', function() {
|
||||
var ds;
|
||||
var modelProperties, exportedForeignKeys;
|
||||
let ds;
|
||||
let modelProperties, exportedForeignKeys;
|
||||
before(function() {
|
||||
ds = new DataSource({connector: 'memory'});
|
||||
|
||||
|
@ -591,7 +591,7 @@ describe('discoverExportedForeignKeys', function() {
|
|||
});
|
||||
|
||||
it('should callback function, passed as options parameter', function(done) {
|
||||
var options = function(err, modelForeignKeys) {
|
||||
const options = function(err, modelForeignKeys) {
|
||||
if (err) return done(err);
|
||||
|
||||
modelForeignKeys.should.be.eql(exportedForeignKeys);
|
||||
|
@ -615,9 +615,9 @@ describe('discoverExportedForeignKeys', function() {
|
|||
});
|
||||
|
||||
describe('Mock connector', function() {
|
||||
var mockConnectors = require('./mock-connectors');
|
||||
const mockConnectors = require('./mock-connectors');
|
||||
describe('customFieldSettings', function() {
|
||||
var ds = new DataSource(mockConnectors.customFieldSettings);
|
||||
const ds = new DataSource(mockConnectors.customFieldSettings);
|
||||
|
||||
it('should be present in discoverSchemas', function(done) {
|
||||
ds.discoverSchemas('person', function(err, schemas) {
|
||||
|
@ -632,7 +632,8 @@ describe('Mock connector', function() {
|
|||
});
|
||||
|
||||
describe('Default memory connector', function() {
|
||||
var ds, nonExistantError = 'Table \'NONEXISTENT\' does not exist.';
|
||||
const nonExistantError = 'Table \'NONEXISTENT\' does not exist.';
|
||||
let ds;
|
||||
|
||||
before(function() {
|
||||
ds = new DataSource({connector: 'memory'});
|
||||
|
|
|
@ -5,19 +5,19 @@
|
|||
|
||||
// This test written in mocha+should.js
|
||||
'use strict';
|
||||
var should = require('./init.js');
|
||||
var assert = require('assert');
|
||||
const should = require('./init.js');
|
||||
const assert = require('assert');
|
||||
|
||||
var jdb = require('../');
|
||||
var ModelBuilder = jdb.ModelBuilder;
|
||||
const jdb = require('../');
|
||||
const ModelBuilder = jdb.ModelBuilder;
|
||||
|
||||
describe('exclude properties ', function() {
|
||||
it('from base model', function(done) {
|
||||
var ds = new ModelBuilder();
|
||||
const ds = new ModelBuilder();
|
||||
// create a base model User which has name and password properties. id property gets
|
||||
// internally created for the User Model
|
||||
var User = ds.define('User', {name: String, password: String});
|
||||
var properties = User.definition.properties;
|
||||
const User = ds.define('User', {name: String, password: String});
|
||||
let properties = User.definition.properties;
|
||||
// User should have id, name & password properties
|
||||
assert(('id' in properties) && ('password' in properties) && ('name' in properties),
|
||||
'User should have id, name & password properties');
|
||||
|
@ -26,7 +26,7 @@ describe('exclude properties ', function() {
|
|||
// With excludeBaseProperties, 'password' and 'id' gets excluded from base User model
|
||||
// With idInjection: false - id property of sub Model Customer gets excluded. At the end
|
||||
// User will have these 2 properties: name (inherited from User model) and vip (from customer Model).
|
||||
var Customer = User.extend('Customer', {vip: {type: String}},
|
||||
const Customer = User.extend('Customer', {vip: {type: String}},
|
||||
{idInjection: false, excludeBaseProperties: ['password', 'id']});
|
||||
// Customer should have these properties: name(from UserModel) & vip
|
||||
properties = Customer.definition.properties;
|
||||
|
|
|
@ -10,36 +10,36 @@
|
|||
|
||||
require('should');
|
||||
|
||||
var GeoPoint = require('../lib/geo').GeoPoint;
|
||||
var nearFilter = require('../lib/geo').nearFilter;
|
||||
var geoFilter = require('../lib/geo').filter;
|
||||
var DELTA = 0.0000001;
|
||||
const GeoPoint = require('../lib/geo').GeoPoint;
|
||||
const nearFilter = require('../lib/geo').nearFilter;
|
||||
const geoFilter = require('../lib/geo').filter;
|
||||
const DELTA = 0.0000001;
|
||||
|
||||
describe('GeoPoint', function() {
|
||||
describe('constructor', function() {
|
||||
it('should support a valid array', function() {
|
||||
var point = new GeoPoint([-34, 150]);
|
||||
const point = new GeoPoint([-34, 150]);
|
||||
|
||||
point.lat.should.equal(-34);
|
||||
point.lng.should.equal(150);
|
||||
});
|
||||
|
||||
it('should support a valid object', function() {
|
||||
var point = new GeoPoint({lat: -34, lng: 150});
|
||||
const point = new GeoPoint({lat: -34, lng: 150});
|
||||
|
||||
point.lat.should.equal(-34);
|
||||
point.lng.should.equal(150);
|
||||
});
|
||||
|
||||
it('should support valid string geo coordinates', function() {
|
||||
var point = new GeoPoint('-34,150');
|
||||
const point = new GeoPoint('-34,150');
|
||||
|
||||
point.lat.should.equal(-34);
|
||||
point.lng.should.equal(150);
|
||||
});
|
||||
|
||||
it('should support coordinates as inline parameters', function() {
|
||||
var point = new GeoPoint(-34, 150);
|
||||
const point = new GeoPoint(-34, 150);
|
||||
|
||||
point.lat.should.equal(-34);
|
||||
point.lng.should.equal(150);
|
||||
|
@ -47,7 +47,7 @@ describe('GeoPoint', function() {
|
|||
|
||||
it('should reject invalid parameters', function() {
|
||||
/* jshint -W024 */
|
||||
var fn = function() {
|
||||
let fn = function() {
|
||||
new GeoPoint('150,-34');
|
||||
};
|
||||
fn.should.throw();
|
||||
|
@ -84,17 +84,17 @@ describe('GeoPoint', function() {
|
|||
|
||||
describe('toString()', function() {
|
||||
it('should return a string in the form "lat,lng"', function() {
|
||||
var point = new GeoPoint({lat: -34, lng: 150});
|
||||
const point = new GeoPoint({lat: -34, lng: 150});
|
||||
point.toString().should.equal('-34,150');
|
||||
});
|
||||
});
|
||||
|
||||
describe('distance calculation between two points', function() {
|
||||
var here = new GeoPoint({lat: 40.77492964101182, lng: -73.90950187151662});
|
||||
var there = new GeoPoint({lat: 40.7753227, lng: -73.909217});
|
||||
const here = new GeoPoint({lat: 40.77492964101182, lng: -73.90950187151662});
|
||||
const there = new GeoPoint({lat: 40.7753227, lng: -73.909217});
|
||||
|
||||
it('should return value in miles by default', function() {
|
||||
var distance = GeoPoint.distanceBetween(here, there);
|
||||
const distance = GeoPoint.distanceBetween(here, there);
|
||||
distance.should.be.a.Number;
|
||||
distance.should.be.approximately(0.03097916611592679, DELTA);
|
||||
});
|
||||
|
@ -109,7 +109,7 @@ describe('GeoPoint', function() {
|
|||
* - `degrees`
|
||||
*/
|
||||
|
||||
var distance = here.distanceTo(there, {type: 'radians'});
|
||||
let distance = here.distanceTo(there, {type: 'radians'});
|
||||
distance.should.be.a.Number;
|
||||
distance.should.be.approximately(0.000007825491914348416, DELTA);
|
||||
|
||||
|
@ -137,7 +137,7 @@ describe('GeoPoint', function() {
|
|||
|
||||
describe('nearFilter()', function() {
|
||||
it('should return a filter includes minDistance if where contains minDistance option', function() {
|
||||
var where = {
|
||||
const where = {
|
||||
location: {
|
||||
near: {
|
||||
lat: 40.77492964101182,
|
||||
|
@ -146,7 +146,7 @@ describe('GeoPoint', function() {
|
|||
minDistance: 100,
|
||||
},
|
||||
};
|
||||
var filter = nearFilter(where);
|
||||
const filter = nearFilter(where);
|
||||
filter[0].key.should.equal('location');
|
||||
filter[0].should.have.properties({
|
||||
key: 'location',
|
||||
|
@ -161,7 +161,7 @@ describe('GeoPoint', function() {
|
|||
|
||||
describe('filter()', function() {
|
||||
it('should be able to filter geo points via minDistance', function() {
|
||||
var points = [{
|
||||
const points = [{
|
||||
location: {
|
||||
lat: 30.283552,
|
||||
lng: 120.126048,
|
||||
|
@ -187,7 +187,7 @@ describe('GeoPoint', function() {
|
|||
lng: 121.483687,
|
||||
},
|
||||
}];
|
||||
var filter = [{
|
||||
const filter = [{
|
||||
key: 'location',
|
||||
near: {
|
||||
lat: 30.278562,
|
||||
|
@ -196,7 +196,7 @@ describe('GeoPoint', function() {
|
|||
unit: 'meters',
|
||||
minDistance: 10000,
|
||||
}];
|
||||
var results = geoFilter(points, filter);
|
||||
const results = geoFilter(points, filter);
|
||||
results.length.should.be.equal(3);
|
||||
});
|
||||
});
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var fmt = require('util').format;
|
||||
const fmt = require('util').format;
|
||||
|
||||
exports.describeIf = function describeIf(cond, name, fn) {
|
||||
if (cond)
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
'use strict';
|
||||
|
||||
var traverse = require('traverse');
|
||||
const traverse = require('traverse');
|
||||
|
||||
exports.ContextRecorder = ContextRecorder;
|
||||
exports.deepCloneToObject = deepCloneToObject;
|
||||
|
@ -18,7 +18,7 @@ function ContextRecorder(initialValue) {
|
|||
}
|
||||
|
||||
ContextRecorder.prototype.recordAndNext = function(transformFm) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
return function(context, next) {
|
||||
if (typeof transformFm === 'function') {
|
||||
transformFm(context);
|
||||
|
|
|
@ -16,12 +16,12 @@ function HookMonitor(opts) {
|
|||
}
|
||||
|
||||
HookMonitor.prototype.install = function(ObservedModel, hookNames) {
|
||||
var monitor = this;
|
||||
const monitor = this;
|
||||
this.names = [];
|
||||
ObservedModel._notify = ObservedModel.notifyObserversOf;
|
||||
ObservedModel.notifyObserversOf = function(operation, context, callback) {
|
||||
if (!Array.isArray(hookNames) || hookNames.indexOf(operation) !== -1) {
|
||||
var item = monitor.options.includeModelName ?
|
||||
const item = monitor.options.includeModelName ?
|
||||
ObservedModel.modelName + ':' + operation :
|
||||
operation;
|
||||
monitor.names.push(item);
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var lastId = 0;
|
||||
let lastId = 0;
|
||||
|
||||
exports.next = function() {
|
||||
lastId++;
|
||||
|
|
|
@ -7,14 +7,14 @@
|
|||
|
||||
// This test written in mocha+should.js
|
||||
/* global getSchema:false */
|
||||
var should = require('./init.js');
|
||||
const should = require('./init.js');
|
||||
|
||||
var j = require('../'),
|
||||
const j = require('../'),
|
||||
Schema = j.Schema,
|
||||
AbstractClass = j.AbstractClass,
|
||||
Hookable = j.Hookable,
|
||||
Hookable = j.Hookable;
|
||||
|
||||
db, User;
|
||||
let db, User;
|
||||
|
||||
describe('hooks', function() {
|
||||
before(function(done) {
|
||||
|
@ -43,7 +43,7 @@ describe('hooks', function() {
|
|||
});
|
||||
|
||||
it('should be triggered on create', function(done) {
|
||||
var user;
|
||||
let user;
|
||||
User.afterInitialize = function() {
|
||||
if (this.name === 'Nickolay') {
|
||||
this.name += ' Rozental';
|
||||
|
@ -70,7 +70,7 @@ describe('hooks', function() {
|
|||
should.fail('This should not be called');
|
||||
next();
|
||||
};
|
||||
var u = new User;
|
||||
const u = new User;
|
||||
});
|
||||
|
||||
it('should be triggered on new+save', function(done) {
|
||||
|
@ -79,7 +79,7 @@ describe('hooks', function() {
|
|||
});
|
||||
|
||||
it('afterCreate should not be triggered on failed create', function(done) {
|
||||
var old = User.dataSource.connector.create;
|
||||
const old = User.dataSource.connector.create;
|
||||
User.dataSource.connector.create = function(modelName, id, cb) {
|
||||
cb(new Error('error'));
|
||||
};
|
||||
|
@ -99,7 +99,7 @@ describe('hooks', function() {
|
|||
next(new Error('fail in beforeCreate'));
|
||||
};
|
||||
|
||||
var old = User.dataSource.connector.create;
|
||||
const old = User.dataSource.connector.create;
|
||||
User.dataSource.connector.create = function(modelName, id, cb) {
|
||||
throw new Error('shouldn\'t be called');
|
||||
};
|
||||
|
@ -259,7 +259,7 @@ describe('hooks', function() {
|
|||
should.fail('afterUpdate shouldn\'t be called');
|
||||
};
|
||||
User.create(function(err, user) {
|
||||
var save = User.dataSource.connector.save;
|
||||
const save = User.dataSource.connector.save;
|
||||
User.dataSource.connector.save = function(modelName, id, cb) {
|
||||
User.dataSource.connector.save = save;
|
||||
cb(new Error('Error'));
|
||||
|
@ -276,7 +276,7 @@ describe('hooks', function() {
|
|||
afterEach(removeHooks('Destroy'));
|
||||
|
||||
it('should be triggered on destroy', function(done) {
|
||||
var hook = 'not called';
|
||||
let hook = 'not called';
|
||||
User.beforeDestroy = function(next) {
|
||||
hook = 'called';
|
||||
next();
|
||||
|
@ -291,7 +291,7 @@ describe('hooks', function() {
|
|||
});
|
||||
|
||||
it('should not trigger after-hook on failed destroy', function(done) {
|
||||
var destroy = User.dataSource.connector.destroy;
|
||||
const destroy = User.dataSource.connector.destroy;
|
||||
User.dataSource.connector.destroy = function(modelName, id, cb) {
|
||||
cb(new Error('error'));
|
||||
};
|
||||
|
@ -308,7 +308,7 @@ describe('hooks', function() {
|
|||
});
|
||||
|
||||
describe('lifecycle', function() {
|
||||
var life = [], user;
|
||||
let life = [], user;
|
||||
before(function(done) {
|
||||
User.beforeSave = function(d) {
|
||||
life.push('beforeSave');
|
||||
|
@ -379,7 +379,7 @@ describe('hooks', function() {
|
|||
});
|
||||
|
||||
it('should describe new+save sequence', function(done) {
|
||||
var u = new User;
|
||||
const u = new User;
|
||||
u.save(function() {
|
||||
life.should.eql([
|
||||
'afterInitialize',
|
||||
|
@ -436,7 +436,8 @@ describe('hooks', function() {
|
|||
});
|
||||
|
||||
function addHooks(name, done) {
|
||||
var called = false, random = String(Math.floor(Math.random() * 1000));
|
||||
const random = String(Math.floor(Math.random() * 1000));
|
||||
let called = false;
|
||||
User['before' + name] = function(next, data) {
|
||||
called = true;
|
||||
data.email = random;
|
||||
|
|
|
@ -6,19 +6,19 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false, connectorCapabilities:false */
|
||||
var assert = require('assert');
|
||||
var async = require('async');
|
||||
var bdd = require('./helpers/bdd-if');
|
||||
var should = require('./init.js');
|
||||
const assert = require('assert');
|
||||
const async = require('async');
|
||||
const bdd = require('./helpers/bdd-if');
|
||||
const should = require('./init.js');
|
||||
|
||||
var DataSource = require('../').DataSource;
|
||||
const DataSource = require('../').DataSource;
|
||||
|
||||
var db, User, Profile, AccessToken, Post, Passport, City, Street, Building, Assembly, Part;
|
||||
let db, User, Profile, AccessToken, Post, Passport, City, Street, Building, Assembly, Part;
|
||||
|
||||
var knownUsers = ['User A', 'User B', 'User C', 'User D', 'User E'];
|
||||
var knownPassports = ['1', '2', '3', '4'];
|
||||
var knownPosts = ['Post A', 'Post B', 'Post C', 'Post D', 'Post E'];
|
||||
var knownProfiles = ['Profile A', 'Profile B', 'Profile Z'];
|
||||
const knownUsers = ['User A', 'User B', 'User C', 'User D', 'User E'];
|
||||
const knownPassports = ['1', '2', '3', '4'];
|
||||
const knownPosts = ['Post A', 'Post B', 'Post C', 'Post D', 'Post E'];
|
||||
const knownProfiles = ['Profile A', 'Profile B', 'Profile Z'];
|
||||
|
||||
describe('include', function() {
|
||||
before(setup);
|
||||
|
@ -34,7 +34,7 @@ describe('include', function() {
|
|||
// The __cachedRelations should be removed from json output
|
||||
p.toJSON().should.not.have.property('__cachedRelations');
|
||||
|
||||
var owner = p.__cachedRelations.owner;
|
||||
const owner = p.__cachedRelations.owner;
|
||||
if (!p.ownerId) {
|
||||
should.not.exist(owner);
|
||||
} else {
|
||||
|
@ -49,7 +49,7 @@ describe('include', function() {
|
|||
it('does not return included item if FK is excluded', function(done) {
|
||||
Passport.find({include: 'owner', fields: 'number'}, function(err, passports) {
|
||||
if (err) return done(err);
|
||||
var owner = passports[0].toJSON().owner;
|
||||
const owner = passports[0].toJSON().owner;
|
||||
should.not.exist(owner);
|
||||
done();
|
||||
});
|
||||
|
@ -117,13 +117,13 @@ describe('include', function() {
|
|||
user.save(function(err) { // save the returned user
|
||||
if (err) return finish(err);
|
||||
// should not store in db the posts
|
||||
var dsName = User.dataSource.name;
|
||||
const dsName = User.dataSource.name;
|
||||
if (dsName === 'memory') {
|
||||
JSON.parse(User.dataSource.adapter.cache.User[1]).should.not.have.property('posts');
|
||||
finish();
|
||||
} else if (dsName === 'mongodb') { // Check native mongodb connector
|
||||
// get hold of native mongodb collection
|
||||
var dbCollection = User.dataSource.connector.collection(User.modelName);
|
||||
const dbCollection = User.dataSource.connector.collection(User.modelName);
|
||||
dbCollection.findOne({_id: user.id})
|
||||
.then(function(foundUser) {
|
||||
if (!foundUser) {
|
||||
|
@ -153,7 +153,7 @@ describe('include', function() {
|
|||
// The __cachedRelations should be removed from json output
|
||||
p.toJSON().should.not.have.property('__cachedRelations');
|
||||
|
||||
var user = p.__cachedRelations.owner;
|
||||
const user = p.__cachedRelations.owner;
|
||||
if (!p.ownerId) {
|
||||
should.not.exist(user);
|
||||
} else {
|
||||
|
@ -183,7 +183,7 @@ describe('include', function() {
|
|||
// The __cachedRelations should be removed from json output
|
||||
passport.toJSON().should.not.have.property('__cachedRelations');
|
||||
|
||||
var user = passport.__cachedRelations.owner;
|
||||
const user = passport.__cachedRelations.owner;
|
||||
should.exist(user);
|
||||
user.id.should.eql(passport.ownerId);
|
||||
user.__cachedRelations.should.have.property('posts');
|
||||
|
@ -199,7 +199,7 @@ describe('include', function() {
|
|||
should.not.exist(err);
|
||||
should.exist(passports);
|
||||
passports.length.should.be.ok;
|
||||
var posts;
|
||||
let posts;
|
||||
if (connectorCapabilities.adhocSort !== false) {
|
||||
posts = passports[0].owner().posts();
|
||||
posts.should.have.length(3);
|
||||
|
@ -222,7 +222,7 @@ describe('include', function() {
|
|||
passports.length.should.be.ok;
|
||||
passports.forEach(function(p) {
|
||||
p.__cachedRelations.should.have.property('owner');
|
||||
var user = p.__cachedRelations.owner;
|
||||
const user = p.__cachedRelations.owner;
|
||||
if (!p.ownerId) {
|
||||
should.not.exist(user);
|
||||
} else {
|
||||
|
@ -235,7 +235,7 @@ describe('include', function() {
|
|||
pp.userId.toString().should.eql(user.id.toString());
|
||||
pp.should.have.property('author');
|
||||
pp.__cachedRelations.should.have.property('author');
|
||||
var author = pp.__cachedRelations.author;
|
||||
const author = pp.__cachedRelations.author;
|
||||
author.id.should.eql(user.id);
|
||||
});
|
||||
}
|
||||
|
@ -253,7 +253,7 @@ describe('include', function() {
|
|||
}, function(err, passports) {
|
||||
should.not.exist(err);
|
||||
should.exist(passports);
|
||||
var passport, owner, posts;
|
||||
let passport, owner, posts;
|
||||
if (connectorCapabilities.adhocSort !== false) {
|
||||
passports.length.should.equal(4);
|
||||
|
||||
|
@ -317,10 +317,10 @@ describe('include', function() {
|
|||
}, function(err, passports) {
|
||||
if (err) return done(err);
|
||||
passports.length.should.equal(2);
|
||||
var posts1 = passports[0].toJSON().owner.posts;
|
||||
const posts1 = passports[0].toJSON().owner.posts;
|
||||
posts1.length.should.equal(1);
|
||||
posts1[0].title.should.equal('Post C');
|
||||
var posts2 = passports[1].toJSON().owner.posts;
|
||||
const posts2 = passports[1].toJSON().owner.posts;
|
||||
posts2.length.should.equal(1);
|
||||
posts2[0].title.should.equal('Post D');
|
||||
|
||||
|
@ -344,9 +344,9 @@ describe('include', function() {
|
|||
}, function(err, passports) {
|
||||
if (err) return done(err);
|
||||
passports.length.should.equal(2);
|
||||
var owner = passports[0].toJSON().owner;
|
||||
let owner = passports[0].toJSON().owner;
|
||||
if (owner) {
|
||||
var posts1 = owner.posts;
|
||||
const posts1 = owner.posts;
|
||||
posts1.length.should.belowOrEqual(1);
|
||||
if (posts1.length === 1) {
|
||||
posts1[0].title.should.be.oneOf(knownPosts);
|
||||
|
@ -354,7 +354,7 @@ describe('include', function() {
|
|||
}
|
||||
owner = passports[1].toJSON().owner;
|
||||
if (owner) {
|
||||
var posts2 = owner.posts;
|
||||
const posts2 = owner.posts;
|
||||
posts2.length.should.belowOrEqual(1);
|
||||
if (posts2.length === 1) {
|
||||
posts2[0].title.should.be.oneOf(knownPosts);
|
||||
|
@ -394,10 +394,10 @@ describe('include', function() {
|
|||
if (err) return done(err);
|
||||
|
||||
passports.length.should.equal(4);
|
||||
var posts1 = passports[0].toJSON().owner.posts;
|
||||
const posts1 = passports[0].toJSON().owner.posts;
|
||||
posts1.length.should.equal(3);
|
||||
posts1[0].title.should.equal('Post A');
|
||||
var posts2 = passports[1].toJSON().owner.posts;
|
||||
const posts2 = passports[1].toJSON().owner.posts;
|
||||
posts2.length.should.equal(1);
|
||||
posts2[0].title.should.equal('Post D');
|
||||
|
||||
|
@ -417,7 +417,7 @@ describe('include', function() {
|
|||
}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var passport = user.passports()[0];
|
||||
const passport = user.passports()[0];
|
||||
// eql instead of equal because mongo uses object id type
|
||||
passport.id.should.eql(createdPassports[0].id);
|
||||
passport.ownerId.should.eql(createdPassports[0].ownerId);
|
||||
|
@ -448,9 +448,9 @@ describe('include', function() {
|
|||
user.name.should.equal('User A');
|
||||
user.age.should.equal(21);
|
||||
user.id.should.eql(createdUsers[0].id);
|
||||
var posts = user.posts();
|
||||
const posts = user.posts();
|
||||
posts.length.should.equal(1);
|
||||
var post = posts[0];
|
||||
const post = posts[0];
|
||||
post.title.should.equal('Post A');
|
||||
// eql instead of equal because mongo uses object id type
|
||||
post.userId.should.eql(createdPosts[0].userId);
|
||||
|
@ -488,7 +488,7 @@ describe('include', function() {
|
|||
}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var ids = user.posts().map(function(p) { return p.id; });
|
||||
const ids = user.posts().map(function(p) { return p.id; });
|
||||
ids.should.eql([createdPosts[1].id, createdPosts[2].id]);
|
||||
|
||||
done();
|
||||
|
@ -506,7 +506,7 @@ describe('include', function() {
|
|||
}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var ids = user.posts().map(function(p) { return p.id; });
|
||||
const ids = user.posts().map(function(p) { return p.id; });
|
||||
ids.should.eql([createdPosts[1].id, createdPosts[2].id]);
|
||||
|
||||
done();
|
||||
|
@ -518,8 +518,8 @@ describe('include', function() {
|
|||
User.findOne({include: {relation: 'posts'}}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var posts = user.posts();
|
||||
var ids = posts.map(function(p) { return p.id; });
|
||||
const posts = user.posts();
|
||||
const ids = posts.map(function(p) { return p.id; });
|
||||
ids.should.eql([
|
||||
createdPosts[0].id,
|
||||
createdPosts[1].id,
|
||||
|
@ -586,7 +586,7 @@ describe('include', function() {
|
|||
user.age.should.equal(21);
|
||||
// eql instead of equal because mongo uses object id type
|
||||
user.id.should.eql(createdUsers[0].id);
|
||||
var profile = user.profile();
|
||||
const profile = user.profile();
|
||||
profile.profileName.should.equal('Profile A');
|
||||
// eql instead of equal because mongo uses object id type
|
||||
profile.userId.should.eql(createdProfiles[0].userId);
|
||||
|
@ -621,9 +621,9 @@ describe('include', function() {
|
|||
});
|
||||
|
||||
it('works when hasManyThrough is called', function(done) {
|
||||
var Physician = db.define('Physician', {name: String});
|
||||
var Patient = db.define('Patient', {name: String});
|
||||
var Appointment = db.define('Appointment', {
|
||||
const Physician = db.define('Physician', {name: String});
|
||||
const Patient = db.define('Patient', {name: String});
|
||||
const Appointment = db.define('Appointment', {
|
||||
date: {
|
||||
type: Date,
|
||||
default: function() {
|
||||
|
@ -631,7 +631,7 @@ describe('include', function() {
|
|||
},
|
||||
},
|
||||
});
|
||||
var Address = db.define('Address', {name: String});
|
||||
const Address = db.define('Address', {name: String});
|
||||
|
||||
Physician.hasMany(Patient, {through: Appointment});
|
||||
Patient.hasMany(Physician, {through: Appointment});
|
||||
|
@ -651,7 +651,7 @@ describe('include', function() {
|
|||
if (err) return done(err);
|
||||
|
||||
patients.should.have.length(1);
|
||||
var p = patients[0];
|
||||
const p = patients[0];
|
||||
p.name.should.equal('a');
|
||||
p.addressId.should.eql(patient.addressId);
|
||||
p.address().id.should.eql(address.id);
|
||||
|
@ -673,7 +673,7 @@ describe('include', function() {
|
|||
profile.profileName.should.equal('Profile A');
|
||||
profile.userId.should.eql(createdProfiles[0].userId);
|
||||
profile.id.should.eql(createdProfiles[0].id);
|
||||
var user = profile.user();
|
||||
const user = profile.user();
|
||||
user.name.should.equal('User A');
|
||||
user.age.should.equal(21);
|
||||
user.id.should.eql(createdUsers[0].id);
|
||||
|
@ -696,10 +696,10 @@ describe('include', function() {
|
|||
}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var passport = user.passports()[0];
|
||||
const passport = user.passports()[0];
|
||||
if (passport) {
|
||||
var knownPassportIds = [];
|
||||
var knownOwnerIds = [];
|
||||
const knownPassportIds = [];
|
||||
const knownOwnerIds = [];
|
||||
createdPassports.forEach(function(p) {
|
||||
if (p.id) knownPassportIds.push(p.id);
|
||||
if (p.ownerId) knownOwnerIds.push(p.ownerId.toString());
|
||||
|
@ -731,7 +731,7 @@ describe('include', function() {
|
|||
}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var posts, post;
|
||||
let posts, post;
|
||||
if (connectorCapabilities.adhocSort !== false) {
|
||||
user.name.should.equal('User A');
|
||||
user.age.should.equal(21);
|
||||
|
@ -745,7 +745,7 @@ describe('include', function() {
|
|||
post.id.should.eql(createdPosts[0].id);
|
||||
} else {
|
||||
user.name.should.be.oneOf(knownUsers);
|
||||
var knownUserIds = [];
|
||||
const knownUserIds = [];
|
||||
createdUsers.forEach(function(u) {
|
||||
knownUserIds.push(u.id.toString());
|
||||
});
|
||||
|
@ -755,7 +755,7 @@ describe('include', function() {
|
|||
post = posts[0];
|
||||
post.title.should.be.oneOf(knownPosts);
|
||||
post.userId.toString().should.be.oneOf(knownUserIds);
|
||||
var knownPostIds = [];
|
||||
const knownPostIds = [];
|
||||
createdPosts.forEach(function(p) {
|
||||
knownPostIds.push(p.id);
|
||||
});
|
||||
|
@ -794,9 +794,9 @@ describe('include', function() {
|
|||
}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var ids = user.posts().map(function(p) { return p.id; });
|
||||
const ids = user.posts().map(function(p) { return p.id; });
|
||||
if (ids.length > 0) {
|
||||
var knownPosts = [];
|
||||
const knownPosts = [];
|
||||
createdPosts.forEach(function(p) {
|
||||
if (p.id) knownPosts.push(p.id);
|
||||
});
|
||||
|
@ -820,9 +820,9 @@ describe('include', function() {
|
|||
}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var ids = user.posts().map(function(p) { return p.id; });
|
||||
const ids = user.posts().map(function(p) { return p.id; });
|
||||
if (ids.length > 0) {
|
||||
var knownPosts = [];
|
||||
const knownPosts = [];
|
||||
createdPosts.forEach(function(p) {
|
||||
if (p.id) knownPosts.push(p.id);
|
||||
});
|
||||
|
@ -840,10 +840,10 @@ describe('include', function() {
|
|||
User.findOne({include: {relation: 'posts'}}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var posts = user.posts();
|
||||
var ids = posts.map(function(p) { return p.id; });
|
||||
const posts = user.posts();
|
||||
const ids = posts.map(function(p) { return p.id; });
|
||||
if (ids.length > 0) {
|
||||
var knownPosts = [];
|
||||
const knownPosts = [];
|
||||
createdPosts.forEach(function(p) {
|
||||
if (p.id) knownPosts.push(p.id);
|
||||
});
|
||||
|
@ -910,8 +910,8 @@ describe('include', function() {
|
|||
User.findOne({include: {relation: 'profile'}}, function(err, user) {
|
||||
if (err) return done(err);
|
||||
|
||||
var knownUserIds = [];
|
||||
var knownProfileIds = [];
|
||||
const knownUserIds = [];
|
||||
const knownProfileIds = [];
|
||||
createdUsers.forEach(function(u) {
|
||||
// FIXME user.id below might be string, so knownUserIds should match
|
||||
knownUserIds.push(u.id.toString());
|
||||
|
@ -924,7 +924,7 @@ describe('include', function() {
|
|||
user.name.should.be.oneOf(knownUsers);
|
||||
// eql instead of equal because mongo uses object id type
|
||||
user.id.toString().should.be.oneOf(knownUserIds);
|
||||
var profile = user.profile();
|
||||
const profile = user.profile();
|
||||
if (profile) {
|
||||
profile.profileName.should.be.oneOf(knownProfiles);
|
||||
// eql instead of equal because mongo uses object id type
|
||||
|
@ -941,7 +941,7 @@ describe('include', function() {
|
|||
User.findOne({include: {relation: 'posts'}}, function(err, user) {
|
||||
if (err) return done();
|
||||
|
||||
var knownUserIds = [];
|
||||
const knownUserIds = [];
|
||||
createdUsers.forEach(function(u) {
|
||||
knownUserIds.push(u.id);
|
||||
});
|
||||
|
@ -955,9 +955,9 @@ describe('include', function() {
|
|||
});
|
||||
|
||||
it('works when hasManyThrough is called', function(done) {
|
||||
var Physician = db.define('Physician', {name: String});
|
||||
var Patient = db.define('Patient', {name: String});
|
||||
var Appointment = db.define('Appointment', {
|
||||
const Physician = db.define('Physician', {name: String});
|
||||
const Patient = db.define('Patient', {name: String});
|
||||
const Appointment = db.define('Appointment', {
|
||||
date: {
|
||||
type: Date,
|
||||
default: function() {
|
||||
|
@ -965,7 +965,7 @@ describe('include', function() {
|
|||
},
|
||||
},
|
||||
});
|
||||
var Address = db.define('Address', {name: String});
|
||||
const Address = db.define('Address', {name: String});
|
||||
|
||||
Physician.hasMany(Patient, {through: Appointment});
|
||||
Patient.hasMany(Physician, {through: Appointment});
|
||||
|
@ -984,7 +984,7 @@ describe('include', function() {
|
|||
function(err, patients) {
|
||||
if (err) return done(err);
|
||||
patients.should.have.length(1);
|
||||
var p = patients[0];
|
||||
const p = patients[0];
|
||||
p.name.should.equal('a');
|
||||
p.addressId.should.eql(patient.addressId);
|
||||
p.address().id.should.eql(address.id);
|
||||
|
@ -1004,8 +1004,8 @@ describe('include', function() {
|
|||
if (err) return done(err);
|
||||
if (!profile) return done(); // not every user has progile
|
||||
|
||||
var knownUserIds = [];
|
||||
var knownProfileIds = [];
|
||||
const knownUserIds = [];
|
||||
const knownProfileIds = [];
|
||||
createdUsers.forEach(function(u) {
|
||||
knownUserIds.push(u.id.toString());
|
||||
});
|
||||
|
@ -1016,7 +1016,7 @@ describe('include', function() {
|
|||
profile.profileName.should.be.oneOf(knownProfiles);
|
||||
if (profile.userId) profile.userId.toString().should.be.oneOf(knownUserIds);
|
||||
if (profile.id) profile.id.toString().should.be.oneOf(knownProfileIds);
|
||||
var user = profile.user();
|
||||
const user = profile.user();
|
||||
if (user) {
|
||||
user.name.should.be.oneOf(knownUsers);
|
||||
user.id.toString().should.be.oneOf(knownUserIds);
|
||||
|
@ -1038,7 +1038,7 @@ describe('include', function() {
|
|||
should.exist(posts);
|
||||
posts.length.should.equal(5);
|
||||
|
||||
var author = posts[0].author();
|
||||
const author = posts[0].author();
|
||||
author.name.should.equal('User A');
|
||||
author.should.have.property('id');
|
||||
author.should.have.property('age', undefined);
|
||||
|
@ -1056,7 +1056,7 @@ describe('include', function() {
|
|||
should.exist(posts);
|
||||
posts.length.should.be.belowOrEqual(5);
|
||||
|
||||
var author = posts[0].author();
|
||||
const author = posts[0].author();
|
||||
if (author) {
|
||||
author.name.should.be.oneOf('User A', 'User B', 'User C', 'User D', 'User E');
|
||||
author.should.have.property('id');
|
||||
|
@ -1081,7 +1081,7 @@ describe('include', function() {
|
|||
users[0].name.should.equal('User A');
|
||||
users[1].name.should.equal('User B');
|
||||
|
||||
var posts = users[0].posts();
|
||||
let posts = users[0].posts();
|
||||
posts.should.be.an.array;
|
||||
posts.should.have.length(3);
|
||||
|
||||
|
@ -1096,7 +1096,7 @@ describe('include', function() {
|
|||
} else {
|
||||
users.forEach(function(u) {
|
||||
u.name.should.be.oneOf(knownUsers);
|
||||
var posts = u.posts();
|
||||
const posts = u.posts();
|
||||
if (posts) {
|
||||
posts.should.be.an.array;
|
||||
posts.length.should.be.belowOrEqual(3);
|
||||
|
@ -1121,7 +1121,7 @@ describe('include', function() {
|
|||
user.should.have.property('posts');
|
||||
user.should.have.property('passports');
|
||||
|
||||
var userObj = user.toJSON();
|
||||
const userObj = user.toJSON();
|
||||
userObj.should.have.property('posts');
|
||||
userObj.should.have.property('passports');
|
||||
userObj.posts.should.be.an.instanceOf(Array);
|
||||
|
@ -1161,7 +1161,7 @@ describe('include', function() {
|
|||
user.should.have.property('posts');
|
||||
user.should.have.property('passports');
|
||||
|
||||
var userObj = user.toJSON();
|
||||
const userObj = user.toJSON();
|
||||
userObj.should.have.property('posts');
|
||||
userObj.should.have.property('passports');
|
||||
userObj.posts.should.be.an.instanceOf(Array);
|
||||
|
@ -1192,7 +1192,7 @@ describe('include', function() {
|
|||
should.exist(users);
|
||||
users.length.should.be.ok;
|
||||
users.forEach(function(user) {
|
||||
var userObj = user.toJSON();
|
||||
const userObj = user.toJSON();
|
||||
userObj.should.not.have.property('accesstokens');
|
||||
});
|
||||
done();
|
||||
|
@ -1228,12 +1228,12 @@ describe('include', function() {
|
|||
should.not.exist(err);
|
||||
should.exist(users);
|
||||
users.length.should.be.ok;
|
||||
var usersWithProfile = 0;
|
||||
let usersWithProfile = 0;
|
||||
users.forEach(function(user) {
|
||||
// The relation should be promoted as the 'owner' property
|
||||
user.should.have.property('profile');
|
||||
var userObj = user.toJSON();
|
||||
var profile = user.profile();
|
||||
const userObj = user.toJSON();
|
||||
const profile = user.profile();
|
||||
if (profile) {
|
||||
profile.should.be.an.instanceOf(Profile);
|
||||
usersWithProfile++;
|
||||
|
@ -1261,7 +1261,7 @@ describe('include', function() {
|
|||
where: {partNumber: 'engine'},
|
||||
}}}, function(err, assemblies) {
|
||||
assemblies.length.should.equal(1);
|
||||
var parts = assemblies[0].parts();
|
||||
const parts = assemblies[0].parts();
|
||||
parts.should.have.length(1);
|
||||
parts[0].partNumber.should.equal('engine');
|
||||
done();
|
||||
|
@ -1273,7 +1273,7 @@ describe('include', function() {
|
|||
include: 'posts',
|
||||
})
|
||||
.then(function(users) {
|
||||
var posts = users[0].posts();
|
||||
const posts = users[0].posts();
|
||||
if (connectorCapabilities.adhocSort !== false) {
|
||||
posts.should.have.length(3);
|
||||
} else {
|
||||
|
@ -1287,7 +1287,7 @@ describe('include', function() {
|
|||
});
|
||||
})
|
||||
.then(function(user) {
|
||||
var posts = user.posts();
|
||||
const posts = user.posts();
|
||||
if (connectorCapabilities.adhocSort !== false) {
|
||||
posts.should.have.length(3);
|
||||
} else {
|
||||
|
@ -1299,10 +1299,10 @@ describe('include', function() {
|
|||
});
|
||||
|
||||
describe('performance', function() {
|
||||
var all;
|
||||
let all;
|
||||
beforeEach(function() {
|
||||
this.called = 0;
|
||||
var self = this;
|
||||
const self = this;
|
||||
all = db.connector.all;
|
||||
db.connector.all = function(model, filter, options, cb) {
|
||||
self.called++;
|
||||
|
@ -1313,9 +1313,9 @@ describe('include', function() {
|
|||
db.connector.all = all;
|
||||
});
|
||||
|
||||
var nDBCalls = connectorCapabilities.supportTwoOrMoreInq !== false ? 2 : 4;
|
||||
const nDBCalls = connectorCapabilities.supportTwoOrMoreInq !== false ? 2 : 4;
|
||||
it('including belongsTo should make only ' + nDBCalls + ' db calls', function(done) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
Passport.find({include: 'owner'}, function(err, passports) {
|
||||
passports.length.should.be.ok;
|
||||
passports.forEach(function(p) {
|
||||
|
@ -1324,7 +1324,7 @@ describe('include', function() {
|
|||
p.should.have.property('owner');
|
||||
// The __cachedRelations should be removed from json output
|
||||
p.toJSON().should.not.have.property('__cachedRelations');
|
||||
var owner = p.__cachedRelations.owner;
|
||||
const owner = p.__cachedRelations.owner;
|
||||
if (!p.ownerId) {
|
||||
should.not.exist(owner);
|
||||
} else {
|
||||
|
@ -1338,7 +1338,7 @@ describe('include', function() {
|
|||
});
|
||||
|
||||
it('including hasManyThrough should make only 3 db calls', function(done) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
Assembly.create([{name: 'sedan'}, {name: 'hatchback'},
|
||||
{name: 'SUV'}],
|
||||
function(err, assemblies) {
|
||||
|
@ -1359,10 +1359,10 @@ describe('include', function() {
|
|||
});
|
||||
}, next);
|
||||
}, function(err) {
|
||||
var autos = connectorCapabilities.supportTwoOrMoreInq !== false ?
|
||||
const autos = connectorCapabilities.supportTwoOrMoreInq !== false ?
|
||||
['sedan', 'hatchback', 'SUV'] : ['sedan'];
|
||||
var resultLength = connectorCapabilities.supportTwoOrMoreInq !== false ? 3 : 1;
|
||||
var dbCalls = connectorCapabilities.supportTwoOrMoreInq !== false ? 3 : 5;
|
||||
const resultLength = connectorCapabilities.supportTwoOrMoreInq !== false ? 3 : 1;
|
||||
const dbCalls = connectorCapabilities.supportTwoOrMoreInq !== false ? 3 : 5;
|
||||
self.called = 0;
|
||||
Assembly.find({
|
||||
where: {
|
||||
|
@ -1376,7 +1376,7 @@ describe('include', function() {
|
|||
should.exists(result);
|
||||
result.length.should.equal(resultLength);
|
||||
// Please note the order of assemblies is random
|
||||
var assemblies = {};
|
||||
const assemblies = {};
|
||||
result.forEach(function(r) {
|
||||
assemblies[r.name] = r;
|
||||
});
|
||||
|
@ -1391,9 +1391,9 @@ describe('include', function() {
|
|||
});
|
||||
});
|
||||
|
||||
var dbCalls = connectorCapabilities.supportTwoOrMoreInq !== false ? 3 : 11;
|
||||
const dbCalls = connectorCapabilities.supportTwoOrMoreInq !== false ? 3 : 11;
|
||||
it('including hasMany should make only ' + dbCalls + ' db calls', function(done) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
User.find({include: ['posts', 'passports']}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
should.exist(users);
|
||||
|
@ -1403,7 +1403,7 @@ describe('include', function() {
|
|||
user.should.have.property('posts');
|
||||
user.should.have.property('passports');
|
||||
|
||||
var userObj = user.toJSON();
|
||||
const userObj = user.toJSON();
|
||||
userObj.should.have.property('posts');
|
||||
userObj.should.have.property('passports');
|
||||
userObj.posts.should.be.an.instanceOf(Array);
|
||||
|
@ -1430,7 +1430,7 @@ describe('include', function() {
|
|||
|
||||
it('should not make n+1 db calls in relation syntax',
|
||||
function(done) {
|
||||
var self = this;
|
||||
const self = this;
|
||||
User.find({include: [{relation: 'posts', scope: {
|
||||
where: {title: 'Post A'},
|
||||
}}, 'passports']}, function(err, users) {
|
||||
|
@ -1442,7 +1442,7 @@ describe('include', function() {
|
|||
user.should.have.property('posts');
|
||||
user.should.have.property('passports');
|
||||
|
||||
var userObj = user.toJSON();
|
||||
const userObj = user.toJSON();
|
||||
userObj.should.have.property('posts');
|
||||
userObj.should.have.property('passports');
|
||||
userObj.posts.should.be.an.instanceOf(Array);
|
||||
|
@ -1470,15 +1470,15 @@ describe('include', function() {
|
|||
});
|
||||
|
||||
it('should support disableInclude for hasAndBelongsToMany', function() {
|
||||
var Patient = db.define('Patient', {name: String});
|
||||
var Doctor = db.define('Doctor', {name: String});
|
||||
var DoctorPatient = db.define('DoctorPatient');
|
||||
const Patient = db.define('Patient', {name: String});
|
||||
const Doctor = db.define('Doctor', {name: String});
|
||||
const DoctorPatient = db.define('DoctorPatient');
|
||||
Doctor.hasAndBelongsToMany('patients', {
|
||||
model: 'Patient',
|
||||
options: {disableInclude: true},
|
||||
});
|
||||
|
||||
var doctor;
|
||||
let doctor;
|
||||
return db.automigrate(['Patient', 'Doctor', 'DoctorPatient']).then(function() {
|
||||
return Doctor.create({name: 'Who'});
|
||||
}).then(function(inst) {
|
||||
|
@ -1493,10 +1493,10 @@ describe('include', function() {
|
|||
});
|
||||
});
|
||||
|
||||
var createdUsers = [];
|
||||
var createdPassports = [];
|
||||
var createdProfiles = [];
|
||||
var createdPosts = [];
|
||||
let createdUsers = [];
|
||||
let createdPassports = [];
|
||||
let createdProfiles = [];
|
||||
let createdPosts = [];
|
||||
function setup(done) {
|
||||
db = getSchema();
|
||||
City = db.define('City');
|
||||
|
@ -1624,12 +1624,12 @@ function setup(done) {
|
|||
}
|
||||
|
||||
function clearAndCreate(model, data, callback) {
|
||||
var createdItems = [];
|
||||
const createdItems = [];
|
||||
model.destroyAll(function() {
|
||||
nextItem(null, null);
|
||||
});
|
||||
|
||||
var itemIndex = 0;
|
||||
let itemIndex = 0;
|
||||
|
||||
function nextItem(err, lastItem) {
|
||||
if (lastItem !== null) {
|
||||
|
@ -1645,7 +1645,7 @@ function clearAndCreate(model, data, callback) {
|
|||
}
|
||||
|
||||
describe('Model instance with included relation .toJSON()', function() {
|
||||
var db, ChallengerModel, GameParticipationModel, ResultModel;
|
||||
let db, ChallengerModel, GameParticipationModel, ResultModel;
|
||||
|
||||
before(function(done) {
|
||||
db = new DataSource({connector: 'memory'});
|
||||
|
@ -1720,12 +1720,12 @@ describe('Model instance with included relation .toJSON()', function() {
|
|||
}
|
||||
|
||||
it('should recursively serialize objects', function(done) {
|
||||
var filter = {include: {gameParticipations: 'results'}};
|
||||
const filter = {include: {gameParticipations: 'results'}};
|
||||
ChallengerModel.find(filter, function(err, challengers) {
|
||||
var levelOneInclusion = challengers[0].toJSON().gameParticipations[0];
|
||||
const levelOneInclusion = challengers[0].toJSON().gameParticipations[0];
|
||||
assert(levelOneInclusion.__data === undefined, '.__data of a level 1 inclusion is undefined.');
|
||||
|
||||
var levelTwoInclusion = challengers[0].toJSON().gameParticipations[0].results[0];
|
||||
const levelTwoInclusion = challengers[0].toJSON().gameParticipations[0].results[0];
|
||||
assert(levelTwoInclusion.__data === undefined, '__data of a level 2 inclusion is undefined.');
|
||||
done();
|
||||
});
|
||||
|
|
|
@ -4,25 +4,25 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
|
||||
'use strict';
|
||||
var assert = require('assert');
|
||||
var should = require('should');
|
||||
const assert = require('assert');
|
||||
const should = require('should');
|
||||
|
||||
var includeUtils = require('../lib/include_utils');
|
||||
const includeUtils = require('../lib/include_utils');
|
||||
|
||||
describe('include_util', function() {
|
||||
describe('#buildOneToOneIdentityMapWithOrigKeys', function() {
|
||||
it('should return an object with keys', function() {
|
||||
var objs = [
|
||||
const objs = [
|
||||
{id: 11, letter: 'A'},
|
||||
{id: 22, letter: 'B'},
|
||||
];
|
||||
var result = includeUtils.buildOneToOneIdentityMapWithOrigKeys(objs, 'id');
|
||||
const result = includeUtils.buildOneToOneIdentityMapWithOrigKeys(objs, 'id');
|
||||
result.get(11).should.be.ok;
|
||||
result.get(22).should.be.ok;
|
||||
});
|
||||
|
||||
it('should report errors if id is missing', function() {
|
||||
var objs = [
|
||||
const objs = [
|
||||
{letter: 'A'},
|
||||
{id: 22, letter: 'B'},
|
||||
];
|
||||
|
@ -33,14 +33,14 @@ describe('include_util', function() {
|
|||
});
|
||||
|
||||
it('should overwrite keys in case of collision', function() {
|
||||
var objs = [
|
||||
const objs = [
|
||||
{id: 11, letter: 'A'},
|
||||
{id: 22, letter: 'B'},
|
||||
{id: 33, letter: 'C'},
|
||||
{id: 11, letter: 'HA!'},
|
||||
];
|
||||
|
||||
var result = includeUtils.buildOneToOneIdentityMapWithOrigKeys(objs, 'id');
|
||||
const result = includeUtils.buildOneToOneIdentityMapWithOrigKeys(objs, 'id');
|
||||
result.getKeys().should.containEql(11);
|
||||
result.getKeys().should.containEql(22);
|
||||
result.getKeys().should.containEql(33);
|
||||
|
@ -49,28 +49,28 @@ describe('include_util', function() {
|
|||
});
|
||||
|
||||
it('should return an object with no additional keys', function() {
|
||||
var objs = [
|
||||
const objs = [
|
||||
{id: 11, letter: 'A'},
|
||||
{id: 22, letter: 'B'},
|
||||
];
|
||||
var result = includeUtils.buildOneToOneIdentityMapWithOrigKeys(objs, 'id');
|
||||
const result = includeUtils.buildOneToOneIdentityMapWithOrigKeys(objs, 'id');
|
||||
result.getKeys().should.eql([11, 22]); // no additional properties
|
||||
});
|
||||
});
|
||||
|
||||
describe('#buildOneToManyIdentityMap', function() {
|
||||
it('should return an object with keys', function() {
|
||||
var objs = [
|
||||
const objs = [
|
||||
{id: 11, letter: 'A'},
|
||||
{id: 22, letter: 'B'},
|
||||
];
|
||||
var result = includeUtils.buildOneToManyIdentityMapWithOrigKeys(objs, 'id');
|
||||
const result = includeUtils.buildOneToManyIdentityMapWithOrigKeys(objs, 'id');
|
||||
result.exist(11).should.be.true;
|
||||
result.exist(22).should.be.true;
|
||||
});
|
||||
|
||||
it('should report errors if id is missing', function() {
|
||||
var objs = [
|
||||
const objs = [
|
||||
{letter: 'A'},
|
||||
{id: 22, letter: 'B'},
|
||||
];
|
||||
|
@ -81,14 +81,14 @@ describe('include_util', function() {
|
|||
});
|
||||
|
||||
it('should collect keys in case of collision', function() {
|
||||
var objs = [
|
||||
const objs = [
|
||||
{'fk_id': 11, letter: 'A'},
|
||||
{'fk_id': 22, letter: 'B'},
|
||||
{'fk_id': 33, letter: 'C'},
|
||||
{'fk_id': 11, letter: 'HA!'},
|
||||
];
|
||||
|
||||
var result = includeUtils.buildOneToManyIdentityMapWithOrigKeys(objs, 'fk_id');
|
||||
const result = includeUtils.buildOneToManyIdentityMapWithOrigKeys(objs, 'fk_id');
|
||||
result.get(11)[0]['letter'].should.equal('A');
|
||||
result.get(11)[1]['letter'].should.equal('HA!');
|
||||
result.get(33)[0]['letter'].should.equal('C');
|
||||
|
@ -98,7 +98,7 @@ describe('include_util', function() {
|
|||
|
||||
describe('KVMap', function() {
|
||||
it('should allow to set and get value with key string', function() {
|
||||
var map = new includeUtils.KVMap();
|
||||
const map = new includeUtils.KVMap();
|
||||
map.set('name', 'Alex');
|
||||
map.set('gender', true);
|
||||
map.set('age', 25);
|
||||
|
@ -107,7 +107,7 @@ describe('KVMap', function() {
|
|||
map.get('age').should.be.equal(25);
|
||||
});
|
||||
it('should allow to set and get value with arbitrary key type', function() {
|
||||
var map = new includeUtils.KVMap();
|
||||
const map = new includeUtils.KVMap();
|
||||
map.set('name', 'Alex');
|
||||
map.set(true, 'male');
|
||||
map.set(false, false);
|
||||
|
@ -118,12 +118,12 @@ describe('KVMap', function() {
|
|||
map.get({isTrue: 'yes'}).should.be.equal(25);
|
||||
});
|
||||
it('should not allow to get values with [] operator', function() {
|
||||
var map = new includeUtils.KVMap();
|
||||
const map = new includeUtils.KVMap();
|
||||
map.set('name', 'Alex');
|
||||
(map['name'] === undefined).should.be.equal(true);
|
||||
});
|
||||
it('should provide .exist() method for checking if key presented', function() {
|
||||
var map = new includeUtils.KVMap();
|
||||
const map = new includeUtils.KVMap();
|
||||
map.set('one', 1);
|
||||
map.set(2, 'two');
|
||||
map.set(true, 'true');
|
||||
|
@ -133,24 +133,24 @@ describe('KVMap', function() {
|
|||
map.exist('two').should.be.false;
|
||||
});
|
||||
it('should return array of original keys with .getKeys()', function() {
|
||||
var map = new includeUtils.KVMap();
|
||||
const map = new includeUtils.KVMap();
|
||||
map.set('one', 1);
|
||||
map.set(2, 'two');
|
||||
map.set(true, 'true');
|
||||
var keys = map.getKeys();
|
||||
const keys = map.getKeys();
|
||||
keys.should.containEql('one');
|
||||
keys.should.containEql(2);
|
||||
keys.should.containEql(true);
|
||||
});
|
||||
it('should allow to store and fetch arrays', function() {
|
||||
var map = new includeUtils.KVMap();
|
||||
const map = new includeUtils.KVMap();
|
||||
map.set(1, [1, 2, 3]);
|
||||
map.set(2, [2, 3, 4]);
|
||||
var valueOne = map.get(1);
|
||||
const valueOne = map.get(1);
|
||||
valueOne.should.be.eql([1, 2, 3]);
|
||||
valueOne.push(99);
|
||||
map.set(1, valueOne);
|
||||
var valueOneUpdated = map.get(1);
|
||||
const valueOneUpdated = map.get(1);
|
||||
valueOneUpdated.should.be.eql([1, 2, 3, 99]);
|
||||
});
|
||||
});
|
||||
|
|
|
@ -18,8 +18,8 @@ module.exports = require('should');
|
|||
}
|
||||
*/
|
||||
|
||||
var ModelBuilder = require('../').ModelBuilder;
|
||||
var Schema = require('../').Schema;
|
||||
const ModelBuilder = require('../').ModelBuilder;
|
||||
const Schema = require('../').Schema;
|
||||
|
||||
if (!('getSchema' in global)) {
|
||||
global.getSchema = function(connector, settings) {
|
||||
|
|
|
@ -4,13 +4,13 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
|
||||
'use strict';
|
||||
var assert = require('assert');
|
||||
var ModelBuilder = require('..').ModelBuilder;
|
||||
var DataSource = require('../').DataSource;
|
||||
var introspectType = require('../lib/introspection')(ModelBuilder);
|
||||
var traverse = require('traverse');
|
||||
const assert = require('assert');
|
||||
const ModelBuilder = require('..').ModelBuilder;
|
||||
const DataSource = require('../').DataSource;
|
||||
const introspectType = require('../lib/introspection')(ModelBuilder);
|
||||
const traverse = require('traverse');
|
||||
|
||||
var json = {
|
||||
const json = {
|
||||
name: 'Joe',
|
||||
age: 30,
|
||||
birthday: new Date(),
|
||||
|
@ -40,7 +40,7 @@ describe('Introspection of model definitions from JSON', function() {
|
|||
});
|
||||
|
||||
it('should handle array types', function() {
|
||||
var type = introspectType(['123']);
|
||||
let type = introspectType(['123']);
|
||||
assert.deepEqual(type, ['string'], 'type should be ["string"]');
|
||||
type = introspectType([1]);
|
||||
assert.deepEqual(type, ['number'], 'type should be ["number"]');
|
||||
|
@ -60,16 +60,16 @@ describe('Introspection of model definitions from JSON', function() {
|
|||
});
|
||||
|
||||
it('should return a schema for object', function() {
|
||||
var json = {a: 'str', b: 0, c: true};
|
||||
var type = introspectType(json);
|
||||
const json = {a: 'str', b: 0, c: true};
|
||||
const type = introspectType(json);
|
||||
assert.equal(type.a, 'string');
|
||||
assert.equal(type.b, 'number');
|
||||
assert.equal(type.c, 'boolean');
|
||||
});
|
||||
|
||||
it('should handle nesting objects', function() {
|
||||
var json = {a: 'str', b: 0, c: true, d: {x: 10, y: 5}};
|
||||
var type = introspectType(json);
|
||||
const json = {a: 'str', b: 0, c: true, d: {x: 10, y: 5}};
|
||||
const type = introspectType(json);
|
||||
assert.equal(type.a, 'string');
|
||||
assert.equal(type.b, 'number');
|
||||
assert.equal(type.c, 'boolean');
|
||||
|
@ -78,8 +78,8 @@ describe('Introspection of model definitions from JSON', function() {
|
|||
});
|
||||
|
||||
it('should handle nesting arrays', function() {
|
||||
var json = {a: 'str', b: 0, c: true, d: [1, 2]};
|
||||
var type = introspectType(json);
|
||||
const json = {a: 'str', b: 0, c: true, d: [1, 2]};
|
||||
const type = introspectType(json);
|
||||
assert.equal(type.a, 'string');
|
||||
assert.equal(type.b, 'number');
|
||||
assert.equal(type.c, 'boolean');
|
||||
|
@ -87,15 +87,15 @@ describe('Introspection of model definitions from JSON', function() {
|
|||
});
|
||||
|
||||
it('should build a model from the introspected schema', function(done) {
|
||||
var copy = traverse(json).clone();
|
||||
const copy = traverse(json).clone();
|
||||
|
||||
var schema = introspectType(json);
|
||||
const schema = introspectType(json);
|
||||
|
||||
var builder = new ModelBuilder();
|
||||
var Model = builder.define('MyModel', schema, {idInjection: false});
|
||||
const builder = new ModelBuilder();
|
||||
const Model = builder.define('MyModel', schema, {idInjection: false});
|
||||
|
||||
// FIXME: [rfeng] The constructor mutates the arguments
|
||||
var obj = new Model(json);
|
||||
let obj = new Model(json);
|
||||
|
||||
obj = obj.toObject();
|
||||
|
||||
|
@ -104,27 +104,27 @@ describe('Introspection of model definitions from JSON', function() {
|
|||
});
|
||||
|
||||
it('should build a model using buildModelFromInstance', function(done) {
|
||||
var copy = traverse(json).clone();
|
||||
const copy = traverse(json).clone();
|
||||
|
||||
var builder = new ModelBuilder();
|
||||
var Model = builder.buildModelFromInstance('MyModel', copy, {idInjection: false});
|
||||
const builder = new ModelBuilder();
|
||||
const Model = builder.buildModelFromInstance('MyModel', copy, {idInjection: false});
|
||||
|
||||
var obj = new Model(json);
|
||||
let obj = new Model(json);
|
||||
obj = obj.toObject();
|
||||
assert.deepEqual(obj, copy);
|
||||
done();
|
||||
});
|
||||
|
||||
it('should build a model using DataSource.buildModelFromInstance', function(done) {
|
||||
var copy = traverse(json).clone();
|
||||
const copy = traverse(json).clone();
|
||||
|
||||
var builder = new DataSource('memory');
|
||||
var Model = builder.buildModelFromInstance('MyModel', copy,
|
||||
const builder = new DataSource('memory');
|
||||
const Model = builder.buildModelFromInstance('MyModel', copy,
|
||||
{idInjection: false});
|
||||
|
||||
assert.equal(Model.dataSource, builder);
|
||||
|
||||
var obj = new Model(json);
|
||||
let obj = new Model(json);
|
||||
obj = obj.toObject();
|
||||
assert.deepEqual(obj, copy);
|
||||
done();
|
||||
|
|
|
@ -7,24 +7,24 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false */
|
||||
var should = require('./init.js');
|
||||
const should = require('./init.js');
|
||||
|
||||
var Schema = require('../').Schema;
|
||||
var ModelBuilder = require('../').ModelBuilder;
|
||||
const Schema = require('../').Schema;
|
||||
const ModelBuilder = require('../').ModelBuilder;
|
||||
|
||||
describe('JSON property', function() {
|
||||
var dataSource, Model;
|
||||
let dataSource, Model;
|
||||
|
||||
it('should be defined', function() {
|
||||
dataSource = getSchema();
|
||||
Model = dataSource.define('Model', {propertyName: ModelBuilder.JSON});
|
||||
var m = new Model;
|
||||
const m = new Model;
|
||||
(new Boolean('propertyName' in m)).should.eql(true);
|
||||
should.not.exist(m.propertyName);
|
||||
});
|
||||
|
||||
it('should accept JSON in constructor and return object', function() {
|
||||
var m = new Model({
|
||||
const m = new Model({
|
||||
propertyName: '{"foo": "bar"}',
|
||||
});
|
||||
m.propertyName.should.be.an.Object;
|
||||
|
@ -32,14 +32,14 @@ describe('JSON property', function() {
|
|||
});
|
||||
|
||||
it('should accept object in setter and return object', function() {
|
||||
var m = new Model;
|
||||
const m = new Model;
|
||||
m.propertyName = {'foo': 'bar'};
|
||||
m.propertyName.should.be.an.Object;
|
||||
m.propertyName.foo.should.equal('bar');
|
||||
});
|
||||
|
||||
it('should accept string in setter and return string', function() {
|
||||
var m = new Model;
|
||||
const m = new Model;
|
||||
m.propertyName = '{"foo": "bar"}';
|
||||
m.propertyName.should.be.a.String;
|
||||
m.propertyName.should.equal('{"foo": "bar"}');
|
||||
|
|
|
@ -4,11 +4,11 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
|
||||
'use strict';
|
||||
var kvMemory = require('../lib/connectors/kv-memory');
|
||||
var DataSource = require('..').DataSource;
|
||||
const kvMemory = require('../lib/connectors/kv-memory');
|
||||
const DataSource = require('..').DataSource;
|
||||
|
||||
describe('Optimized KeyValue-Memory connector', function() {
|
||||
var dataSourceFactory = function() {
|
||||
const dataSourceFactory = function() {
|
||||
return new DataSource({connector: kvMemory});
|
||||
};
|
||||
|
||||
|
@ -16,8 +16,8 @@ describe('Optimized KeyValue-Memory connector', function() {
|
|||
});
|
||||
|
||||
describe('Unoptimized KeyValue-Memory connector', function() {
|
||||
var dataSourceFactory = function() {
|
||||
var ds = new DataSource({connector: kvMemory});
|
||||
const dataSourceFactory = function() {
|
||||
const ds = new DataSource({connector: kvMemory});
|
||||
|
||||
// disable optimized methods
|
||||
ds.connector.deleteAll = false;
|
||||
|
|
|
@ -5,10 +5,10 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var debug = require('debug')('test');
|
||||
var extend = require('util')._extend;
|
||||
var fs = require('fs');
|
||||
var path = require('path');
|
||||
const debug = require('debug')('test');
|
||||
const extend = require('util')._extend;
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
module.exports = function(dataSourceFactory, connectorCapabilities) {
|
||||
connectorCapabilities = extend({
|
||||
|
@ -18,16 +18,16 @@ module.exports = function(dataSourceFactory, connectorCapabilities) {
|
|||
}, connectorCapabilities);
|
||||
|
||||
describe('KeyValue API', function loadAllTestFiles() {
|
||||
var testRoot = path.resolve(__dirname, 'kvao');
|
||||
var testFiles = fs.readdirSync(testRoot);
|
||||
const testRoot = path.resolve(__dirname, 'kvao');
|
||||
let testFiles = fs.readdirSync(testRoot);
|
||||
testFiles = testFiles.filter(function(it) {
|
||||
return !!require.extensions[path.extname(it).toLowerCase()] &&
|
||||
/\.suite\.[^.]+$/.test(it);
|
||||
});
|
||||
|
||||
for (var ix in testFiles) {
|
||||
var name = testFiles[ix];
|
||||
var fullPath = path.resolve(testRoot, name);
|
||||
for (const ix in testFiles) {
|
||||
const name = testFiles[ix];
|
||||
const fullPath = path.resolve(testRoot, name);
|
||||
debug('Loading test suite %s (%s)', name, fullPath);
|
||||
require(fullPath)(dataSourceFactory, connectorCapabilities);
|
||||
}
|
||||
|
|
|
@ -23,7 +23,7 @@ function givenModel(dataSourceFactory, modelName,
|
|||
}
|
||||
|
||||
function givenKeys(Model, keys, cb) {
|
||||
var p = Promise.all(
|
||||
let p = Promise.all(
|
||||
keys.map(function(k) {
|
||||
return Model.set(k, 'value-' + k);
|
||||
})
|
||||
|
|
|
@ -5,7 +5,7 @@ const helpers = require('./_helpers');
|
|||
const should = require('should');
|
||||
|
||||
module.exports = function(dataSourceFactory, connectorCapabilities) {
|
||||
var supportsDeleteAll = 'deleteAll' in dataSourceFactory().connector;
|
||||
const supportsDeleteAll = 'deleteAll' in dataSourceFactory().connector;
|
||||
|
||||
bdd.describeIf(supportsDeleteAll, 'deleteAll', () => {
|
||||
let CacheItem;
|
||||
|
|
|
@ -1,18 +1,18 @@
|
|||
'use strict';
|
||||
|
||||
var bdd = require('../helpers/bdd-if');
|
||||
var should = require('should');
|
||||
var helpers = require('./_helpers');
|
||||
const bdd = require('../helpers/bdd-if');
|
||||
const should = require('should');
|
||||
const helpers = require('./_helpers');
|
||||
|
||||
module.exports = function(dataSourceFactory, connectorCapabilities) {
|
||||
// While we support millisecond precision, for the purpose of tests
|
||||
// it's better to use intervals at least 10ms long.
|
||||
var ttlPrecision = connectorCapabilities.ttlPrecision || 10;
|
||||
const ttlPrecision = connectorCapabilities.ttlPrecision || 10;
|
||||
|
||||
var canExpire = connectorCapabilities.canExpire !== false;
|
||||
const canExpire = connectorCapabilities.canExpire !== false;
|
||||
|
||||
bdd.describeIf(canExpire, 'expire', function() {
|
||||
var CacheItem;
|
||||
let CacheItem;
|
||||
beforeEach(setupCacheItem);
|
||||
|
||||
it('sets key ttl - Callback API', function(done) {
|
||||
|
|
|
@ -1,13 +1,13 @@
|
|||
'use strict';
|
||||
|
||||
var should = require('should');
|
||||
var helpers = require('./_helpers');
|
||||
const should = require('should');
|
||||
const helpers = require('./_helpers');
|
||||
|
||||
module.exports = function(dataSourceFactory, connectorCapabilities) {
|
||||
var TTL_PRECISION = connectorCapabilities.ttlPrecision;
|
||||
const TTL_PRECISION = connectorCapabilities.ttlPrecision;
|
||||
|
||||
describe('get/set', function() {
|
||||
var CacheItem;
|
||||
let CacheItem;
|
||||
beforeEach(setupCacheItem);
|
||||
|
||||
it('works for string values - Callback API', function(done) {
|
||||
|
|
|
@ -1,21 +1,21 @@
|
|||
'use strict';
|
||||
|
||||
var asyncIterators = require('async-iterators');
|
||||
var bdd = require('../helpers/bdd-if');
|
||||
var helpers = require('./_helpers');
|
||||
var should = require('should');
|
||||
const asyncIterators = require('async-iterators');
|
||||
const bdd = require('../helpers/bdd-if');
|
||||
const helpers = require('./_helpers');
|
||||
const should = require('should');
|
||||
|
||||
module.exports = function(dataSourceFactory, connectorCapabilities) {
|
||||
var canIterateKeys = connectorCapabilities.canIterateKeys !== false;
|
||||
const canIterateKeys = connectorCapabilities.canIterateKeys !== false;
|
||||
|
||||
bdd.describeIf(canIterateKeys, 'iterateKeys', function() {
|
||||
var CacheItem;
|
||||
let CacheItem;
|
||||
beforeEach(setupCacheItem);
|
||||
|
||||
it('returns AsyncIterator covering all keys', function() {
|
||||
return helpers.givenKeys(CacheItem, ['key1', 'key2'])
|
||||
.then(function() {
|
||||
var it = CacheItem.iterateKeys();
|
||||
const it = CacheItem.iterateKeys();
|
||||
should(it).have.property('next');
|
||||
return toArray(it);
|
||||
})
|
||||
|
@ -26,7 +26,7 @@ module.exports = function(dataSourceFactory, connectorCapabilities) {
|
|||
});
|
||||
|
||||
it('returns AsyncIterator supporting Promises', function() {
|
||||
var iterator;
|
||||
let iterator;
|
||||
return helpers.givenKeys(CacheItem, ['key'])
|
||||
.then(function() {
|
||||
iterator = CacheItem.iterateKeys();
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
'use strict';
|
||||
|
||||
var bdd = require('../helpers/bdd-if');
|
||||
var helpers = require('./_helpers');
|
||||
var should = require('should');
|
||||
const bdd = require('../helpers/bdd-if');
|
||||
const helpers = require('./_helpers');
|
||||
const should = require('should');
|
||||
|
||||
module.exports = function(dataSourceFactory, connectorCapabilities) {
|
||||
var canIterateKeys = connectorCapabilities.canIterateKeys !== false;
|
||||
const canIterateKeys = connectorCapabilities.canIterateKeys !== false;
|
||||
|
||||
bdd.describeIf(canIterateKeys, 'keys', function() {
|
||||
let CacheItem;
|
||||
|
@ -52,10 +52,10 @@ module.exports = function(dataSourceFactory, connectorCapabilities) {
|
|||
.then(keys => should(keys).eql(['key1', 'key2']));
|
||||
});
|
||||
|
||||
var largeKeySets = connectorCapabilities.canIterateLargeKeySets !== false;
|
||||
const largeKeySets = connectorCapabilities.canIterateLargeKeySets !== false;
|
||||
bdd.itIf(largeKeySets, 'handles large key set', function() {
|
||||
var expectedKeys = [];
|
||||
for (var ix = 0; ix < 1000; ix++)
|
||||
const expectedKeys = [];
|
||||
for (let ix = 0; ix < 1000; ix++)
|
||||
expectedKeys.push('key-' + ix);
|
||||
expectedKeys.sort();
|
||||
|
||||
|
|
|
@ -1,22 +1,22 @@
|
|||
'use strict';
|
||||
|
||||
var bdd = require('../helpers/bdd-if');
|
||||
var should = require('should');
|
||||
var helpers = require('./_helpers');
|
||||
const bdd = require('../helpers/bdd-if');
|
||||
const should = require('should');
|
||||
const helpers = require('./_helpers');
|
||||
|
||||
module.exports = function(dataSourceFactory, connectorCapabilities) {
|
||||
var TTL_PRECISION = connectorCapabilities.ttlPrecision;
|
||||
const TTL_PRECISION = connectorCapabilities.ttlPrecision;
|
||||
|
||||
// Use ~1s for stores with precision of 1 ms,
|
||||
// about 3s for stores with precision of 1s.
|
||||
var INITIAL_TTL = Math.max(TTL_PRECISION + 1000, TTL_PRECISION * 3);
|
||||
const INITIAL_TTL = Math.max(TTL_PRECISION + 1000, TTL_PRECISION * 3);
|
||||
|
||||
// A small delay to allow the backend to process the request, run any
|
||||
// TTL/expire checks, etc. Use 1ms for backends supporting sub-10ms
|
||||
// resolution to ensure the delay is not too short..
|
||||
var SMALL_DELAY = Math.max(1, Math.floor(TTL_PRECISION / 10));
|
||||
const SMALL_DELAY = Math.max(1, Math.floor(TTL_PRECISION / 10));
|
||||
|
||||
var canQueryTtl = connectorCapabilities.canQueryTtl !== false;
|
||||
const canQueryTtl = connectorCapabilities.canQueryTtl !== false;
|
||||
|
||||
bdd.describeIf(canQueryTtl, 'ttl', function() {
|
||||
let CacheItem;
|
||||
|
|
|
@ -5,8 +5,8 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var should = require('./init.js');
|
||||
var List = require('../lib/list');
|
||||
const should = require('./init.js');
|
||||
const List = require('../lib/list');
|
||||
|
||||
/**
|
||||
* Phone as a class
|
||||
|
@ -40,31 +40,31 @@ function PhoneCtor(label, num) {
|
|||
|
||||
describe('list of items typed by a class', function() {
|
||||
it('allows itemType to be a class', function() {
|
||||
var phones = givenPhones();
|
||||
const phones = givenPhones();
|
||||
|
||||
var list = new List(phones, Phone);
|
||||
const list = new List(phones, Phone);
|
||||
list.should.be.an.instanceOf(Array);
|
||||
list.toJSON().should.be.eql(phones);
|
||||
});
|
||||
|
||||
it('converts items of plain json to the itemType', function() {
|
||||
var phones = givenPhonesAsJSON();
|
||||
const phones = givenPhonesAsJSON();
|
||||
|
||||
var list = new List(phones, Phone);
|
||||
const list = new List(phones, Phone);
|
||||
list[0].should.be.an.instanceOf(Phone);
|
||||
});
|
||||
|
||||
it('converts stringified items to the itemType', function() {
|
||||
var phones = givenPhonesAsJSON();
|
||||
const phones = givenPhonesAsJSON();
|
||||
|
||||
var list = new List(JSON.stringify(phones), Phone);
|
||||
const list = new List(JSON.stringify(phones), Phone);
|
||||
list[0].should.be.an.instanceOf(Phone);
|
||||
});
|
||||
|
||||
it('converts items of plain json to the itemType with push', function() {
|
||||
var phones = givenPhonesAsJSON();
|
||||
const phones = givenPhonesAsJSON();
|
||||
|
||||
var list = new List([], Phone);
|
||||
const list = new List([], Phone);
|
||||
list.push(phones[0]);
|
||||
list[0].should.be.an.instanceOf(Phone);
|
||||
});
|
||||
|
@ -72,31 +72,31 @@ describe('list of items typed by a class', function() {
|
|||
|
||||
describe('list of items typed by a ctor', function() {
|
||||
it('allows itemType to be a ctor', function() {
|
||||
var phones = givenPhonesWithCtor();
|
||||
const phones = givenPhonesWithCtor();
|
||||
|
||||
var list = new List(phones, PhoneCtor);
|
||||
const list = new List(phones, PhoneCtor);
|
||||
list.should.be.an.instanceOf(Array);
|
||||
list.toJSON().should.be.eql(phones);
|
||||
});
|
||||
|
||||
it('converts items of plain json to the itemType', function() {
|
||||
var phones = givenPhonesAsJSON();
|
||||
const phones = givenPhonesAsJSON();
|
||||
|
||||
var list = new List(phones, PhoneCtor);
|
||||
const list = new List(phones, PhoneCtor);
|
||||
list[0].should.be.an.instanceOf(PhoneCtor);
|
||||
});
|
||||
|
||||
it('converts stringified items to the itemType', function() {
|
||||
var phones = givenPhonesAsJSON();
|
||||
const phones = givenPhonesAsJSON();
|
||||
|
||||
var list = new List(JSON.stringify(phones), PhoneCtor);
|
||||
const list = new List(JSON.stringify(phones), PhoneCtor);
|
||||
list[0].should.be.an.instanceOf(PhoneCtor);
|
||||
});
|
||||
|
||||
it('converts items of plain json to the itemType with push', function() {
|
||||
var phones = givenPhonesAsJSON();
|
||||
const phones = givenPhonesAsJSON();
|
||||
|
||||
var list = new List([], PhoneCtor);
|
||||
const list = new List([], PhoneCtor);
|
||||
list.push(phones[0]);
|
||||
list[0].should.be.an.instanceOf(PhoneCtor);
|
||||
});
|
||||
|
|
|
@ -5,9 +5,9 @@
|
|||
|
||||
// This test written in mocha+should.js
|
||||
'use strict';
|
||||
var should = require('./init.js');
|
||||
const should = require('./init.js');
|
||||
|
||||
var loopbackData = require('../');
|
||||
const loopbackData = require('../');
|
||||
|
||||
describe('loopback-datasource-juggler', function() {
|
||||
it('should expose version', function() {
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -7,15 +7,15 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false, connectorCapabilities:false */
|
||||
var async = require('async');
|
||||
var bdd = require('./helpers/bdd-if');
|
||||
var should = require('./init.js');
|
||||
var uid = require('./helpers/uid-generator');
|
||||
const async = require('async');
|
||||
const bdd = require('./helpers/bdd-if');
|
||||
const should = require('./init.js');
|
||||
const uid = require('./helpers/uid-generator');
|
||||
|
||||
var db, Person;
|
||||
var ValidationError = require('..').ValidationError;
|
||||
let db, Person;
|
||||
const ValidationError = require('..').ValidationError;
|
||||
|
||||
var UUID_REGEXP = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;
|
||||
const UUID_REGEXP = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;
|
||||
|
||||
describe('manipulation', function() {
|
||||
before(function(done) {
|
||||
|
@ -36,19 +36,19 @@ describe('manipulation', function() {
|
|||
// A simplified implementation of LoopBack's User model
|
||||
// to reproduce problems related to properties with dynamic setters
|
||||
// For the purpose of the tests, we use a counter instead of a hash fn.
|
||||
var StubUser;
|
||||
var stubPasswordCounter;
|
||||
let StubUser;
|
||||
let stubPasswordCounter;
|
||||
|
||||
before(function setupStubUserModel(done) {
|
||||
StubUser = db.createModel('StubUser', {password: String}, {forceId: true});
|
||||
StubUser.setter.password = function(plain) {
|
||||
if (plain.length === 0) throw new Error('password cannot be empty');
|
||||
var hashed = false;
|
||||
let hashed = false;
|
||||
if (!plain) return;
|
||||
var pos = plain.indexOf('-');
|
||||
const pos = plain.indexOf('-');
|
||||
if (pos !== -1) {
|
||||
var head = plain.substr(0, pos);
|
||||
var tail = plain.substr(pos + 1, plain.length);
|
||||
const head = plain.substr(0, pos);
|
||||
const tail = plain.substr(pos + 1, plain.length);
|
||||
hashed = head.toUpperCase() === tail;
|
||||
}
|
||||
if (hashed) return;
|
||||
|
@ -67,7 +67,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('forceId', function() {
|
||||
var TestForceId;
|
||||
let TestForceId;
|
||||
before(function(done) {
|
||||
TestForceId = db.define('TestForceId');
|
||||
db.automigrate('TestForceId', done);
|
||||
|
@ -112,7 +112,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should instantiate an object', function(done) {
|
||||
var p = new Person({name: 'Anatoliy'});
|
||||
const p = new Person({name: 'Anatoliy'});
|
||||
p.name.should.equal('Anatoliy');
|
||||
p.isNewRecord().should.be.true;
|
||||
p.save(function(err, inst) {
|
||||
|
@ -124,7 +124,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should instantiate an object (promise variant)', function(done) {
|
||||
var p = new Person({name: 'Anatoliy'});
|
||||
const p = new Person({name: 'Anatoliy'});
|
||||
p.name.should.equal('Anatoliy');
|
||||
p.isNewRecord().should.be.true;
|
||||
p.save()
|
||||
|
@ -137,7 +137,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should not return instance of object', function(done) {
|
||||
var person = Person.create(function(err, p) {
|
||||
const person = Person.create(function(err, p) {
|
||||
if (err) return done(err);
|
||||
should.exist(p.id);
|
||||
if (person) person.should.not.be.an.instanceOf(Person);
|
||||
|
@ -170,7 +170,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should not allow user-defined value for the id of object - save', function(done) {
|
||||
var p = new Person({id: 123456});
|
||||
const p = new Person({id: 123456});
|
||||
p.isNewRecord().should.be.true;
|
||||
p.save(function(err, inst) {
|
||||
err.should.be.instanceof(ValidationError);
|
||||
|
@ -182,7 +182,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should not allow user-defined value for the id of object - save (promise variant)', function(done) {
|
||||
var p = new Person({id: 123456});
|
||||
const p = new Person({id: 123456});
|
||||
p.isNewRecord().should.be.true;
|
||||
p.save()
|
||||
.then(function(inst) {
|
||||
|
@ -249,12 +249,12 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should create batch of objects', function(done) {
|
||||
var batch = [
|
||||
const batch = [
|
||||
{name: 'Shaltay'},
|
||||
{name: 'Boltay'},
|
||||
{},
|
||||
];
|
||||
var res = Person.create(batch, function(e, ps) {
|
||||
const res = Person.create(batch, function(e, ps) {
|
||||
if (res) res.should.not.be.instanceOf(Array);
|
||||
should.not.exist(e);
|
||||
should.exist(ps);
|
||||
|
@ -279,7 +279,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should create batch of objects (promise variant)', function(done) {
|
||||
var batch = [
|
||||
const batch = [
|
||||
{name: 'ShaltayPromise'},
|
||||
{name: 'BoltayPromise'},
|
||||
{},
|
||||
|
@ -314,7 +314,7 @@ describe('manipulation', function() {
|
|||
return next();
|
||||
}
|
||||
};
|
||||
var batch = [
|
||||
const batch = [
|
||||
{name: 'A'},
|
||||
{name: 'B'},
|
||||
undefined,
|
||||
|
@ -342,7 +342,7 @@ describe('manipulation', function() {
|
|||
|
||||
Person.findById(created.id, function(err, found) {
|
||||
if (err) return done(err);
|
||||
var result = found.toObject();
|
||||
const result = found.toObject();
|
||||
result.should.containEql({
|
||||
id: created.id,
|
||||
name: 'a-name',
|
||||
|
@ -359,7 +359,7 @@ describe('manipulation', function() {
|
|||
'object with duplicate id', function(done) {
|
||||
// NOTE(bajtos) We cannot reuse Person model here,
|
||||
// `settings.forceId` aborts the CREATE request at the validation step.
|
||||
var Product = db.define('ProductTest', {name: String}, {forceId: false});
|
||||
const Product = db.define('ProductTest', {name: String}, {forceId: false});
|
||||
db.automigrate('ProductTest', function(err) {
|
||||
if (err) return done(err);
|
||||
|
||||
|
@ -379,7 +379,7 @@ describe('manipulation', function() {
|
|||
|
||||
describe('save', function() {
|
||||
it('should save new object', function(done) {
|
||||
var p = new Person;
|
||||
const p = new Person;
|
||||
should.not.exist(p.id);
|
||||
p.save(function(err) {
|
||||
if (err) return done(err);
|
||||
|
@ -389,7 +389,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should save new object (promise variant)', function(done) {
|
||||
var p = new Person;
|
||||
const p = new Person;
|
||||
should.not.exist(p.id);
|
||||
p.save()
|
||||
.then(function() {
|
||||
|
@ -515,7 +515,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('updateAttributes', function() {
|
||||
var person;
|
||||
let person;
|
||||
|
||||
before(function(done) {
|
||||
Person.destroyAll(function(err) {
|
||||
|
@ -727,7 +727,7 @@ describe('manipulation', function() {
|
|||
|
||||
it('should allow same stringified id value on updateAttributes',
|
||||
function(done) {
|
||||
var pid = person.id;
|
||||
let pid = person.id;
|
||||
if (typeof person.id === 'object' || typeof person.id === 'number') {
|
||||
// For example MongoDB ObjectId
|
||||
pid = person.id.toString();
|
||||
|
@ -785,7 +785,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should raises on connector error', function(done) {
|
||||
var fakeConnector = {
|
||||
const fakeConnector = {
|
||||
updateAttributes: function(model, id, data, options, cb) {
|
||||
cb(new Error('Database Error'));
|
||||
},
|
||||
|
@ -799,7 +799,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('updateOrCreate', function() {
|
||||
var Post, Todo;
|
||||
let Post, Todo;
|
||||
|
||||
before('prepare "Post" and "Todo" models', function(done) {
|
||||
Post = db.define('Post', {
|
||||
|
@ -896,7 +896,7 @@ describe('manipulation', function() {
|
|||
it('should preserve properties with dynamic setters on update', function(done) {
|
||||
StubUser.create({password: 'foo'}, function(err, created) {
|
||||
if (err) return done(err);
|
||||
var data = {id: created.id, password: 'bar'};
|
||||
const data = {id: created.id, password: 'bar'};
|
||||
StubUser.updateOrCreate(data, function(err, updated) {
|
||||
if (err) return done(err);
|
||||
updated.password.should.equal('bar-BAR');
|
||||
|
@ -914,7 +914,7 @@ describe('manipulation', function() {
|
|||
{name: 'a-name', gender: undefined},
|
||||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
var result = instance.toObject();
|
||||
const result = instance.toObject();
|
||||
result.id.should.eql(instance.id);
|
||||
should.equal(result.name, 'a-name');
|
||||
should.equal(result.gender, undefined);
|
||||
|
@ -923,7 +923,7 @@ describe('manipulation', function() {
|
|||
{id: instance.id, name: 'updated name'},
|
||||
function(err, updated) {
|
||||
if (err) return done(err);
|
||||
var result = updated.toObject();
|
||||
const result = updated.toObject();
|
||||
result.id.should.eql(instance.id);
|
||||
should.equal(result.name, 'updated name');
|
||||
should.equal(result.gender, null);
|
||||
|
@ -938,7 +938,7 @@ describe('manipulation', function() {
|
|||
it('updates specific instances when PK is not an auto-generated id', function(done) {
|
||||
// skip the test if the connector is mssql
|
||||
// https://github.com/strongloop/loopback-connector-mssql/pull/92#r72853474
|
||||
var dsName = Post.dataSource.name;
|
||||
const dsName = Post.dataSource.name;
|
||||
if (dsName === 'mssql') return done();
|
||||
|
||||
Post.create([
|
||||
|
@ -952,7 +952,7 @@ describe('manipulation', function() {
|
|||
}, function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var result = instance.toObject();
|
||||
const result = instance.toObject();
|
||||
result.should.have.properties({
|
||||
title: 'postA',
|
||||
content: 'newContent',
|
||||
|
@ -972,7 +972,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should allow save() of the created instance', function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 999;
|
||||
const unknownId = uid.fromConnector(db) || 999;
|
||||
Person.updateOrCreate(
|
||||
{id: unknownId, name: 'a-name'},
|
||||
function(err, inst) {
|
||||
|
@ -985,9 +985,9 @@ describe('manipulation', function() {
|
|||
|
||||
bdd.describeIf(connectorCapabilities.supportForceId !== false,
|
||||
'updateOrCreate when forceId is true', function() {
|
||||
var Post;
|
||||
let Post;
|
||||
before(function definePostModel(done) {
|
||||
var ds = getSchema();
|
||||
const ds = getSchema();
|
||||
Post = ds.define('Post', {
|
||||
title: {type: String, length: 255},
|
||||
content: {type: String},
|
||||
|
@ -996,8 +996,8 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('fails when id does not exist in db & validate is true', function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 123;
|
||||
var post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
const unknownId = uid.fromConnector(db) || 123;
|
||||
const post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
Post.updateOrCreate(post, {validate: true}, (err) => {
|
||||
should(err).have.property('statusCode', 404);
|
||||
done();
|
||||
|
@ -1005,8 +1005,8 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('fails when id does not exist in db & validate is false', function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 123;
|
||||
var post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
const unknownId = uid.fromConnector(db) || 123;
|
||||
const post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
Post.updateOrCreate(post, {validate: false}, (err) => {
|
||||
should(err).have.property('statusCode', 404);
|
||||
done();
|
||||
|
@ -1015,8 +1015,8 @@ describe('manipulation', function() {
|
|||
|
||||
it('fails when id does not exist in db & validate is false when using updateAttributes',
|
||||
function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 123;
|
||||
var post = new Post({id: unknownId});
|
||||
const unknownId = uid.fromConnector(db) || 123;
|
||||
const post = new Post({id: unknownId});
|
||||
post.updateAttributes({title: 'updated title', content: 'AAA'}, {validate: false}, (err) => {
|
||||
should(err).have.property('statusCode', 404);
|
||||
done();
|
||||
|
@ -1024,7 +1024,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works on create if the request does not include an id', function(done) {
|
||||
var post = {title: 'a', content: 'AAA'};
|
||||
const post = {title: 'a', content: 'AAA'};
|
||||
Post.updateOrCreate(post, (err, p) => {
|
||||
if (err) return done(err);
|
||||
p.title.should.equal(post.title);
|
||||
|
@ -1049,14 +1049,14 @@ describe('manipulation', function() {
|
|||
});
|
||||
});
|
||||
|
||||
var hasReplaceById = connectorCapabilities.cloudantCompatible !== false &&
|
||||
const hasReplaceById = connectorCapabilities.cloudantCompatible !== false &&
|
||||
!!getSchema().connector.replaceById;
|
||||
|
||||
if (!hasReplaceById) {
|
||||
describe.skip('replaceById - not implemented', function() {});
|
||||
} else {
|
||||
describe('replaceOrCreate', function() {
|
||||
var Post, unknownId;
|
||||
let Post, unknownId;
|
||||
before(function(done) {
|
||||
db = getSchema();
|
||||
unknownId = uid.fromConnector(db) || 123;
|
||||
|
@ -1069,7 +1069,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works without options on create (promise variant)', function(done) {
|
||||
var post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
const post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
Post.replaceOrCreate(post)
|
||||
.then(function(p) {
|
||||
should.exist(p);
|
||||
|
@ -1091,7 +1091,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works with options on create (promise variant)', function(done) {
|
||||
var post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
const post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
Post.replaceOrCreate(post, {validate: false})
|
||||
.then(function(p) {
|
||||
should.exist(p);
|
||||
|
@ -1113,7 +1113,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works without options on update (promise variant)', function(done) {
|
||||
var post = {title: 'a', content: 'AAA', comments: ['Comment1']};
|
||||
const post = {title: 'a', content: 'AAA', comments: ['Comment1']};
|
||||
Post.create(post)
|
||||
.then(function(created) {
|
||||
created = created.toObject();
|
||||
|
@ -1144,7 +1144,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works with options on update (promise variant)', function(done) {
|
||||
var post = {title: 'a', content: 'AAA', comments: ['Comment1']};
|
||||
const post = {title: 'a', content: 'AAA', comments: ['Comment1']};
|
||||
Post.create(post)
|
||||
.then(function(created) {
|
||||
created = created.toObject();
|
||||
|
@ -1234,7 +1234,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works without options on create (callback variant)', function(done) {
|
||||
var post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
const post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
Post.replaceOrCreate(post, function(err, p) {
|
||||
if (err) return done(err);
|
||||
p.id.should.eql(post.id);
|
||||
|
@ -1254,7 +1254,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works with options on create (callback variant)', function(done) {
|
||||
var post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
const post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
Post.replaceOrCreate(post, {validate: false}, function(err, p) {
|
||||
if (err) return done(err);
|
||||
p.id.should.eql(post.id);
|
||||
|
@ -1277,7 +1277,7 @@ describe('manipulation', function() {
|
|||
|
||||
bdd.describeIf(hasReplaceById && connectorCapabilities.supportForceId !== false, 'replaceOrCreate ' +
|
||||
'when forceId is true', function() {
|
||||
var Post, unknownId;
|
||||
let Post, unknownId;
|
||||
before(function(done) {
|
||||
db = getSchema();
|
||||
unknownId = uid.fromConnector(db) || 123;
|
||||
|
@ -1289,7 +1289,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('fails when id does not exist in db', function(done) {
|
||||
var post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
const post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
|
||||
Post.replaceOrCreate(post, function(err, p) {
|
||||
err.statusCode.should.equal(404);
|
||||
|
@ -1299,7 +1299,7 @@ describe('manipulation', function() {
|
|||
|
||||
// eslint-disable-next-line mocha/no-identical-title
|
||||
it('works on create if the request does not include an id', function(done) {
|
||||
var post = {title: 'a', content: 'AAA'};
|
||||
const post = {title: 'a', content: 'AAA'};
|
||||
Post.replaceOrCreate(post, function(err, p) {
|
||||
if (err) return done(err);
|
||||
p.title.should.equal(post.title);
|
||||
|
@ -1329,9 +1329,9 @@ describe('manipulation', function() {
|
|||
describe.skip('replaceAttributes/replaceById - not implemented', function() {});
|
||||
} else {
|
||||
describe('replaceAttributes', function() {
|
||||
var postInstance;
|
||||
var Post;
|
||||
var ds = getSchema();
|
||||
let postInstance;
|
||||
let Post;
|
||||
const ds = getSchema();
|
||||
before(function(done) {
|
||||
Post = ds.define('Post', {
|
||||
title: {type: String, length: 255, index: true},
|
||||
|
@ -1486,12 +1486,12 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should fail when changing id', function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 999;
|
||||
const unknownId = uid.fromConnector(db) || 999;
|
||||
Post.findById(postInstance.id, function(err, p) {
|
||||
if (err) return done(err);
|
||||
p.replaceAttributes({title: 'b', id: unknownId}, function(err, p) {
|
||||
should.exist(err);
|
||||
var expectedErrMsg = 'id property (id) cannot be updated from ' +
|
||||
const expectedErrMsg = 'id property (id) cannot be updated from ' +
|
||||
postInstance.id + ' to ' + unknownId;
|
||||
err.message.should.equal(expectedErrMsg);
|
||||
done();
|
||||
|
@ -1533,7 +1533,7 @@ describe('manipulation', function() {
|
|||
}
|
||||
|
||||
bdd.describeIf(hasReplaceById, 'replaceById', function() {
|
||||
var Post;
|
||||
let Post;
|
||||
before(function(done) {
|
||||
db = getSchema();
|
||||
Post = db.define('Post', {
|
||||
|
@ -1545,8 +1545,8 @@ describe('manipulation', function() {
|
|||
|
||||
bdd.itIf(connectorCapabilities.supportForceId !== false, 'fails when id does not exist in db ' +
|
||||
'using replaceById', function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 123;
|
||||
var post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
const unknownId = uid.fromConnector(db) || 123;
|
||||
const post = {id: unknownId, title: 'a', content: 'AAA'};
|
||||
Post.replaceById(post.id, post, function(err, p) {
|
||||
err.statusCode.should.equal(404);
|
||||
done();
|
||||
|
@ -1590,8 +1590,8 @@ describe('manipulation', function() {
|
|||
should.exist(res);
|
||||
res.should.be.instanceOf(Array);
|
||||
res.should.have.lengthOf(2);
|
||||
var p = res[0];
|
||||
var created = res[1];
|
||||
const p = res[0];
|
||||
const created = res[1];
|
||||
p.should.be.instanceOf(Person);
|
||||
p.name.should.equal('Jed');
|
||||
p.gender.should.equal('male');
|
||||
|
@ -1609,8 +1609,8 @@ describe('manipulation', function() {
|
|||
.then(function(res) {
|
||||
res.should.be.instanceOf(Array);
|
||||
res.should.have.lengthOf(2);
|
||||
var p = res[0];
|
||||
var created = res[1];
|
||||
const p = res[0];
|
||||
const created = res[1];
|
||||
p.should.be.instanceOf(Person);
|
||||
p.name.should.equal('Jed');
|
||||
p.gender.should.equal('male');
|
||||
|
@ -1757,7 +1757,7 @@ describe('manipulation', function() {
|
|||
|
||||
bdd.describeIf(connectorCapabilities.reportDeletedCount === false &&
|
||||
connectorCapabilities.deleteWithOtherThanId === false, 'deleteAll/destroyAll case 2', function() {
|
||||
var idJohn, idJane;
|
||||
let idJohn, idJane;
|
||||
beforeEach(function clearOldData(done) {
|
||||
Person.deleteAll(done);
|
||||
});
|
||||
|
@ -1807,7 +1807,7 @@ describe('manipulation', function() {
|
|||
// eslint-disable-next-line mocha/no-identical-title
|
||||
it('should report zero deleted instances when no matches are found',
|
||||
function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 1234567890;
|
||||
const unknownId = uid.fromConnector(db) || 1234567890;
|
||||
Person.deleteAll({id: unknownId}, function(err, info) {
|
||||
if (err) return done(err);
|
||||
should.not.exist(info.count);
|
||||
|
@ -1855,7 +1855,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should allow deleteById(id) - fail', function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 9999;
|
||||
const unknownId = uid.fromConnector(db) || 9999;
|
||||
Person.settings.strictDelete = false;
|
||||
Person.deleteById(unknownId, function(err, info) {
|
||||
if (err) return done(err);
|
||||
|
@ -1869,8 +1869,8 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should allow deleteById(id) - fail with error', function(done) {
|
||||
var unknownId = uid.fromConnector(db) || 9999;
|
||||
var errMsg = 'No instance with id ' + unknownId.toString() + ' found for Person';
|
||||
const unknownId = uid.fromConnector(db) || 9999;
|
||||
const errMsg = 'No instance with id ' + unknownId.toString() + ' found for Person';
|
||||
Person.settings.strictDelete = true;
|
||||
Person.deleteById(unknownId, function(err) {
|
||||
should.exist(err);
|
||||
|
@ -1949,7 +1949,7 @@ describe('manipulation', function() {
|
|||
|
||||
describe('initialize', function() {
|
||||
it('should initialize object properly', function() {
|
||||
var hw = 'Hello word',
|
||||
const hw = 'Hello word',
|
||||
now = Date.now(),
|
||||
person = new Person({name: hw});
|
||||
|
||||
|
@ -1960,7 +1960,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('Date $now function (type: Date)', function() {
|
||||
var CustomModel;
|
||||
let CustomModel;
|
||||
|
||||
before(function(done) {
|
||||
CustomModel = db.define('CustomModel1', {
|
||||
|
@ -1971,7 +1971,7 @@ describe('manipulation', function() {
|
|||
|
||||
it('should report current date as default value for date property',
|
||||
function(done) {
|
||||
var now = Date.now();
|
||||
const now = Date.now();
|
||||
|
||||
CustomModel.create(function(err, model) {
|
||||
should.not.exists(err);
|
||||
|
@ -1984,7 +1984,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('Date $now function (type: String)', function() {
|
||||
var CustomModel;
|
||||
let CustomModel;
|
||||
|
||||
before(function(done) {
|
||||
CustomModel = db.define('CustomModel2', {
|
||||
|
@ -2006,7 +2006,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('now defaultFn', function() {
|
||||
var CustomModel;
|
||||
let CustomModel;
|
||||
|
||||
before(function(done) {
|
||||
CustomModel = db.define('CustomModel3', {
|
||||
|
@ -2017,7 +2017,7 @@ describe('manipulation', function() {
|
|||
|
||||
it('should generate current time when "defaultFn" is "now"',
|
||||
function(done) {
|
||||
var now = Date.now();
|
||||
const now = Date.now();
|
||||
CustomModel.create(function(err, model) {
|
||||
if (err) return done(err);
|
||||
model.now.should.be.instanceOf(Date);
|
||||
|
@ -2028,7 +2028,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('guid defaultFn', function() {
|
||||
var CustomModel;
|
||||
let CustomModel;
|
||||
|
||||
before(function(done) {
|
||||
CustomModel = db.define('CustomModel4', {
|
||||
|
@ -2047,7 +2047,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('uuid defaultFn', function() {
|
||||
var CustomModel;
|
||||
let CustomModel;
|
||||
|
||||
before(function(done) {
|
||||
CustomModel = db.define('CustomModel5', {
|
||||
|
@ -2066,7 +2066,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('uuidv4 defaultFn', function() {
|
||||
var CustomModel;
|
||||
let CustomModel;
|
||||
|
||||
before(function(done) {
|
||||
CustomModel = db.define('CustomModel5', {
|
||||
|
@ -2085,11 +2085,11 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('shortid defaultFn', function() {
|
||||
var ModelWithShortId;
|
||||
let ModelWithShortId;
|
||||
before(createModelWithShortId);
|
||||
|
||||
it('should generate a new id when "defaultFn" is "shortid"', function(done) {
|
||||
var SHORTID_REGEXP = /^[0-9a-z_\-]{7,14}$/i;
|
||||
const SHORTID_REGEXP = /^[0-9a-z_\-]{7,14}$/i;
|
||||
ModelWithShortId.create(function(err, modelWithShortId) {
|
||||
if (err) return done(err);
|
||||
modelWithShortId.shortid.should.match(SHORTID_REGEXP);
|
||||
|
@ -2114,7 +2114,7 @@ describe('manipulation', function() {
|
|||
|
||||
describe('property value coercion', function() {
|
||||
it('should coerce boolean types properly', function() {
|
||||
var p1 = new Person({name: 'John', married: 'false'});
|
||||
let p1 = new Person({name: 'John', married: 'false'});
|
||||
p1.married.should.equal(false);
|
||||
|
||||
p1 = new Person({name: 'John', married: 'true'});
|
||||
|
@ -2155,7 +2155,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('should coerce date types properly', function() {
|
||||
var p1 = new Person({name: 'John', dob: '2/1/2015'});
|
||||
let p1 = new Person({name: 'John', dob: '2/1/2015'});
|
||||
p1.dob.should.eql(new Date('2/1/2015'));
|
||||
|
||||
p1 = new Person({name: 'John', dob: '2/1/2015'});
|
||||
|
@ -2180,8 +2180,8 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('update/updateAll', function() {
|
||||
var idBrett, idCarla, idDonna, idFrank, idGrace, idHarry;
|
||||
var filterBrett, filterHarry;
|
||||
let idBrett, idCarla, idDonna, idFrank, idGrace, idHarry;
|
||||
let filterBrett, filterHarry;
|
||||
|
||||
beforeEach(function clearOldData(done) {
|
||||
db = getSchema();
|
||||
|
@ -2230,7 +2230,7 @@ describe('manipulation', function() {
|
|||
it('should not update instances that do not satisfy the where condition',
|
||||
function(done) {
|
||||
idHarry = uid.fromConnector(db) || undefined;
|
||||
var filter = connectorCapabilities.updateWithOtherThanId === false ?
|
||||
const filter = connectorCapabilities.updateWithOtherThanId === false ?
|
||||
{id: idHarry} : {name: 'Harry Hoe'};
|
||||
Person.update(filter, {name: 'Marta Moe'}, function(err,
|
||||
info) {
|
||||
|
@ -2250,7 +2250,7 @@ describe('manipulation', function() {
|
|||
|
||||
it('should only update instances that satisfy the where condition',
|
||||
function(done) {
|
||||
var filter = connectorCapabilities.deleteWithOtherThanId === false ?
|
||||
const filter = connectorCapabilities.deleteWithOtherThanId === false ?
|
||||
{id: idBrett} : {name: 'Brett Boe'};
|
||||
Person.update(filter, {name: 'Harry Hoe'}, function(err,
|
||||
info) {
|
||||
|
@ -2325,7 +2325,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
describe('upsertWithWhere', function() {
|
||||
var ds, Person;
|
||||
let ds, Person;
|
||||
before('prepare "Person" model', function(done) {
|
||||
ds = getSchema();
|
||||
Person = ds.define('Person', {
|
||||
|
@ -2355,7 +2355,7 @@ describe('manipulation', function() {
|
|||
it('should preserve properties with dynamic setters on update', function(done) {
|
||||
StubUser.create({password: 'foo'}, function(err, created) {
|
||||
if (err) return done(err);
|
||||
var data = {password: 'bar'};
|
||||
const data = {password: 'bar'};
|
||||
StubUser.upsertWithWhere({id: created.id}, data, function(err, updated) {
|
||||
if (err) return done(err);
|
||||
updated.password.should.equal('bar-BAR');
|
||||
|
@ -2383,7 +2383,7 @@ describe('manipulation', function() {
|
|||
{name: 'updated name'},
|
||||
function(err, updated) {
|
||||
if (err) return done(err);
|
||||
var result = updated.toObject();
|
||||
const result = updated.toObject();
|
||||
result.should.have.properties({
|
||||
id: instance.id,
|
||||
name: 'updated name',
|
||||
|
@ -2406,7 +2406,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works without options on create (promise variant)', function(done) {
|
||||
var person = {id: 123, name: 'a', city: 'city a'};
|
||||
const person = {id: 123, name: 'a', city: 'city a'};
|
||||
Person.upsertWithWhere({id: 123}, person)
|
||||
.then(function(p) {
|
||||
should.exist(p);
|
||||
|
@ -2428,7 +2428,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works with options on create (promise variant)', function(done) {
|
||||
var person = {id: 234, name: 'b', city: 'city b'};
|
||||
const person = {id: 234, name: 'b', city: 'city b'};
|
||||
Person.upsertWithWhere({id: 234}, person, {validate: false})
|
||||
.then(function(p) {
|
||||
should.exist(p);
|
||||
|
@ -2450,7 +2450,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works without options on update (promise variant)', function(done) {
|
||||
var person = {id: 456, name: 'AAA', city: 'city AAA'};
|
||||
const person = {id: 456, name: 'AAA', city: 'city AAA'};
|
||||
Person.create(person)
|
||||
.then(function(created) {
|
||||
created = created.toObject();
|
||||
|
@ -2477,7 +2477,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('works with options on update (promise variant)', function(done) {
|
||||
var person = {id: 789, name: 'CCC', city: 'city CCC'};
|
||||
const person = {id: 789, name: 'CCC', city: 'city CCC'};
|
||||
Person.create(person)
|
||||
.then(function(created) {
|
||||
created = created.toObject();
|
||||
|
@ -2504,7 +2504,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
it('fails the upsertWithWhere operation when data object is empty', function(done) {
|
||||
var options = {};
|
||||
const options = {};
|
||||
Person.upsertWithWhere({name: 'John Lennon'}, {}, options,
|
||||
function(err) {
|
||||
err.message.should.equal('data object cannot be empty!');
|
||||
|
@ -2567,7 +2567,7 @@ describe('manipulation', function() {
|
|||
});
|
||||
|
||||
function givenSomePeople(done) {
|
||||
var beatles = [
|
||||
const beatles = [
|
||||
{name: 'John Lennon', gender: 'male'},
|
||||
{name: 'Paul McCartney', gender: 'male'},
|
||||
{name: 'George Harrison', gender: 'male'},
|
||||
|
|
|
@ -4,21 +4,21 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
|
||||
'use strict';
|
||||
var jdb = require('../');
|
||||
var DataSource = jdb.DataSource;
|
||||
var path = require('path');
|
||||
var fs = require('fs');
|
||||
var assert = require('assert');
|
||||
var async = require('async');
|
||||
var should = require('./init.js');
|
||||
var Memory = require('../lib/connectors/memory').Memory;
|
||||
const jdb = require('../');
|
||||
const DataSource = jdb.DataSource;
|
||||
const path = require('path');
|
||||
const fs = require('fs');
|
||||
const assert = require('assert');
|
||||
const async = require('async');
|
||||
const should = require('./init.js');
|
||||
const Memory = require('../lib/connectors/memory').Memory;
|
||||
|
||||
describe('Memory connector', function() {
|
||||
var file = path.join(__dirname, 'memory.json');
|
||||
const file = path.join(__dirname, 'memory.json');
|
||||
|
||||
function readModels(done) {
|
||||
fs.readFile(file, function(err, data) {
|
||||
var json = JSON.parse(data.toString());
|
||||
const json = JSON.parse(data.toString());
|
||||
assert(json.models);
|
||||
assert(json.ids.User);
|
||||
done(err, json);
|
||||
|
@ -34,15 +34,15 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
describe('with file', function() {
|
||||
var ds;
|
||||
let ds;
|
||||
|
||||
function createUserModel() {
|
||||
var ds = new DataSource({
|
||||
const ds = new DataSource({
|
||||
connector: 'memory',
|
||||
file: file,
|
||||
});
|
||||
|
||||
var User = ds.createModel('User', {
|
||||
const User = ds.createModel('User', {
|
||||
id: {
|
||||
type: Number,
|
||||
id: true,
|
||||
|
@ -57,8 +57,8 @@ describe('Memory connector', function() {
|
|||
return User;
|
||||
}
|
||||
|
||||
var User;
|
||||
var ids = [];
|
||||
let User;
|
||||
const ids = [];
|
||||
|
||||
before(function() {
|
||||
User = createUserModel();
|
||||
|
@ -73,7 +73,7 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
it('should persist create', function(done) {
|
||||
var count = 0;
|
||||
let count = 0;
|
||||
async.eachSeries(['John1', 'John2', 'John3'], function(item, cb) {
|
||||
User.create({name: item}, function(err, result) {
|
||||
ids.push(result.id);
|
||||
|
@ -95,8 +95,8 @@ describe('Memory connector', function() {
|
|||
it('should not have out of sequence read/write', function(done) {
|
||||
// Create the new data source with the same file to simulate
|
||||
// existing records
|
||||
var User = createUserModel();
|
||||
var ds = User.dataSource;
|
||||
const User = createUserModel();
|
||||
const ds = User.dataSource;
|
||||
|
||||
async.times(10, function(n, next) {
|
||||
if (n === 10) {
|
||||
|
@ -107,7 +107,7 @@ describe('Memory connector', function() {
|
|||
next();
|
||||
}, function(err) {
|
||||
async.eachSeries(['John4', 'John5'], function(item, cb) {
|
||||
var count = 0;
|
||||
const count = 0;
|
||||
User.create({name: item}, function(err, result) {
|
||||
ids.push(result.id);
|
||||
cb(err);
|
||||
|
@ -152,7 +152,7 @@ describe('Memory connector', function() {
|
|||
return done(err);
|
||||
}
|
||||
assert.equal(Object.keys(json.models.User).length, 4);
|
||||
var user = JSON.parse(json.models.User[ids[1]]);
|
||||
const user = JSON.parse(json.models.User[ids[1]]);
|
||||
assert.equal(user.name, 'John');
|
||||
assert(user.id === ids[1]);
|
||||
done();
|
||||
|
@ -171,7 +171,7 @@ describe('Memory connector', function() {
|
|||
return done(err);
|
||||
}
|
||||
assert.equal(Object.keys(json.models.User).length, 4);
|
||||
var user = JSON.parse(json.models.User[ids[1]]);
|
||||
const user = JSON.parse(json.models.User[ids[1]]);
|
||||
assert.equal(user.name, 'John1');
|
||||
assert(user.id === ids[1]);
|
||||
done();
|
||||
|
@ -190,11 +190,11 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
describe('Query for memory connector', function() {
|
||||
var ds = new DataSource({
|
||||
const ds = new DataSource({
|
||||
connector: 'memory',
|
||||
});
|
||||
|
||||
var User = ds.define('User', {
|
||||
const User = ds.define('User', {
|
||||
seq: {type: Number, index: true},
|
||||
name: {type: String, index: true, sort: true},
|
||||
email: {type: String, index: true},
|
||||
|
@ -471,7 +471,7 @@ describe('Memory connector', function() {
|
|||
User.find({where: {seq: {neq: 4}}}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
users.length.should.be.equal(5);
|
||||
for (var i = 0; i < users.length; i++) {
|
||||
for (let i = 0; i < users.length; i++) {
|
||||
users[i].seq.should.not.be.equal(4);
|
||||
}
|
||||
done();
|
||||
|
@ -482,7 +482,7 @@ describe('Memory connector', function() {
|
|||
User.find({where: {role: {neq: 'lead'}}}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
users.length.should.be.equal(4);
|
||||
for (var i = 0; i < users.length; i++) {
|
||||
for (let i = 0; i < users.length; i++) {
|
||||
if (users[i].role) {
|
||||
users[i].role.not.be.equal('lead');
|
||||
}
|
||||
|
@ -495,7 +495,7 @@ describe('Memory connector', function() {
|
|||
User.find({where: {role: {neq: null}}}, function(err, users) {
|
||||
should.not.exist(err);
|
||||
users.length.should.be.equal(2);
|
||||
for (var i = 0; i < users.length; i++) {
|
||||
for (let i = 0; i < users.length; i++) {
|
||||
should.exist(users[i].role);
|
||||
}
|
||||
done();
|
||||
|
@ -554,7 +554,7 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
function seed(done) {
|
||||
var beatles = [
|
||||
const beatles = [
|
||||
{
|
||||
seq: 0,
|
||||
name: 'John Lennon',
|
||||
|
@ -616,19 +616,19 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
it('should use collection setting', function(done) {
|
||||
var ds = new DataSource({
|
||||
const ds = new DataSource({
|
||||
connector: 'memory',
|
||||
});
|
||||
|
||||
var Product = ds.createModel('Product', {
|
||||
const Product = ds.createModel('Product', {
|
||||
name: String,
|
||||
});
|
||||
|
||||
var Tool = ds.createModel('Tool', {
|
||||
const Tool = ds.createModel('Tool', {
|
||||
name: String,
|
||||
}, {memory: {collection: 'Product'}});
|
||||
|
||||
var Widget = ds.createModel('Widget', {
|
||||
const Widget = ds.createModel('Widget', {
|
||||
name: String,
|
||||
}, {memory: {collection: 'Product'}});
|
||||
|
||||
|
@ -658,8 +658,8 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
it('should refuse to create object with duplicate id', function(done) {
|
||||
var ds = new DataSource({connector: 'memory'});
|
||||
var Product = ds.define('ProductTest', {name: String}, {forceId: false});
|
||||
const ds = new DataSource({connector: 'memory'});
|
||||
const Product = ds.define('ProductTest', {name: String}, {forceId: false});
|
||||
ds.automigrate('ProductTest', function(err) {
|
||||
if (err) return done(err);
|
||||
|
||||
|
@ -678,7 +678,7 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
describe('automigrate', function() {
|
||||
var ds;
|
||||
let ds;
|
||||
beforeEach(function() {
|
||||
ds = new DataSource({
|
||||
connector: 'memory',
|
||||
|
@ -757,7 +757,7 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
describe('findOrCreate', function() {
|
||||
var ds, Cars;
|
||||
let ds, Cars;
|
||||
before(function() {
|
||||
ds = new DataSource({connector: 'memory'});
|
||||
Cars = ds.define('Cars', {
|
||||
|
@ -766,10 +766,10 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
it('should create a specific object once and in the subsequent calls it should find it', function(done) {
|
||||
var creationNum = 0;
|
||||
let creationNum = 0;
|
||||
async.times(100, function(n, next) {
|
||||
var initialData = {color: 'white'};
|
||||
var query = {'where': initialData};
|
||||
const initialData = {color: 'white'};
|
||||
const query = {'where': initialData};
|
||||
Cars.findOrCreate(query, initialData, function(err, car, created) {
|
||||
if (created) creationNum++;
|
||||
next(err, car);
|
||||
|
@ -788,7 +788,7 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
describe('automigrate when NO models are attached', function() {
|
||||
var ds;
|
||||
let ds;
|
||||
beforeEach(function() {
|
||||
ds = new DataSource({
|
||||
connector: 'memory',
|
||||
|
@ -811,7 +811,7 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
describe('With mocked autoupdate', function() {
|
||||
var ds, model;
|
||||
let ds, model;
|
||||
beforeEach(function() {
|
||||
ds = new DataSource({
|
||||
connector: 'memory',
|
||||
|
@ -902,7 +902,7 @@ describe('Memory connector', function() {
|
|||
});
|
||||
|
||||
describe('Optimized connector', function() {
|
||||
var ds = new DataSource({connector: Memory});
|
||||
const ds = new DataSource({connector: Memory});
|
||||
|
||||
require('./persistence-hooks.suite')(ds, should, {
|
||||
replaceOrCreateReportsNewInstance: true,
|
||||
|
@ -910,7 +910,7 @@ describe('Optimized connector', function() {
|
|||
});
|
||||
|
||||
describe('Unoptimized connector', function() {
|
||||
var ds = new DataSource({connector: Memory});
|
||||
const ds = new DataSource({connector: Memory});
|
||||
|
||||
// disable optimized methods
|
||||
ds.connector.updateOrCreate = false;
|
||||
|
@ -923,7 +923,8 @@ describe('Unoptimized connector', function() {
|
|||
});
|
||||
|
||||
describe('Memory connector with options', function() {
|
||||
var ds, savedOptions = {}, Post;
|
||||
const savedOptions = {};
|
||||
let ds, Post;
|
||||
|
||||
before(function() {
|
||||
ds = new DataSource({connector: 'memory'});
|
||||
|
@ -955,7 +956,7 @@ describe('Memory connector with options', function() {
|
|||
});
|
||||
|
||||
it('should receive options from the find method', function(done) {
|
||||
var opts = {transaction: 'tx1'};
|
||||
const opts = {transaction: 'tx1'};
|
||||
Post.find({where: {title: 't1'}}, opts, function(err, p) {
|
||||
savedOptions.find.should.be.eql(opts);
|
||||
done(err);
|
||||
|
@ -963,7 +964,7 @@ describe('Memory connector with options', function() {
|
|||
});
|
||||
|
||||
it('should treat first object arg as filter for find', function(done) {
|
||||
var filter = {title: 't1'};
|
||||
const filter = {title: 't1'};
|
||||
Post.find(filter, function(err, p) {
|
||||
savedOptions.find.should.be.eql({});
|
||||
done(err);
|
||||
|
@ -971,7 +972,7 @@ describe('Memory connector with options', function() {
|
|||
});
|
||||
|
||||
it('should receive options from the create method', function(done) {
|
||||
var opts = {transaction: 'tx3'};
|
||||
const opts = {transaction: 'tx3'};
|
||||
Post.create({title: 't1', content: 'c1'}, opts, function(err, p) {
|
||||
savedOptions.create.should.be.eql(opts);
|
||||
done(err);
|
||||
|
@ -979,7 +980,7 @@ describe('Memory connector with options', function() {
|
|||
});
|
||||
|
||||
it('should receive options from the update method', function(done) {
|
||||
var opts = {transaction: 'tx4'};
|
||||
const opts = {transaction: 'tx4'};
|
||||
Post.update({title: 't1'}, {content: 'c1 --> c2'},
|
||||
opts, function(err, p) {
|
||||
savedOptions.update.should.be.eql(opts);
|
||||
|
@ -989,7 +990,7 @@ describe('Memory connector with options', function() {
|
|||
});
|
||||
|
||||
describe('Memory connector with observers', function() {
|
||||
var ds = new DataSource({
|
||||
const ds = new DataSource({
|
||||
connector: 'memory',
|
||||
});
|
||||
|
||||
|
@ -999,10 +1000,10 @@ describe('Memory connector with observers', function() {
|
|||
});
|
||||
|
||||
it('should notify observers', function(done) {
|
||||
var events = [];
|
||||
const events = [];
|
||||
ds.connector.execute = function(command, params, options, cb) {
|
||||
var self = this;
|
||||
var context = {command: command, params: params, options: options};
|
||||
const self = this;
|
||||
const context = {command: command, params: params, options: options};
|
||||
self.notifyObserversOf('before execute', context, function(err) {
|
||||
process.nextTick(function() {
|
||||
if (err) return cb(err);
|
||||
|
|
|
@ -5,21 +5,21 @@
|
|||
|
||||
// This test written in mocha+should.js
|
||||
'use strict';
|
||||
var should = require('./init.js');
|
||||
const should = require('./init.js');
|
||||
|
||||
var jdb = require('../');
|
||||
var ModelBuilder = jdb.ModelBuilder;
|
||||
var DataSource = jdb.DataSource;
|
||||
var Memory = require('../lib/connectors/memory');
|
||||
const jdb = require('../');
|
||||
const ModelBuilder = jdb.ModelBuilder;
|
||||
const DataSource = jdb.DataSource;
|
||||
const Memory = require('../lib/connectors/memory');
|
||||
|
||||
var modelBuilder = new ModelBuilder();
|
||||
var mixins = modelBuilder.mixins;
|
||||
const modelBuilder = new ModelBuilder();
|
||||
const mixins = modelBuilder.mixins;
|
||||
|
||||
function timestamps(Model, options) {
|
||||
Model.defineProperty('createdAt', {type: Date});
|
||||
Model.defineProperty('updatedAt', {type: Date});
|
||||
|
||||
var originalBeforeSave = Model.beforeSave;
|
||||
const originalBeforeSave = Model.beforeSave;
|
||||
Model.beforeSave = function(next, data) {
|
||||
Model.applyTimestamps(data, this.isNewRecord());
|
||||
if (data.createdAt) {
|
||||
|
@ -62,24 +62,24 @@ describe('Model class', function() {
|
|||
});
|
||||
|
||||
it('should apply a mixin class', function() {
|
||||
var Address = modelBuilder.define('Address', {
|
||||
const Address = modelBuilder.define('Address', {
|
||||
street: {type: 'string', required: true},
|
||||
city: {type: 'string', required: true},
|
||||
});
|
||||
|
||||
var memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
var Item = memory.createModel('Item', {name: 'string'}, {
|
||||
const memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
const Item = memory.createModel('Item', {name: 'string'}, {
|
||||
mixins: {Address: true},
|
||||
});
|
||||
|
||||
var properties = Item.definition.properties;
|
||||
const properties = Item.definition.properties;
|
||||
|
||||
properties.street.should.eql({type: String, required: true});
|
||||
properties.city.should.eql({type: String, required: true});
|
||||
});
|
||||
|
||||
it('should fail to apply an undefined mixin class', function() {
|
||||
var memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
const memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
function applyMixin() {
|
||||
memory.createModel('Item', {name: 'string'}, {
|
||||
mixins: {UndefinedMixin: true},
|
||||
|
@ -89,8 +89,8 @@ describe('Model class', function() {
|
|||
});
|
||||
|
||||
it('should apply mixins', function(done) {
|
||||
var memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
var Item = memory.createModel('Item', {name: 'string'}, {
|
||||
const memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
const Item = memory.createModel('Item', {name: 'string'}, {
|
||||
mixins: {
|
||||
TimeStamp: true,
|
||||
Demo: {value: true},
|
||||
|
@ -108,7 +108,7 @@ describe('Model class', function() {
|
|||
Item.multiMixin.foo.should.equal('bar');
|
||||
Item.multiMixin.fox.should.equal('baz');
|
||||
|
||||
var properties = Item.definition.properties;
|
||||
const properties = Item.definition.properties;
|
||||
properties.createdAt.should.eql({type: Date});
|
||||
properties.updatedAt.should.eql({type: Date});
|
||||
|
||||
|
@ -121,8 +121,8 @@ describe('Model class', function() {
|
|||
});
|
||||
|
||||
it('should fail to apply undefined mixin', function() {
|
||||
var memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
var Item = memory.createModel('Item', {name: 'string'});
|
||||
const memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
const Item = memory.createModel('Item', {name: 'string'});
|
||||
|
||||
function applyMixin() {
|
||||
Item.mixin('UndefinedMixin', {foo: 'bar'});
|
||||
|
@ -131,14 +131,14 @@ describe('Model class', function() {
|
|||
});
|
||||
|
||||
describe('#mixin()', function() {
|
||||
var Person, Author, Address;
|
||||
let Person, Author, Address;
|
||||
|
||||
beforeEach(function() {
|
||||
Address = modelBuilder.define('Address', {
|
||||
street: {type: 'string', required: true},
|
||||
city: {type: 'string', required: true},
|
||||
});
|
||||
var memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
const memory = new DataSource('mem', {connector: Memory}, modelBuilder);
|
||||
Person = memory.createModel('Person', {name: 'string'});
|
||||
Author = memory.createModel('Author', {name: 'string'});
|
||||
});
|
||||
|
|
|
@ -8,7 +8,7 @@
|
|||
const should = require('./init.js');
|
||||
|
||||
const juggler = require('../');
|
||||
var ModelBuilder = juggler.ModelBuilder;
|
||||
const ModelBuilder = juggler.ModelBuilder;
|
||||
|
||||
describe('ModelBuilder', () => {
|
||||
describe('define()', () => {
|
||||
|
|
|
@ -5,26 +5,26 @@
|
|||
|
||||
// This test written in mocha+should.js
|
||||
'use strict';
|
||||
var should = require('./init.js');
|
||||
var assert = require('assert');
|
||||
const should = require('./init.js');
|
||||
const assert = require('assert');
|
||||
|
||||
var jdb = require('../');
|
||||
var ModelBuilder = jdb.ModelBuilder;
|
||||
var DataSource = jdb.DataSource;
|
||||
var Memory = require('../lib/connectors/memory');
|
||||
const jdb = require('../');
|
||||
const ModelBuilder = jdb.ModelBuilder;
|
||||
const DataSource = jdb.DataSource;
|
||||
const Memory = require('../lib/connectors/memory');
|
||||
|
||||
var ModelDefinition = require('../lib/model-definition');
|
||||
const ModelDefinition = require('../lib/model-definition');
|
||||
|
||||
describe('ModelDefinition class', function() {
|
||||
var memory;
|
||||
let memory;
|
||||
beforeEach(function() {
|
||||
memory = new DataSource({connector: Memory});
|
||||
});
|
||||
|
||||
it('should be able to define plain models', function(done) {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var User = new ModelDefinition(modelBuilder, 'User', {
|
||||
const User = new ModelDefinition(modelBuilder, 'User', {
|
||||
name: 'string',
|
||||
bio: ModelBuilder.Text,
|
||||
approved: Boolean,
|
||||
|
@ -39,7 +39,7 @@ describe('ModelDefinition class', function() {
|
|||
assert.equal(User.properties.joinedAt.type, Date);
|
||||
assert.equal(User.properties.age.type, Number);
|
||||
|
||||
var json = User.toJSON();
|
||||
const json = User.toJSON();
|
||||
assert.equal(json.name, 'User');
|
||||
assert.equal(json.properties.name.type, 'String');
|
||||
assert.equal(json.properties.bio.type, 'Text');
|
||||
|
@ -53,9 +53,9 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should be able to define additional properties', function(done) {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var User = new ModelDefinition(modelBuilder, 'User', {
|
||||
const User = new ModelDefinition(modelBuilder, 'User', {
|
||||
name: 'string',
|
||||
bio: ModelBuilder.Text,
|
||||
approved: Boolean,
|
||||
|
@ -65,7 +65,7 @@ describe('ModelDefinition class', function() {
|
|||
|
||||
User.build();
|
||||
|
||||
var json = User.toJSON();
|
||||
let json = User.toJSON();
|
||||
|
||||
User.defineProperty('id', {type: 'number', id: true});
|
||||
assert.equal(User.properties.name.type, String);
|
||||
|
@ -83,9 +83,9 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should be able to define nesting models', function(done) {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var User = new ModelDefinition(modelBuilder, 'User', {
|
||||
const User = new ModelDefinition(modelBuilder, 'User', {
|
||||
name: String,
|
||||
bio: ModelBuilder.Text,
|
||||
approved: Boolean,
|
||||
|
@ -107,7 +107,7 @@ describe('ModelDefinition class', function() {
|
|||
assert.equal(User.properties.age.type, Number);
|
||||
assert.equal(typeof User.properties.address.type, 'function');
|
||||
|
||||
var json = User.toJSON();
|
||||
const json = User.toJSON();
|
||||
assert.equal(json.name, 'User');
|
||||
assert.equal(json.properties.name.type, 'String');
|
||||
assert.equal(json.properties.bio.type, 'Text');
|
||||
|
@ -124,15 +124,15 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should be able to define referencing models', function(done) {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var Address = modelBuilder.define('Address', {
|
||||
const Address = modelBuilder.define('Address', {
|
||||
street: String,
|
||||
city: String,
|
||||
zipCode: String,
|
||||
state: String,
|
||||
});
|
||||
var User = new ModelDefinition(modelBuilder, 'User', {
|
||||
const User = new ModelDefinition(modelBuilder, 'User', {
|
||||
name: String,
|
||||
bio: ModelBuilder.Text,
|
||||
approved: Boolean,
|
||||
|
@ -150,7 +150,7 @@ describe('ModelDefinition class', function() {
|
|||
assert.equal(User.properties.age.type, Number);
|
||||
assert.equal(User.properties.address.type, Address);
|
||||
|
||||
var json = User.toJSON();
|
||||
const json = User.toJSON();
|
||||
assert.equal(json.name, 'User');
|
||||
assert.equal(json.properties.name.type, 'String');
|
||||
assert.equal(json.properties.bio.type, 'Text');
|
||||
|
@ -164,15 +164,15 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should be able to define referencing models by name', function(done) {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var Address = modelBuilder.define('Address', {
|
||||
const Address = modelBuilder.define('Address', {
|
||||
street: String,
|
||||
city: String,
|
||||
zipCode: String,
|
||||
state: String,
|
||||
});
|
||||
var User = new ModelDefinition(modelBuilder, 'User', {
|
||||
const User = new ModelDefinition(modelBuilder, 'User', {
|
||||
name: String,
|
||||
bio: ModelBuilder.Text,
|
||||
approved: Boolean,
|
||||
|
@ -190,7 +190,7 @@ describe('ModelDefinition class', function() {
|
|||
assert.equal(User.properties.age.type, Number);
|
||||
assert.equal(User.properties.address.type, Address);
|
||||
|
||||
var json = User.toJSON();
|
||||
const json = User.toJSON();
|
||||
assert.equal(json.name, 'User');
|
||||
assert.equal(json.properties.name.type, 'String');
|
||||
assert.equal(json.properties.bio.type, 'Text');
|
||||
|
@ -204,9 +204,9 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should report correct id names', function(done) {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var User = new ModelDefinition(modelBuilder, 'User', {
|
||||
const User = new ModelDefinition(modelBuilder, 'User', {
|
||||
userId: {type: String, id: true},
|
||||
name: 'string',
|
||||
bio: ModelBuilder.Text,
|
||||
|
@ -221,9 +221,9 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should sort id properties by its index', function() {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var User = new ModelDefinition(modelBuilder, 'User', {
|
||||
const User = new ModelDefinition(modelBuilder, 'User', {
|
||||
userId: {type: String, id: 2},
|
||||
userType: {type: String, id: 1},
|
||||
name: 'string',
|
||||
|
@ -233,7 +233,7 @@ describe('ModelDefinition class', function() {
|
|||
age: 'number',
|
||||
});
|
||||
|
||||
var ids = User.ids();
|
||||
const ids = User.ids();
|
||||
assert.ok(Array.isArray(ids));
|
||||
assert.equal(ids.length, 2);
|
||||
assert.equal(ids[0].id, 1);
|
||||
|
@ -243,9 +243,9 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should report correct table/column names', function(done) {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var User = new ModelDefinition(modelBuilder, 'User', {
|
||||
const User = new ModelDefinition(modelBuilder, 'User', {
|
||||
userId: {type: String, id: true, oracle: {column: 'ID'}},
|
||||
name: 'string',
|
||||
}, {oracle: {table: 'USER'}});
|
||||
|
@ -259,11 +259,11 @@ describe('ModelDefinition class', function() {
|
|||
|
||||
describe('maxDepthOfQuery', function() {
|
||||
it('should report errors for deep query than maxDepthOfQuery', function(done) {
|
||||
var MyModel = memory.createModel('my-model', {}, {
|
||||
const MyModel = memory.createModel('my-model', {}, {
|
||||
maxDepthOfQuery: 5,
|
||||
});
|
||||
|
||||
var filter = givenComplexFilter();
|
||||
const filter = givenComplexFilter();
|
||||
|
||||
MyModel.find(filter, function(err) {
|
||||
should.exist(err);
|
||||
|
@ -273,11 +273,11 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should honor maxDepthOfQuery setting', function(done) {
|
||||
var MyModel = memory.createModel('my-model', {}, {
|
||||
const MyModel = memory.createModel('my-model', {}, {
|
||||
maxDepthOfQuery: 20,
|
||||
});
|
||||
|
||||
var filter = givenComplexFilter();
|
||||
const filter = givenComplexFilter();
|
||||
|
||||
MyModel.find(filter, function(err) {
|
||||
should.not.exist(err);
|
||||
|
@ -286,11 +286,11 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should honor maxDepthOfQuery in options', function(done) {
|
||||
var MyModel = memory.createModel('my-model', {}, {
|
||||
const MyModel = memory.createModel('my-model', {}, {
|
||||
maxDepthOfQuery: 5,
|
||||
});
|
||||
|
||||
var filter = givenComplexFilter();
|
||||
const filter = givenComplexFilter();
|
||||
|
||||
MyModel.find(filter, {maxDepthOfQuery: 20}, function(err) {
|
||||
should.not.exist(err);
|
||||
|
@ -299,28 +299,28 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
function givenComplexFilter() {
|
||||
var filter = {where: {and: [{and: [{and: [{and: [{and: [{and:
|
||||
const filter = {where: {and: [{and: [{and: [{and: [{and: [{and:
|
||||
[{and: [{and: [{and: [{x: 1}]}]}]}]}]}]}]}]}]}};
|
||||
return filter;
|
||||
}
|
||||
});
|
||||
|
||||
it('should serialize protected properties into JSON', function() {
|
||||
var ProtectedModel = memory.createModel('protected', {}, {
|
||||
const ProtectedModel = memory.createModel('protected', {}, {
|
||||
protected: ['protectedProperty'],
|
||||
});
|
||||
var pm = new ProtectedModel({
|
||||
const pm = new ProtectedModel({
|
||||
id: 1, foo: 'bar', protectedProperty: 'protected',
|
||||
});
|
||||
var serialized = pm.toJSON();
|
||||
const serialized = pm.toJSON();
|
||||
assert.deepEqual(serialized, {
|
||||
id: 1, foo: 'bar', protectedProperty: 'protected',
|
||||
});
|
||||
});
|
||||
|
||||
it('should not serialize protected properties of nested models into JSON', function(done) {
|
||||
var Parent = memory.createModel('parent');
|
||||
var Child = memory.createModel('child', {}, {protected: ['protectedProperty']});
|
||||
const Parent = memory.createModel('parent');
|
||||
const Child = memory.createModel('child', {}, {protected: ['protectedProperty']});
|
||||
Parent.hasMany(Child);
|
||||
Parent.create({
|
||||
name: 'parent',
|
||||
|
@ -333,8 +333,8 @@ describe('ModelDefinition class', function() {
|
|||
if (err) return done(err);
|
||||
Parent.find({include: 'children'}, function(err, parents) {
|
||||
if (err) return done(err);
|
||||
var serialized = parents[0].toJSON();
|
||||
var child = serialized.children[0];
|
||||
const serialized = parents[0].toJSON();
|
||||
const child = serialized.children[0];
|
||||
assert.equal(child.name, 'child');
|
||||
assert.notEqual(child.protectedProperty, 'protectedValue');
|
||||
done();
|
||||
|
@ -344,15 +344,15 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should not serialize hidden properties into JSON', function() {
|
||||
var HiddenModel = memory.createModel('hidden', {}, {
|
||||
const HiddenModel = memory.createModel('hidden', {}, {
|
||||
hidden: ['secret'],
|
||||
});
|
||||
var hm = new HiddenModel({
|
||||
const hm = new HiddenModel({
|
||||
id: 1,
|
||||
foo: 'bar',
|
||||
secret: 'secret',
|
||||
});
|
||||
var serialized = hm.toJSON();
|
||||
const serialized = hm.toJSON();
|
||||
assert.deepEqual(serialized, {
|
||||
id: 1,
|
||||
foo: 'bar',
|
||||
|
@ -360,8 +360,8 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should not serialize hidden properties of nested models into JSON', function(done) {
|
||||
var Parent = memory.createModel('parent');
|
||||
var Child = memory.createModel('child', {}, {hidden: ['secret']});
|
||||
const Parent = memory.createModel('parent');
|
||||
const Child = memory.createModel('child', {}, {hidden: ['secret']});
|
||||
Parent.hasMany(Child);
|
||||
Parent.create({
|
||||
name: 'parent',
|
||||
|
@ -374,8 +374,8 @@ describe('ModelDefinition class', function() {
|
|||
if (err) return done(err);
|
||||
Parent.find({include: 'children'}, function(err, parents) {
|
||||
if (err) return done(err);
|
||||
var serialized = parents[0].toJSON();
|
||||
var child = serialized.children[0];
|
||||
const serialized = parents[0].toJSON();
|
||||
const child = serialized.children[0];
|
||||
assert.equal(child.name, 'child');
|
||||
assert.notEqual(child.secret, 'secret');
|
||||
done();
|
||||
|
@ -385,7 +385,7 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
describe('hidden properties', function() {
|
||||
var Child;
|
||||
let Child;
|
||||
|
||||
describe('with hidden array', function() {
|
||||
beforeEach(function() { givenChildren(); });
|
||||
|
@ -493,7 +493,7 @@ describe('ModelDefinition class', function() {
|
|||
};
|
||||
|
||||
describe('hidden nested properties', function() {
|
||||
var Child;
|
||||
let Child;
|
||||
beforeEach(givenChildren);
|
||||
|
||||
it('should be removed if used in where as a composite key - x.secret', function() {
|
||||
|
@ -515,7 +515,7 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
function givenChildren() {
|
||||
var hiddenProps = {hidden: ['secret']};
|
||||
const hiddenProps = {hidden: ['secret']};
|
||||
Child = memory.createModel('child', {
|
||||
name: String,
|
||||
x: {
|
||||
|
@ -555,8 +555,8 @@ describe('ModelDefinition class', function() {
|
|||
}
|
||||
|
||||
describe('protected properties', function() {
|
||||
var Parent;
|
||||
var Child;
|
||||
let Parent;
|
||||
let Child;
|
||||
beforeEach(givenParentAndChild);
|
||||
|
||||
it('should be removed if used in include scope', function() {
|
||||
|
@ -614,8 +614,8 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
describe('hidden properties in include', function() {
|
||||
var Parent;
|
||||
var Child;
|
||||
let Parent;
|
||||
let Child;
|
||||
beforeEach(givenParentAndChildWithHiddenProperty);
|
||||
|
||||
it('should be rejected if used in scope', function() {
|
||||
|
@ -653,7 +653,7 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should report deprecation warning for property named constructor', function() {
|
||||
var message = 'deprecation not reported';
|
||||
let message = 'deprecation not reported';
|
||||
process.once('deprecation', function(err) { message = err.message; });
|
||||
|
||||
memory.createModel('Ctor', {'constructor': String});
|
||||
|
@ -663,7 +663,7 @@ describe('ModelDefinition class', function() {
|
|||
|
||||
it('should throw error for dynamic property names containing dot',
|
||||
function(done) {
|
||||
var Model = memory.createModel('DynamicDotted');
|
||||
const Model = memory.createModel('DynamicDotted');
|
||||
Model.create({'dot.name': 'dot.value'}, function(err) {
|
||||
err.should.be.instanceOf(Error);
|
||||
err.message.should.match(/dot\(s\).*DynamicDotted.*dot\.name/);
|
||||
|
@ -672,7 +672,7 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should throw error for dynamic property named constructor', function(done) {
|
||||
var Model = memory.createModel('DynamicCtor');
|
||||
const Model = memory.createModel('DynamicCtor');
|
||||
Model.create({'constructor': 'myCtor'}, function(err) {
|
||||
assert.equal(err.message, 'Property name "constructor" is not allowed in DynamicCtor data');
|
||||
done();
|
||||
|
@ -680,18 +680,18 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
it('should support "array" type shortcut', function() {
|
||||
var Model = memory.createModel('TwoArrays', {
|
||||
const Model = memory.createModel('TwoArrays', {
|
||||
regular: Array,
|
||||
sugar: 'array',
|
||||
});
|
||||
|
||||
var props = Model.definition.properties;
|
||||
const props = Model.definition.properties;
|
||||
props.regular.type.should.equal(props.sugar.type);
|
||||
});
|
||||
|
||||
context('hasPK', function() {
|
||||
context('with primary key defined', function() {
|
||||
var Todo;
|
||||
let Todo;
|
||||
before(function prepModel() {
|
||||
Todo = new ModelDefinition(new ModelBuilder(), 'Todo', {
|
||||
content: 'string',
|
||||
|
@ -709,7 +709,7 @@ describe('ModelDefinition class', function() {
|
|||
});
|
||||
|
||||
context('without primary key defined', function() {
|
||||
var Todo;
|
||||
let Todo;
|
||||
before(function prepModel() {
|
||||
Todo = new ModelDefinition(new ModelBuilder(), 'Todo', {
|
||||
content: 'string',
|
||||
|
|
|
@ -74,7 +74,7 @@ describe('Model class inheritance', function() {
|
|||
};
|
||||
|
||||
// saving original getMergePolicy method
|
||||
let originalGetMergePolicy = base.getMergePolicy;
|
||||
const originalGetMergePolicy = base.getMergePolicy;
|
||||
|
||||
// the injected getMergePolicy method captures the provided configureModelMerge option
|
||||
base.getMergePolicy = function(options) {
|
||||
|
@ -154,9 +154,9 @@ describe('Model class inheritance', function() {
|
|||
});
|
||||
|
||||
it('allows model extension', function(done) {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var User = modelBuilder.define('User', {
|
||||
const User = modelBuilder.define('User', {
|
||||
name: String,
|
||||
bio: ModelBuilder.Text,
|
||||
approved: Boolean,
|
||||
|
@ -164,9 +164,9 @@ describe('Model class inheritance', function() {
|
|||
age: Number,
|
||||
});
|
||||
|
||||
var Customer = User.extend('Customer', {customerId: {type: String, id: true}});
|
||||
const Customer = User.extend('Customer', {customerId: {type: String, id: true}});
|
||||
|
||||
var customer = new Customer({name: 'Joe', age: 20, customerId: 'c01'});
|
||||
const customer = new Customer({name: 'Joe', age: 20, customerId: 'c01'});
|
||||
|
||||
customer.should.be.type('object').and.have.property('name', 'Joe');
|
||||
customer.should.have.property('name', 'Joe');
|
||||
|
@ -179,8 +179,8 @@ describe('Model class inheritance', function() {
|
|||
// Remove internal properties
|
||||
return k.indexOf('__') === -1;
|
||||
}).length, 0);
|
||||
var count = 0;
|
||||
for (var p in customer.toObject()) {
|
||||
let count = 0;
|
||||
for (const p in customer.toObject()) {
|
||||
if (p.indexOf('__') === 0) {
|
||||
continue;
|
||||
}
|
||||
|
@ -198,9 +198,9 @@ describe('Model class inheritance', function() {
|
|||
});
|
||||
|
||||
it('allows model extension with merged settings', function(done) {
|
||||
var modelBuilder = new ModelBuilder();
|
||||
const modelBuilder = new ModelBuilder();
|
||||
|
||||
var User = modelBuilder.define('User', {
|
||||
const User = modelBuilder.define('User', {
|
||||
name: String,
|
||||
}, {
|
||||
defaultPermission: 'ALLOW',
|
||||
|
@ -219,7 +219,7 @@ describe('Model class inheritance', function() {
|
|||
},
|
||||
});
|
||||
|
||||
var Customer = User.extend('Customer',
|
||||
const Customer = User.extend('Customer',
|
||||
{customerId: {type: String, id: true}}, {
|
||||
defaultPermission: 'DENY',
|
||||
acls: [
|
||||
|
|
|
@ -4,23 +4,23 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
|
||||
'use strict';
|
||||
var jdb = require('../');
|
||||
var DataSource = jdb.DataSource;
|
||||
var path = require('path');
|
||||
var fs = require('fs');
|
||||
var assert = require('assert');
|
||||
var async = require('async');
|
||||
var should = require('./init.js');
|
||||
var Memory = require('../lib/connectors/memory').Memory;
|
||||
const jdb = require('../');
|
||||
const DataSource = jdb.DataSource;
|
||||
const path = require('path');
|
||||
const fs = require('fs');
|
||||
const assert = require('assert');
|
||||
const async = require('async');
|
||||
const should = require('./init.js');
|
||||
const Memory = require('../lib/connectors/memory').Memory;
|
||||
|
||||
describe('normalizeUndefinedInQuery', function() {
|
||||
describe('with setting "throw"', function() {
|
||||
var ds = new DataSource({
|
||||
const ds = new DataSource({
|
||||
connector: 'memory',
|
||||
normalizeUndefinedInQuery: 'throw',
|
||||
});
|
||||
|
||||
var User = ds.define('User', {
|
||||
const User = ds.define('User', {
|
||||
seq: {type: Number, index: true},
|
||||
name: {type: String, index: true, sort: true},
|
||||
email: {type: String, index: true},
|
||||
|
@ -87,11 +87,11 @@ describe('normalizeUndefinedInQuery', function() {
|
|||
});
|
||||
|
||||
describe('with setting "nullify"', function() {
|
||||
var ds = new DataSource({
|
||||
const ds = new DataSource({
|
||||
connector: 'memory',
|
||||
});
|
||||
|
||||
var User = ds.define('User', {
|
||||
const User = ds.define('User', {
|
||||
seq: {type: Number, index: true},
|
||||
name: {type: String, index: true, sort: true},
|
||||
email: {type: String, index: true},
|
||||
|
@ -165,11 +165,11 @@ describe('normalizeUndefinedInQuery', function() {
|
|||
});
|
||||
|
||||
describe('with setting "ignore"', function() {
|
||||
var ds = new DataSource({
|
||||
const ds = new DataSource({
|
||||
connector: 'memory',
|
||||
});
|
||||
|
||||
var User = ds.define('User', {
|
||||
const User = ds.define('User', {
|
||||
seq: {type: Number, index: true},
|
||||
name: {type: String, index: true, sort: true},
|
||||
email: {type: String, index: true},
|
||||
|
@ -244,7 +244,7 @@ describe('normalizeUndefinedInQuery', function() {
|
|||
});
|
||||
|
||||
function seed(User, done) {
|
||||
var beatles = [
|
||||
const beatles = [
|
||||
{
|
||||
seq: 0,
|
||||
name: 'John Lennon',
|
||||
|
|
|
@ -5,18 +5,18 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var ValidationError = require('../..').ValidationError;
|
||||
const ValidationError = require('../..').ValidationError;
|
||||
|
||||
var contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
var ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
var aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
const contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
const ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
const aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
|
||||
var uid = require('../helpers/uid-generator');
|
||||
var HookMonitor = require('../helpers/hook-monitor');
|
||||
const uid = require('../helpers/uid-generator');
|
||||
const HookMonitor = require('../helpers/hook-monitor');
|
||||
|
||||
module.exports = function(dataSource, should, connectorCapabilities) {
|
||||
describe('EmbedsMany - create', function() {
|
||||
var ctxRecorder, hookMonitor, expectedError;
|
||||
let ctxRecorder, hookMonitor, expectedError;
|
||||
|
||||
beforeEach(function setupHelpers() {
|
||||
ctxRecorder = new ContextRecorder('hook not called');
|
||||
|
@ -24,8 +24,8 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
expectedError = new Error('test error');
|
||||
});
|
||||
|
||||
var Owner, Embedded, ownerInstance;
|
||||
var migrated = false;
|
||||
let Owner, Embedded, ownerInstance;
|
||||
let migrated = false;
|
||||
|
||||
beforeEach(function setupDatabase() {
|
||||
Embedded = dataSource.createModel('Embedded', {
|
||||
|
@ -57,7 +57,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
});
|
||||
|
||||
function callCreate() {
|
||||
var item = new Embedded({name: 'created'});
|
||||
const item = new Embedded({name: 'created'});
|
||||
return ownerInstance.embeddedList.create(item);
|
||||
}
|
||||
|
||||
|
|
|
@ -5,26 +5,26 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var ValidationError = require('../..').ValidationError;
|
||||
const ValidationError = require('../..').ValidationError;
|
||||
|
||||
var contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
var ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
var aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
const contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
const ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
const aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
|
||||
var uid = require('../helpers/uid-generator');
|
||||
var HookMonitor = require('../helpers/hook-monitor');
|
||||
const uid = require('../helpers/uid-generator');
|
||||
const HookMonitor = require('../helpers/hook-monitor');
|
||||
|
||||
module.exports = function(dataSource, should, connectorCapabilities) {
|
||||
describe('EmbedsMany - destroy', function() {
|
||||
var ctxRecorder, hookMonitor, expectedError;
|
||||
let ctxRecorder, hookMonitor, expectedError;
|
||||
beforeEach(function sharedSetup() {
|
||||
ctxRecorder = new ContextRecorder('hook not called');
|
||||
hookMonitor = new HookMonitor({includeModelName: true});
|
||||
expectedError = new Error('test error');
|
||||
});
|
||||
|
||||
var Owner, Embedded;
|
||||
var migrated = false;
|
||||
let Owner, Embedded;
|
||||
let migrated = false;
|
||||
beforeEach(function setupDatabase() {
|
||||
Embedded = dataSource.createModel('Embedded', {
|
||||
// Set id.generated to false to honor client side values
|
||||
|
@ -47,14 +47,14 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
}
|
||||
});
|
||||
|
||||
var ownerInstance, existingInstance, existingItem;
|
||||
let ownerInstance, existingInstance, existingItem;
|
||||
beforeEach(function setupData() {
|
||||
return Owner.create({})
|
||||
.then(function(inst) {
|
||||
ownerInstance = inst;
|
||||
})
|
||||
.then(function() {
|
||||
var item = new Embedded({name: 'created'});
|
||||
const item = new Embedded({name: 'created'});
|
||||
return ownerInstance.embeddedList.create(item).then(function(it) {
|
||||
existingItem = it;
|
||||
});
|
||||
|
|
|
@ -5,26 +5,26 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var ValidationError = require('../..').ValidationError;
|
||||
const ValidationError = require('../..').ValidationError;
|
||||
|
||||
var contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
var ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
var aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
const contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
const ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
const aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
|
||||
var uid = require('../helpers/uid-generator');
|
||||
var HookMonitor = require('../helpers/hook-monitor');
|
||||
const uid = require('../helpers/uid-generator');
|
||||
const HookMonitor = require('../helpers/hook-monitor');
|
||||
|
||||
module.exports = function(dataSource, should, connectorCapabilities) {
|
||||
describe('EmbedsMany - update', function() {
|
||||
var ctxRecorder, hookMonitor, expectedError;
|
||||
let ctxRecorder, hookMonitor, expectedError;
|
||||
beforeEach(function setupHelpers() {
|
||||
ctxRecorder = new ContextRecorder('hook not called');
|
||||
hookMonitor = new HookMonitor({includeModelName: true});
|
||||
expectedError = new Error('test error');
|
||||
});
|
||||
|
||||
var Owner, Embedded;
|
||||
var migrated = false;
|
||||
let Owner, Embedded;
|
||||
let migrated = false;
|
||||
beforeEach(function setupDatabase() {
|
||||
Embedded = dataSource.createModel('Embedded', {
|
||||
// Set id.generated to false to honor client side values
|
||||
|
@ -47,14 +47,14 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
}
|
||||
});
|
||||
|
||||
var ownerInstance, existingItem;
|
||||
let ownerInstance, existingItem;
|
||||
beforeEach(function setupData() {
|
||||
return Owner.create({})
|
||||
.then(function(inst) {
|
||||
ownerInstance = inst;
|
||||
})
|
||||
.then(function() {
|
||||
var item = new Embedded({name: 'created'});
|
||||
const item = new Embedded({name: 'created'});
|
||||
return ownerInstance.embeddedList.create(item).then(function(it) {
|
||||
existingItem = it;
|
||||
});
|
||||
|
|
|
@ -5,18 +5,18 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var ValidationError = require('../..').ValidationError;
|
||||
const ValidationError = require('../..').ValidationError;
|
||||
|
||||
var contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
var ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
var aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
const contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
const ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
const aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
|
||||
var uid = require('../helpers/uid-generator');
|
||||
var HookMonitor = require('../helpers/hook-monitor');
|
||||
const uid = require('../helpers/uid-generator');
|
||||
const HookMonitor = require('../helpers/hook-monitor');
|
||||
|
||||
module.exports = function(dataSource, should, connectorCapabilities) {
|
||||
describe('EmbedsOne - create', function() {
|
||||
var ctxRecorder, hookMonitor, expectedError;
|
||||
let ctxRecorder, hookMonitor, expectedError;
|
||||
|
||||
beforeEach(function setupHelpers() {
|
||||
ctxRecorder = new ContextRecorder('hook not called');
|
||||
|
@ -24,8 +24,8 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
expectedError = new Error('test error');
|
||||
});
|
||||
|
||||
var Owner, Embedded, ownerInstance;
|
||||
var migrated = false;
|
||||
let Owner, Embedded, ownerInstance;
|
||||
let migrated = false;
|
||||
|
||||
beforeEach(function setupDatabase() {
|
||||
Embedded = dataSource.createModel('Embedded', {
|
||||
|
@ -57,7 +57,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
});
|
||||
|
||||
function callCreate() {
|
||||
var item = new Embedded({name: 'created'});
|
||||
const item = new Embedded({name: 'created'});
|
||||
return ownerInstance.embeddedItem.create(item);
|
||||
}
|
||||
|
||||
|
|
|
@ -5,26 +5,26 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var ValidationError = require('../..').ValidationError;
|
||||
const ValidationError = require('../..').ValidationError;
|
||||
|
||||
var contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
var ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
var aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
const contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
const ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
const aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
|
||||
var uid = require('../helpers/uid-generator');
|
||||
var HookMonitor = require('../helpers/hook-monitor');
|
||||
const uid = require('../helpers/uid-generator');
|
||||
const HookMonitor = require('../helpers/hook-monitor');
|
||||
|
||||
module.exports = function(dataSource, should, connectorCapabilities) {
|
||||
describe('EmbedsOne - destroy', function() {
|
||||
var ctxRecorder, hookMonitor, expectedError;
|
||||
let ctxRecorder, hookMonitor, expectedError;
|
||||
beforeEach(function sharedSetup() {
|
||||
ctxRecorder = new ContextRecorder('hook not called');
|
||||
hookMonitor = new HookMonitor({includeModelName: true});
|
||||
expectedError = new Error('test error');
|
||||
});
|
||||
|
||||
var Owner, Embedded;
|
||||
var migrated = false;
|
||||
let Owner, Embedded;
|
||||
let migrated = false;
|
||||
beforeEach(function setupDatabase() {
|
||||
Embedded = dataSource.createModel('Embedded', {
|
||||
// Set id.generated to false to honor client side values
|
||||
|
@ -47,14 +47,14 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
}
|
||||
});
|
||||
|
||||
var ownerInstance, existingInstance, existingItem;
|
||||
let ownerInstance, existingInstance, existingItem;
|
||||
beforeEach(function setupData() {
|
||||
return Owner.create({})
|
||||
.then(function(inst) {
|
||||
ownerInstance = inst;
|
||||
})
|
||||
.then(function() {
|
||||
var item = new Embedded({name: 'created'});
|
||||
const item = new Embedded({name: 'created'});
|
||||
return ownerInstance.embeddedItem.create(item).then(function(it) {
|
||||
existingItem = it;
|
||||
});
|
||||
|
|
|
@ -5,26 +5,26 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
var ValidationError = require('../..').ValidationError;
|
||||
const ValidationError = require('../..').ValidationError;
|
||||
|
||||
var contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
var ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
var aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
const contextTestHelpers = require('../helpers/context-test-helpers');
|
||||
const ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
const aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
|
||||
var uid = require('../helpers/uid-generator');
|
||||
var HookMonitor = require('../helpers/hook-monitor');
|
||||
const uid = require('../helpers/uid-generator');
|
||||
const HookMonitor = require('../helpers/hook-monitor');
|
||||
|
||||
module.exports = function(dataSource, should, connectorCapabilities) {
|
||||
describe('EmbedsOne - update', function() {
|
||||
var ctxRecorder, hookMonitor, expectedError;
|
||||
let ctxRecorder, hookMonitor, expectedError;
|
||||
beforeEach(function setupHelpers() {
|
||||
ctxRecorder = new ContextRecorder('hook not called');
|
||||
hookMonitor = new HookMonitor({includeModelName: true});
|
||||
expectedError = new Error('test error');
|
||||
});
|
||||
|
||||
var Owner, Embedded;
|
||||
var migrated = false;
|
||||
let Owner, Embedded;
|
||||
let migrated = false;
|
||||
beforeEach(function setupDatabase() {
|
||||
Embedded = dataSource.createModel('Embedded', {
|
||||
// Set id.generated to false to honor client side values
|
||||
|
@ -47,14 +47,14 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
}
|
||||
});
|
||||
|
||||
var ownerInstance, existingItem;
|
||||
let ownerInstance, existingItem;
|
||||
beforeEach(function setupData() {
|
||||
return Owner.create({})
|
||||
.then(function(inst) {
|
||||
ownerInstance = inst;
|
||||
})
|
||||
.then(function() {
|
||||
var item = new Embedded({name: 'created'});
|
||||
const item = new Embedded({name: 'created'});
|
||||
return ownerInstance.embeddedItem.create(item).then(function(it) {
|
||||
existingItem = it;
|
||||
});
|
||||
|
|
|
@ -1,18 +1,18 @@
|
|||
'use strict';
|
||||
|
||||
var debug = require('debug')('test');
|
||||
var fs = require('fs');
|
||||
var path = require('path');
|
||||
const debug = require('debug')('test');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
module.exports = function(dataSource, should, connectorCapabilities) {
|
||||
var operations = fs.readdirSync(__dirname);
|
||||
let operations = fs.readdirSync(__dirname);
|
||||
operations = operations.filter(function(it) {
|
||||
return it !== path.basename(__filename) &&
|
||||
!!require.extensions[path.extname(it).toLowerCase()];
|
||||
});
|
||||
for (var ix in operations) {
|
||||
var name = operations[ix];
|
||||
var fullPath = require.resolve('./' + name);
|
||||
for (const ix in operations) {
|
||||
const name = operations[ix];
|
||||
const fullPath = require.resolve('./' + name);
|
||||
debug('Loading test suite %s (%s)', name, fullPath);
|
||||
require(fullPath).apply(this, arguments);
|
||||
}
|
||||
|
|
|
@ -7,16 +7,16 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false */
|
||||
var async = require('async');
|
||||
var should = require('./init.js');
|
||||
var db, User, options, ModelWithForceId, whereCount = 0;
|
||||
var j = require('../');
|
||||
var ValidationError = j.ValidationError;
|
||||
const async = require('async');
|
||||
const should = require('./init.js');
|
||||
let db, User, options, ModelWithForceId, whereCount = 0;
|
||||
const j = require('../');
|
||||
const ValidationError = j.ValidationError;
|
||||
|
||||
var INITIAL_NAME = 'Bert';
|
||||
var NEW_NAME = 'Ernie';
|
||||
var INVALID_DATA = {name: null};
|
||||
var VALID_DATA = {name: INITIAL_NAME};
|
||||
const INITIAL_NAME = 'Bert';
|
||||
const NEW_NAME = 'Ernie';
|
||||
const INVALID_DATA = {name: null};
|
||||
const VALID_DATA = {name: INITIAL_NAME};
|
||||
|
||||
describe('optional-validation', function() {
|
||||
before(function(done) {
|
||||
|
@ -103,7 +103,7 @@ describe('optional-validation', function() {
|
|||
function callUpdateOrCreateWithExistingUserId(name, options, cb) {
|
||||
User.create({'name': 'Groover'}, function(err, user) {
|
||||
if (err) return cb(err);
|
||||
var data = {name: name};
|
||||
const data = {name: name};
|
||||
data.id = user.id;
|
||||
User.updateOrCreate(data, options, cb);
|
||||
});
|
||||
|
|
|
@ -4,35 +4,35 @@
|
|||
// License text available at https://opensource.org/licenses/MIT
|
||||
|
||||
'use strict';
|
||||
var ValidationError = require('../').ValidationError;
|
||||
const ValidationError = require('../').ValidationError;
|
||||
|
||||
var async = require('async');
|
||||
var contextTestHelpers = require('./helpers/context-test-helpers');
|
||||
var ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
var deepCloneToObject = contextTestHelpers.deepCloneToObject;
|
||||
var aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
var GeoPoint = require('../lib/geo.js').GeoPoint;
|
||||
const async = require('async');
|
||||
const contextTestHelpers = require('./helpers/context-test-helpers');
|
||||
const ContextRecorder = contextTestHelpers.ContextRecorder;
|
||||
const deepCloneToObject = contextTestHelpers.deepCloneToObject;
|
||||
const aCtxForModel = contextTestHelpers.aCtxForModel;
|
||||
const GeoPoint = require('../lib/geo.js').GeoPoint;
|
||||
|
||||
var uid = require('./helpers/uid-generator');
|
||||
var getLastGeneratedUid = uid.last;
|
||||
const uid = require('./helpers/uid-generator');
|
||||
const getLastGeneratedUid = uid.last;
|
||||
|
||||
var HookMonitor = require('./helpers/hook-monitor');
|
||||
var isNewInstanceFlag;
|
||||
const HookMonitor = require('./helpers/hook-monitor');
|
||||
let isNewInstanceFlag;
|
||||
|
||||
module.exports = function(dataSource, should, connectorCapabilities) {
|
||||
isNewInstanceFlag = connectorCapabilities.replaceOrCreateReportsNewInstance;
|
||||
if (!connectorCapabilities) connectorCapabilities = {};
|
||||
if (isNewInstanceFlag === undefined) {
|
||||
var warn = 'The connector does not support a recently added feature:' +
|
||||
const warn = 'The connector does not support a recently added feature:' +
|
||||
' replaceOrCreateReportsNewInstance';
|
||||
console.warn(warn);
|
||||
}
|
||||
describe('Persistence hooks', function() {
|
||||
var ctxRecorder, hookMonitor, expectedError;
|
||||
var TestModel, existingInstance, GeoModel;
|
||||
var migrated = false;
|
||||
let ctxRecorder, hookMonitor, expectedError;
|
||||
let TestModel, existingInstance, GeoModel;
|
||||
let migrated = false;
|
||||
|
||||
var undefinedValue = undefined;
|
||||
let undefinedValue = undefined;
|
||||
|
||||
beforeEach(function setupDatabase(done) {
|
||||
ctxRecorder = new ContextRecorder('hook not called');
|
||||
|
@ -82,8 +82,8 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
|
||||
TestModel.create({name: 'second'}, function(err) {
|
||||
if (err) return done(err);
|
||||
var location1 = new GeoPoint({lat: 10.2, lng: 6.7});
|
||||
var location2 = new GeoPoint({lat: 10.3, lng: 6.8});
|
||||
const location1 = new GeoPoint({lat: 10.2, lng: 6.7});
|
||||
const location2 = new GeoPoint({lat: 10.3, lng: 6.8});
|
||||
GeoModel.create([
|
||||
{name: 'Rome', location: location1},
|
||||
{name: 'Tokyo', location: location2},
|
||||
|
@ -143,8 +143,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
|
||||
it('triggers the loaded hook multiple times when multiple instances exist when near filter is used',
|
||||
function(done) {
|
||||
var hookMonitorGeoModel;
|
||||
hookMonitorGeoModel = new HookMonitor({includeModelName: false});
|
||||
const hookMonitorGeoModel = new HookMonitor({includeModelName: false});
|
||||
|
||||
function monitorHookExecutionGeoModel(hookNames) {
|
||||
hookMonitorGeoModel.install(GeoModel, hookNames);
|
||||
|
@ -152,7 +151,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
|
||||
monitorHookExecutionGeoModel();
|
||||
|
||||
var query = {
|
||||
const query = {
|
||||
where: {location: {near: '10,5'}},
|
||||
};
|
||||
GeoModel.find(query, function(err, list) {
|
||||
|
@ -170,7 +169,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
next();
|
||||
});
|
||||
|
||||
var query = {
|
||||
const query = {
|
||||
where: {location: {near: '10,5'}},
|
||||
};
|
||||
|
||||
|
@ -191,7 +190,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
next();
|
||||
});
|
||||
|
||||
var query = {
|
||||
const query = {
|
||||
where: {location: {near: '10,5'}},
|
||||
};
|
||||
|
||||
|
@ -1325,7 +1324,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
// The rationale behind passing { persisted: true } is to bypass the check
|
||||
// made by DAO to determine whether the instance should be saved via
|
||||
// PersistedModel.create and force it to call connector.save()
|
||||
var instance = new TestModel(
|
||||
const instance = new TestModel(
|
||||
{id: 'new-id', name: 'created'},
|
||||
{persisted: true}
|
||||
);
|
||||
|
@ -1391,7 +1390,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
it('triggers `before save` hook', function(done) {
|
||||
TestModel.observe('before save', ctxRecorder.recordAndNext());
|
||||
|
||||
var currentInstance = deepCloneToObject(existingInstance);
|
||||
const currentInstance = deepCloneToObject(existingInstance);
|
||||
|
||||
existingInstance.updateAttributes({name: 'changed'}, function(err) {
|
||||
if (err) return done(err);
|
||||
|
@ -1494,13 +1493,13 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
});
|
||||
|
||||
it('applies updates from `persist` hook - for nested model instance', function(done) {
|
||||
var Address = dataSource.createModel('NestedAddress', {
|
||||
const Address = dataSource.createModel('NestedAddress', {
|
||||
id: {type: String, id: true, default: 1},
|
||||
city: {type: String, required: true},
|
||||
country: {type: String, required: true},
|
||||
});
|
||||
|
||||
var User = dataSource.createModel('UserWithAddress', {
|
||||
const User = dataSource.createModel('UserWithAddress', {
|
||||
id: {type: String, id: true, default: uid.next},
|
||||
name: {type: String, required: true},
|
||||
address: {type: Address, required: false},
|
||||
|
@ -1512,7 +1511,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
User.create({name: 'Joe'}, function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var existingUser = instance;
|
||||
const existingUser = instance;
|
||||
|
||||
User.observe('persist', ctxRecorder.recordAndNext(function(ctx) {
|
||||
should.exist(ctx.data.address);
|
||||
|
@ -1762,13 +1761,13 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
});
|
||||
|
||||
it('applies updates from `persist` hook - for nested model instance', function(done) {
|
||||
var Address = dataSource.createModel('NestedAddress', {
|
||||
const Address = dataSource.createModel('NestedAddress', {
|
||||
id: {type: String, id: true, default: 1},
|
||||
city: {type: String, required: true},
|
||||
country: {type: String, required: true},
|
||||
});
|
||||
|
||||
var User = dataSource.createModel('UserWithAddress', {
|
||||
const User = dataSource.createModel('UserWithAddress', {
|
||||
id: {type: String, id: true, default: uid.next},
|
||||
name: {type: String, required: true},
|
||||
address: {type: Address, required: false},
|
||||
|
@ -1780,7 +1779,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
User.create({name: 'Joe'}, function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var existingUser = instance;
|
||||
const existingUser = instance;
|
||||
|
||||
User.observe('persist', ctxRecorder.recordAndNext(function(ctx) {
|
||||
should.exist(ctx.data.address);
|
||||
|
@ -2215,7 +2214,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expectedContext = aCtxForModel(TestModel, {
|
||||
const expectedContext = aCtxForModel(TestModel, {
|
||||
where: {id: existingInstance.id},
|
||||
data: {
|
||||
id: existingInstance.id,
|
||||
|
@ -2504,7 +2503,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
if (err)
|
||||
return done(err);
|
||||
|
||||
var expectedContext = aCtxForModel(TestModel, {
|
||||
const expectedContext = aCtxForModel(TestModel, {
|
||||
instance: instance,
|
||||
});
|
||||
|
||||
|
@ -2522,7 +2521,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expectedContext = aCtxForModel(TestModel, {
|
||||
const expectedContext = aCtxForModel(TestModel, {
|
||||
instance: {
|
||||
id: existingInstance.id,
|
||||
name: 'replaced name',
|
||||
|
@ -2548,7 +2547,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expectedContext = aCtxForModel(TestModel, {
|
||||
const expectedContext = aCtxForModel(TestModel, {
|
||||
instance: {
|
||||
id: 'new-id',
|
||||
name: 'a name',
|
||||
|
@ -2603,7 +2602,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expectedContext = aCtxForModel(TestModel, {
|
||||
const expectedContext = aCtxForModel(TestModel, {
|
||||
currentInstance: {
|
||||
id: 'new-id',
|
||||
name: 'a name',
|
||||
|
@ -2637,7 +2636,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expected = {
|
||||
const expected = {
|
||||
where: {id: existingInstance.id},
|
||||
data: {
|
||||
id: existingInstance.id,
|
||||
|
@ -2650,7 +2649,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
},
|
||||
};
|
||||
|
||||
var expectedContext = aCtxForModel(TestModel, expected);
|
||||
const expectedContext = aCtxForModel(TestModel, expected);
|
||||
|
||||
if (!dataSource.connector.replaceOrCreate) {
|
||||
expectedContext.isNewInstance = false;
|
||||
|
@ -2718,7 +2717,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expected = {
|
||||
const expected = {
|
||||
data: {
|
||||
id: 'new-id',
|
||||
name: 'a name',
|
||||
|
@ -2743,7 +2742,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expected = {
|
||||
const expected = {
|
||||
data: {
|
||||
id: existingInstance.id,
|
||||
name: 'replaced name',
|
||||
|
@ -2779,7 +2778,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expected = {
|
||||
const expected = {
|
||||
instance: {
|
||||
id: existingInstance.id,
|
||||
name: 'replaced name',
|
||||
|
@ -2805,7 +2804,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expected = {
|
||||
const expected = {
|
||||
instance: {
|
||||
id: instance.id,
|
||||
name: 'a name',
|
||||
|
@ -3498,7 +3497,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
{id: existingInstance.id, name: 'updated name'},
|
||||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
var expectedContext = aCtxForModel(TestModel, {
|
||||
const expectedContext = aCtxForModel(TestModel, {
|
||||
where: {id: existingInstance.id},
|
||||
data: {
|
||||
id: existingInstance.id,
|
||||
|
@ -3525,7 +3524,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
{id: 'new-id', name: 'a name'},
|
||||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
var expectedContext = aCtxForModel(TestModel, {});
|
||||
const expectedContext = aCtxForModel(TestModel, {});
|
||||
|
||||
if (dataSource.connector.upsertWithWhere) {
|
||||
expectedContext.data = {id: 'new-id', name: 'a name'};
|
||||
|
@ -3607,7 +3606,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
|
||||
var expectedContext = aCtxForModel(TestModel, {
|
||||
const expectedContext = aCtxForModel(TestModel, {
|
||||
data: {id: 'new-id', name: 'a name'},
|
||||
currentInstance: {
|
||||
id: 'new-id',
|
||||
|
@ -3633,7 +3632,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
{id: existingInstance.id, name: 'updated name'},
|
||||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
var expectedContext = aCtxForModel(TestModel, {
|
||||
const expectedContext = aCtxForModel(TestModel, {
|
||||
where: {id: existingInstance.id},
|
||||
data: {
|
||||
id: existingInstance.id,
|
||||
|
@ -3675,7 +3674,7 @@ module.exports = function(dataSource, should, connectorCapabilities) {
|
|||
{id: existingInstance.id, name: 'updated name'},
|
||||
function(err, instance) {
|
||||
if (err) return done(err);
|
||||
var expectedContext = aCtxForModel(TestModel, {
|
||||
const expectedContext = aCtxForModel(TestModel, {
|
||||
data: {
|
||||
id: existingInstance.id,
|
||||
name: 'updated name',
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -7,15 +7,17 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false */
|
||||
var should = require('./init.js');
|
||||
const should = require('./init.js');
|
||||
|
||||
var db = getSchema(), slave = getSchema(), Model, SlaveModel;
|
||||
const db = getSchema();
|
||||
const slave = getSchema();
|
||||
let Model, SlaveModel;
|
||||
|
||||
describe('dataSource', function() {
|
||||
it('should define Model', function() {
|
||||
Model = db.define('Model');
|
||||
Model.dataSource.should.eql(db);
|
||||
var m = new Model;
|
||||
const m = new Model;
|
||||
m.getDataSource().should.eql(db);
|
||||
});
|
||||
|
||||
|
@ -23,7 +25,7 @@ describe('dataSource', function() {
|
|||
SlaveModel = slave.copyModel(Model);
|
||||
SlaveModel.dataSource.should.equal(slave);
|
||||
slave.should.not.equal(db);
|
||||
var sm = new SlaveModel;
|
||||
const sm = new SlaveModel;
|
||||
sm.should.be.instanceOf(Model);
|
||||
sm.getDataSource().should.not.equal(db);
|
||||
sm.getDataSource().should.equal(slave);
|
||||
|
@ -34,10 +36,10 @@ describe('dataSource', function() {
|
|||
});
|
||||
|
||||
it('should create transaction', function(done) {
|
||||
var tr = db.transaction();
|
||||
const tr = db.transaction();
|
||||
tr.connected.should.be.false;
|
||||
tr.connecting.should.be.false;
|
||||
var called = false;
|
||||
let called = false;
|
||||
tr.models.Model.create(Array(3), function() {
|
||||
called = true;
|
||||
});
|
||||
|
|
|
@ -7,9 +7,9 @@
|
|||
'use strict';
|
||||
|
||||
/* global getSchema:false */
|
||||
var should = require('./init.js');
|
||||
const should = require('./init.js');
|
||||
|
||||
var db, Railway, Station;
|
||||
let db, Railway, Station;
|
||||
|
||||
describe('scope', function() {
|
||||
before(function() {
|
||||
|
@ -161,7 +161,7 @@ describe('scope - order', function() {
|
|||
});
|
||||
|
||||
describe('scope - filtered count, updateAll and destroyAll', function() {
|
||||
var stationA;
|
||||
let stationA;
|
||||
|
||||
before(function() {
|
||||
db = getSchema();
|
||||
|
@ -284,13 +284,13 @@ describe('scope - filtered count, updateAll and destroyAll', function() {
|
|||
verify();
|
||||
});
|
||||
|
||||
var verify = function() {
|
||||
function verify() {
|
||||
Station.flagged.count(function(err, count) {
|
||||
if (err) return done(err);
|
||||
count.should.equal(2);
|
||||
done();
|
||||
});
|
||||
};
|
||||
}
|
||||
});
|
||||
|
||||
it('should allow filtered updateAll', function(done) {
|
||||
|
@ -300,13 +300,13 @@ describe('scope - filtered count, updateAll and destroyAll', function() {
|
|||
verify();
|
||||
});
|
||||
|
||||
var verify = function() {
|
||||
function verify() {
|
||||
Station.flagged.count(function(err, count) {
|
||||
if (err) return done(err);
|
||||
count.should.equal(2);
|
||||
done();
|
||||
});
|
||||
};
|
||||
}
|
||||
});
|
||||
|
||||
it('should allow filtered destroyAll', function(done) {
|
||||
|
@ -315,7 +315,7 @@ describe('scope - filtered count, updateAll and destroyAll', function() {
|
|||
verify();
|
||||
});
|
||||
|
||||
var verify = function() {
|
||||
function verify() {
|
||||
Station.ordered.count(function(err, count) {
|
||||
if (err) return done(err);
|
||||
count.should.equal(2);
|
||||
|
@ -325,12 +325,12 @@ describe('scope - filtered count, updateAll and destroyAll', function() {
|
|||
done();
|
||||
});
|
||||
});
|
||||
};
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
describe('scope - dynamic target class', function() {
|
||||
var Collection, Image, Video;
|
||||
let Collection, Image, Video;
|
||||
|
||||
before(function() {
|
||||
db = getSchema();
|
||||
|
@ -414,7 +414,7 @@ describe('scope - dynamic target class', function() {
|
|||
});
|
||||
|
||||
describe('scope - dynamic function', function() {
|
||||
var Item, seed = 0;
|
||||
let Item, seed = 0;
|
||||
|
||||
before(function() {
|
||||
db = getSchema();
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue