You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
122 lines
4.6 KiB
122 lines
4.6 KiB
/* global describe, it */
|
|
var assert = require('assert');
|
|
var knex = require('knex')({});
|
|
var knexJsonQuery = require('./');
|
|
require('simple-mocha');
|
|
|
|
|
|
var conditions= [
|
|
/* -----------Tests for and conditoins---------- */
|
|
{
|
|
name: 'handle simple and conditions',
|
|
input:{ f1: 10, f2: 20, f3: 30 },
|
|
output: 'select * where ("f1" = 10 and "f2" = 20 and "f3" = 30)'
|
|
},
|
|
{
|
|
name: 'handle simple and conditions',
|
|
input:{"firstName":[["LIKE","H%"],["OR","hemanth"]]},
|
|
output: 'select * where (("firstName" LIKE \'H%\' or "firstName" = \'hemanth\'))'
|
|
},
|
|
{
|
|
name: 'handle regex query: MongoQuery',
|
|
input:{"firstName":{ $regex: "H*" }},
|
|
output: 'select * where ("firstName" REGEXP \'H*\')'
|
|
},
|
|
{
|
|
name: 'handle regex query and should omit $options: MongoQuery',
|
|
input:{"firstName":{ $regex: "H*", $options: 'i' }},
|
|
output: 'select * where ("firstName" REGEXP \'H*\')'
|
|
},
|
|
{
|
|
name: 'handle simple and conditions',
|
|
input:{ f1: [[ 'A' ],['LIKE', 'B' ]], f2: 20, f3: 30 },
|
|
output: 'select * where (("f1" = \'A\' and "f1" LIKE \'B\') and "f2" = 20 and "f3" = 30)'
|
|
},
|
|
{
|
|
name: 'handle basic operators :: greater-than less-than',
|
|
input:{ f1: ['>', 10], f2: [ '<', 20 ], f3: 30 },
|
|
output: 'select * where ("f1" > 10 and "f2" < 20 and "f3" = 30)'
|
|
},
|
|
{
|
|
name: 'handle basic operators :: in',
|
|
input:{ f1: ['IN', [10,50]], f2: [ '<', 20 ], f3: 30 },
|
|
output: 'select * where ("f1" in (10, 50) and "f2" < 20 and "f3" = 30)'
|
|
},
|
|
{
|
|
name: 'handle multiple conditions in one field',
|
|
input:{ f1: [ [ 'LIKE', 20 ], 21, [ 'AND_BETWEEN', [ 40, 45 ] ] ], f2: 20, f3: 30 },
|
|
output: 'select * where (("f1" LIKE 20 and "f1" = 21 and "f1" between 40 and 45) and "f2" = 20 and "f3" = 30)'
|
|
},
|
|
{
|
|
name: 'handle simple and condition with like statement',
|
|
input:{ f1: [ 'LIKE', 20 ], f2: 20, f3: 30 },
|
|
output: 'select * where ("f1" LIKE 20 and "f2" = 20 and "f3" = 30)'
|
|
},
|
|
{
|
|
name: 'handle simple and condition with between statement',
|
|
input:{ f1: ['BETWEEN', [50, 60] ], f2: 20, f3: 30 },
|
|
output: 'select * where ("f1" between 50 and 60 and "f2" = 20 and "f3" = 30)'
|
|
},
|
|
{
|
|
name: 'handle simple and condition with in statement',
|
|
input:{ f1: ['IN', [ 50, 60 ] ], f2: 20, f3: 30 },
|
|
output: 'select * where ("f1" in (50, 60) and "f2" = 20 and "f3" = 30)'
|
|
},
|
|
/* -----------Tests for or conditoins---------- */
|
|
{
|
|
name: 'handle simple or condition',
|
|
input:[ { f1: 10 }, { f2: 20 }, { f3: 30 } ],
|
|
output: 'select * where (("f1" = 10) or ("f2" = 20) or ("f3" = 30))'
|
|
},
|
|
{
|
|
name: 'handle multiple conditions in one field',
|
|
input:{ f1: [ [ 'LIKE', 20 ], [ 'OR', 21 ], [ 'OR_BETWEEN', [ 40, 45 ] ] ], f2: 20, f3: 30 },
|
|
output: 'select * where (("f1" LIKE 20 or "f1" = 21 or "f1" between 40 and 45) and "f2" = 20 and "f3" = 30)'
|
|
},
|
|
{
|
|
name: 'handle multiple conditions in one field: MongoQuery',
|
|
input:{ f1: { $like: 20, $or: 21, $or_between: [ 40, 45 ] }, f2: 20, f3: 30 },
|
|
output: 'select * where (("f1" LIKE 20 or "f1" = 21 or "f1" between 40 and 45) and "f2" = 20 and "f3" = 30)'
|
|
},
|
|
{
|
|
name: 'handle simple or condition with like statement',
|
|
input:[ { f1: ['LIKE',10] }, { f2: 20 }, { f3: 30 } ],
|
|
output: 'select * where (("f1" LIKE 10) or ("f2" = 20) or ("f3" = 30))'
|
|
},
|
|
{
|
|
name: 'handle simple or condition with like statement: MongoQuery',
|
|
input:[ { f1: { $like: 10 } }, { f2: 20 }, { f3: 30 } ],
|
|
output: 'select * where (("f1" LIKE 10) or ("f2" = 20) or ("f3" = 30))'
|
|
},
|
|
{
|
|
name: 'handle simple or condition with between statement',
|
|
input:[ { f1: ['BETWEEN',[50, 60] ] }, { f2: 20 }, { f3: 30 } ],
|
|
output: 'select * where (("f1" between 50 and 60) or ("f2" = 20) or ("f3" = 30))'
|
|
},
|
|
{
|
|
name: 'handle simple or condition with between statement :MongoQuery',
|
|
input:[ { f1: { $between:[50, 60] } }, { f2: 20 }, { f3: 30 } ],
|
|
output: 'select * where (("f1" between 50 and 60) or ("f2" = 20) or ("f3" = 30))'
|
|
},
|
|
{
|
|
name: 'handle simple or condition with in statement',
|
|
input:[ { f1: ['IN',[ 50, 60 ]] }, { f2: 20 }, { f3: 30 } ],
|
|
output: 'select * where (("f1" in (50, 60)) or ("f2" = 20) or ("f3" = 30))'
|
|
},
|
|
{
|
|
name: 'handle simple or condition with in statement :MongoQuery',
|
|
input:[ { f1: {$in:[ 50, 60 ]} }, { f2: 20 }, { f3: 30 } ],
|
|
output: 'select * where (("f1" in (50, 60)) or ("f2" = 20) or ("f3" = 30))'
|
|
},
|
|
];
|
|
|
|
|
|
describe('SQL query generation from json query', function(){
|
|
conditions.forEach(function(v){
|
|
it( 'should ' + v.name , function(){
|
|
var expectedOut = knex.where( knexJsonQuery(v.input) ) + '';
|
|
assert.equal( v.output, expectedOut );
|
|
});
|
|
});
|
|
});
|
|
|
|
|