forked from brianc/node-sql
-
Notifications
You must be signed in to change notification settings - Fork 0
/
function-tests.js
93 lines (72 loc) · 3.49 KB
/
function-tests.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
'use strict';
var assert = require('assert');
var sql = require(__dirname + '/../lib').setDialect('postgres');
var user = sql.define({
name: 'user',
columns: [
{name: 'id'},
{name:'email'},
{name: 'name'},
{name: 'age', property: 'howOld'}
]
});
suite('function', function() {
test('alias function call', function() {
var upper = sql.functions.UPPER;
var aliasedUpper = upper(user.email).as('upperAlias').toQuery();
assert.equal(aliasedUpper.text, 'UPPER("user"."email") AS "upperAlias"');
});
test('function call on aliased column', function() {
var round = sql.functions.ROUND;
var aliasedRound = round(user.howOld, 2).toQuery();
assert.equal(aliasedRound.text, 'ROUND("user"."age", $1)');
assert.equal(aliasedRound.values[0], 2);
});
test('creating function call works', function() {
var upper = sql.functionCallCreator('UPPER');
var functionCall = upper('hello', 'world').toQuery();
assert.equal(functionCall.text, 'UPPER($1, $2)');
assert.equal(functionCall.values[0], 'hello');
assert.equal(functionCall.values[1], 'world');
});
test('creating function call on columns works', function() {
var upper = sql.functionCallCreator('UPPER');
var functionCall = upper(user.id, user.email).toQuery();
assert.equal(functionCall.text, 'UPPER("user"."id", "user"."email")');
assert.equal(functionCall.values.length, 0);
});
test('function call inside select works', function() {
var upper = sql.functionCallCreator('UPPER');
var query = sql.select(upper(user.id, user.email)).from(user).where(user.email.equals('[email protected]')).toQuery();
assert.equal(query.text, 'SELECT UPPER("user"."id", "user"."email") FROM "user" WHERE ("user"."email" = $1)');
assert.equal(query.values[0], '[email protected]');
});
test('standard aggregate functions with having clause', function() {
var count = sql.functions.COUNT;
var distinct = sql.functions.DISTINCT;
var distinctEmailCount = count(distinct(user.email));
var query = user.select(user.id, distinctEmailCount).group(user.id).having(distinctEmailCount.gt(100)).toQuery();
assert.equal(query.text, 'SELECT "user"."id", COUNT(DISTINCT("user"."email")) FROM "user" GROUP BY "user"."id" HAVING (COUNT(DISTINCT("user"."email")) > $1)');
assert.equal(query.values[0], 100);
});
test('custom and standard functions behave the same', function() {
var standardUpper = sql.functions.UPPER;
var customUpper = sql.functionCallCreator('UPPER');
var standardQuery = user.select(standardUpper(user.name)).toQuery();
var customQuery = user.select(customUpper(user.name)).toQuery();
var expectedQuery = 'SELECT UPPER("user"."name") FROM "user"';
assert.equal(standardQuery.text, expectedQuery);
assert.equal(customQuery.text, expectedQuery);
});
test('combine function with operations', function() {
var f = sql.functions;
var query = user.select(f.AVG(f.DISTINCT(f.COUNT(user.id).plus(f.MAX(user.id))).minus(f.MIN(user.id))).multiply(100)).toQuery();
assert.equal(query.text, 'SELECT (AVG((DISTINCT((COUNT("user"."id") + MAX("user"."id"))) - MIN("user"."id"))) * $1) FROM "user"');
assert.equal(query.values[0], 100);
});
test('use custom function', function() {
var query = user.select(sql.function('PHRASE_TO_TSQUERY')('simple', user.name)).toQuery();
assert.equal(query.text, 'SELECT PHRASE_TO_TSQUERY($1, "user"."name") FROM "user"');
assert.equal(query.values[0], 'simple');
});
});