@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.
Files changed (173) hide show
  1. package/action/action.d.ts +33 -29
  2. package/action/action.js +22 -7
  3. package/action/executor.d.ts +3 -3
  4. package/action/executor.js +8 -3
  5. package/action/experimental_action.d.ts +32 -22
  6. package/action/experimental_action.js +35 -9
  7. package/action/index.d.ts +2 -0
  8. package/action/index.js +7 -1
  9. package/action/orchestrator.d.ts +32 -15
  10. package/action/orchestrator.js +249 -53
  11. package/action/privacy.d.ts +2 -2
  12. package/action/relative_value.d.ts +47 -0
  13. package/action/relative_value.js +125 -0
  14. package/action/transaction.d.ts +10 -0
  15. package/action/transaction.js +23 -0
  16. package/auth/auth.d.ts +1 -1
  17. package/core/base.d.ts +61 -37
  18. package/core/base.js +7 -1
  19. package/core/clause.d.ts +85 -40
  20. package/core/clause.js +375 -64
  21. package/core/config.d.ts +12 -1
  22. package/core/config.js +7 -1
  23. package/core/const.d.ts +3 -0
  24. package/core/const.js +6 -0
  25. package/core/context.d.ts +6 -4
  26. package/core/context.js +20 -2
  27. package/core/convert.d.ts +1 -1
  28. package/core/date.js +1 -5
  29. package/core/db.d.ts +11 -8
  30. package/core/db.js +20 -8
  31. package/core/ent.d.ts +86 -30
  32. package/core/ent.js +626 -197
  33. package/core/global_schema.d.ts +7 -0
  34. package/core/global_schema.js +51 -0
  35. package/core/loaders/assoc_count_loader.d.ts +3 -2
  36. package/core/loaders/assoc_count_loader.js +10 -2
  37. package/core/loaders/assoc_edge_loader.d.ts +2 -2
  38. package/core/loaders/assoc_edge_loader.js +8 -11
  39. package/core/loaders/index.d.ts +1 -1
  40. package/core/loaders/index.js +1 -3
  41. package/core/loaders/index_loader.d.ts +3 -3
  42. package/core/loaders/loader.d.ts +2 -2
  43. package/core/loaders/loader.js +5 -5
  44. package/core/loaders/object_loader.d.ts +32 -11
  45. package/core/loaders/object_loader.js +225 -78
  46. package/core/loaders/query_loader.d.ts +7 -13
  47. package/core/loaders/query_loader.js +52 -11
  48. package/core/loaders/raw_count_loader.d.ts +2 -2
  49. package/core/loaders/raw_count_loader.js +5 -1
  50. package/core/logger.d.ts +1 -1
  51. package/core/logger.js +1 -0
  52. package/core/privacy.d.ts +25 -24
  53. package/core/privacy.js +21 -25
  54. package/core/query/assoc_query.d.ts +7 -6
  55. package/core/query/assoc_query.js +9 -1
  56. package/core/query/custom_clause_query.d.ts +27 -0
  57. package/core/query/custom_clause_query.js +84 -0
  58. package/core/query/custom_query.d.ts +20 -5
  59. package/core/query/custom_query.js +87 -12
  60. package/core/query/index.d.ts +1 -0
  61. package/core/query/index.js +3 -1
  62. package/core/query/query.d.ts +8 -4
  63. package/core/query/query.js +101 -53
  64. package/core/query/shared_assoc_test.d.ts +2 -1
  65. package/core/query/shared_assoc_test.js +35 -45
  66. package/core/query/shared_test.d.ts +8 -1
  67. package/core/query/shared_test.js +470 -236
  68. package/core/viewer.d.ts +3 -3
  69. package/core/viewer.js +1 -1
  70. package/graphql/graphql.d.ts +51 -19
  71. package/graphql/graphql.js +160 -136
  72. package/graphql/graphql_field_helpers.d.ts +7 -1
  73. package/graphql/graphql_field_helpers.js +21 -1
  74. package/graphql/index.d.ts +2 -2
  75. package/graphql/index.js +3 -5
  76. package/graphql/query/connection_type.d.ts +9 -9
  77. package/graphql/query/edge_connection.d.ts +9 -9
  78. package/graphql/query/page_info.d.ts +1 -1
  79. package/graphql/query/shared_assoc_test.js +1 -1
  80. package/graphql/query/shared_edge_connection.js +1 -19
  81. package/graphql/scalars/orderby_direction.d.ts +2 -0
  82. package/graphql/scalars/orderby_direction.js +15 -0
  83. package/imports/dataz/example1/_auth.js +128 -47
  84. package/imports/dataz/example1/_viewer.js +87 -39
  85. package/imports/index.d.ts +6 -1
  86. package/imports/index.js +19 -4
  87. package/index.d.ts +13 -5
  88. package/index.js +21 -7
  89. package/package.json +17 -17
  90. package/parse_schema/parse.d.ts +31 -9
  91. package/parse_schema/parse.js +155 -13
  92. package/schema/base_schema.d.ts +7 -3
  93. package/schema/base_schema.js +10 -0
  94. package/schema/field.d.ts +78 -21
  95. package/schema/field.js +231 -71
  96. package/schema/index.d.ts +2 -2
  97. package/schema/index.js +5 -1
  98. package/schema/json_field.d.ts +16 -4
  99. package/schema/json_field.js +32 -2
  100. package/schema/schema.d.ts +89 -19
  101. package/schema/schema.js +11 -13
  102. package/schema/struct_field.d.ts +15 -3
  103. package/schema/struct_field.js +117 -22
  104. package/schema/union_field.d.ts +1 -1
  105. package/scripts/custom_compiler.js +10 -6
  106. package/scripts/custom_graphql.js +128 -31
  107. package/scripts/migrate_v0.1.js +36 -0
  108. package/scripts/move_types.js +120 -0
  109. package/scripts/read_schema.js +20 -5
  110. package/testutils/action/complex_schemas.d.ts +69 -0
  111. package/testutils/action/complex_schemas.js +398 -0
  112. package/testutils/builder.d.ts +41 -47
  113. package/testutils/builder.js +76 -49
  114. package/testutils/db/fixture.d.ts +10 -0
  115. package/testutils/db/fixture.js +26 -0
  116. package/testutils/db/{test_db.d.ts → temp_db.d.ts} +24 -8
  117. package/testutils/db/{test_db.js → temp_db.js} +182 -45
  118. package/testutils/db/value.d.ts +7 -0
  119. package/testutils/db/value.js +251 -0
  120. package/testutils/db_mock.d.ts +16 -4
  121. package/testutils/db_mock.js +52 -7
  122. package/testutils/db_time_zone.d.ts +4 -0
  123. package/testutils/db_time_zone.js +41 -0
  124. package/testutils/ent-graphql-tests/index.d.ts +7 -1
  125. package/testutils/ent-graphql-tests/index.js +52 -23
  126. package/testutils/fake_comms.js +1 -1
  127. package/testutils/fake_data/const.d.ts +2 -1
  128. package/testutils/fake_data/const.js +3 -0
  129. package/testutils/fake_data/fake_contact.d.ts +7 -3
  130. package/testutils/fake_data/fake_contact.js +13 -7
  131. package/testutils/fake_data/fake_event.d.ts +4 -1
  132. package/testutils/fake_data/fake_event.js +7 -6
  133. package/testutils/fake_data/fake_tag.d.ts +36 -0
  134. package/testutils/fake_data/fake_tag.js +89 -0
  135. package/testutils/fake_data/fake_user.d.ts +8 -5
  136. package/testutils/fake_data/fake_user.js +16 -15
  137. package/testutils/fake_data/index.js +5 -1
  138. package/testutils/fake_data/internal.d.ts +2 -0
  139. package/testutils/fake_data/internal.js +7 -1
  140. package/testutils/fake_data/tag_query.d.ts +13 -0
  141. package/testutils/fake_data/tag_query.js +43 -0
  142. package/testutils/fake_data/test_helpers.d.ts +11 -4
  143. package/testutils/fake_data/test_helpers.js +28 -12
  144. package/testutils/fake_data/user_query.d.ts +13 -6
  145. package/testutils/fake_data/user_query.js +54 -22
  146. package/testutils/fake_log.d.ts +3 -3
  147. package/testutils/fake_log.js +1 -1
  148. package/testutils/parse_sql.d.ts +6 -0
  149. package/testutils/parse_sql.js +16 -2
  150. package/testutils/test_edge_global_schema.d.ts +15 -0
  151. package/testutils/test_edge_global_schema.js +62 -0
  152. package/testutils/write.d.ts +2 -2
  153. package/testutils/write.js +33 -7
  154. package/tsc/ast.d.ts +25 -2
  155. package/tsc/ast.js +141 -17
  156. package/tsc/compilerOptions.js +5 -1
  157. package/tsc/move_generated.d.ts +1 -0
  158. package/tsc/move_generated.js +164 -0
  159. package/tsc/transform.d.ts +22 -0
  160. package/tsc/transform.js +181 -0
  161. package/tsc/transform_action.d.ts +22 -0
  162. package/tsc/transform_action.js +183 -0
  163. package/tsc/transform_ent.d.ts +17 -0
  164. package/tsc/transform_ent.js +60 -0
  165. package/tsc/transform_schema.d.ts +27 -0
  166. package/{scripts → tsc}/transform_schema.js +146 -117
  167. package/graphql/enums.d.ts +0 -3
  168. package/graphql/enums.js +0 -25
  169. package/scripts/move_generated.js +0 -142
  170. package/scripts/transform_code.js +0 -113
  171. package/scripts/transform_schema.d.ts +0 -1
  172. /package/scripts/{move_generated.d.ts → migrate_v0.1.d.ts} +0 -0
  173. /package/scripts/{transform_code.d.ts → move_types.d.ts} +0 -0
