pogi 2.11.1 → 3.0.0-beta
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.vscode/launch.json +47 -15
- package/jest.config.js +23 -0
- package/lib/bin/generateInterface.js +2 -2
- package/lib/bin/generateInterface.js.map +1 -1
- package/lib/pgConverters.js +1 -1
- package/lib/pgConverters.js.map +1 -1
- package/lib/pgDb.js +5 -5
- package/lib/pgDb.js.map +1 -1
- package/lib/pgTable.js +7 -7
- package/lib/pgTable.js.map +1 -1
- package/lib/pgUtils.d.ts +3 -1
- package/lib/pgUtils.js +61 -23
- package/lib/pgUtils.js.map +1 -1
- package/lib/src/bin/generateInterface.d.ts +1 -0
- package/lib/src/bin/generateInterface.js +53 -0
- package/lib/src/bin/generateInterface.js.map +1 -0
- package/lib/src/connectionOptions.d.ts +34 -0
- package/lib/src/connectionOptions.js +3 -0
- package/lib/src/connectionOptions.js.map +1 -0
- package/lib/src/index.d.ts +6 -0
- package/lib/src/index.js +12 -0
- package/lib/src/index.js.map +1 -0
- package/lib/src/pgConverters.d.ts +9 -0
- package/lib/src/pgConverters.js +71 -0
- package/lib/src/pgConverters.js.map +1 -0
- package/lib/src/pgConverters.test.d.ts +1 -0
- package/lib/src/pgConverters.test.js +13 -0
- package/lib/src/pgConverters.test.js.map +1 -0
- package/lib/src/pgDb.d.ts +79 -0
- package/lib/src/pgDb.js +764 -0
- package/lib/src/pgDb.js.map +1 -0
- package/lib/src/pgDb.test.d.ts +1 -0
- package/lib/src/pgDb.test.js +1126 -0
- package/lib/src/pgDb.test.js.map +1 -0
- package/lib/src/pgDbInterface.js +11 -0
- package/lib/src/pgDbInterface.js.map +1 -0
- package/lib/src/pgDbLogger.d.ts +5 -0
- package/lib/src/pgDbLogger.js +3 -0
- package/lib/src/pgDbLogger.js.map +1 -0
- package/lib/src/pgDbOperators.d.ts +113 -0
- package/lib/src/pgDbOperators.js +41 -0
- package/lib/src/pgDbOperators.js.map +1 -0
- package/lib/src/pgDbOperators.test.d.ts +1 -0
- package/lib/src/pgDbOperators.test.js +313 -0
- package/lib/src/pgDbOperators.test.js.map +1 -0
- package/lib/src/pgSchema.d.ts +17 -0
- package/lib/src/pgSchema.js +16 -0
- package/lib/src/pgSchema.js.map +1 -0
- package/lib/src/pgSchemaInterface.d.ts +12 -0
- package/lib/src/pgSchemaInterface.js +3 -0
- package/lib/src/pgSchemaInterface.js.map +1 -0
- package/lib/src/pgTable.d.ts +105 -0
- package/lib/src/pgTable.js +322 -0
- package/lib/src/pgTable.js.map +1 -0
- package/lib/src/pgTableInterface.d.ts +102 -0
- package/lib/src/pgTableInterface.js +4 -0
- package/lib/src/pgTableInterface.js.map +1 -0
- package/lib/src/pgUtils.d.ts +41 -0
- package/lib/src/pgUtils.js +282 -0
- package/lib/src/pgUtils.js.map +1 -0
- package/lib/src/queryAble.d.ts +40 -0
- package/lib/src/queryAble.js +338 -0
- package/lib/src/queryAble.js.map +1 -0
- package/lib/src/queryAbleInterface.d.ts +59 -0
- package/lib/src/queryAbleInterface.js +7 -0
- package/lib/src/queryAbleInterface.js.map +1 -0
- package/lib/src/queryWhere.d.ts +8 -0
- package/lib/src/queryWhere.js +245 -0
- package/lib/src/queryWhere.js.map +1 -0
- package/package.json +20 -14
- package/src/bin/generateInterface.ts +2 -2
- package/src/connectionOptions.ts +46 -13
- package/src/index.d.ts +7 -0
- package/src/pgConverters.test.ts +10 -0
- package/src/pgConverters.ts +30 -26
- package/src/{test/pgDbSpec.ts → pgDb.test.ts} +170 -185
- package/src/pgDb.ts +91 -88
- package/src/pgDbInterface.ts +57 -0
- package/src/pgDbOperators.test.ts +478 -0
- package/src/pgDbOperators.ts +45 -22
- package/src/pgSchema.ts +10 -9
- package/src/pgSchemaInterface.ts +12 -0
- package/src/pgTable.ts +65 -97
- package/src/pgTableInterface.ts +131 -0
- package/src/pgUtils.ts +156 -42
- package/src/queryAble.ts +61 -118
- package/src/queryAbleInterface.ts +108 -0
- package/src/queryWhere.ts +42 -43
- package/{spec/resources → src/test}/init.sql +0 -0
- package/{spec/resources → src/test}/throw_exception.sql +0 -0
- package/{spec/resources → src/test}/tricky.sql +0 -0
- package/{src/tsconfig.json → tsconfig.json} +8 -6
- package/spec/run.js +0 -5
- package/spec/support/jasmine.json +0 -9
- package/src/test/pgDbOperatorSpec.ts +0 -492
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const pgDb_1 = require("./pgDb");
|
|
5
|
+
describe("pgdb", () => {
|
|
6
|
+
let pgdb;
|
|
7
|
+
let schema = 'pgdb_test';
|
|
8
|
+
let tableUsers;
|
|
9
|
+
let viewUsers;
|
|
10
|
+
beforeAll(() => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
11
|
+
try {
|
|
12
|
+
pgdb = yield pgDb_1.PgDb.connect({ connectionString: "postgres://" });
|
|
13
|
+
}
|
|
14
|
+
catch (e) {
|
|
15
|
+
console.error("connection failed! Are you specified PGUSER/PGDATABASE/PGPASSWORD correctly?");
|
|
16
|
+
console.error(e);
|
|
17
|
+
process.exit(1);
|
|
18
|
+
}
|
|
19
|
+
yield pgdb.run('CREATE SCHEMA IF NOT EXISTS "' + schema + '"');
|
|
20
|
+
yield pgdb.execute('src/test/init.sql', (cmd) => cmd.replace(/__SCHEMA__/g, '"' + schema + '"'));
|
|
21
|
+
yield pgdb.reload();
|
|
22
|
+
pgdb.setLogger(console);
|
|
23
|
+
tableUsers = pgdb.schemas[schema]['users'];
|
|
24
|
+
viewUsers = pgdb.schemas[schema]['users_view'];
|
|
25
|
+
return Promise.resolve();
|
|
26
|
+
}));
|
|
27
|
+
beforeEach(() => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
28
|
+
yield tableUsers.run('DELETE FROM ' + tableUsers);
|
|
29
|
+
}));
|
|
30
|
+
afterAll(() => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
31
|
+
yield pgdb.close();
|
|
32
|
+
}));
|
|
33
|
+
it("Testing Array operators", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
34
|
+
yield tableUsers.insert({ name: 'S', favourites: ['sport'] });
|
|
35
|
+
yield tableUsers.insert({ name: 'SF', favourites: ['sport', 'food'] });
|
|
36
|
+
yield tableUsers.insert({ name: 'TF', favourites: ['tech', 'food'] });
|
|
37
|
+
let res;
|
|
38
|
+
res = yield tableUsers.find({ 'favourites': 'sport' }, { fields: ['name'] });
|
|
39
|
+
expect(res.map(r => r.name)).toEqual(['S', 'SF']);
|
|
40
|
+
res = yield tableUsers.find({ 'favourites': ['sport', 'food'] }, { fields: ['name'] });
|
|
41
|
+
expect(res.map(r => r.name)).toEqual(['SF']);
|
|
42
|
+
res = yield tableUsers.find({ 'favourites @>': ['sport'] });
|
|
43
|
+
expect(res.map(r => r.name)).toEqual(['S', 'SF']);
|
|
44
|
+
res = yield tableUsers.find({ 'favourites <@': ['sport', 'food', 'tech'] });
|
|
45
|
+
expect(res.map(r => r.name)).toEqual(['S', 'SF', 'TF']);
|
|
46
|
+
res = yield tableUsers.find({ 'favourites &&': ['sport', 'music'] });
|
|
47
|
+
expect(res.map(r => r.name)).toEqual(['S', 'SF']);
|
|
48
|
+
res = yield tableUsers.find({ 'favourites !=': ['sport'] });
|
|
49
|
+
expect(res.map(r => r.name)).toEqual(['SF', 'TF']);
|
|
50
|
+
}));
|
|
51
|
+
it("Testing Array operators on view", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
52
|
+
yield viewUsers.insert({ name: 'S', favourites: ['sport'] });
|
|
53
|
+
yield viewUsers.insert({ name: 'SF', favourites: ['sport', 'food'] });
|
|
54
|
+
yield viewUsers.insert({ name: 'TF', favourites: ['tech', 'food'] });
|
|
55
|
+
let res;
|
|
56
|
+
res = yield viewUsers.find({ 'favourites': 'sport' }, { fields: ['name'] });
|
|
57
|
+
expect(res.map(r => r.name)).toEqual(['S', 'SF']);
|
|
58
|
+
res = yield viewUsers.find({ 'favourites': ['sport', 'food'] }, { fields: ['name'] });
|
|
59
|
+
expect(res.map(r => r.name)).toEqual(['SF']);
|
|
60
|
+
res = yield viewUsers.find({ 'favourites @>': ['sport'] });
|
|
61
|
+
expect(res.map(r => r.name)).toEqual(['S', 'SF']);
|
|
62
|
+
res = yield viewUsers.find({ 'favourites <@': ['sport', 'food', 'tech'] });
|
|
63
|
+
expect(res.map(r => r.name)).toEqual(['S', 'SF', 'TF']);
|
|
64
|
+
res = yield viewUsers.find({ 'favourites &&': ['sport', 'music'] });
|
|
65
|
+
expect(res.map(r => r.name)).toEqual(['S', 'SF']);
|
|
66
|
+
res = yield viewUsers.find({ 'favourites !=': ['sport'] });
|
|
67
|
+
expect(res.map(r => r.name)).toEqual(['SF', 'TF']);
|
|
68
|
+
}));
|
|
69
|
+
it("Searching in elements in jsonList", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
70
|
+
yield tableUsers.insert({ name: 'Medium and high risk', jsonList: [{ risk: 'H' }, { risk: 'M' }] });
|
|
71
|
+
let query1 = {
|
|
72
|
+
or: [{ '"jsonList" @>': [{ "risk": "H" }] }, { '"jsonList" @>': [{ "risk": "L" }] }]
|
|
73
|
+
};
|
|
74
|
+
let query2 = {
|
|
75
|
+
or: [{ 'jsonList @>': [{ "risk": "H" }] }, { 'jsonList @>': [{ "risk": "L" }] }]
|
|
76
|
+
};
|
|
77
|
+
let query3 = {
|
|
78
|
+
or: [{ 'jsonList @>': '[{"risk": "H"}]' }, { 'jsonList @>': '[{"risk": "L"}]' }]
|
|
79
|
+
};
|
|
80
|
+
let res;
|
|
81
|
+
res = yield tableUsers.find(query1, { fields: ['name'] });
|
|
82
|
+
expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
|
|
83
|
+
res = yield tableUsers.find(query2, { fields: ['name'] });
|
|
84
|
+
expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
|
|
85
|
+
res = yield tableUsers.find(query3, { fields: ['name'] });
|
|
86
|
+
expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
|
|
87
|
+
}));
|
|
88
|
+
it("Free text search", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
89
|
+
yield tableUsers.insert({ name: 'Medium and high risk', jsonList: [{ name: "The return of the Jedi" }] });
|
|
90
|
+
let res;
|
|
91
|
+
for (let searchCol of ['"name"||"jsonList" @@', 'tsv @@']) {
|
|
92
|
+
res = yield tableUsers.find({ [searchCol]: 'risk & return' }, { fields: ['name'] });
|
|
93
|
+
expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
|
|
94
|
+
res = yield tableUsers.find({ [searchCol]: 'risk & future' }, { fields: ['name'] });
|
|
95
|
+
expect(res.length).toEqual(0);
|
|
96
|
+
res = yield tableUsers.find({
|
|
97
|
+
[searchCol]: {
|
|
98
|
+
lang: 'english',
|
|
99
|
+
query: 'risk & return'
|
|
100
|
+
}
|
|
101
|
+
}, { fields: ['name'] });
|
|
102
|
+
expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
|
|
103
|
+
}
|
|
104
|
+
}));
|
|
105
|
+
it("Testing Jsonb list selector operators", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
106
|
+
yield tableUsers.insert({ name: 'Somebody', jsonList: ['sport', 'season'] });
|
|
107
|
+
yield tableUsers.insert({ name: 'Anybody', jsonList: ['art', 'age'] });
|
|
108
|
+
yield tableUsers.insert({ name: 'Nobody', jsonList: ['neverending', 'nearby'] });
|
|
109
|
+
yield tableUsers.insert({ name: 'Noone', jsonList: null, });
|
|
110
|
+
yield tableUsers.insert({ name: 'Anonymous', jsonList: [] });
|
|
111
|
+
yield tableUsers.insert({ name: 'Obi1', jsonObject: { a: { b: 3 } } });
|
|
112
|
+
yield tableUsers.insert({ name: 'Obi2', jsonObject: { a: { b: [3, 4, 5, 6] }, d: 'c', g: 'e' } });
|
|
113
|
+
let res;
|
|
114
|
+
res = yield tableUsers.find({ '"jsonObject" ?|': ['d', 'f'] }, { fields: ['name'] });
|
|
115
|
+
expect(res.map(r => r.name)).toEqual(['Obi2']);
|
|
116
|
+
res = yield tableUsers.find({ 'jsonList @>': ['sport'] }, { fields: ['name'] });
|
|
117
|
+
expect(res.map(r => r.name)).toEqual(['Somebody']);
|
|
118
|
+
res = yield tableUsers.find({ 'jsonList <@': ['sport', 'tech', 'season'] }, { fields: ['name'] });
|
|
119
|
+
expect(res.map(r => r.name)).toEqual(['Somebody', 'Anonymous']);
|
|
120
|
+
res = yield tableUsers.find({ 'jsonList ?': 0 }, { fields: ['name'] });
|
|
121
|
+
expect(res.map(r => r.name)).toEqual([]);
|
|
122
|
+
res = yield tableUsers.find({ 'jsonList ?': '0' }, { fields: ['name'] });
|
|
123
|
+
expect(res.map(r => r.name)).toEqual([]);
|
|
124
|
+
res = yield tableUsers.find({ 'jsonObject -> a': { b: 3 } }, { fields: ['name'] });
|
|
125
|
+
expect(res.map(r => r.name)).toEqual(['Obi1']);
|
|
126
|
+
res = yield tableUsers.find({ "jsonObject -> 'a'": { b: 3 } }, { fields: ['name'] });
|
|
127
|
+
expect(res.map(r => r.name)).toEqual(['Obi1']);
|
|
128
|
+
res = yield tableUsers.find({ 'jsonList ->> 0': 'art' }, { fields: ['name'] });
|
|
129
|
+
expect(res.map(r => r.name)).toEqual(['Anybody']);
|
|
130
|
+
res = yield tableUsers.find({ 'jsonObject ->> a': '{"b": 3}' }, { fields: ['name'] });
|
|
131
|
+
expect(res.map(r => r.name)).toEqual(['Obi1']);
|
|
132
|
+
res = yield tableUsers.find({ "jsonObject ->> 'a'": '{"b": 3}' }, { fields: ['name'] });
|
|
133
|
+
expect(res.map(r => r.name)).toEqual(['Obi1']);
|
|
134
|
+
res = yield tableUsers.find({ "jsonList ->> '0'": 'art' }, { fields: ['name'] });
|
|
135
|
+
expect(res.map(r => r.name)).toEqual([]);
|
|
136
|
+
res = yield tableUsers.find({ "jsonObject #> {a}": { b: 3 } }, { fields: ['name'] });
|
|
137
|
+
expect(res.map(r => r.name)).toEqual(['Obi1']);
|
|
138
|
+
res = yield tableUsers.find({ "jsonObject #>> {a}": '{"b": 3}' }, { fields: ['name'] });
|
|
139
|
+
expect(res.map(r => r.name)).toEqual(['Obi1']);
|
|
140
|
+
res = yield tableUsers.find({ "jsonObject #>> {a,b}": 3 }, { fields: ['name'] });
|
|
141
|
+
expect(res.map(r => r.name)).toEqual(['Obi1']);
|
|
142
|
+
res = yield tableUsers.find({ "jsonObject #>> {a,b,1}": 4 }, { fields: ['name'] });
|
|
143
|
+
expect(res.map(r => r.name)).toEqual(['Obi2']);
|
|
144
|
+
res = yield tableUsers.find({ "jsonObject #>> {a,b,1}": '4' }, { fields: ['name'] });
|
|
145
|
+
expect(res.map(r => r.name)).toEqual(['Obi2']);
|
|
146
|
+
}));
|
|
147
|
+
it("Testing Jsonb list update", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
148
|
+
yield tableUsers.insert({ name: 'Somebody', jsonList: ['sport', 'season'] });
|
|
149
|
+
yield tableUsers.update({ name: 'Somebody' }, { jsonList: [{ name: 'sport' }, { name: 'season' }] });
|
|
150
|
+
let res = yield tableUsers.findAll();
|
|
151
|
+
expect(res.map(r => r.jsonList.map((e) => e.name))[0]).toEqual(['sport', 'season']);
|
|
152
|
+
}));
|
|
153
|
+
it("Testing Jsonb list operators", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
154
|
+
yield tableUsers.insert({ name: 'Somebody', jsonObject: { realName: 'somebody', webpage: 's.com' } });
|
|
155
|
+
yield tableUsers.insert({ name: 'Anybody', jsonObject: { realName: 'anybody', webpage: 'a.com' } });
|
|
156
|
+
yield tableUsers.insert({ name: 'Nobody', jsonObject: { realName: 'nobody', email: 'nobody@nowhere.com' } });
|
|
157
|
+
yield tableUsers.insert({ name: 'Noone', jsonObject: null });
|
|
158
|
+
yield tableUsers.insert({ name: 'Anonymous', jsonObject: {} });
|
|
159
|
+
let res;
|
|
160
|
+
res = yield tableUsers.find({ 'jsonObject ?': 'email' }, { fields: ['name'] });
|
|
161
|
+
expect(res.map(r => r.name)).toEqual(['Nobody']);
|
|
162
|
+
res = yield tableUsers.find({ 'jsonObject ?&': ['email', 'realName'] }, { fields: ['name'] });
|
|
163
|
+
expect(res.map(r => r.name)).toEqual(['Nobody']);
|
|
164
|
+
res = yield tableUsers.find({ 'jsonObject ?|': ['email', 'webpage'] }, { fields: ['name'] });
|
|
165
|
+
expect(res.map(r => r.name)).toEqual(['Somebody', 'Anybody', 'Nobody']);
|
|
166
|
+
res = yield tableUsers.find({ 'jsonObject @>': { realName: 'somebody' } }, { fields: ['name'] });
|
|
167
|
+
expect(res.map(r => r.name)).toEqual(['Somebody']);
|
|
168
|
+
res = yield tableUsers.find({ 'jsonObject ->> realName': 'somebody' }, { fields: ['name'] });
|
|
169
|
+
expect(res.map(r => r.name)).toEqual(['Somebody']);
|
|
170
|
+
res = yield tableUsers.find({ 'jsonObject ->> \'realName\'': 'somebody' }, { fields: ['name'] });
|
|
171
|
+
expect(res.map(r => r.name)).toEqual(['Somebody']);
|
|
172
|
+
res = yield tableUsers.find({ '"jsonObject" ->> \'realName\'': 'somebody' }, { fields: ['name'] });
|
|
173
|
+
expect(res.map(r => r.name)).toEqual(['Somebody']);
|
|
174
|
+
res = yield tableUsers.find({ 'jsonObject ->> realName': ['somebody', 'anybody'] }, { fields: ['name'] });
|
|
175
|
+
expect(res.map(r => r.name)).toEqual(['Somebody', 'Anybody']);
|
|
176
|
+
res = yield tableUsers.find({ 'jsonObject ->> realName like': '%body' }, { fields: ['name'] });
|
|
177
|
+
expect(res.map(r => r.name)).toEqual(['Somebody', 'Anybody', 'Nobody']);
|
|
178
|
+
res = yield tableUsers.find({ 'jsonObject ->> realName ~~': '%body' }, { fields: ['name'] });
|
|
179
|
+
expect(res.map(r => r.name)).toEqual(['Somebody', 'Anybody', 'Nobody']);
|
|
180
|
+
}));
|
|
181
|
+
it("Test deep jsonb @>", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
182
|
+
yield tableUsers.insert({ name: 'Somebody', jsonObject: { service: { indexing: { by: [1, 2, 3] }, database: true }, paid: true } });
|
|
183
|
+
yield tableUsers.insert({ name: 'Anybody', jsonList: [{ realName: 'anyone' }, { realName: 'anybody' }] });
|
|
184
|
+
let res;
|
|
185
|
+
res = yield tableUsers.find({ 'jsonObject @>': { service: { indexing: { by: [1] } }, paid: true } });
|
|
186
|
+
expect(res.map(r => r.name)).toEqual(['Somebody']);
|
|
187
|
+
res = yield tableUsers.find({ 'jsonList @>': [{ realName: 'anybody' }] });
|
|
188
|
+
expect(res.map(r => r.name)).toEqual(['Anybody']);
|
|
189
|
+
}));
|
|
190
|
+
it("Testing is (not) null", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
191
|
+
yield tableUsers.insert({ name: 'Noone', jsonObject: null });
|
|
192
|
+
yield tableUsers.insert({ name: 'Anonymous', jsonObject: {} });
|
|
193
|
+
let count;
|
|
194
|
+
count = yield tableUsers.count({ 'jsonObject !': null });
|
|
195
|
+
expect(count).toEqual(1);
|
|
196
|
+
count = yield tableUsers.count({ 'jsonObject': null });
|
|
197
|
+
expect(count).toEqual(1);
|
|
198
|
+
count = yield tableUsers.count({});
|
|
199
|
+
expect(count).toEqual(2);
|
|
200
|
+
}));
|
|
201
|
+
it("Test regexp ~,~*,!~,!~*", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
202
|
+
yield tableUsers.insert({ name: "All' o Phoibe" });
|
|
203
|
+
yield tableUsers.insert({ name: "I've got that tune" });
|
|
204
|
+
let res = yield tableUsers.find({ 'name ~': "\\so\\s" });
|
|
205
|
+
expect(res.map(r => r.name)).toEqual(["All' o Phoibe"]);
|
|
206
|
+
res = yield tableUsers.find({ 'name ~*': "\\sO\\s" });
|
|
207
|
+
expect(res.map(r => r.name)).toEqual(["All' o Phoibe"]);
|
|
208
|
+
res = yield tableUsers.find({ 'name !~': "\\so\\s" });
|
|
209
|
+
expect(res.map(r => r.name)).toEqual(["I've got that tune"]);
|
|
210
|
+
res = yield tableUsers.find({ 'name !~*': "\\sO\\s" });
|
|
211
|
+
expect(res.map(r => r.name)).toEqual(["I've got that tune"]);
|
|
212
|
+
}));
|
|
213
|
+
it("Test regexp " +
|
|
214
|
+
"~/~* ANY" +
|
|
215
|
+
"!~/!~* ALL", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
216
|
+
yield tableUsers.insert({ name: "All' o Phoibe" });
|
|
217
|
+
yield tableUsers.insert({ name: "I've got that tune" });
|
|
218
|
+
let res = yield tableUsers.find({ 'name ~': ["\\so\\s", '\\d+'] });
|
|
219
|
+
expect(res.map(r => r.name)).toEqual(["All' o Phoibe"]);
|
|
220
|
+
res = yield tableUsers.find({ 'name ~*': ["\\sO\\s", '\\d+'] });
|
|
221
|
+
expect(res.map(r => r.name)).toEqual(["All' o Phoibe"]);
|
|
222
|
+
res = yield tableUsers.find({ 'name !~': ["\\so\\s", '\\d+'] });
|
|
223
|
+
expect(res.map(r => r.name)).toEqual(["I've got that tune"]);
|
|
224
|
+
res = yield tableUsers.find({ 'name !~*': ["\\sO\\s", '\\d+'] });
|
|
225
|
+
expect(res.map(r => r.name)).toEqual(["I've got that tune"]);
|
|
226
|
+
}));
|
|
227
|
+
it("Test like ~~, like, ~~*, ilike, !~~, not like, !~~*, not ilike", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
228
|
+
yield tableUsers.insert({ name: 'Iced lemonade' });
|
|
229
|
+
yield tableUsers.insert({ name: 'Cucumber pear juice' });
|
|
230
|
+
let res;
|
|
231
|
+
res = yield tableUsers.find({ 'name ~~': '%lemon%' });
|
|
232
|
+
expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
|
|
233
|
+
res = yield tableUsers.find({ 'name like': '%lemon%' });
|
|
234
|
+
expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
|
|
235
|
+
res = yield tableUsers.find({ 'name ~~*': '%LEMON%' });
|
|
236
|
+
expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
|
|
237
|
+
res = yield tableUsers.find({ 'name ilike': '%LEMON%' });
|
|
238
|
+
expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
|
|
239
|
+
res = yield tableUsers.find({ 'name !~~': '%lemon%' });
|
|
240
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
241
|
+
res = yield tableUsers.find({ 'name not like': '%lemon%' });
|
|
242
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
243
|
+
res = yield tableUsers.find({ 'name !~~*': '%LEMON%' });
|
|
244
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
245
|
+
res = yield tableUsers.find({ 'name not ilike': '%LEMON%' });
|
|
246
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
247
|
+
}));
|
|
248
|
+
it("Test " +
|
|
249
|
+
"like/~~/ilike/~~* ANY(), " +
|
|
250
|
+
"not like/!~~/not ilike/!~~* ALL()", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
251
|
+
yield tableUsers.insert({ name: 'Iced lemonade' });
|
|
252
|
+
yield tableUsers.insert({ name: 'Cucumber pear juice' });
|
|
253
|
+
let res;
|
|
254
|
+
res = yield tableUsers.find({ 'name ~~': ['BB', '%lemon%'] });
|
|
255
|
+
expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
|
|
256
|
+
res = yield tableUsers.find({ 'name like': ['BB', '%lemon%'] });
|
|
257
|
+
expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
|
|
258
|
+
res = yield tableUsers.find({ 'name ~~*': ['bb', '%LEMON%'] });
|
|
259
|
+
expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
|
|
260
|
+
res = yield tableUsers.find({ 'name ilike': ['bb', '%LEMON%'] });
|
|
261
|
+
expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
|
|
262
|
+
res = yield tableUsers.find({ 'name !~~': ['BB', '%lemon%'] });
|
|
263
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
264
|
+
res = yield tableUsers.find({ 'name not like': ['BB', '%lemon%'] });
|
|
265
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
266
|
+
res = yield tableUsers.find({ 'name !~~*': ['bb', '%LEMON%'] });
|
|
267
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
268
|
+
res = yield tableUsers.find({ 'name not ilike': ['bb', '%LEMON%'] });
|
|
269
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
270
|
+
}));
|
|
271
|
+
it("Special added operators =*, icontains", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
272
|
+
yield tableUsers.insert({ name: 'Iced lemonade' });
|
|
273
|
+
yield tableUsers.insert({ name: 'Cucumber pear juice', textList: ['good', 'better', 'best'] });
|
|
274
|
+
let res;
|
|
275
|
+
res = yield tableUsers.find({ 'name =*': 'ICED LEMONADE' });
|
|
276
|
+
expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
|
|
277
|
+
res = yield tableUsers.find({ 'textList icontains': 'GOOD' });
|
|
278
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
279
|
+
res = yield tableUsers.find({ 'textList =*': 'GOOD' });
|
|
280
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
281
|
+
res = yield tableUsers.find({ 'textList &&*': ['GOOD', 'Bad'] });
|
|
282
|
+
expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
|
|
283
|
+
}));
|
|
284
|
+
});
|
|
285
|
+
function parseComplexTypeArray(str) {
|
|
286
|
+
let list = JSON.parse('[' + str.substring(1, str.length - 1) + ']');
|
|
287
|
+
let result = [];
|
|
288
|
+
for (let elementStr of list) {
|
|
289
|
+
result.push(parseComplexType(elementStr));
|
|
290
|
+
}
|
|
291
|
+
return result;
|
|
292
|
+
}
|
|
293
|
+
function parseComplexType(str) {
|
|
294
|
+
str = str.substring(1, str.length - 1);
|
|
295
|
+
let e = /"((?:[^"]|"")*)"(?:,|$)|([^,]*)(?:,|$)/g;
|
|
296
|
+
let valList = [];
|
|
297
|
+
let parsingResult;
|
|
298
|
+
let valStr;
|
|
299
|
+
let hasNextValue;
|
|
300
|
+
do {
|
|
301
|
+
parsingResult = e.exec(str);
|
|
302
|
+
if (!parsingResult)
|
|
303
|
+
break;
|
|
304
|
+
valStr = (parsingResult[0] == '' || parsingResult[0] == ',' || parsingResult[2] == 'null') ? null : parsingResult[1] || parsingResult[2];
|
|
305
|
+
if (parsingResult[0] == '"",' || parsingResult[0] == '""') {
|
|
306
|
+
valStr = '';
|
|
307
|
+
}
|
|
308
|
+
valList.push(valStr ? valStr.replace(/""/g, '"') : valStr);
|
|
309
|
+
hasNextValue = parsingResult[0].substring(parsingResult[0].length - 1, parsingResult[0].length) == ',';
|
|
310
|
+
} while (hasNextValue);
|
|
311
|
+
return valList;
|
|
312
|
+
}
|
|
313
|
+
//# sourceMappingURL=pgDbOperators.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pgDbOperators.test.js","sourceRoot":"","sources":["../../src/pgDbOperators.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { QueryAble } from "./queryAble";
|
|
2
|
+
import { IPgDb } from "./pgDbInterface";
|
|
3
|
+
import { IPgTable } from "./pgTableInterface";
|
|
4
|
+
import { IPgSchema } from "./pgSchemaInterface";
|
|
5
|
+
export declare class PgSchema extends QueryAble implements IPgSchema {
|
|
6
|
+
db: IPgDb;
|
|
7
|
+
schemaName: string;
|
|
8
|
+
schema: IPgSchema;
|
|
9
|
+
tables: {
|
|
10
|
+
[name: string]: IPgTable<any>;
|
|
11
|
+
};
|
|
12
|
+
fn: {
|
|
13
|
+
[name: string]: (...args: any[]) => any;
|
|
14
|
+
};
|
|
15
|
+
[name: string]: any | IPgTable<any>;
|
|
16
|
+
constructor(db: IPgDb, schemaName: string);
|
|
17
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PgSchema = void 0;
|
|
4
|
+
const queryAble_1 = require("./queryAble");
|
|
5
|
+
class PgSchema extends queryAble_1.QueryAble {
|
|
6
|
+
constructor(db, schemaName) {
|
|
7
|
+
super();
|
|
8
|
+
this.db = db;
|
|
9
|
+
this.schemaName = schemaName;
|
|
10
|
+
this.tables = {};
|
|
11
|
+
this.fn = {};
|
|
12
|
+
this.schema = this;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.PgSchema = PgSchema;
|
|
16
|
+
//# sourceMappingURL=pgSchema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pgSchema.js","sourceRoot":"","sources":["../../src/pgSchema.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AAKxC,MAAa,QAAS,SAAQ,qBAAS;IAMnC,YAAmB,EAAS,EAAS,UAAkB;QACnD,KAAK,EAAE,CAAC;QADO,OAAE,GAAF,EAAE,CAAO;QAAS,eAAU,GAAV,UAAU,CAAQ;QAJvD,WAAM,GAAsC,EAAE,CAAC;QAC/C,OAAE,GAAgD,EAAE,CAAC;QAKjD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACvB,CAAC;CACJ;AAVD,4BAUC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { IPgTable } from "./pgTableInterface";
|
|
2
|
+
import { IQueryAble } from "./queryAbleInterface";
|
|
3
|
+
export interface IPgSchema extends IQueryAble {
|
|
4
|
+
schemaName: string;
|
|
5
|
+
tables: {
|
|
6
|
+
[name: string]: IPgTable<any>;
|
|
7
|
+
};
|
|
8
|
+
fn: {
|
|
9
|
+
[name: string]: (...args: any[]) => any;
|
|
10
|
+
};
|
|
11
|
+
[name: string]: any | IPgTable<any>;
|
|
12
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pgSchemaInterface.js","sourceRoot":"","sources":["../../src/pgSchemaInterface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { QueryAble, QueryOptions } from "./queryAble";
|
|
3
|
+
import { FieldType } from "./pgDb";
|
|
4
|
+
import { IPgDb } from "./pgDbInterface";
|
|
5
|
+
import { PgSchema } from "./pgSchema";
|
|
6
|
+
import * as stream from "stream";
|
|
7
|
+
import { IPgTable, TruncateOptions, InsertOption, Return, UpdateDeleteOption, UpsertOption, Stream, CountOption } from "./pgTableInterface";
|
|
8
|
+
export declare class PgTable<T> extends QueryAble implements IPgTable<T> {
|
|
9
|
+
schema: PgSchema;
|
|
10
|
+
protected desc: {
|
|
11
|
+
name: string;
|
|
12
|
+
pkey?: string;
|
|
13
|
+
schema: string;
|
|
14
|
+
};
|
|
15
|
+
qualifiedName: string;
|
|
16
|
+
pkey: string;
|
|
17
|
+
db: IPgDb;
|
|
18
|
+
fieldTypes: {
|
|
19
|
+
[index: string]: FieldType;
|
|
20
|
+
};
|
|
21
|
+
constructor(schema: PgSchema, desc: {
|
|
22
|
+
name: string;
|
|
23
|
+
pkey?: string;
|
|
24
|
+
schema: string;
|
|
25
|
+
}, fieldTypes?: Record<string, FieldType>);
|
|
26
|
+
toString(): string;
|
|
27
|
+
insert(records: T[], options?: InsertOption): Promise<number>;
|
|
28
|
+
insert(records: T, options?: InsertOption): Promise<number>;
|
|
29
|
+
insertAndGet(records: T[], options?: InsertOption & Return): Promise<T[]>;
|
|
30
|
+
insertAndGet(records: T, options?: InsertOption & Return): Promise<T>;
|
|
31
|
+
updateOne(conditions: {
|
|
32
|
+
[k: string]: any;
|
|
33
|
+
}, fields: {
|
|
34
|
+
[k: string]: any;
|
|
35
|
+
}, options?: UpdateDeleteOption): Promise<number>;
|
|
36
|
+
updateAndGetOne(conditions: {
|
|
37
|
+
[k: string]: any;
|
|
38
|
+
}, fields: {
|
|
39
|
+
[k: string]: any;
|
|
40
|
+
}, options?: UpdateDeleteOption & Return): Promise<T>;
|
|
41
|
+
update(conditions: {
|
|
42
|
+
[k: string]: any;
|
|
43
|
+
}, fields: {
|
|
44
|
+
[k: string]: any;
|
|
45
|
+
}, options?: UpdateDeleteOption): Promise<number>;
|
|
46
|
+
updateAndGet(conditions: {
|
|
47
|
+
[k: string]: any;
|
|
48
|
+
}, fields: {
|
|
49
|
+
[k: string]: any;
|
|
50
|
+
}, options?: UpdateDeleteOption & Return): Promise<T[]>;
|
|
51
|
+
upsert(record: T, options?: UpsertOption): Promise<number>;
|
|
52
|
+
upsertAndGet(record: T, options?: UpsertOption & Return): Promise<T>;
|
|
53
|
+
delete(conditions: {
|
|
54
|
+
[k: string]: any;
|
|
55
|
+
}, options?: UpdateDeleteOption): Promise<number>;
|
|
56
|
+
deleteOne(conditions: {
|
|
57
|
+
[k: string]: any;
|
|
58
|
+
}, options?: UpdateDeleteOption): Promise<number>;
|
|
59
|
+
deleteAndGet(conditions: {
|
|
60
|
+
[k: string]: any;
|
|
61
|
+
}, options?: UpdateDeleteOption & Return): Promise<any[]>;
|
|
62
|
+
deleteAndGetOne(conditions: {
|
|
63
|
+
[k: string]: any;
|
|
64
|
+
}, options?: UpdateDeleteOption & Return): Promise<any>;
|
|
65
|
+
truncate(options?: TruncateOptions): Promise<void>;
|
|
66
|
+
find(conditions: {
|
|
67
|
+
[k: string]: any;
|
|
68
|
+
}, options?: QueryOptions): Promise<T[]>;
|
|
69
|
+
find(conditions: {
|
|
70
|
+
[k: string]: any;
|
|
71
|
+
}, options?: QueryOptions & Stream): Promise<stream.Readable>;
|
|
72
|
+
findWhere(where: string, params: any[] | {}, options?: QueryOptions): Promise<T[]>;
|
|
73
|
+
findWhere(where: string, params: any[] | {}, options?: QueryOptions & Stream): Promise<stream.Readable>;
|
|
74
|
+
findAll(options?: QueryOptions): Promise<T[]>;
|
|
75
|
+
findAll(options?: QueryOptions & Stream): Promise<stream.Readable>;
|
|
76
|
+
findOne(conditions: Record<string, any>, options?: QueryOptions): Promise<T>;
|
|
77
|
+
findFirst(conditions: Record<string, any>, options?: QueryOptions): Promise<T>;
|
|
78
|
+
count(conditions?: Record<string, any>, options?: CountOption): Promise<number>;
|
|
79
|
+
findOneFieldOnly(conditions: Record<string, any>, field: string, options?: QueryOptions): Promise<any>;
|
|
80
|
+
private getInsertQuery;
|
|
81
|
+
protected getUpdateSetSnippet(fields: {
|
|
82
|
+
[k: string]: any;
|
|
83
|
+
}, parameters?: any[]): {
|
|
84
|
+
snippet: string;
|
|
85
|
+
parameters: any[];
|
|
86
|
+
};
|
|
87
|
+
protected getUpdateQuery(conditions: {
|
|
88
|
+
[k: string]: any;
|
|
89
|
+
}, fields: {
|
|
90
|
+
[k: string]: any;
|
|
91
|
+
}, options?: UpdateDeleteOption): {
|
|
92
|
+
sql: string;
|
|
93
|
+
parameters: any[];
|
|
94
|
+
};
|
|
95
|
+
protected getUpsertQuery(record: T, options?: UpsertOption): {
|
|
96
|
+
sql: string;
|
|
97
|
+
parameters: any[];
|
|
98
|
+
};
|
|
99
|
+
protected getDeleteQuery(conditions: {
|
|
100
|
+
[k: string]: any;
|
|
101
|
+
}, options?: UpdateDeleteOption): {
|
|
102
|
+
sql: string;
|
|
103
|
+
parameters: any[];
|
|
104
|
+
};
|
|
105
|
+
}
|