2015-12-07 12:03:42 -05:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
// Load the test base
|
2016-01-26 19:29:12 -05:00
|
|
|
const reload = require('require-reload')(require);
|
|
|
|
reload.emptyCache();
|
2016-03-14 16:07:39 -04:00
|
|
|
const fs = require('fs');
|
2016-01-26 19:29:12 -05:00
|
|
|
const testBase = reload('../base');
|
2016-03-11 10:41:04 -05:00
|
|
|
const expect = testBase.expect;
|
|
|
|
const promiseTestRunner = testBase.promiseTestRunner;
|
|
|
|
const testRunner = testBase.testRunner;
|
2016-01-26 19:29:12 -05:00
|
|
|
let tests = reload('../base/tests');
|
2015-12-07 12:03:42 -05:00
|
|
|
|
|
|
|
// Load the test config file
|
2016-03-16 08:51:05 -04:00
|
|
|
const config = testBase.config;
|
2015-12-07 12:03:42 -05:00
|
|
|
|
2016-03-11 10:41:04 -05:00
|
|
|
// Set up the query builder object
|
|
|
|
let nodeQuery = require('../../lib/NodeQuery')(config.dblite);
|
|
|
|
let qb = nodeQuery.getQuery();
|
2015-12-07 12:03:42 -05:00
|
|
|
|
2016-03-11 10:41:04 -05:00
|
|
|
suite('Dblite adapter tests -', () => {
|
|
|
|
suiteSetup(done => {
|
|
|
|
// Set up the sqlite database
|
2016-03-14 16:07:39 -04:00
|
|
|
fs.readFile(`${__dirname}/../sql/sqlite.sql`, 'utf8', (err, data) => {
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
2015-12-07 12:03:42 -05:00
|
|
|
|
2016-03-14 16:07:39 -04:00
|
|
|
qb.query(data, () => done());
|
|
|
|
});
|
2016-03-11 10:41:04 -05:00
|
|
|
});
|
2016-01-26 19:29:12 -05:00
|
|
|
|
2016-03-11 10:41:04 -05:00
|
|
|
/*---------------------------------------------------------------------------
|
|
|
|
Callback Tests
|
|
|
|
---------------------------------------------------------------------------*/
|
2016-01-26 19:29:12 -05:00
|
|
|
|
2016-03-15 15:37:24 -04:00
|
|
|
testRunner(qb, (err, result, done) => {
|
2016-03-11 10:41:04 -05:00
|
|
|
expect(err).is.not.ok;
|
2016-03-15 15:37:24 -04:00
|
|
|
expect(result.rows).is.an('array');
|
|
|
|
expect(result.columns).is.an('array');
|
|
|
|
expect(result.rowCount()).to.not.be.undefined;
|
|
|
|
expect(result.columnCount()).to.not.be.undefined;
|
2016-03-11 10:41:04 -05:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
test('Callback - Select with function and argument in WHERE clause', done => {
|
|
|
|
qb.select('id')
|
|
|
|
.from('create_test')
|
|
|
|
.where('id', 'ABS(-88)')
|
|
|
|
.get((err, rows) => {
|
2016-01-26 19:29:12 -05:00
|
|
|
expect(err).is.not.ok;
|
|
|
|
return done();
|
2015-12-07 14:33:48 -05:00
|
|
|
});
|
2016-03-11 10:41:04 -05:00
|
|
|
});
|
|
|
|
test('Callback - Test Insert Batch', done => {
|
|
|
|
let data = [
|
|
|
|
{
|
|
|
|
id: 544,
|
|
|
|
key: 3,
|
|
|
|
val: new Buffer('7'),
|
|
|
|
}, {
|
|
|
|
id: 89,
|
|
|
|
key: 34,
|
|
|
|
val: new Buffer('10 o\'clock'),
|
|
|
|
}, {
|
|
|
|
id: 48,
|
|
|
|
key: 403,
|
|
|
|
val: new Buffer('97'),
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
2016-03-15 15:37:24 -04:00
|
|
|
qb.insertBatch('create_test', data, err => {
|
2016-03-11 10:41:04 -05:00
|
|
|
expect(err).is.not.ok;
|
|
|
|
return done();
|
2015-12-07 12:03:42 -05:00
|
|
|
});
|
2016-03-11 10:41:04 -05:00
|
|
|
});
|
2016-01-26 19:29:12 -05:00
|
|
|
|
2016-03-11 10:41:04 -05:00
|
|
|
/*---------------------------------------------------------------------------
|
|
|
|
Promise Tests
|
|
|
|
---------------------------------------------------------------------------*/
|
|
|
|
promiseTestRunner(qb);
|
|
|
|
test('Promise - Select with function and argument in WHERE clause', () => {
|
|
|
|
let promise = qb.select('id')
|
|
|
|
.from('create_test')
|
|
|
|
.where('id', 'ABS(-88)')
|
|
|
|
.get();
|
2016-01-26 19:29:12 -05:00
|
|
|
|
2016-03-11 10:41:04 -05:00
|
|
|
expect(promise).to.be.fulfilled;
|
2015-12-07 12:03:42 -05:00
|
|
|
});
|
2016-03-11 16:32:38 -05:00
|
|
|
test('Promise - Test Insert Batch', () => {
|
|
|
|
let data = [
|
|
|
|
{
|
|
|
|
id: 544,
|
|
|
|
key: 3,
|
|
|
|
val: new Buffer('7'),
|
|
|
|
}, {
|
|
|
|
id: 89,
|
|
|
|
key: 34,
|
|
|
|
val: new Buffer('10 o\'clock'),
|
|
|
|
}, {
|
|
|
|
id: 48,
|
|
|
|
key: 403,
|
|
|
|
val: new Buffer('97'),
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
let promise = qb.query(qb.driver.truncate('create_test')).then(
|
|
|
|
() => qb.insertBatch('create_test', data)
|
|
|
|
);
|
|
|
|
expect(promise).to.be.fulfilled;
|
|
|
|
});
|
|
|
|
suiteTeardown(() => {
|
|
|
|
qb.end();
|
|
|
|
});
|
2016-03-11 10:41:04 -05:00
|
|
|
});
|