@@ -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 User {
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.id;
28
- this.firstName = data.first_name;
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.User = User;
35
- class Event {
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 = "Event";
41
- this.id = data.id;
44
+ this.nodeType = "User";
45
+ this.firstName = data.first_name;
42
46
  }
43
- getPrivacyPolicy() {
44
- return privacy_1.AlwaysAllowPrivacyPolicy;
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(viewer, data) {
50
- this.viewer = viewer;
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(viewer, data) {
65
- this.viewer = viewer;
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(viewer, data) {
78
- this.viewer = viewer;
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(viewer, data) {
91
- this.viewer = viewer;
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
- inputKey: (0, camel_case_1.camelCase)(k),
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.validators = [];
254
- this.triggers = [];
255
- this.observers = [];
256
- this.builder = new SimpleBuilder(this.viewer, schema, fields, operation, existingEnt, this);
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
- declare type options = Pick<Column, "nullable" | "primaryKey" | "default" | "foreignKey" | "unique">;
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 uniqueIndex(name: string): Constraint;
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
- constructor(dialect: Dialect, tables?: CoreConcept[]);
71
- constructor(tables: CoreConcept[]);
82
+ private setTables;
83
+ constructor(dialect: Dialect, tables?: CoreConcept[] | (() => CoreConcept[]));
72
84
  getDialect(): Dialect;
73
- getTables(): Map<string, CoreConcept>;
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 sqliteSetupOptions {
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?: sqliteSetupOptions): void;
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 {};