@snowtop/ent 0.1.0-alpha13 → 0.1.0-alpha131
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/action/action.d.ts +33 -29
- package/action/action.js +22 -7
- package/action/executor.d.ts +3 -3
- package/action/executor.js +8 -3
- package/action/experimental_action.d.ts +32 -22
- package/action/experimental_action.js +35 -9
- package/action/index.d.ts +2 -0
- package/action/index.js +7 -1
- package/action/orchestrator.d.ts +32 -15
- package/action/orchestrator.js +249 -53
- package/action/privacy.d.ts +2 -2
- package/action/relative_value.d.ts +47 -0
- package/action/relative_value.js +125 -0
- package/action/transaction.d.ts +10 -0
- package/action/transaction.js +23 -0
- package/auth/auth.d.ts +1 -1
- package/core/base.d.ts +61 -37
- package/core/base.js +7 -1
- package/core/clause.d.ts +85 -40
- package/core/clause.js +375 -64
- package/core/config.d.ts +12 -1
- package/core/config.js +7 -1
- package/core/const.d.ts +3 -0
- package/core/const.js +6 -0
- package/core/context.d.ts +6 -4
- package/core/context.js +20 -2
- package/core/convert.d.ts +1 -1
- package/core/date.js +1 -5
- package/core/db.d.ts +11 -8
- package/core/db.js +20 -8
- package/core/ent.d.ts +86 -30
- package/core/ent.js +626 -197
- package/core/global_schema.d.ts +7 -0
- package/core/global_schema.js +51 -0
- package/core/loaders/assoc_count_loader.d.ts +3 -2
- package/core/loaders/assoc_count_loader.js +10 -2
- package/core/loaders/assoc_edge_loader.d.ts +2 -2
- package/core/loaders/assoc_edge_loader.js +8 -11
- package/core/loaders/index.d.ts +1 -1
- package/core/loaders/index.js +1 -3
- package/core/loaders/index_loader.d.ts +3 -3
- package/core/loaders/loader.d.ts +2 -2
- package/core/loaders/loader.js +5 -5
- package/core/loaders/object_loader.d.ts +32 -11
- package/core/loaders/object_loader.js +225 -78
- package/core/loaders/query_loader.d.ts +7 -13
- package/core/loaders/query_loader.js +52 -11
- package/core/loaders/raw_count_loader.d.ts +2 -2
- package/core/loaders/raw_count_loader.js +5 -1
- package/core/logger.d.ts +1 -1
- package/core/logger.js +1 -0
- package/core/privacy.d.ts +25 -24
- package/core/privacy.js +21 -25
- package/core/query/assoc_query.d.ts +7 -6
- package/core/query/assoc_query.js +9 -1
- package/core/query/custom_clause_query.d.ts +27 -0
- package/core/query/custom_clause_query.js +84 -0
- package/core/query/custom_query.d.ts +20 -5
- package/core/query/custom_query.js +87 -12
- package/core/query/index.d.ts +1 -0
- package/core/query/index.js +3 -1
- package/core/query/query.d.ts +8 -4
- package/core/query/query.js +101 -53
- package/core/query/shared_assoc_test.d.ts +2 -1
- package/core/query/shared_assoc_test.js +35 -45
- package/core/query/shared_test.d.ts +8 -1
- package/core/query/shared_test.js +470 -236
- package/core/viewer.d.ts +3 -3
- package/core/viewer.js +1 -1
- package/graphql/graphql.d.ts +51 -19
- package/graphql/graphql.js +160 -136
- package/graphql/graphql_field_helpers.d.ts +7 -1
- package/graphql/graphql_field_helpers.js +21 -1
- package/graphql/index.d.ts +2 -2
- package/graphql/index.js +3 -5
- package/graphql/query/connection_type.d.ts +9 -9
- package/graphql/query/edge_connection.d.ts +9 -9
- package/graphql/query/page_info.d.ts +1 -1
- package/graphql/query/shared_assoc_test.js +1 -1
- package/graphql/query/shared_edge_connection.js +1 -19
- package/graphql/scalars/orderby_direction.d.ts +2 -0
- package/graphql/scalars/orderby_direction.js +15 -0
- package/imports/dataz/example1/_auth.js +128 -47
- package/imports/dataz/example1/_viewer.js +87 -39
- package/imports/index.d.ts +6 -1
- package/imports/index.js +19 -4
- package/index.d.ts +13 -5
- package/index.js +21 -7
- package/package.json +17 -17
- package/parse_schema/parse.d.ts +31 -9
- package/parse_schema/parse.js +155 -13
- package/schema/base_schema.d.ts +7 -3
- package/schema/base_schema.js +10 -0
- package/schema/field.d.ts +78 -21
- package/schema/field.js +231 -71
- package/schema/index.d.ts +2 -2
- package/schema/index.js +5 -1
- package/schema/json_field.d.ts +16 -4
- package/schema/json_field.js +32 -2
- package/schema/schema.d.ts +89 -19
- package/schema/schema.js +11 -13
- package/schema/struct_field.d.ts +15 -3
- package/schema/struct_field.js +117 -22
- package/schema/union_field.d.ts +1 -1
- package/scripts/custom_compiler.js +10 -6
- package/scripts/custom_graphql.js +128 -31
- package/scripts/migrate_v0.1.js +36 -0
- package/scripts/move_types.js +120 -0
- package/scripts/read_schema.js +20 -5
- package/testutils/action/complex_schemas.d.ts +69 -0
- package/testutils/action/complex_schemas.js +398 -0
- package/testutils/builder.d.ts +41 -47
- package/testutils/builder.js +76 -49
- package/testutils/db/fixture.d.ts +10 -0
- package/testutils/db/fixture.js +26 -0
- package/testutils/db/{test_db.d.ts → temp_db.d.ts} +24 -8
- package/testutils/db/{test_db.js → temp_db.js} +182 -45
- package/testutils/db/value.d.ts +7 -0
- package/testutils/db/value.js +251 -0
- package/testutils/db_mock.d.ts +16 -4
- package/testutils/db_mock.js +52 -7
- package/testutils/db_time_zone.d.ts +4 -0
- package/testutils/db_time_zone.js +41 -0
- package/testutils/ent-graphql-tests/index.d.ts +7 -1
- package/testutils/ent-graphql-tests/index.js +52 -23
- package/testutils/fake_comms.js +1 -1
- package/testutils/fake_data/const.d.ts +2 -1
- package/testutils/fake_data/const.js +3 -0
- package/testutils/fake_data/fake_contact.d.ts +7 -3
- package/testutils/fake_data/fake_contact.js +13 -7
- package/testutils/fake_data/fake_event.d.ts +4 -1
- package/testutils/fake_data/fake_event.js +7 -6
- package/testutils/fake_data/fake_tag.d.ts +36 -0
- package/testutils/fake_data/fake_tag.js +89 -0
- package/testutils/fake_data/fake_user.d.ts +8 -5
- package/testutils/fake_data/fake_user.js +16 -15
- package/testutils/fake_data/index.js +5 -1
- package/testutils/fake_data/internal.d.ts +2 -0
- package/testutils/fake_data/internal.js +7 -1
- package/testutils/fake_data/tag_query.d.ts +13 -0
- package/testutils/fake_data/tag_query.js +43 -0
- package/testutils/fake_data/test_helpers.d.ts +11 -4
- package/testutils/fake_data/test_helpers.js +28 -12
- package/testutils/fake_data/user_query.d.ts +13 -6
- package/testutils/fake_data/user_query.js +54 -22
- package/testutils/fake_log.d.ts +3 -3
- package/testutils/fake_log.js +1 -1
- package/testutils/parse_sql.d.ts +6 -0
- package/testutils/parse_sql.js +16 -2
- package/testutils/test_edge_global_schema.d.ts +15 -0
- package/testutils/test_edge_global_schema.js +62 -0
- package/testutils/write.d.ts +2 -2
- package/testutils/write.js +33 -7
- package/tsc/ast.d.ts +25 -2
- package/tsc/ast.js +141 -17
- package/tsc/compilerOptions.js +5 -1
- package/tsc/move_generated.d.ts +1 -0
- package/tsc/move_generated.js +164 -0
- package/tsc/transform.d.ts +22 -0
- package/tsc/transform.js +181 -0
- package/tsc/transform_action.d.ts +22 -0
- package/tsc/transform_action.js +183 -0
- package/tsc/transform_ent.d.ts +17 -0
- package/tsc/transform_ent.js +60 -0
- package/tsc/transform_schema.d.ts +27 -0
- package/{scripts → tsc}/transform_schema.js +146 -117
- package/graphql/enums.d.ts +0 -3
- package/graphql/enums.js +0 -25
- package/scripts/move_generated.js +0 -142
- package/scripts/transform_code.js +0 -113
- package/scripts/transform_schema.d.ts +0 -1
- /package/scripts/{move_generated.d.ts → migrate_v0.1.d.ts} +0 -0
- /package/scripts/{transform_code.d.ts → move_types.d.ts} +0 -0
package/testutils/builder.js
CHANGED
|
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.SimpleAction = exports.SimpleBuilder = exports.getFieldInfo = exports.getTableName = exports.getSchemaName = exports.getBuilderSchemaTZFromFields = exports.getBuilderSchemaFromFields = exports.getBuilderSchema = exports.Address = exports.Message = exports.Group = exports.Contact = exports.Event = exports.User = void 0;
|
|
6
|
+
exports.SimpleAction = exports.SimpleBuilder = exports.getFieldInfo = exports.getTableName = exports.getSchemaName = exports.getBuilderSchemaTZFromFields = exports.getBuilderSchemaFromFields = exports.getBuilderSchema = exports.EntBuilderSchema = exports.Address = exports.Message = exports.Group = exports.Contact = exports.Event = exports.User = exports.BaseEnt = void 0;
|
|
7
7
|
const privacy_1 = require("../core/privacy");
|
|
8
8
|
const orchestrator_1 = require("../action/orchestrator");
|
|
9
9
|
const action_1 = require("../action");
|
|
@@ -16,89 +16,89 @@ const convert_1 = require("../core/convert");
|
|
|
16
16
|
const camel_case_1 = require("camel-case");
|
|
17
17
|
const base_schema_1 = require("../schema/base_schema");
|
|
18
18
|
const schema_2 = require("../schema/schema");
|
|
19
|
-
class
|
|
19
|
+
class BaseEnt {
|
|
20
20
|
constructor(viewer, data) {
|
|
21
21
|
this.viewer = viewer;
|
|
22
22
|
this.data = data;
|
|
23
|
-
this.accountID = "";
|
|
24
|
-
this.nodeType = "User";
|
|
25
23
|
this.data.created_at = (0, convert_1.convertDate)(data.created_at);
|
|
26
24
|
this.data.updated_at = (0, convert_1.convertDate)(data.updated_at);
|
|
27
|
-
this.id = data.
|
|
28
|
-
|
|
25
|
+
this.id = data[this.getKey()];
|
|
26
|
+
}
|
|
27
|
+
getKey() {
|
|
28
|
+
return "id";
|
|
29
29
|
}
|
|
30
30
|
getPrivacyPolicy() {
|
|
31
31
|
return privacy_1.AlwaysAllowPrivacyPolicy;
|
|
32
32
|
}
|
|
33
|
+
__setRawDBData(data) {
|
|
34
|
+
// doesn't apply here so ignore...
|
|
35
|
+
}
|
|
33
36
|
}
|
|
34
|
-
exports.
|
|
35
|
-
class
|
|
37
|
+
exports.BaseEnt = BaseEnt;
|
|
38
|
+
class User extends BaseEnt {
|
|
36
39
|
constructor(viewer, data) {
|
|
40
|
+
super(viewer, data);
|
|
37
41
|
this.viewer = viewer;
|
|
38
42
|
this.data = data;
|
|
39
43
|
this.accountID = "";
|
|
40
|
-
this.nodeType = "
|
|
41
|
-
this.
|
|
44
|
+
this.nodeType = "User";
|
|
45
|
+
this.firstName = data.first_name;
|
|
42
46
|
}
|
|
43
|
-
|
|
44
|
-
|
|
47
|
+
}
|
|
48
|
+
exports.User = User;
|
|
49
|
+
class Event extends BaseEnt {
|
|
50
|
+
constructor() {
|
|
51
|
+
super(...arguments);
|
|
52
|
+
this.accountID = "";
|
|
53
|
+
this.nodeType = "Event";
|
|
45
54
|
}
|
|
46
55
|
}
|
|
47
56
|
exports.Event = Event;
|
|
48
|
-
class Contact {
|
|
49
|
-
constructor(
|
|
50
|
-
|
|
51
|
-
this.data = data;
|
|
57
|
+
class Contact extends BaseEnt {
|
|
58
|
+
constructor() {
|
|
59
|
+
super(...arguments);
|
|
52
60
|
this.accountID = "";
|
|
53
61
|
this.nodeType = "Contact";
|
|
54
|
-
this.data.created_at = (0, convert_1.convertDate)(data.created_at);
|
|
55
|
-
this.data.updated_at = (0, convert_1.convertDate)(data.updated_at);
|
|
56
|
-
this.id = data.id;
|
|
57
62
|
}
|
|
58
63
|
getPrivacyPolicy() {
|
|
59
64
|
return privacy_1.AlwaysAllowPrivacyPolicy;
|
|
60
65
|
}
|
|
61
66
|
}
|
|
62
67
|
exports.Contact = Contact;
|
|
63
|
-
class Group {
|
|
64
|
-
constructor(
|
|
65
|
-
|
|
66
|
-
this.data = data;
|
|
68
|
+
class Group extends BaseEnt {
|
|
69
|
+
constructor() {
|
|
70
|
+
super(...arguments);
|
|
67
71
|
this.accountID = "";
|
|
68
72
|
this.nodeType = "Group";
|
|
69
|
-
this.id = data.id;
|
|
70
73
|
}
|
|
71
74
|
getPrivacyPolicy() {
|
|
72
75
|
return privacy_1.AlwaysAllowPrivacyPolicy;
|
|
73
76
|
}
|
|
74
77
|
}
|
|
75
78
|
exports.Group = Group;
|
|
76
|
-
class Message {
|
|
77
|
-
constructor(
|
|
78
|
-
|
|
79
|
-
this.data = data;
|
|
79
|
+
class Message extends BaseEnt {
|
|
80
|
+
constructor() {
|
|
81
|
+
super(...arguments);
|
|
80
82
|
this.accountID = "";
|
|
81
83
|
this.nodeType = "Message";
|
|
82
|
-
this.id = data.id;
|
|
83
|
-
}
|
|
84
|
-
getPrivacyPolicy() {
|
|
85
|
-
return privacy_1.AlwaysAllowPrivacyPolicy;
|
|
86
84
|
}
|
|
87
85
|
}
|
|
88
86
|
exports.Message = Message;
|
|
89
|
-
class Address {
|
|
90
|
-
constructor(
|
|
91
|
-
|
|
92
|
-
this.data = data;
|
|
87
|
+
class Address extends BaseEnt {
|
|
88
|
+
constructor() {
|
|
89
|
+
super(...arguments);
|
|
93
90
|
this.accountID = "";
|
|
94
91
|
this.nodeType = "Address";
|
|
95
|
-
this.id = data.id;
|
|
96
|
-
}
|
|
97
|
-
getPrivacyPolicy() {
|
|
98
|
-
return privacy_1.AlwaysAllowPrivacyPolicy;
|
|
99
92
|
}
|
|
100
93
|
}
|
|
101
94
|
exports.Address = Address;
|
|
95
|
+
class EntBuilderSchema extends base_schema_1.EntSchema {
|
|
96
|
+
constructor(ent, cfg) {
|
|
97
|
+
super(cfg);
|
|
98
|
+
this.ent = ent;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
exports.EntBuilderSchema = EntBuilderSchema;
|
|
102
102
|
function getBuilderSchema(cfg, ent) {
|
|
103
103
|
return {
|
|
104
104
|
...new base_schema_1.EntSchema(cfg),
|
|
@@ -106,9 +106,9 @@ function getBuilderSchema(cfg, ent) {
|
|
|
106
106
|
};
|
|
107
107
|
}
|
|
108
108
|
exports.getBuilderSchema = getBuilderSchema;
|
|
109
|
-
function getBuilderSchemaFromFields(fields, ent) {
|
|
109
|
+
function getBuilderSchemaFromFields(fields, ent, opts) {
|
|
110
110
|
return {
|
|
111
|
-
...new base_schema_1.EntSchema({ fields }),
|
|
111
|
+
...new base_schema_1.EntSchema({ ...opts, fields }),
|
|
112
112
|
ent,
|
|
113
113
|
};
|
|
114
114
|
}
|
|
@@ -137,7 +137,8 @@ function getFieldInfo(value) {
|
|
|
137
137
|
for (const [k, f] of fields) {
|
|
138
138
|
ret[k] = {
|
|
139
139
|
dbCol: (0, schema_2.getStorageKey)(f, k),
|
|
140
|
-
|
|
140
|
+
// in tests (anything using SimpleBuilder), make it be the same as the fieldName
|
|
141
|
+
inputKey: k,
|
|
141
142
|
};
|
|
142
143
|
}
|
|
143
144
|
return ret;
|
|
@@ -145,11 +146,12 @@ function getFieldInfo(value) {
|
|
|
145
146
|
exports.getFieldInfo = getFieldInfo;
|
|
146
147
|
// reuses orchestrator and standard things
|
|
147
148
|
class SimpleBuilder {
|
|
148
|
-
constructor(viewer, schema, fields, operation = action_1.WriteOperation.Insert, existingEnt, action) {
|
|
149
|
+
constructor(viewer, schema, fields, operation = action_1.WriteOperation.Insert, existingEnt, action, expressions) {
|
|
149
150
|
this.viewer = viewer;
|
|
150
151
|
this.schema = schema;
|
|
151
152
|
this.operation = operation;
|
|
152
153
|
this.existingEnt = existingEnt;
|
|
154
|
+
this.m = new Map();
|
|
153
155
|
// create dynamic placeholder
|
|
154
156
|
// TODO: do we need to use this as the node when there's an existingEnt
|
|
155
157
|
// same for generated builders.
|
|
@@ -195,6 +197,7 @@ class SimpleBuilder {
|
|
|
195
197
|
},
|
|
196
198
|
builder: this,
|
|
197
199
|
action: action,
|
|
200
|
+
expressions,
|
|
198
201
|
schema: this.schema,
|
|
199
202
|
editedFields: () => {
|
|
200
203
|
// to simulate what we do in generated builders where we return a new Map
|
|
@@ -207,6 +210,13 @@ class SimpleBuilder {
|
|
|
207
210
|
updateInput: this.updateInput.bind(this),
|
|
208
211
|
});
|
|
209
212
|
}
|
|
213
|
+
getInput() {
|
|
214
|
+
let ret = {};
|
|
215
|
+
for (const [k, v] of this.fields) {
|
|
216
|
+
ret[k] = v;
|
|
217
|
+
}
|
|
218
|
+
return ret;
|
|
219
|
+
}
|
|
210
220
|
updateInput(input) {
|
|
211
221
|
const knownFields = (0, schema_1.getFields)(this.schema);
|
|
212
222
|
for (const k in input) {
|
|
@@ -223,6 +233,14 @@ class SimpleBuilder {
|
|
|
223
233
|
}
|
|
224
234
|
}
|
|
225
235
|
}
|
|
236
|
+
// store data in Builder that can be retrieved by another validator, trigger, observer later in the action
|
|
237
|
+
storeData(k, v) {
|
|
238
|
+
this.m.set(k, v);
|
|
239
|
+
}
|
|
240
|
+
// retrieve data stored in this Builder with key
|
|
241
|
+
getStoredData(k) {
|
|
242
|
+
return this.m.get(k);
|
|
243
|
+
}
|
|
226
244
|
build() {
|
|
227
245
|
return this.orchestrator.build();
|
|
228
246
|
}
|
|
@@ -247,13 +265,19 @@ class SimpleBuilder {
|
|
|
247
265
|
}
|
|
248
266
|
exports.SimpleBuilder = SimpleBuilder;
|
|
249
267
|
class SimpleAction {
|
|
250
|
-
constructor(viewer, schema, fields, operation = action_1.WriteOperation.Insert, existingEnt) {
|
|
268
|
+
constructor(viewer, schema, fields, operation = action_1.WriteOperation.Insert, existingEnt, expressions) {
|
|
251
269
|
this.viewer = viewer;
|
|
252
270
|
this.fields = fields;
|
|
253
|
-
this.
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
271
|
+
this.builder = new SimpleBuilder(this.viewer, schema, fields, operation, existingEnt, this, expressions);
|
|
272
|
+
}
|
|
273
|
+
getTriggers() {
|
|
274
|
+
return [];
|
|
275
|
+
}
|
|
276
|
+
getValidators() {
|
|
277
|
+
return [];
|
|
278
|
+
}
|
|
279
|
+
getObservers() {
|
|
280
|
+
return [];
|
|
257
281
|
}
|
|
258
282
|
getPrivacyPolicy() {
|
|
259
283
|
return privacy_1.AlwaysAllowPrivacyPolicy;
|
|
@@ -274,6 +298,9 @@ class SimpleAction {
|
|
|
274
298
|
validX() {
|
|
275
299
|
return this.builder.orchestrator.validX();
|
|
276
300
|
}
|
|
301
|
+
validWithErrors() {
|
|
302
|
+
return this.builder.orchestrator.validWithErrors();
|
|
303
|
+
}
|
|
277
304
|
async save() {
|
|
278
305
|
await (0, action_1.saveBuilder)(this.builder);
|
|
279
306
|
if (this.builder.operation !== action_1.WriteOperation.Delete) {
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Client } from "pg";
|
|
2
|
+
import { Data } from "../../core/base";
|
|
3
|
+
import { Schema } from "../../schema";
|
|
4
|
+
interface Options {
|
|
5
|
+
overrides?: Data;
|
|
6
|
+
client: Client;
|
|
7
|
+
tableName: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function writeFixture(schema: Schema, opts: Options): Promise<void>;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.writeFixture = void 0;
|
|
4
|
+
const schema_1 = require("../../schema");
|
|
5
|
+
const value_1 = require("./value");
|
|
6
|
+
const ent_1 = require("../../core/ent");
|
|
7
|
+
async function writeFixture(schema, opts) {
|
|
8
|
+
const fields = (0, schema_1.getFields)(schema);
|
|
9
|
+
const d = {};
|
|
10
|
+
for (const [fieldName, field] of fields) {
|
|
11
|
+
const col = (0, schema_1.getStorageKey)(field, fieldName);
|
|
12
|
+
const val = (0, value_1.getDefaultValue)(field, col);
|
|
13
|
+
d[col] = val;
|
|
14
|
+
}
|
|
15
|
+
if (opts.overrides) {
|
|
16
|
+
for (const k in opts.overrides) {
|
|
17
|
+
d[k] = opts.overrides[k];
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
const q = (0, ent_1.buildInsertQuery)({
|
|
21
|
+
tableName: opts.tableName,
|
|
22
|
+
fields: d,
|
|
23
|
+
});
|
|
24
|
+
await opts.client.query(q[0], q[1]);
|
|
25
|
+
}
|
|
26
|
+
exports.writeFixture = writeFixture;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Client as PGClient } from "pg";
|
|
2
2
|
import { Dialect } from "../../core/db";
|
|
3
3
|
import { Database as SqliteDatabase } from "better-sqlite3";
|
|
4
|
+
import { Field } from "../../schema";
|
|
4
5
|
import { BuilderSchema } from "../builder";
|
|
5
6
|
import { Ent } from "../../core/base";
|
|
6
7
|
interface SchemaItem {
|
|
@@ -12,6 +13,7 @@ interface Column extends SchemaItem {
|
|
|
12
13
|
primaryKey?: boolean;
|
|
13
14
|
unique?: boolean;
|
|
14
15
|
default?: string;
|
|
16
|
+
index?: boolean | indexOptions;
|
|
15
17
|
foreignKey?: {
|
|
16
18
|
table: string;
|
|
17
19
|
col: string;
|
|
@@ -20,22 +22,32 @@ interface Column extends SchemaItem {
|
|
|
20
22
|
interface Constraint extends SchemaItem {
|
|
21
23
|
generate(): string;
|
|
22
24
|
}
|
|
25
|
+
interface Index extends SchemaItem {
|
|
26
|
+
generate(): string;
|
|
27
|
+
postCreate?(): boolean;
|
|
28
|
+
}
|
|
23
29
|
export interface CoreConcept {
|
|
24
30
|
name: string;
|
|
25
31
|
create(): string;
|
|
32
|
+
postCreate?(): string[];
|
|
26
33
|
drop(): string;
|
|
27
34
|
}
|
|
28
35
|
export interface Table extends CoreConcept {
|
|
29
36
|
columns: Column[];
|
|
30
37
|
constraints?: Constraint[];
|
|
31
38
|
}
|
|
32
|
-
|
|
39
|
+
type options = Pick<Column, "nullable" | "primaryKey" | "default" | "foreignKey" | "unique" | "index">;
|
|
33
40
|
export declare function primaryKey(name: string, cols: string[]): Constraint;
|
|
34
41
|
export declare function foreignKey(name: string, cols: string[], fkey: {
|
|
35
42
|
table: string;
|
|
36
43
|
cols: string[];
|
|
37
44
|
}): Constraint;
|
|
38
|
-
export declare function
|
|
45
|
+
export declare function check(name: string, condition: string): Constraint;
|
|
46
|
+
interface indexOptions {
|
|
47
|
+
type?: string;
|
|
48
|
+
unique?: boolean;
|
|
49
|
+
}
|
|
50
|
+
export declare function index(tableName: string, cols: string[], opts?: indexOptions): Index;
|
|
39
51
|
export declare function uuid(name: string, opts?: options): Column;
|
|
40
52
|
export declare function text(name: string, opts?: options): Column;
|
|
41
53
|
export declare function enumCol(name: string, type: string): Column;
|
|
@@ -67,11 +79,12 @@ export declare class TempDB {
|
|
|
67
79
|
private tables;
|
|
68
80
|
private dialect;
|
|
69
81
|
private sqlite;
|
|
70
|
-
|
|
71
|
-
constructor(
|
|
82
|
+
private setTables;
|
|
83
|
+
constructor(dialect: Dialect, tables?: CoreConcept[] | (() => CoreConcept[]));
|
|
72
84
|
getDialect(): Dialect;
|
|
73
|
-
|
|
85
|
+
__getTables(): Map<string, CoreConcept>;
|
|
74
86
|
beforeAll(setupConnString?: boolean): Promise<void>;
|
|
87
|
+
createImpl(table: CoreConcept): Promise<void>;
|
|
75
88
|
getSqliteClient(): SqliteDatabase;
|
|
76
89
|
getPostgresClient(): PGClient;
|
|
77
90
|
afterAll(): Promise<void>;
|
|
@@ -81,10 +94,13 @@ export declare class TempDB {
|
|
|
81
94
|
create(...tables: CoreConcept[]): Promise<void>;
|
|
82
95
|
}
|
|
83
96
|
export declare function assoc_edge_config_table(): Table;
|
|
84
|
-
export declare function assoc_edge_table(name: string): Table;
|
|
85
|
-
interface
|
|
97
|
+
export declare function assoc_edge_table(name: string, global?: boolean): Table;
|
|
98
|
+
interface setupOptions {
|
|
86
99
|
disableDeleteAfterEachTest?: boolean;
|
|
87
100
|
}
|
|
88
|
-
export declare function setupSqlite(connString: string, tables: () => Table[], opts?:
|
|
101
|
+
export declare function setupSqlite(connString: string, tables: () => Table[], opts?: setupOptions): TempDB;
|
|
102
|
+
export declare function setupPostgres(tables: () => Table[], opts?: setupOptions): void;
|
|
103
|
+
export declare function doSQLiteTestFromSchemas(schemas: BuilderSchema<Ent>[], doTest: () => Promise<void>, db?: string): Promise<TempDB>;
|
|
89
104
|
export declare function getSchemaTable(schema: BuilderSchema<Ent>, dialect: Dialect): Table;
|
|
105
|
+
export declare function getColumnFromField(fieldName: string, f: Field, dialect: Dialect): Column;
|
|
90
106
|
export {};
|