waterline-utils
Version:
Various utilities for working with Waterline queries and adapters.
93 lines (86 loc) • 2.27 kB
JavaScript
var Analyzer = require('../../../index').query.analyzer;
var tokenize = require('../../support/tokenize');
var assert = require('assert');
describe('Analyzer ::', function() {
describe('WHERE NOT IN statements', function() {
it('should generate a valid group', function() {
var tokens = tokenize({
select: ['name'],
from: 'users',
where: {
and: [
{
id: {
nin: [1, 2, 3]
}
}
]
}
});
var result = Analyzer(tokens);
assert.deepEqual(result, [
[
{ type: 'IDENTIFIER', value: 'SELECT' },
{ type: 'VALUE', value: 'name' }
],
[
{ type: 'IDENTIFIER', value: 'FROM' },
{ type: 'VALUE', value: 'users' }
],
[
{ type: 'IDENTIFIER', value: 'WHERE' },
{ type: 'CONDITION', value: 'AND' },
[
{ type: 'KEY', value: 'id' },
{ type: 'CONDITION', value: 'NOTIN' },
{ type: 'VALUE', value: [1, 2, 3] }
]
]
]);
});
it('should generate a valid group when in an OR statement', function() {
var tokens = tokenize({
select: ['name'],
from: 'users',
where: {
or: [
{
id: {
nin: [1, 2, 3]
}
},
{
id: {
nin: [4, 5, 6]
}
}
]
}
});
var result = Analyzer(tokens);
assert.deepEqual(result, [
[
{ type: 'IDENTIFIER', value: 'SELECT' },
{ type: 'VALUE', value: 'name' }
],
[
{ type: 'IDENTIFIER', value: 'FROM' },
{ type: 'VALUE', value: 'users' }
],
[
{ type: 'IDENTIFIER', value: 'WHERE' },
[
{ type: 'KEY', value: 'id' },
{ type: 'CONDITION', value: 'NOTIN' },
{ type: 'VALUE', value: [1, 2, 3] }
],
[
{ type: 'KEY', value: 'id' },
{ type: 'CONDITION', value: 'NOTIN' },
{ type: 'VALUE', value: [4, 5, 6] }
]
]
]);
});
});
});