Merge pull request #390 from strongloop/refactor/juggler-test
feat: run shared tests
This commit is contained in:
commit
f556b7cf99
|
@ -0,0 +1 @@
|
||||||
|
**/node_modules/
|
|
@ -1,6 +1,5 @@
|
||||||
language: node_js
|
language: node_js
|
||||||
node_js:
|
node_js:
|
||||||
- "6"
|
|
||||||
- "8"
|
- "8"
|
||||||
- "10"
|
- "10"
|
||||||
# Xenial build environment comes with MySQL 5.7
|
# Xenial build environment comes with MySQL 5.7
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
"name": "juggler-v3",
|
||||||
|
"version": "3.0.0",
|
||||||
|
"dependencies": {
|
||||||
|
"loopback-datasource-juggler":"3.x",
|
||||||
|
"should": "^8.4.0"
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,31 @@
|
||||||
|
// Copyright IBM Corp. 2019. All Rights Reserved.
|
||||||
|
// Node module: loopback-connector-mysql
|
||||||
|
// This file is licensed under the Artistic License 2.0.
|
||||||
|
// License text available at https://opensource.org/licenses/Artistic-2.0
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
const should = require('should');
|
||||||
|
const juggler = require('loopback-datasource-juggler');
|
||||||
|
const name = require('./package.json').name;
|
||||||
|
|
||||||
|
require('../../test/init');
|
||||||
|
|
||||||
|
describe(name, function() {
|
||||||
|
before(function() {
|
||||||
|
return global.resetDataSourceClass(juggler.DataSource);
|
||||||
|
});
|
||||||
|
|
||||||
|
after(function() {
|
||||||
|
return global.resetDataSourceClass();
|
||||||
|
});
|
||||||
|
|
||||||
|
require('loopback-datasource-juggler/test/common.batch.js');
|
||||||
|
require('loopback-datasource-juggler/test/include.test.js');
|
||||||
|
|
||||||
|
// === Operation hooks ==== //
|
||||||
|
|
||||||
|
const suite = require('loopback-datasource-juggler/test/persistence-hooks.suite.js');
|
||||||
|
const customConfig = Object.assign({}, global.config);
|
||||||
|
suite(global.getDataSource(customConfig, juggler.DataSource), should, {replaceOrCreateReportsNewInstance: false});
|
||||||
|
});
|
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
"name": "juggler-v4",
|
||||||
|
"version": "4.0.0",
|
||||||
|
"dependencies": {
|
||||||
|
"loopback-datasource-juggler":"4.x",
|
||||||
|
"should": "^13.2.3"
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,32 @@
|
||||||
|
// Copyright IBM Corp. 2019. All Rights Reserved.
|
||||||
|
// Node module: loopback-connector-mysql
|
||||||
|
// This file is licensed under the Artistic License 2.0.
|
||||||
|
// License text available at https://opensource.org/licenses/Artistic-2.0
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
const semver = require('semver');
|
||||||
|
const should = require('should');
|
||||||
|
const juggler = require('loopback-datasource-juggler');
|
||||||
|
const name = require('./package.json').name;
|
||||||
|
|
||||||
|
require('../../test/init');
|
||||||
|
|
||||||
|
describe(name, function() {
|
||||||
|
before(function() {
|
||||||
|
return global.resetDataSourceClass(juggler.DataSource);
|
||||||
|
});
|
||||||
|
|
||||||
|
after(function() {
|
||||||
|
return global.resetDataSourceClass();
|
||||||
|
});
|
||||||
|
|
||||||
|
require('loopback-datasource-juggler/test/common.batch.js');
|
||||||
|
require('loopback-datasource-juggler/test/include.test.js');
|
||||||
|
|
||||||
|
// === Operation hooks ==== //
|
||||||
|
|
||||||
|
const suite = require('loopback-datasource-juggler/test/persistence-hooks.suite.js');
|
||||||
|
const customConfig = Object.assign({}, global.config);
|
||||||
|
suite(global.getDataSource(customConfig, juggler.DataSource), should, {replaceOrCreateReportsNewInstance: false});
|
||||||
|
});
|
10
lib/mysql.js
10
lib/mysql.js
|
@ -444,6 +444,12 @@ MySQL.prototype.fromColumnValue = function(prop, val) {
|
||||||
lat: val.y,
|
lat: val.y,
|
||||||
};
|
};
|
||||||
break;
|
break;
|
||||||
|
case 'ObjectID':
|
||||||
|
val = new prop.type(val);
|
||||||
|
break;
|
||||||
|
case 'Buffer':
|
||||||
|
val = prop.type(val);
|
||||||
|
break;
|
||||||
case 'List':
|
case 'List':
|
||||||
case 'Array':
|
case 'Array':
|
||||||
case 'Object':
|
case 'Object':
|
||||||
|
@ -453,10 +459,6 @@ MySQL.prototype.fromColumnValue = function(prop, val) {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (!Array.isArray(prop.type) && !prop.type.modelName) {
|
|
||||||
// Do not convert array and model types
|
|
||||||
val = prop.type(val);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,13 +3,13 @@
|
||||||
"version": "5.4.1",
|
"version": "5.4.1",
|
||||||
"description": "MySQL connector for loopback-datasource-juggler",
|
"description": "MySQL connector for loopback-datasource-juggler",
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=6"
|
"node": ">=8"
|
||||||
},
|
},
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"pretest": "node pretest.js",
|
"pretest": "node pretest.js",
|
||||||
"lint": "eslint .",
|
"lint": "eslint .",
|
||||||
"test": "mocha --timeout 10000 --require test/init.js test/*.js",
|
"test": "mocha --timeout 10000 test/*.test.js node_modules/juggler-v3/test.js node_modules/juggler-v4/test.js",
|
||||||
"posttest": "npm run lint"
|
"posttest": "npm run lint"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
@ -24,7 +24,9 @@
|
||||||
"bluebird": "~2.9.10",
|
"bluebird": "~2.9.10",
|
||||||
"eslint": "^4.3.0",
|
"eslint": "^4.3.0",
|
||||||
"eslint-config-loopback": "^8.0.0",
|
"eslint-config-loopback": "^8.0.0",
|
||||||
"loopback-datasource-juggler": "^3.0.0",
|
"juggler-v3": "file:./deps/juggler-v3",
|
||||||
|
"juggler-v4": "file:./deps/juggler-v4",
|
||||||
|
"loopback-datasource-juggler": "^3.0.0 || ^4.0.0",
|
||||||
"mocha": "^2.1.0",
|
"mocha": "^2.1.0",
|
||||||
"rc": "^1.0.0",
|
"rc": "^1.0.0",
|
||||||
"should": "^8.0.2",
|
"should": "^8.0.2",
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
require('./init.js');
|
require('./init.js');
|
||||||
var assert = require('assert');
|
var assert = require('assert');
|
||||||
var _ = require('lodash');
|
var _ = require('lodash');
|
||||||
|
const GeoPoint = require('loopback-datasource-juggler').GeoPoint;
|
||||||
|
|
||||||
var db, BlobModel, EnumModel, ANIMAL_ENUM, City, Account;
|
var db, BlobModel, EnumModel, ANIMAL_ENUM, City, Account;
|
||||||
|
|
||||||
|
@ -206,7 +207,8 @@ describe('MySQL specific datatypes', function() {
|
||||||
var xcor, ycor;
|
var xcor, ycor;
|
||||||
City.create(city1, function(err, res) {
|
City.create(city1, function(err, res) {
|
||||||
if (err) return done(err);
|
if (err) return done(err);
|
||||||
res.loc.should.deepEqual(city1.loc);
|
const loc_in_geo_type = new GeoPoint(city1.loc);
|
||||||
|
res.loc.should.deepEqual(loc_in_geo_type);
|
||||||
res.name.should.equal(city1.name);
|
res.name.should.equal(city1.name);
|
||||||
var sqlStmt = 'select ST_X(loc),ST_Y(loc) from City where id=1';
|
var sqlStmt = 'select ST_X(loc),ST_Y(loc) from City where id=1';
|
||||||
db.connector.execute(sqlStmt, function(err, res) {
|
db.connector.execute(sqlStmt, function(err, res) {
|
||||||
|
|
|
@ -1,14 +0,0 @@
|
||||||
// Copyright IBM Corp. 2013,2016. All Rights Reserved.
|
|
||||||
// Node module: loopback-connector-mysql
|
|
||||||
// This file is licensed under the MIT License.
|
|
||||||
// License text available at https://opensource.org/licenses/MIT
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
describe('mysql imported features', function() {
|
|
||||||
before(function() {
|
|
||||||
require('./init.js');
|
|
||||||
});
|
|
||||||
|
|
||||||
require('loopback-datasource-juggler/test/common.batch.js');
|
|
||||||
require('loopback-datasource-juggler/test/include.test.js');
|
|
||||||
});
|
|
20
test/init.js
20
test/init.js
|
@ -6,8 +6,8 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
module.exports = require('should');
|
module.exports = require('should');
|
||||||
|
const juggler = require('loopback-datasource-juggler');
|
||||||
var DataSource = require('loopback-datasource-juggler').DataSource;
|
let DataSource = juggler.DataSource;
|
||||||
|
|
||||||
var config = require('rc')('loopback', {test: {mysql: {}}}).test.mysql;
|
var config = require('rc')('loopback', {test: {mysql: {}}}).test.mysql;
|
||||||
global.getConfig = function(options) {
|
global.getConfig = function(options) {
|
||||||
|
@ -28,11 +28,23 @@ global.getConfig = function(options) {
|
||||||
return dbConf;
|
return dbConf;
|
||||||
};
|
};
|
||||||
|
|
||||||
global.getDataSource = global.getSchema = function(options) {
|
let db;
|
||||||
var db = new DataSource(require('../'), global.getConfig(options));
|
global.getDataSource = global.getSchema = function(options, customClass) {
|
||||||
|
const ctor = customClass || DataSource;
|
||||||
|
db = new ctor(require('../'), global.getConfig(options));
|
||||||
|
db.log = function(a) {
|
||||||
|
console.log(a);
|
||||||
|
};
|
||||||
return db;
|
return db;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
global.resetDataSourceClass = function(ctor) {
|
||||||
|
DataSource = ctor || juggler.DataSource;
|
||||||
|
const promise = db ? db.disconnect() : Promise.resolve();
|
||||||
|
db = undefined;
|
||||||
|
return promise;
|
||||||
|
};
|
||||||
|
|
||||||
global.connectorCapabilities = {
|
global.connectorCapabilities = {
|
||||||
ilike: false,
|
ilike: false,
|
||||||
nilike: false,
|
nilike: false,
|
||||||
|
|
|
@ -639,7 +639,9 @@ var getFields = function(model, cb) {
|
||||||
res.forEach(function(field) {
|
res.forEach(function(field) {
|
||||||
fields[field.Field] = field;
|
fields[field.Field] = field;
|
||||||
});
|
});
|
||||||
cb(err, fields);
|
// The returned data are in arrays of type `RowDataPacket`,
|
||||||
|
// which are not objects.
|
||||||
|
cb(err, JSON.parse(JSON.stringify(fields)));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
var async = require('async');
|
var async = require('async');
|
||||||
var should = require('./init.js');
|
var should = require('./init.js');
|
||||||
var sinon = require('sinon');
|
var sinon = require('sinon');
|
||||||
|
const List = require('loopback-datasource-juggler/lib/list');
|
||||||
|
|
||||||
var Post, PostWithStringId, PostWithUniqueTitle, PostWithNumId, Student, db;
|
var Post, PostWithStringId, PostWithUniqueTitle, PostWithNumId, Student, db;
|
||||||
|
|
||||||
|
@ -88,7 +89,7 @@ describe('mysql', function() {
|
||||||
|
|
||||||
p.content.should.be.equal(post.content);
|
p.content.should.be.equal(post.content);
|
||||||
p.title.should.be.equal('a');
|
p.title.should.be.equal('a');
|
||||||
p.comments.should.eql(['1', '2']);
|
p.comments.should.eql(new List(['1', '2']));
|
||||||
p.history.should.eql({a: 1, b: 'b'});
|
p.history.should.eql({a: 1, b: 'b'});
|
||||||
|
|
||||||
done();
|
done();
|
||||||
|
|
|
@ -1,12 +0,0 @@
|
||||||
// Copyright IBM Corp. 2015,2017. All Rights Reserved.
|
|
||||||
// Node module: loopback-connector-mysql
|
|
||||||
// This file is licensed under the MIT License.
|
|
||||||
// License text available at https://opensource.org/licenses/MIT
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
var should = require('./init');
|
|
||||||
var suite = require('loopback-datasource-juggler/test/persistence-hooks.suite.js');
|
|
||||||
|
|
||||||
suite(global.getDataSource(), should, {
|
|
||||||
replaceOrCreateReportsNewInstance: false,
|
|
||||||
});
|
|
Loading…
Reference in New Issue