64 lines
1.5 KiB
JavaScript
64 lines
1.5 KiB
JavaScript
|
/* eslint-env node, mocha */
|
||
|
'use strict';
|
||
|
|
||
|
// Load the test base
|
||
|
const reload = require('require-reload')(require);
|
||
|
reload.emptyCache();
|
||
|
const testBase = reload('../base');
|
||
|
const expect = testBase.expect;
|
||
|
const testRunner = testBase.promiseTestRunner;
|
||
|
|
||
|
// Load the test config file
|
||
|
const config = testBase.config;
|
||
|
|
||
|
// Set up the query builder object
|
||
|
let nodeQuery = require('../../lib/NodeQuery')(config.sqlite3);
|
||
|
let qb = nodeQuery.getQuery();
|
||
|
|
||
|
suite('Sqlite3 adapter tests -', () => {
|
||
|
suiteSetup(done => {
|
||
|
// Set up the sqlite database
|
||
|
const createTest = 'CREATE TABLE IF NOT EXISTS "create_test" ("id" INTEGER PRIMARY KEY, "key" TEXT, "val" TEXT);';
|
||
|
const createJoin = 'CREATE TABLE IF NOT EXISTS "create_join" ("id" INTEGER PRIMARY KEY, "key" TEXT, "val" TEXT);';
|
||
|
|
||
|
qb.query(createTest)
|
||
|
.then(() => qb.query(createJoin))
|
||
|
.then(() => {
|
||
|
return done();
|
||
|
});
|
||
|
});
|
||
|
|
||
|
testRunner(qb);
|
||
|
test('Promise - Select with function and argument in WHERE clause', () => {
|
||
|
let promise = qb.select('id')
|
||
|
.from('create_test')
|
||
|
.where('id', 'ABS(-88)')
|
||
|
.get();
|
||
|
|
||
|
expect(promise).to.be.fulfilled;
|
||
|
});
|
||
|
test('Promise - Test Insert Batch', () => {
|
||
|
let data = [
|
||
|
{
|
||
|
id: 544,
|
||
|
key: 3,
|
||
|
val: Buffer.from('7')
|
||
|
}, {
|
||
|
id: 89,
|
||
|
key: 34,
|
||
|
val: Buffer.from('10 o\'clock')
|
||
|
}, {
|
||
|
id: 48,
|
||
|
key: 403,
|
||
|
val: Buffer.from('97')
|
||
|
}
|
||
|
];
|
||
|
|
||
|
let promise = qb.insertBatch('create_test', data);
|
||
|
expect(promise).to.be.fulfilled;
|
||
|
});
|
||
|
suiteTeardown(() => {
|
||
|
qb.end();
|
||
|
});
|
||
|
});
|