@itwin/core-backend 5.8.0-dev.5 → 5.8.0-dev.8

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 (86) hide show
  1. package/CHANGELOG.md +11 -1
  2. package/lib/cjs/ECDb.d.ts +26 -0
  3. package/lib/cjs/ECDb.d.ts.map +1 -1
  4. package/lib/cjs/ECDb.js +53 -2
  5. package/lib/cjs/ECDb.js.map +1 -1
  6. package/lib/cjs/ECSqlRowExecutor.d.ts +66 -0
  7. package/lib/cjs/ECSqlRowExecutor.d.ts.map +1 -0
  8. package/lib/cjs/ECSqlRowExecutor.js +135 -0
  9. package/lib/cjs/ECSqlRowExecutor.js.map +1 -0
  10. package/lib/cjs/ECSqlStatement.d.ts +13 -1
  11. package/lib/cjs/ECSqlStatement.d.ts.map +1 -1
  12. package/lib/cjs/ECSqlStatement.js +30 -0
  13. package/lib/cjs/ECSqlStatement.js.map +1 -1
  14. package/lib/cjs/ECSqlSyncReader.d.ts +104 -0
  15. package/lib/cjs/ECSqlSyncReader.d.ts.map +1 -0
  16. package/lib/cjs/ECSqlSyncReader.js +191 -0
  17. package/lib/cjs/ECSqlSyncReader.js.map +1 -0
  18. package/lib/cjs/IModelDb.d.ts +21 -1
  19. package/lib/cjs/IModelDb.d.ts.map +1 -1
  20. package/lib/cjs/IModelDb.js +43 -0
  21. package/lib/cjs/IModelDb.js.map +1 -1
  22. package/lib/cjs/IpcHost.d.ts.map +1 -1
  23. package/lib/cjs/IpcHost.js.map +1 -1
  24. package/lib/cjs/core-backend.d.ts +1 -0
  25. package/lib/cjs/core-backend.d.ts.map +1 -1
  26. package/lib/cjs/core-backend.js +1 -0
  27. package/lib/cjs/core-backend.js.map +1 -1
  28. package/lib/cjs/internal/workspace/WorkspaceImpl.d.ts.map +1 -1
  29. package/lib/cjs/internal/workspace/WorkspaceImpl.js +10 -2
  30. package/lib/cjs/internal/workspace/WorkspaceImpl.js.map +1 -1
  31. package/lib/esm/ECDb.d.ts +26 -0
  32. package/lib/esm/ECDb.d.ts.map +1 -1
  33. package/lib/esm/ECDb.js +54 -3
  34. package/lib/esm/ECDb.js.map +1 -1
  35. package/lib/esm/ECSqlRowExecutor.d.ts +66 -0
  36. package/lib/esm/ECSqlRowExecutor.d.ts.map +1 -0
  37. package/lib/esm/ECSqlRowExecutor.js +131 -0
  38. package/lib/esm/ECSqlRowExecutor.js.map +1 -0
  39. package/lib/esm/ECSqlStatement.d.ts +13 -1
  40. package/lib/esm/ECSqlStatement.d.ts.map +1 -1
  41. package/lib/esm/ECSqlStatement.js +30 -0
  42. package/lib/esm/ECSqlStatement.js.map +1 -1
  43. package/lib/esm/ECSqlSyncReader.d.ts +104 -0
  44. package/lib/esm/ECSqlSyncReader.d.ts.map +1 -0
  45. package/lib/esm/ECSqlSyncReader.js +187 -0
  46. package/lib/esm/ECSqlSyncReader.js.map +1 -0
  47. package/lib/esm/IModelDb.d.ts +21 -1
  48. package/lib/esm/IModelDb.d.ts.map +1 -1
  49. package/lib/esm/IModelDb.js +43 -0
  50. package/lib/esm/IModelDb.js.map +1 -1
  51. package/lib/esm/IpcHost.d.ts.map +1 -1
  52. package/lib/esm/IpcHost.js.map +1 -1
  53. package/lib/esm/core-backend.d.ts +1 -0
  54. package/lib/esm/core-backend.d.ts.map +1 -1
  55. package/lib/esm/core-backend.js +1 -0
  56. package/lib/esm/core-backend.js.map +1 -1
  57. package/lib/esm/internal/workspace/WorkspaceImpl.d.ts.map +1 -1
  58. package/lib/esm/internal/workspace/WorkspaceImpl.js +10 -2
  59. package/lib/esm/internal/workspace/WorkspaceImpl.js.map +1 -1
  60. package/lib/esm/test/ecdb/ECSqlQuery.test.js +21 -12
  61. package/lib/esm/test/ecdb/ECSqlQuery.test.js.map +1 -1
  62. package/lib/esm/test/ecdb/ECSqlSyncReader.test.d.ts +2 -0
  63. package/lib/esm/test/ecdb/ECSqlSyncReader.test.d.ts.map +1 -0
  64. package/lib/esm/test/ecdb/ECSqlSyncReader.test.js +122 -0
  65. package/lib/esm/test/ecdb/ECSqlSyncReader.test.js.map +1 -0
  66. package/lib/esm/test/ecdb/QueryReaders.test.d.ts +2 -0
  67. package/lib/esm/test/ecdb/QueryReaders.test.d.ts.map +1 -0
  68. package/lib/esm/test/ecdb/QueryReaders.test.js +1427 -0
  69. package/lib/esm/test/ecdb/QueryReaders.test.js.map +1 -0
  70. package/lib/esm/test/ecsql/src/ECSqlTestParser.d.ts +1 -1
  71. package/lib/esm/test/ecsql/src/ECSqlTestParser.d.ts.map +1 -1
  72. package/lib/esm/test/ecsql/src/ECSqlTestParser.js +7 -5
  73. package/lib/esm/test/ecsql/src/ECSqlTestParser.js.map +1 -1
  74. package/lib/esm/test/ecsql/src/ECSqlTestRunner.test.js +172 -98
  75. package/lib/esm/test/ecsql/src/ECSqlTestRunner.test.js.map +1 -1
  76. package/lib/esm/test/standalone/Workspace.test.js +53 -0
  77. package/lib/esm/test/standalone/Workspace.test.js.map +1 -1
  78. package/lib/esm/test/standalone/iModelDb.test.d.ts +2 -0
  79. package/lib/esm/test/standalone/iModelDb.test.d.ts.map +1 -0
  80. package/lib/esm/test/standalone/iModelDb.test.js +35 -0
  81. package/lib/esm/test/standalone/iModelDb.test.js.map +1 -0
  82. package/package.json +13 -13
  83. package/lib/esm/test/ecdb/ECSqlReader.test.d.ts +0 -2
  84. package/lib/esm/test/ecdb/ECSqlReader.test.d.ts.map +0 -1
  85. package/lib/esm/test/ecdb/ECSqlReader.test.js +0 -669
  86. package/lib/esm/test/ecdb/ECSqlReader.test.js.map +0 -1
@@ -0,0 +1,1427 @@
1
+ var __addDisposableResource = (this && this.__addDisposableResource) || function (env, value, async) {
2
+ if (value !== null && value !== void 0) {
3
+ if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
4
+ var dispose, inner;
5
+ if (async) {
6
+ if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
7
+ dispose = value[Symbol.asyncDispose];
8
+ }
9
+ if (dispose === void 0) {
10
+ if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
11
+ dispose = value[Symbol.dispose];
12
+ if (async) inner = dispose;
13
+ }
14
+ if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
15
+ if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };
16
+ env.stack.push({ value: value, dispose: dispose, async: async });
17
+ }
18
+ else if (async) {
19
+ env.stack.push({ async: true });
20
+ }
21
+ return value;
22
+ };
23
+ var __disposeResources = (this && this.__disposeResources) || (function (SuppressedError) {
24
+ return function (env) {
25
+ function fail(e) {
26
+ env.error = env.hasError ? new SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
27
+ env.hasError = true;
28
+ }
29
+ var r, s = 0;
30
+ function next() {
31
+ while (r = env.stack.pop()) {
32
+ try {
33
+ if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);
34
+ if (r.dispose) {
35
+ var result = r.dispose.call(r.value);
36
+ if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
37
+ }
38
+ else s |= 1;
39
+ }
40
+ catch (e) {
41
+ fail(e);
42
+ }
43
+ }
44
+ if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();
45
+ if (env.hasError) throw env.error;
46
+ }
47
+ return next();
48
+ };
49
+ })(typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
50
+ var e = new Error(message);
51
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
52
+ });
53
+ /*---------------------------------------------------------------------------------------------
54
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
55
+ * See LICENSE.md in the project root for license terms and full copyright notice.
56
+ *--------------------------------------------------------------------------------------------*/
57
+ import { DbResult } from "@itwin/core-bentley";
58
+ import { Code, ColorDef, IModel, QueryBinder, QueryOptionsBuilder, QueryRowFormat } from "@itwin/core-common";
59
+ import { DefinitionModel, ElementTreeDeleter, ElementTreeWalkerScope, PhysicalModel, PhysicalObject, SnapshotDb, Subject } from "../../core-backend";
60
+ import { IModelTestUtils } from "../IModelTestUtils";
61
+ import { KnownTestLocations } from "../KnownTestLocations";
62
+ import { ECDbTestHelper } from "./ECDbTestHelper";
63
+ import * as chai from "chai";
64
+ import * as chaiAsPromised from "chai-as-promised";
65
+ chai.use(chaiAsPromised);
66
+ const assert = chai.assert;
67
+ const expect = chai.expect;
68
+ describe("QueryReaders - createQueryReader() and withQueryReader() api tests", (() => {
69
+ let iModel;
70
+ before(async () => {
71
+ iModel = SnapshotDb.openFile(IModelTestUtils.resolveAssetFile("test.bim"));
72
+ });
73
+ after(async () => {
74
+ iModel.close();
75
+ });
76
+ describe("bind Id64 enumerable", async () => {
77
+ const outDir = KnownTestLocations.outputDir;
78
+ it("ecsql reader simple", async () => {
79
+ const env_1 = { stack: [], error: void 0, hasError: false };
80
+ try {
81
+ const ecdb = __addDisposableResource(env_1, ECDbTestHelper.createECDb(outDir, "test.ecdb", `<ECSchema schemaName="Test" alias="ts" version="01.00.00" xmlns="http://www.bentley.com/schemas/Bentley.ECXML.3.2">
82
+ <ECEntityClass typeName="Foo" modifier="Sealed">
83
+ <ECProperty propertyName="n" typeName="int"/>
84
+ </ECEntityClass>
85
+ </ECSchema>`), false);
86
+ assert.isTrue(ecdb.isOpen);
87
+ ecdb.saveChanges();
88
+ const params = new QueryBinder();
89
+ params.bindIdSet(1, ["0x32"]);
90
+ const optionBuilder = new QueryOptionsBuilder();
91
+ optionBuilder.setRowFormat(QueryRowFormat.UseJsPropertyNames);
92
+ const readerCallback = async (readerObj) => {
93
+ const rows = await readerObj.toArray();
94
+ assert.equal(rows[0].id, "0x32");
95
+ assert.equal(rows.length, 1);
96
+ };
97
+ const syncReaderCallback = (syncReader) => {
98
+ const rows = syncReader.toArray();
99
+ assert.equal(rows[0].id, "0x32");
100
+ assert.equal(rows.length, 1);
101
+ };
102
+ ecdb.withQueryReader("SELECT ECInstanceId, Name FROM meta.ECClassDef WHERE InVirtualSet(?, ECInstanceId)", syncReaderCallback, params, optionBuilder.getOptions());
103
+ const reader = ecdb.createQueryReader("SELECT ECInstanceId, Name FROM meta.ECClassDef WHERE InVirtualSet(?, ECInstanceId)", params, optionBuilder.getOptions());
104
+ await readerCallback(reader);
105
+ }
106
+ catch (e_1) {
107
+ env_1.error = e_1;
108
+ env_1.hasError = true;
109
+ }
110
+ finally {
111
+ __disposeResources(env_1);
112
+ }
113
+ });
114
+ it("ecsql reader simple for IdSet", async () => {
115
+ const env_2 = { stack: [], error: void 0, hasError: false };
116
+ try {
117
+ const ecdb = __addDisposableResource(env_2, ECDbTestHelper.createECDb(outDir, "test.ecdb", `<ECSchema schemaName="Test" alias="ts" version="01.00.00" xmlns="http://www.bentley.com/schemas/Bentley.ECXML.3.2">
118
+ <ECEntityClass typeName="Foo" modifier="Sealed">
119
+ <ECProperty propertyName="n" typeName="int"/>
120
+ </ECEntityClass>
121
+ </ECSchema>`), false);
122
+ assert.isTrue(ecdb.isOpen);
123
+ ecdb.saveChanges();
124
+ const params = new QueryBinder();
125
+ params.bindIdSet(1, ["0x32"]);
126
+ const optionBuilder = new QueryOptionsBuilder();
127
+ optionBuilder.setRowFormat(QueryRowFormat.UseJsPropertyNames);
128
+ const readerCallback = async (readerObj) => {
129
+ const rows = await readerObj.toArray();
130
+ assert.equal(rows[0].id, "0x32");
131
+ assert.equal(rows.length, 1);
132
+ };
133
+ const syncReaderCallback = (syncReader) => {
134
+ const rows = syncReader.toArray();
135
+ assert.equal(rows[0].id, "0x32");
136
+ assert.equal(rows.length, 1);
137
+ };
138
+ ecdb.withQueryReader("SELECT ECInstanceId, Name FROM meta.ECClassDef, IdSet(?) WHERE id = ECInstanceId ECSQLOPTIONS ENABLE_EXPERIMENTAL_FEATURES", syncReaderCallback, params, optionBuilder.getOptions());
139
+ const reader = ecdb.createQueryReader("SELECT ECInstanceId, Name FROM meta.ECClassDef, IdSet(?) WHERE id = ECInstanceId ECSQLOPTIONS ENABLE_EXPERIMENTAL_FEATURES", params, optionBuilder.getOptions());
140
+ await readerCallback(reader);
141
+ }
142
+ catch (e_2) {
143
+ env_2.error = e_2;
144
+ env_2.hasError = true;
145
+ }
146
+ finally {
147
+ __disposeResources(env_2);
148
+ }
149
+ });
150
+ it("bindIdSet not working with integer Ids", async () => {
151
+ const env_3 = { stack: [], error: void 0, hasError: false };
152
+ try {
153
+ const ecdb = __addDisposableResource(env_3, ECDbTestHelper.createECDb(outDir, "test.ecdb", `<ECSchema schemaName="Test" alias="ts" version="01.00.00" xmlns="http://www.bentley.com/schemas/Bentley.ECXML.3.2">
154
+ <ECEntityClass typeName="Foo" modifier="Sealed">
155
+ <ECProperty propertyName="n" typeName="int"/>
156
+ </ECEntityClass>
157
+ </ECSchema>`), false);
158
+ assert.isTrue(ecdb.isOpen);
159
+ ecdb.saveChanges();
160
+ const params = new QueryBinder();
161
+ params.bindIdSet(1, ["50"]);
162
+ const optionBuilder = new QueryOptionsBuilder();
163
+ optionBuilder.setRowFormat(QueryRowFormat.UseJsPropertyNames);
164
+ const readerCallback = async (readerObj) => {
165
+ const rows = await readerObj.toArray();
166
+ assert.equal(rows.length, 0);
167
+ };
168
+ const syncreaderCallback = (syncReader) => {
169
+ const rows = syncReader.toArray();
170
+ assert.equal(rows.length, 0);
171
+ };
172
+ ecdb.withQueryReader("SELECT ECInstanceId, Name FROM meta.ECClassDef WHERE InVirtualSet(?, ECInstanceId)", syncreaderCallback, params, optionBuilder.getOptions());
173
+ const reader = ecdb.createQueryReader("SELECT ECInstanceId, Name FROM meta.ECClassDef WHERE InVirtualSet(?, ECInstanceId)", params, optionBuilder.getOptions());
174
+ await readerCallback(reader);
175
+ }
176
+ catch (e_3) {
177
+ env_3.error = e_3;
178
+ env_3.hasError = true;
179
+ }
180
+ finally {
181
+ __disposeResources(env_3);
182
+ }
183
+ });
184
+ it("ecsql reader simple using query reader", async () => {
185
+ const env_4 = { stack: [], error: void 0, hasError: false };
186
+ try {
187
+ const ecdb = __addDisposableResource(env_4, ECDbTestHelper.createECDb(outDir, "test.ecdb", `<ECSchema schemaName="Test" alias="ts" version="01.00.00" xmlns="http://www.bentley.com/schemas/Bentley.ECXML.3.2">
188
+ <ECEntityClass typeName="Foo" modifier="Sealed">
189
+ <ECProperty propertyName="n" typeName="int"/>
190
+ </ECEntityClass>
191
+ </ECSchema>`), false);
192
+ assert.isTrue(ecdb.isOpen);
193
+ const insertResult = await ecdb.withCachedWriteStatement("INSERT INTO ts.Foo(n) VALUES(20)", async (stmt) => {
194
+ return stmt.stepForInsert();
195
+ });
196
+ ecdb.saveChanges();
197
+ assert.equal(insertResult.status, DbResult.BE_SQLITE_DONE);
198
+ assert.equal(insertResult.id, "0x1");
199
+ const params = new QueryBinder();
200
+ params.bindId("firstId", insertResult.id);
201
+ const resultAssertCallback = (queryReader) => {
202
+ assert.equal(queryReader.current.id, "0x1");
203
+ assert.equal(queryReader.current.ecinstanceid, "0x1");
204
+ assert.equal(queryReader.current.n, 20);
205
+ assert.equal(queryReader.current.ID, "0x1");
206
+ assert.equal(queryReader.current.ECINSTANCEID, "0x1");
207
+ assert.equal(queryReader.current[0], "0x1");
208
+ assert.equal(queryReader.current[1], 20);
209
+ const row0 = queryReader.current.toRow();
210
+ assert.equal(row0.ECInstanceId, "0x1");
211
+ assert.equal(row0.n, 20);
212
+ };
213
+ const readerCallback = async (readerObj) => {
214
+ assert.isTrue(await readerObj.step());
215
+ resultAssertCallback(readerObj);
216
+ assert.isFalse(await readerObj.step());
217
+ };
218
+ const synReaderCallback = (syncReader) => {
219
+ assert.isTrue(syncReader.step());
220
+ resultAssertCallback(syncReader);
221
+ assert.isFalse(syncReader.step());
222
+ };
223
+ ecdb.withQueryReader("SELECT ECInstanceId, n FROM ts.Foo WHERE ECInstanceId=:firstId LIMIT 1", synReaderCallback, params);
224
+ const reader = ecdb.createQueryReader("SELECT ECInstanceId, n FROM ts.Foo WHERE ECInstanceId=:firstId", params, { limit: { count: 1 } });
225
+ await readerCallback(reader);
226
+ }
227
+ catch (e_4) {
228
+ env_4.error = e_4;
229
+ env_4.hasError = true;
230
+ }
231
+ finally {
232
+ __disposeResources(env_4);
233
+ }
234
+ });
235
+ it("ecsql reader simple using query row reader", async () => {
236
+ // Use existing element from test.bim
237
+ const elementId = "0x1";
238
+ const params = new QueryBinder();
239
+ params.bindId("firstId", elementId);
240
+ const resultAssertCallback = (queryReader) => {
241
+ assert.equal(queryReader.current.id, "0x1");
242
+ assert.equal(queryReader.current.ecinstanceid, "0x1");
243
+ assert.isDefined(queryReader.current.ecclassid);
244
+ assert.equal(queryReader.current.ID, "0x1");
245
+ assert.equal(queryReader.current.ECINSTANCEID, "0x1");
246
+ assert.equal(queryReader.current[0], "0x1");
247
+ assert.isDefined(queryReader.current[1]);
248
+ const row0 = queryReader.current.toRow();
249
+ assert.equal(row0.ECInstanceId, "0x1");
250
+ assert.isDefined(row0.ECClassId);
251
+ };
252
+ const readerCallback = async (readerObj) => {
253
+ assert.isTrue(await readerObj.step());
254
+ resultAssertCallback(readerObj);
255
+ assert.isFalse(await readerObj.step());
256
+ };
257
+ const synReaderCallback = (syncReader) => {
258
+ assert.isTrue(syncReader.step());
259
+ resultAssertCallback(syncReader);
260
+ assert.isFalse(syncReader.step());
261
+ };
262
+ iModel.withQueryReader("SELECT ECInstanceId, ECClassId FROM bis.Element WHERE ECInstanceId=:firstId", synReaderCallback, params);
263
+ const reader = iModel.createQueryReader("SELECT ECInstanceId, ECClassId FROM bis.Element WHERE ECInstanceId=:firstId", params, { limit: { count: 1 } });
264
+ await readerCallback(reader);
265
+ });
266
+ });
267
+ describe("Works as iterable iterator", () => {
268
+ it("iterable in for loop", async () => {
269
+ const expectedRowCount = 46; // 46 Elements in test.bim
270
+ const readerCallback = async (readerObj) => {
271
+ let actualRowCount = 0;
272
+ for await (const row of readerObj) {
273
+ actualRowCount++;
274
+ assert.isDefined(row[0]);
275
+ }
276
+ assert.equal(actualRowCount, expectedRowCount);
277
+ };
278
+ const syncReaderCallback = (syncReader) => {
279
+ let actualRowCount = 0;
280
+ for (const row of syncReader) {
281
+ actualRowCount++;
282
+ assert.isDefined(row[0]);
283
+ }
284
+ assert.equal(actualRowCount, expectedRowCount);
285
+ };
286
+ iModel.withQueryReader("SELECT * FROM bis.Element", syncReaderCallback);
287
+ const reader = iModel.createQueryReader("SELECT * FROM bis.Element");
288
+ await readerCallback(reader);
289
+ });
290
+ it("iterable with .next()", async () => {
291
+ const readerCallback = async (readerObj) => {
292
+ let row;
293
+ let actualRowCount = 0;
294
+ while ((row = await readerObj.next()).done === false) {
295
+ actualRowCount++;
296
+ assert.equal(row.value[0], `0x${actualRowCount}`);
297
+ }
298
+ assert.equal(actualRowCount, 5);
299
+ };
300
+ const syncReaderCallback = (syncReader) => {
301
+ let row;
302
+ let actualRowCount = 0;
303
+ while ((row = syncReader.next()).done === false) {
304
+ actualRowCount++;
305
+ assert.equal(row.value[0], `0x${actualRowCount}`);
306
+ }
307
+ assert.equal(actualRowCount, 5);
308
+ };
309
+ iModel.withQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC LIMIT 5", syncReaderCallback);
310
+ const reader = iModel.createQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", undefined, { limit: { count: 5 } });
311
+ await readerCallback(reader);
312
+ });
313
+ it("Should not fail on empty array", async () => {
314
+ const idSet = [];
315
+ const binder = QueryBinder.from([idSet]);
316
+ const reader = iModel.createQueryReader("SELECT ECInstanceId, ECClassId, Name from ecdbf.ExternalFileInfo WHERE InVirtualSet(?, ECInstanceId)", binder);
317
+ assert.isFalse(await reader.step());
318
+ });
319
+ });
320
+ describe("Common usages", () => {
321
+ describe("Get all rows", () => {
322
+ const expectedRowCount = 46; // 46 Elements in test.bim
323
+ it("Get all rows using iterable iterator", async () => {
324
+ const readerCallback = async (readerObj) => {
325
+ let rowCount = 0;
326
+ for await (const _row of readerObj) {
327
+ rowCount++;
328
+ }
329
+ assert.equal(rowCount, expectedRowCount);
330
+ };
331
+ const syncReaderCallback = (syncReader) => {
332
+ let rowCount = 0;
333
+ for (const _row of syncReader) {
334
+ rowCount++;
335
+ }
336
+ assert.equal(rowCount, expectedRowCount);
337
+ };
338
+ iModel.withQueryReader("SELECT * FROM bis.Element", syncReaderCallback);
339
+ const reader = iModel.createQueryReader("SELECT * FROM bis.Element");
340
+ await readerCallback(reader);
341
+ });
342
+ it("Get all rows using step", async () => {
343
+ const readerCallback = async (readerObj) => {
344
+ let rowCount = 0;
345
+ while (await readerObj.step()) {
346
+ rowCount++;
347
+ }
348
+ assert.equal(rowCount, expectedRowCount);
349
+ };
350
+ const syncReaderCallback = (syncReader) => {
351
+ let rowCount = 0;
352
+ while (syncReader.step()) {
353
+ rowCount++;
354
+ }
355
+ assert.equal(rowCount, expectedRowCount);
356
+ };
357
+ iModel.withQueryReader("SELECT * FROM bis.Element", syncReaderCallback);
358
+ const reader = iModel.createQueryReader("SELECT * FROM bis.Element");
359
+ await readerCallback(reader);
360
+ });
361
+ it("Get all rows using toArray", async () => {
362
+ const readerCallback = async (readerObj) => {
363
+ const rows = await readerObj.toArray();
364
+ assert.equal(rows.length, expectedRowCount);
365
+ };
366
+ const syncReaderCallback = (syncReader) => {
367
+ const rows = syncReader.toArray();
368
+ assert.equal(rows.length, expectedRowCount);
369
+ };
370
+ iModel.withQueryReader("SELECT * FROM bis.Element", syncReaderCallback);
371
+ const reader = iModel.createQueryReader("SELECT * FROM bis.Element");
372
+ await readerCallback(reader);
373
+ });
374
+ });
375
+ describe("Get id from each row", () => {
376
+ it("Get id using iterable iterator with unspecified rowFormat", async () => {
377
+ const resultAssertCallback = (row, expectedId) => {
378
+ assert.equal(row[0], expectedId);
379
+ assert.equal(row.id, expectedId);
380
+ assert.equal(row.ecinstanceid, expectedId);
381
+ assert.equal(row.ECINSTANCEID, expectedId);
382
+ assert.equal(row.ECInstanceId, expectedId);
383
+ assert.equal(row.toArray()[0], expectedId);
384
+ assert.equal(row.toRow().ECInstanceId, expectedId);
385
+ };
386
+ const readerCallback = async (readerObj) => {
387
+ let counter = 1;
388
+ let rowCount = 0;
389
+ for await (const row of readerObj) {
390
+ const currentExpectedId = `0x${counter}`;
391
+ resultAssertCallback(row, currentExpectedId);
392
+ counter++;
393
+ rowCount++;
394
+ }
395
+ assert.equal(rowCount, 5);
396
+ };
397
+ const syncReaderCallback = (syncReader) => {
398
+ let counter = 1;
399
+ let rowCount = 0;
400
+ for (const row of syncReader) {
401
+ const currentExpectedId = `0x${counter}`;
402
+ resultAssertCallback(row, currentExpectedId);
403
+ counter++;
404
+ rowCount++;
405
+ }
406
+ assert.equal(rowCount, 5);
407
+ };
408
+ iModel.withQueryReader("SELECT * FROM meta.ECSchemaDef LIMIT 5", syncReaderCallback);
409
+ const reader = iModel.createQueryReader("SELECT * FROM meta.ECSchemaDef", undefined, { limit: { count: 5 } });
410
+ await readerCallback(reader);
411
+ });
412
+ it("Get id using iterable iterator with UseJsPropertyNames rowFormat", async () => {
413
+ const resultAssertCallback = (row, expectedId) => {
414
+ assert.equal(row[0], expectedId);
415
+ assert.equal(row.id, expectedId);
416
+ assert.equal(row.ecinstanceid, expectedId);
417
+ assert.equal(row.ECINSTANCEID, expectedId);
418
+ assert.equal(row.ECInstanceId, expectedId);
419
+ assert.equal(row.toArray()[0], expectedId);
420
+ assert.equal(row.toRow().id, expectedId);
421
+ };
422
+ const readerCallback = async (readerObj) => {
423
+ let counter = 1;
424
+ let rowCount = 0;
425
+ for await (const row of readerObj) {
426
+ const currentExpectedId = `0x${counter}`;
427
+ resultAssertCallback(row, currentExpectedId);
428
+ counter++;
429
+ rowCount++;
430
+ }
431
+ assert.equal(rowCount, 5);
432
+ };
433
+ const syncReaderCallback = (syncReader) => {
434
+ let counter = 1;
435
+ let rowCount = 0;
436
+ for (const row of syncReader) {
437
+ const currentExpectedId = `0x${counter}`;
438
+ resultAssertCallback(row, currentExpectedId);
439
+ counter++;
440
+ rowCount++;
441
+ }
442
+ assert.equal(rowCount, 5);
443
+ };
444
+ iModel.withQueryReader("SELECT * FROM meta.ECSchemaDef LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseJsPropertyNames });
445
+ const reader = iModel.createQueryReader("SELECT * FROM meta.ECSchemaDef", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseJsPropertyNames });
446
+ await readerCallback(reader);
447
+ });
448
+ it("Get id using iterable iterator with UseECSqlPropertyNames rowFormat", async () => {
449
+ const resultAssertCallback = (row, expectedId) => {
450
+ assert.equal(row[0], expectedId);
451
+ assert.equal(row.id, expectedId);
452
+ assert.equal(row.ecinstanceid, expectedId);
453
+ assert.equal(row.ECINSTANCEID, expectedId);
454
+ assert.equal(row.ECInstanceId, expectedId);
455
+ assert.equal(row.toArray()[0], expectedId);
456
+ assert.equal(row.toRow().ECInstanceId, expectedId);
457
+ };
458
+ const readerCallback = async (readerObj) => {
459
+ let counter = 1;
460
+ let rowCount = 0;
461
+ for await (const row of readerObj) {
462
+ const currentExpectedId = `0x${counter}`;
463
+ resultAssertCallback(row, currentExpectedId);
464
+ counter++;
465
+ rowCount++;
466
+ }
467
+ assert.equal(rowCount, 5);
468
+ };
469
+ const syncReaderCallback = (syncReader) => {
470
+ let counter = 1;
471
+ let rowCount = 0;
472
+ for (const row of syncReader) {
473
+ const currentExpectedId = `0x${counter}`;
474
+ resultAssertCallback(row, currentExpectedId);
475
+ counter++;
476
+ rowCount++;
477
+ }
478
+ assert.equal(rowCount, 5);
479
+ };
480
+ iModel.withQueryReader("SELECT * FROM meta.ECSchemaDef LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyNames });
481
+ const reader = iModel.createQueryReader("SELECT * FROM meta.ECSchemaDef", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyNames });
482
+ await readerCallback(reader);
483
+ });
484
+ it("Get id using iterable iterator with UseECSqlPropertyIndexes rowFormat", async () => {
485
+ const resultAssertCallback = (row, expectedId) => {
486
+ assert.equal(row[0], expectedId);
487
+ assert.equal(row.id, expectedId);
488
+ assert.equal(row.ecinstanceid, expectedId);
489
+ assert.equal(row.ECINSTANCEID, expectedId);
490
+ assert.equal(row.ECInstanceId, expectedId);
491
+ assert.equal(row.toArray()[0], expectedId);
492
+ assert.equal(row.toRow().ECInstanceId, expectedId);
493
+ };
494
+ const readerCallback = async (readerObj) => {
495
+ let counter = 1;
496
+ let rowCount = 0;
497
+ for await (const row of readerObj) {
498
+ const currentExpectedId = `0x${counter}`;
499
+ resultAssertCallback(row, currentExpectedId);
500
+ counter++;
501
+ rowCount++;
502
+ }
503
+ assert.equal(rowCount, 5);
504
+ };
505
+ const syncreaderCallback = (syncReader) => {
506
+ let counter = 1;
507
+ let rowCount = 0;
508
+ for (const row of syncReader) {
509
+ const currentExpectedId = `0x${counter}`;
510
+ resultAssertCallback(row, currentExpectedId);
511
+ counter++;
512
+ rowCount++;
513
+ }
514
+ assert.equal(rowCount, 5);
515
+ };
516
+ iModel.withQueryReader("SELECT * FROM meta.ECSchemaDef LIMIT 5", syncreaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
517
+ const reader = iModel.createQueryReader("SELECT * FROM meta.ECSchemaDef", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
518
+ await readerCallback(reader);
519
+ });
520
+ it("Get id using step with unspecified rowFormat", async () => {
521
+ const resultAssertCallback = (queryReader, expectedId) => {
522
+ assert.equal(queryReader.current[0], expectedId);
523
+ assert.equal(queryReader.current.id, expectedId);
524
+ assert.equal(queryReader.current.ecinstanceid, expectedId);
525
+ assert.equal(queryReader.current.ECINSTANCEID, expectedId);
526
+ assert.equal(queryReader.current.ECInstanceId, expectedId);
527
+ assert.equal(queryReader.current.toArray()[0], expectedId);
528
+ assert.equal(queryReader.current.toRow().ECInstanceId, expectedId);
529
+ };
530
+ const readerCallback = async (readerObj) => {
531
+ let counter = 1;
532
+ let rowCount = 0;
533
+ while (await readerObj.step()) {
534
+ const currentExpectedId = `0x${counter}`;
535
+ resultAssertCallback(readerObj, currentExpectedId);
536
+ counter++;
537
+ rowCount++;
538
+ }
539
+ assert.equal(rowCount, 5);
540
+ };
541
+ const synReaderCallback = (syncReader) => {
542
+ let counter = 1;
543
+ let rowCount = 0;
544
+ while (syncReader.step()) {
545
+ const currentExpectedId = `0x${counter}`;
546
+ resultAssertCallback(syncReader, currentExpectedId);
547
+ counter++;
548
+ rowCount++;
549
+ }
550
+ assert.equal(rowCount, 5);
551
+ };
552
+ iModel.withQueryReader("SELECT * FROM meta.ECSchemaDef LIMIT 5", synReaderCallback);
553
+ const reader = iModel.createQueryReader("SELECT * FROM meta.ECSchemaDef", undefined, { limit: { count: 5 } });
554
+ await readerCallback(reader);
555
+ });
556
+ it("Get id using step with UseJsPropertyNames rowFormat", async () => {
557
+ const resultAssertCallback = (queryReader, expectedId) => {
558
+ assert.equal(queryReader.current[0], expectedId);
559
+ assert.equal(queryReader.current.id, expectedId);
560
+ assert.equal(queryReader.current.ecinstanceid, expectedId);
561
+ assert.equal(queryReader.current.ECINSTANCEID, expectedId);
562
+ assert.equal(queryReader.current.ECInstanceId, expectedId);
563
+ assert.equal(queryReader.current.toArray()[0], expectedId);
564
+ assert.equal(queryReader.current.toRow().id, expectedId);
565
+ };
566
+ const readerCallback = async (readerObj) => {
567
+ let counter = 1;
568
+ let rowCount = 0;
569
+ while (await readerObj.step()) {
570
+ const currentExpectedId = `0x${counter}`;
571
+ resultAssertCallback(readerObj, currentExpectedId);
572
+ counter++;
573
+ rowCount++;
574
+ }
575
+ assert.equal(rowCount, 5);
576
+ };
577
+ const syncReaderCallback = (syncReader) => {
578
+ let counter = 1;
579
+ let rowCount = 0;
580
+ while (syncReader.step()) {
581
+ const currentExpectedId = `0x${counter}`;
582
+ resultAssertCallback(syncReader, currentExpectedId);
583
+ counter++;
584
+ rowCount++;
585
+ }
586
+ assert.equal(rowCount, 5);
587
+ };
588
+ iModel.withQueryReader("SELECT * FROM meta.ECSchemaDef LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseJsPropertyNames });
589
+ const reader = iModel.createQueryReader("SELECT * FROM meta.ECSchemaDef", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseJsPropertyNames });
590
+ await readerCallback(reader);
591
+ });
592
+ it("Get id using step with UseECSqlPropertyNames rowFormat", async () => {
593
+ const resultassertCallback = (queryReader, expectedId) => {
594
+ assert.equal(queryReader.current[0], expectedId);
595
+ assert.equal(queryReader.current.id, expectedId);
596
+ assert.equal(queryReader.current.ecinstanceid, expectedId);
597
+ assert.equal(queryReader.current.ECINSTANCEID, expectedId);
598
+ assert.equal(queryReader.current.ECInstanceId, expectedId);
599
+ assert.equal(queryReader.current.toArray()[0], expectedId);
600
+ assert.equal(queryReader.current.toRow().ECInstanceId, expectedId);
601
+ };
602
+ const readerCallback = async (readerObj) => {
603
+ let counter = 1;
604
+ let rowCount = 0;
605
+ while (await readerObj.step()) {
606
+ const currentExpectedId = `0x${counter}`;
607
+ resultassertCallback(readerObj, currentExpectedId);
608
+ counter++;
609
+ rowCount++;
610
+ }
611
+ assert.equal(rowCount, 5);
612
+ };
613
+ const syncReaderCallback = (syncReader) => {
614
+ let counter = 1;
615
+ let rowCount = 0;
616
+ while (syncReader.step()) {
617
+ const currentExpectedId = `0x${counter}`;
618
+ resultassertCallback(syncReader, currentExpectedId);
619
+ counter++;
620
+ rowCount++;
621
+ }
622
+ assert.equal(rowCount, 5);
623
+ };
624
+ iModel.withQueryReader("SELECT * FROM meta.ECSchemaDef LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyNames });
625
+ const reader = iModel.createQueryReader("SELECT * FROM meta.ECSchemaDef", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyNames });
626
+ await readerCallback(reader);
627
+ });
628
+ it("Get id using step with UseECSqlPropertyIndexes rowFormat", async () => {
629
+ const resultassertCallback = (queryReader, expectedId) => {
630
+ assert.equal(queryReader.current[0], expectedId);
631
+ assert.equal(queryReader.current.id, expectedId);
632
+ assert.equal(queryReader.current.ecinstanceid, expectedId);
633
+ assert.equal(queryReader.current.ECINSTANCEID, expectedId);
634
+ assert.equal(queryReader.current.ECInstanceId, expectedId);
635
+ assert.equal(queryReader.current.toArray()[0], expectedId);
636
+ assert.equal(queryReader.current.toRow().ECInstanceId, expectedId);
637
+ };
638
+ const readerCallback = async (readerObj) => {
639
+ let counter = 1;
640
+ let rowCount = 0;
641
+ while (await readerObj.step()) {
642
+ const currentExpectedId = `0x${counter}`;
643
+ resultassertCallback(readerObj, currentExpectedId);
644
+ counter++;
645
+ rowCount++;
646
+ }
647
+ assert.equal(rowCount, 5);
648
+ };
649
+ const syncReaderCallback = (syncReader) => {
650
+ let counter = 1;
651
+ let rowCount = 0;
652
+ while (syncReader.step()) {
653
+ const currentExpectedId = `0x${counter}`;
654
+ resultassertCallback(syncReader, currentExpectedId);
655
+ counter++;
656
+ rowCount++;
657
+ }
658
+ assert.equal(rowCount, 5);
659
+ };
660
+ iModel.withQueryReader("SELECT * FROM meta.ECSchemaDef LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
661
+ const reader = iModel.createQueryReader("SELECT * FROM meta.ECSchemaDef", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
662
+ await readerCallback(reader);
663
+ });
664
+ });
665
+ describe("Get duplicate property names", () => {
666
+ it("Get duplicate property names using iterable iterator with unspecified rowFormat", async () => {
667
+ const expectedIds = ["0x1", "0xe", "0x10", "0x11", "0x12"];
668
+ const resultassertCallback = (row, expectedId) => {
669
+ assert.equal(row[0], expectedId);
670
+ assert.equal(row.id, expectedId);
671
+ assert.equal(row.ecinstanceid, expectedId);
672
+ assert.equal(row.ECINSTANCEID, expectedId);
673
+ assert.equal(row.ECInstanceId, expectedId);
674
+ assert.equal(row.toArray()[0], expectedId);
675
+ assert.equal(row.toRow().ECInstanceId, expectedId);
676
+ };
677
+ const readerCallback = async (readerObj) => {
678
+ let counter = 1;
679
+ let rowCount = 0;
680
+ for await (const row of readerObj) {
681
+ const currentExpectedId = expectedIds[counter - 1];
682
+ resultassertCallback(row, currentExpectedId);
683
+ counter++;
684
+ rowCount++;
685
+ }
686
+ assert.equal(rowCount, 5);
687
+ };
688
+ const syncReaderCallback = (syncReader) => {
689
+ let counter = 1;
690
+ let rowCount = 0;
691
+ for (const row of syncReader) {
692
+ const currentExpectedId = expectedIds[counter - 1];
693
+ resultassertCallback(row, currentExpectedId);
694
+ counter++;
695
+ rowCount++;
696
+ }
697
+ assert.equal(rowCount, 5);
698
+ };
699
+ iModel.withQueryReader("SELECT * FROM bis.Element c JOIN bis.Element p ON p.ECInstanceId = c.ECInstanceId LIMIT 5", syncReaderCallback);
700
+ const reader = iModel.createQueryReader("SELECT * FROM bis.Element c JOIN bis.Element p ON p.ECInstanceId = c.ECInstanceId", undefined, { limit: { count: 5 } });
701
+ await readerCallback(reader);
702
+ });
703
+ it("Get duplicate property names using iterable iterator with UseJsPropertyNames rowFormat", async () => {
704
+ const expectedIds = ["0x1", "0xe", "0x10", "0x11", "0x12"];
705
+ const resultassertCallback = (row, expectedId) => {
706
+ assert.equal(row[0], expectedId);
707
+ assert.equal(row.id, expectedId);
708
+ assert.equal(row.ecinstanceid, expectedId);
709
+ assert.equal(row.ECINSTANCEID, expectedId);
710
+ assert.equal(row.ECInstanceId, expectedId);
711
+ assert.equal(row.toArray()[0], expectedId);
712
+ assert.equal(row.toRow().id, expectedId);
713
+ };
714
+ const readerCallback = async (readerObj) => {
715
+ let counter = 1;
716
+ let rowCount = 0;
717
+ for await (const row of readerObj) {
718
+ const currentExpectedId = expectedIds[counter - 1];
719
+ resultassertCallback(row, currentExpectedId);
720
+ counter++;
721
+ rowCount++;
722
+ }
723
+ assert.equal(rowCount, 5);
724
+ };
725
+ const syncReaderCallback = (syncReader) => {
726
+ let counter = 1;
727
+ let rowCount = 0;
728
+ for (const row of syncReader) {
729
+ const currentExpectedId = expectedIds[counter - 1];
730
+ resultassertCallback(row, currentExpectedId);
731
+ counter++;
732
+ rowCount++;
733
+ }
734
+ assert.equal(rowCount, 5);
735
+ };
736
+ iModel.withQueryReader("SELECT * FROM bis.Element c JOIN bis.Element p ON p.ECInstanceId = c.ECInstanceId LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseJsPropertyNames });
737
+ const reader = iModel.createQueryReader("SELECT * FROM bis.Element c JOIN bis.Element p ON p.ECInstanceId = c.ECInstanceId", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseJsPropertyNames });
738
+ await readerCallback(reader);
739
+ });
740
+ it("Get duplicate property names using iterable iterator with UseECSqlPropertyNames rowFormat", async () => {
741
+ const expectedIds = ["0x1", "0xe", "0x10", "0x11", "0x12"];
742
+ const resultassertCallback = (row, expectedId) => {
743
+ assert.equal(row[0], expectedId);
744
+ assert.equal(row.id, expectedId);
745
+ assert.equal(row.ecinstanceid, expectedId);
746
+ assert.equal(row.ECINSTANCEID, expectedId);
747
+ assert.equal(row.ECInstanceId, expectedId);
748
+ assert.equal(row.toArray()[0], expectedId);
749
+ assert.equal(row.toRow().ECInstanceId, expectedId);
750
+ };
751
+ const readerCallback = async (readerObj) => {
752
+ let counter = 1;
753
+ let rowCount = 0;
754
+ for await (const row of readerObj) {
755
+ const currentExpectedId = expectedIds[counter - 1];
756
+ resultassertCallback(row, currentExpectedId);
757
+ counter++;
758
+ rowCount++;
759
+ }
760
+ assert.equal(rowCount, 5);
761
+ };
762
+ const syncReaderCallback = (syncReader) => {
763
+ let counter = 1;
764
+ let rowCount = 0;
765
+ for (const row of syncReader) {
766
+ const currentExpectedId = expectedIds[counter - 1];
767
+ resultassertCallback(row, currentExpectedId);
768
+ counter++;
769
+ rowCount++;
770
+ }
771
+ assert.equal(rowCount, 5);
772
+ };
773
+ iModel.withQueryReader("SELECT * FROM bis.Element c JOIN bis.Element p ON p.ECInstanceId = c.ECInstanceId LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyNames });
774
+ const reader = iModel.createQueryReader("SELECT * FROM bis.Element c JOIN bis.Element p ON p.ECInstanceId = c.ECInstanceId", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyNames });
775
+ await readerCallback(reader);
776
+ });
777
+ it("Get duplicate property names using iterable iterator with UseECSqlPropertyIndexes rowFormat", async () => {
778
+ const expectedIds = ["0x1", "0xe", "0x10", "0x11", "0x12"];
779
+ const resultassertCallback = (row, expectedId) => {
780
+ assert.equal(row[0], expectedId);
781
+ assert.equal(row.id, expectedId);
782
+ assert.equal(row.ecinstanceid, expectedId);
783
+ assert.equal(row.ECINSTANCEID, expectedId);
784
+ assert.equal(row.ECInstanceId, expectedId);
785
+ assert.equal(row.toArray()[0], expectedId);
786
+ assert.equal(row.toRow().ECInstanceId, expectedId);
787
+ };
788
+ const readerCallback = async (readerObj) => {
789
+ let counter = 1;
790
+ let rowCount = 0;
791
+ for await (const row of readerObj) {
792
+ const currentExpectedId = expectedIds[counter - 1];
793
+ resultassertCallback(row, currentExpectedId);
794
+ counter++;
795
+ rowCount++;
796
+ }
797
+ assert.equal(rowCount, 5);
798
+ };
799
+ const syncreaderCallback = (syncReader) => {
800
+ let counter = 1;
801
+ let rowCount = 0;
802
+ for (const row of syncReader) {
803
+ const currentExpectedId = expectedIds[counter - 1];
804
+ resultassertCallback(row, currentExpectedId);
805
+ counter++;
806
+ rowCount++;
807
+ }
808
+ assert.equal(rowCount, 5);
809
+ };
810
+ iModel.withQueryReader("SELECT * FROM bis.Element c JOIN bis.Element p ON p.ECInstanceId = c.ECInstanceId LIMIT 5", syncreaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
811
+ const reader = iModel.createQueryReader("SELECT * FROM bis.Element c JOIN bis.Element p ON p.ECInstanceId = c.ECInstanceId", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
812
+ await readerCallback(reader);
813
+ });
814
+ });
815
+ describe("Get specific values", () => {
816
+ it("Get only ECInstanceId with unspecified rowFormat", async () => {
817
+ const resuktassertCallback = (queryReader, expectedId) => {
818
+ assert.equal(queryReader.current[0], expectedId);
819
+ assert.equal(queryReader.current.id, expectedId);
820
+ assert.equal(queryReader.current.ecinstanceid, expectedId);
821
+ assert.equal(queryReader.current.ECINSTANCEID, expectedId);
822
+ assert.equal(queryReader.current.ECInstanceId, expectedId);
823
+ assert.equal(queryReader.current.toArray()[0], expectedId);
824
+ assert.equal(queryReader.current.toRow().ECInstanceId, expectedId);
825
+ };
826
+ const readerCallback = async (readerObj) => {
827
+ let counter = 1;
828
+ let rowCount = 0;
829
+ while (await readerObj.step()) {
830
+ const currentExpectedId = `0x${counter}`;
831
+ resuktassertCallback(readerObj, currentExpectedId);
832
+ counter++;
833
+ rowCount++;
834
+ }
835
+ assert.equal(rowCount, 5);
836
+ };
837
+ const syncReaderCallback = (syncReader) => {
838
+ let counter = 1;
839
+ let rowCount = 0;
840
+ while (syncReader.step()) {
841
+ const currentExpectedId = `0x${counter}`;
842
+ resuktassertCallback(syncReader, currentExpectedId);
843
+ counter++;
844
+ rowCount++;
845
+ }
846
+ assert.equal(rowCount, 5);
847
+ };
848
+ iModel.withQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC LIMIT 5", syncReaderCallback);
849
+ const reader = iModel.createQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", undefined, { limit: { count: 5 } });
850
+ await readerCallback(reader);
851
+ });
852
+ it("Get only ECInstanceId with UseJsPropertyNames rowFormat", async () => {
853
+ const resultassertCallback = (queryReader, expectedId) => {
854
+ assert.equal(queryReader.current[0], expectedId);
855
+ assert.equal(queryReader.current.id, expectedId);
856
+ assert.equal(queryReader.current.ecinstanceid, expectedId);
857
+ assert.equal(queryReader.current.ECINSTANCEID, expectedId);
858
+ assert.equal(queryReader.current.ECInstanceId, expectedId);
859
+ assert.equal(queryReader.current.toArray()[0], expectedId);
860
+ assert.equal(queryReader.current.toRow().id, expectedId);
861
+ };
862
+ const readerCallback = async (readerObj) => {
863
+ let counter = 1;
864
+ let rowCount = 0;
865
+ while (await readerObj.step()) {
866
+ const currentExpectedId = `0x${counter}`;
867
+ resultassertCallback(readerObj, currentExpectedId);
868
+ counter++;
869
+ rowCount++;
870
+ }
871
+ assert.equal(rowCount, 5);
872
+ };
873
+ const syncReaderCallback = (syncReader) => {
874
+ let counter = 1;
875
+ let rowCount = 0;
876
+ while (syncReader.step()) {
877
+ const currentExpectedId = `0x${counter}`;
878
+ resultassertCallback(syncReader, currentExpectedId);
879
+ counter++;
880
+ rowCount++;
881
+ }
882
+ assert.equal(rowCount, 5);
883
+ };
884
+ iModel.withQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseJsPropertyNames });
885
+ const reader = iModel.createQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseJsPropertyNames });
886
+ await readerCallback(reader);
887
+ });
888
+ it("Get only ECInstanceId with UseECSqlPropertyNames rowFormat", async () => {
889
+ const resultassertCallback = (queryReader, expectedId) => {
890
+ assert.equal(queryReader.current[0], expectedId);
891
+ assert.equal(queryReader.current.id, expectedId);
892
+ assert.equal(queryReader.current.ecinstanceid, expectedId);
893
+ assert.equal(queryReader.current.ECINSTANCEID, expectedId);
894
+ assert.equal(queryReader.current.ECInstanceId, expectedId);
895
+ assert.equal(queryReader.current.toArray()[0], expectedId);
896
+ assert.equal(queryReader.current.toRow().ECInstanceId, expectedId);
897
+ };
898
+ const readerCallback = async (readerObj) => {
899
+ let counter = 1;
900
+ let rowCount = 0;
901
+ while (await readerObj.step()) {
902
+ const currentExpectedId = `0x${counter}`;
903
+ resultassertCallback(readerObj, currentExpectedId);
904
+ counter++;
905
+ rowCount++;
906
+ }
907
+ assert.equal(rowCount, 5);
908
+ };
909
+ const syncReaderCallback = (syncReader) => {
910
+ let counter = 1;
911
+ let rowCount = 0;
912
+ while (syncReader.step()) {
913
+ const currentExpectedId = `0x${counter}`;
914
+ resultassertCallback(syncReader, currentExpectedId);
915
+ counter++;
916
+ rowCount++;
917
+ }
918
+ assert.equal(rowCount, 5);
919
+ };
920
+ iModel.withQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyNames });
921
+ const reader = iModel.createQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyNames });
922
+ await readerCallback(reader);
923
+ });
924
+ it("Get only ECInstanceId with UseECSqlPropertyIndexes rowFormat", async () => {
925
+ const resultassertCallback = (queryReader, expectedId) => {
926
+ assert.equal(queryReader.current[0], expectedId);
927
+ assert.equal(queryReader.current.id, expectedId);
928
+ assert.equal(queryReader.current.ecinstanceid, expectedId);
929
+ assert.equal(queryReader.current.ECINSTANCEID, expectedId);
930
+ assert.equal(queryReader.current.ECInstanceId, expectedId);
931
+ assert.equal(queryReader.current.toArray()[0], expectedId);
932
+ assert.equal(queryReader.current.toRow().ECInstanceId, expectedId);
933
+ };
934
+ const readerCallback = async (readerObj) => {
935
+ let counter = 1;
936
+ let rowCount = 0;
937
+ while (await readerObj.step()) {
938
+ const currentExpectedId = `0x${counter}`;
939
+ resultassertCallback(readerObj, currentExpectedId);
940
+ counter++;
941
+ rowCount++;
942
+ }
943
+ assert.equal(rowCount, 5);
944
+ };
945
+ const syncReaderCallback = (syncReader) => {
946
+ let counter = 1;
947
+ let rowCount = 0;
948
+ while (syncReader.step()) {
949
+ const currentExpectedId = `0x${counter}`;
950
+ resultassertCallback(syncReader, currentExpectedId);
951
+ counter++;
952
+ rowCount++;
953
+ }
954
+ assert.equal(rowCount, 5);
955
+ };
956
+ iModel.withQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
957
+ const reader = iModel.createQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
958
+ await readerCallback(reader);
959
+ });
960
+ it("Get one column with custom name with unspecified rowFormat", async () => {
961
+ const resultassertCallback = (queryReader, expectedId) => {
962
+ assert.equal(queryReader.current[0], expectedId);
963
+ assert.equal(queryReader.current.customColumnName, expectedId);
964
+ assert.equal(queryReader.current.toArray()[0], expectedId);
965
+ assert.equal(queryReader.current.toRow().customColumnName, expectedId);
966
+ };
967
+ const readerCallback = async (readerObj) => {
968
+ let counter = 1;
969
+ let rowCount = 0;
970
+ while (await readerObj.step()) {
971
+ const currentExpectedId = `0x${counter}`;
972
+ resultassertCallback(readerObj, currentExpectedId);
973
+ counter++;
974
+ rowCount++;
975
+ }
976
+ assert.equal(rowCount, 5);
977
+ };
978
+ const syncReaderCallback = (syncReader) => {
979
+ let counter = 1;
980
+ let rowCount = 0;
981
+ while (syncReader.step()) {
982
+ const currentExpectedId = `0x${counter}`;
983
+ resultassertCallback(syncReader, currentExpectedId);
984
+ counter++;
985
+ rowCount++;
986
+ }
987
+ assert.equal(rowCount, 5);
988
+ };
989
+ iModel.withQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC LIMIT 5", syncReaderCallback);
990
+ const reader = iModel.createQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", undefined, { limit: { count: 5 } });
991
+ await readerCallback(reader);
992
+ });
993
+ it("Get one column with custom name with UseJsPropertyNames rowFormat", async () => {
994
+ const resultassertCallback = (queryReader, expectedId) => {
995
+ assert.equal(queryReader.current[0], expectedId);
996
+ assert.equal(queryReader.current.customColumnName, expectedId);
997
+ assert.equal(queryReader.current.toArray()[0], expectedId);
998
+ assert.equal(queryReader.current.toRow().customColumnName, expectedId);
999
+ };
1000
+ const readerCallback = async (readerObj) => {
1001
+ let counter = 1;
1002
+ let rowCount = 0;
1003
+ while (await readerObj.step()) {
1004
+ const currentExpectedId = `0x${counter}`;
1005
+ resultassertCallback(readerObj, currentExpectedId);
1006
+ counter++;
1007
+ rowCount++;
1008
+ }
1009
+ assert.equal(rowCount, 5);
1010
+ };
1011
+ const syncReaderCallback = (syncReader) => {
1012
+ let counter = 1;
1013
+ let rowCount = 0;
1014
+ while (syncReader.step()) {
1015
+ const currentExpectedId = `0x${counter}`;
1016
+ resultassertCallback(syncReader, currentExpectedId);
1017
+ counter++;
1018
+ rowCount++;
1019
+ }
1020
+ assert.equal(rowCount, 5);
1021
+ };
1022
+ iModel.withQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseJsPropertyNames });
1023
+ const reader = iModel.createQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseJsPropertyNames });
1024
+ await readerCallback(reader);
1025
+ });
1026
+ it("Get one column with custom name with UseECSqlPropertyNames rowFormat", async () => {
1027
+ const resultassertCallback = (queryReader, expectedId) => {
1028
+ assert.equal(queryReader.current[0], expectedId);
1029
+ assert.equal(queryReader.current.customColumnName, expectedId);
1030
+ assert.equal(queryReader.current.toArray()[0], expectedId);
1031
+ assert.equal(queryReader.current.toRow().customColumnName, expectedId);
1032
+ };
1033
+ const readerCallback = async (readerObj) => {
1034
+ let counter = 1;
1035
+ let rowCount = 0;
1036
+ while (await readerObj.step()) {
1037
+ const currentExpectedId = `0x${counter}`;
1038
+ resultassertCallback(readerObj, currentExpectedId);
1039
+ counter++;
1040
+ rowCount++;
1041
+ }
1042
+ assert.equal(rowCount, 5);
1043
+ };
1044
+ const syncReaderCallback = (syncReader) => {
1045
+ let counter = 1;
1046
+ let rowCount = 0;
1047
+ while (syncReader.step()) {
1048
+ const currentExpectedId = `0x${counter}`;
1049
+ resultassertCallback(syncReader, currentExpectedId);
1050
+ counter++;
1051
+ rowCount++;
1052
+ }
1053
+ assert.equal(rowCount, 5);
1054
+ };
1055
+ iModel.withQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyNames });
1056
+ const reader = iModel.createQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyNames });
1057
+ await readerCallback(reader);
1058
+ });
1059
+ it("Get one column with custom name with UseECSqlPropertyIndexes rowFormat", async () => {
1060
+ const resultassertCallback = (queryReader, expectedId) => {
1061
+ assert.equal(queryReader.current[0], expectedId);
1062
+ assert.equal(queryReader.current.customColumnName, expectedId);
1063
+ assert.equal(queryReader.current.toArray()[0], expectedId);
1064
+ assert.equal(queryReader.current.toRow().customColumnName, expectedId);
1065
+ };
1066
+ const readerCallback = async (readerObj) => {
1067
+ let counter = 1;
1068
+ let rowCount = 0;
1069
+ while (await readerObj.step()) {
1070
+ const currentExpectedId = `0x${counter}`;
1071
+ resultassertCallback(readerObj, currentExpectedId);
1072
+ counter++;
1073
+ rowCount++;
1074
+ }
1075
+ assert.equal(rowCount, 5);
1076
+ };
1077
+ const syncReaderCallback = (syncReader) => {
1078
+ let counter = 1;
1079
+ let rowCount = 0;
1080
+ while (syncReader.step()) {
1081
+ const currentExpectedId = `0x${counter}`;
1082
+ resultassertCallback(syncReader, currentExpectedId);
1083
+ counter++;
1084
+ rowCount++;
1085
+ }
1086
+ assert.equal(rowCount, 5);
1087
+ };
1088
+ iModel.withQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC LIMIT 5", syncReaderCallback, undefined, { rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
1089
+ const reader = iModel.createQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", undefined, { limit: { count: 5 }, rowFormat: QueryRowFormat.UseECSqlPropertyIndexes });
1090
+ await readerCallback(reader);
1091
+ });
1092
+ });
1093
+ describe("Get count of results", () => {
1094
+ const expectedRowCount = 46; // 46 Elements in test.bim
1095
+ const sql = "SELECT COUNT(*) numResults FROM (SELECT * FROM bis.Element)";
1096
+ it("Get count of rows using current index", async () => {
1097
+ const syncReaderCallback = (syncReader) => {
1098
+ syncReader.step();
1099
+ assert.equal(syncReader.current[0], expectedRowCount);
1100
+ };
1101
+ const readerCallback = async (readerObj) => {
1102
+ await readerObj.step();
1103
+ assert.equal(readerObj.current[0], expectedRowCount);
1104
+ };
1105
+ iModel.withQueryReader(sql, syncReaderCallback);
1106
+ const reader = iModel.createQueryReader(sql);
1107
+ await readerCallback(reader);
1108
+ });
1109
+ it("Get count of rows using current column name", async () => {
1110
+ const readerCallback = async (readerObj) => {
1111
+ await readerObj.step();
1112
+ assert.equal(readerObj.current.numResults, expectedRowCount);
1113
+ };
1114
+ const syncReaderCallback = (syncReader) => {
1115
+ syncReader.step();
1116
+ assert.equal(syncReader.current.numResults, expectedRowCount);
1117
+ };
1118
+ iModel.withQueryReader(sql, syncReaderCallback);
1119
+ const reader = iModel.createQueryReader(sql);
1120
+ await readerCallback(reader);
1121
+ });
1122
+ it("Get count of rows using current and toRow", async () => {
1123
+ const readerCallback = async (readerObj) => {
1124
+ await readerObj.step();
1125
+ assert.equal(readerObj.current.toRow().numResults, expectedRowCount);
1126
+ };
1127
+ const syncReaderCallback = (syncReader) => {
1128
+ syncReader.step();
1129
+ assert.equal(syncReader.current.toRow().numResults, expectedRowCount);
1130
+ };
1131
+ iModel.withQueryReader(sql, syncReaderCallback);
1132
+ const reader = iModel.createQueryReader(sql);
1133
+ await readerCallback(reader);
1134
+ });
1135
+ it("Get count of rows using toArray result itself", async () => {
1136
+ const readerCallback = async (readerObj) => {
1137
+ await readerObj.step();
1138
+ assert.equal(readerObj.current.toArray()[0], expectedRowCount);
1139
+ };
1140
+ const syncReaderCallback = (syncReader) => {
1141
+ syncReader.step();
1142
+ assert.equal(syncReader.current.toArray()[0], expectedRowCount);
1143
+ };
1144
+ iModel.withQueryReader(sql, syncReaderCallback);
1145
+ const reader = iModel.createQueryReader(sql);
1146
+ await readerCallback(reader);
1147
+ });
1148
+ it("Get count of rows using iterable iterator and index", async () => {
1149
+ const readerCallback = async (readerObj) => {
1150
+ let count = 0;
1151
+ for await (const row of readerObj) {
1152
+ count = row[0];
1153
+ }
1154
+ assert.equal(count, expectedRowCount);
1155
+ };
1156
+ const syncReaderCallback = (syncReader) => {
1157
+ let count = 0;
1158
+ for (const row of syncReader) {
1159
+ count = row[0];
1160
+ }
1161
+ assert.equal(count, expectedRowCount);
1162
+ };
1163
+ iModel.withQueryReader(sql, syncReaderCallback);
1164
+ const reader = iModel.createQueryReader(sql);
1165
+ await readerCallback(reader);
1166
+ });
1167
+ it("Get count of rows using iterable iterator and column name", async () => {
1168
+ const readerCallback = async (readerObj) => {
1169
+ let count = 0;
1170
+ for await (const row of readerObj) {
1171
+ count = row.numResults;
1172
+ }
1173
+ assert.equal(count, expectedRowCount);
1174
+ };
1175
+ const syncReaderCallback = (syncReader) => {
1176
+ let count = 0;
1177
+ for (const row of syncReader) {
1178
+ count = row.numResults;
1179
+ }
1180
+ assert.equal(count, expectedRowCount);
1181
+ };
1182
+ iModel.withQueryReader(sql, syncReaderCallback);
1183
+ const reader = iModel.createQueryReader(sql);
1184
+ await readerCallback(reader);
1185
+ });
1186
+ it("Get count of rows using iterable iterator and toRow", async () => {
1187
+ const readerCallback = async (readerObj) => {
1188
+ let count = 0;
1189
+ for await (const row of readerObj) {
1190
+ count = row.toRow().numResults;
1191
+ }
1192
+ assert.equal(count, expectedRowCount);
1193
+ };
1194
+ const syncReaderCallback = (syncReader) => {
1195
+ let count = 0;
1196
+ for (const row of syncReader) {
1197
+ count = row.toRow().numResults;
1198
+ }
1199
+ assert.equal(count, expectedRowCount);
1200
+ };
1201
+ iModel.withQueryReader(sql, syncReaderCallback);
1202
+ const reader = iModel.createQueryReader(sql);
1203
+ await readerCallback(reader);
1204
+ });
1205
+ });
1206
+ describe("Tests for extendedType and extendType property behaviour of QueryPropertyMetaData", () => {
1207
+ it("Id type column with alias", async () => {
1208
+ const readerCallback = async (readerObj) => {
1209
+ const metaData = await readerObj.getMetaData();
1210
+ assert.equal("Id", metaData[0].extendedType);
1211
+ assert.equal("Id", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1212
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1213
+ };
1214
+ const syncReaderCallback = (syncReader) => {
1215
+ const metaData = syncReader.getMetaData();
1216
+ assert.equal("Id", metaData[0].extendedType);
1217
+ assert.equal("Id", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1218
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1219
+ };
1220
+ iModel.withQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", syncReaderCallback);
1221
+ const reader = iModel.createQueryReader("SELECT ECInstanceId customColumnName FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC");
1222
+ await readerCallback(reader);
1223
+ });
1224
+ it("Id type column without alias", async () => {
1225
+ const readerCallback = async (readerObj) => {
1226
+ const metaData = await readerObj.getMetaData();
1227
+ assert.equal("Id", metaData[0].extendedType);
1228
+ assert.equal("Id", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1229
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1230
+ };
1231
+ const syncReaderCallback = (syncReader) => {
1232
+ const metaData = syncReader.getMetaData();
1233
+ assert.equal("Id", metaData[0].extendedType);
1234
+ assert.equal("Id", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1235
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1236
+ };
1237
+ iModel.withQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC", syncReaderCallback);
1238
+ const reader = iModel.createQueryReader("SELECT ECInstanceId FROM meta.ECSchemaDef ORDER BY ECInstanceId ASC");
1239
+ await readerCallback(reader);
1240
+ });
1241
+ it("ClassId type column", async () => {
1242
+ const readerCallback = async (readerObj) => {
1243
+ const metaData = await readerObj.getMetaData();
1244
+ assert.equal("ClassId", metaData[0].extendedType);
1245
+ assert.equal("ClassId", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1246
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1247
+ };
1248
+ const syncReaderCallback = (syncReader) => {
1249
+ const metaData = syncReader.getMetaData();
1250
+ assert.equal("ClassId", metaData[0].extendedType);
1251
+ assert.equal("ClassId", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1252
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1253
+ };
1254
+ iModel.withQueryReader("SELECT ECClassId FROM bis.Element ORDER BY ECClassId ASC", syncReaderCallback);
1255
+ const reader = iModel.createQueryReader("SELECT ECClassId FROM bis.Element ORDER BY ECClassId ASC");
1256
+ await readerCallback(reader);
1257
+ });
1258
+ it("Column without extended type", async () => {
1259
+ const readerCallback = async (readerObj) => {
1260
+ const metaData = await readerObj.getMetaData();
1261
+ assert.equal(undefined, metaData[0].extendedType);
1262
+ assert.equal("", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1263
+ };
1264
+ const syncReaderCallback = (syncReader) => {
1265
+ const metaData = syncReader.getMetaData();
1266
+ assert.equal(undefined, metaData[0].extendedType);
1267
+ assert.equal("", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1268
+ };
1269
+ iModel.withQueryReader("SELECT s.Name FROM meta.ECSchemaDef s ORDER BY s.Name ASC", syncReaderCallback);
1270
+ const reader = iModel.createQueryReader("SELECT s.Name FROM meta.ECSchemaDef s ORDER BY s.Name ASC");
1271
+ await readerCallback(reader);
1272
+ });
1273
+ it("Column without extended type with alias", async () => {
1274
+ const readerCallback = async (readerObj) => {
1275
+ const metaData = await readerObj.getMetaData();
1276
+ assert.equal(undefined, metaData[0].extendedType);
1277
+ assert.equal("", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1278
+ };
1279
+ const syncReaderCallback = (syncReader) => {
1280
+ const metaData = syncReader.getMetaData();
1281
+ assert.equal(undefined, metaData[0].extendedType);
1282
+ assert.equal("", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1283
+ };
1284
+ iModel.withQueryReader("SELECT s.Name a FROM meta.ECSchemaDef s ORDER BY a ASC", syncReaderCallback);
1285
+ const reader = iModel.createQueryReader("SELECT s.Name a FROM meta.ECSchemaDef s ORDER BY a ASC");
1286
+ await readerCallback(reader);
1287
+ });
1288
+ it("Geometric type column with alias", async () => {
1289
+ const readerCallback = async (readerObj) => {
1290
+ const metaData = await readerObj.getMetaData();
1291
+ assert.equal("GeometryStream", metaData[0].extendedType);
1292
+ assert.equal("GeometryStream", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1293
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1294
+ };
1295
+ const syncReaderCallback = (syncReader) => {
1296
+ const metaData = syncReader.getMetaData();
1297
+ assert.equal("GeometryStream", metaData[0].extendedType);
1298
+ assert.equal("GeometryStream", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1299
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1300
+ };
1301
+ iModel.withQueryReader("select GeometryStream A from bis.GeometricElement3d LIMIT 1", syncReaderCallback);
1302
+ const reader = iModel.createQueryReader("select GeometryStream A from bis.GeometricElement3d LIMIT 1");
1303
+ await readerCallback(reader);
1304
+ });
1305
+ it("Geometric type column without alias", async () => {
1306
+ const readerCallback = async (readerObj) => {
1307
+ const metaData = await readerObj.getMetaData();
1308
+ assert.equal("GeometryStream", metaData[0].extendedType);
1309
+ assert.equal("GeometryStream", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1310
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1311
+ };
1312
+ const syncReaderCallback = (syncReader) => {
1313
+ const metaData = syncReader.getMetaData();
1314
+ assert.equal("GeometryStream", metaData[0].extendedType);
1315
+ assert.equal("GeometryStream", metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1316
+ assert.equal(metaData[0].extendedType, metaData[0].extendType); // eslint-disable-line @typescript-eslint/no-deprecated
1317
+ };
1318
+ iModel.withQueryReader("select GeometryStream from bis.GeometricElement3d LIMIT 1", syncReaderCallback);
1319
+ const reader = iModel.createQueryReader("select GeometryStream from bis.GeometricElement3d LIMIT 1");
1320
+ await readerCallback(reader);
1321
+ });
1322
+ });
1323
+ });
1324
+ }));
1325
+ describe("createQueryReader vs withQueryReader ", () => {
1326
+ /** Deletes an entire element tree, including sub-models, child elements and code scope references.
1327
+ * Items are deleted in bottom-up order. Definitions and Subjects are deleted after normal elements.
1328
+ * Call deleteNormalElements on each tree. Then call deleteSpecialElements.
1329
+ */
1330
+ class TestElementCascadingDeleter extends ElementTreeDeleter {
1331
+ shouldVisitCodeScopes(_elementId, _scope) {
1332
+ return true;
1333
+ }
1334
+ /** The main tree-walking function */
1335
+ processElementTree(element, scope) {
1336
+ if (this.shouldVisitCodeScopes(element, scope)) {
1337
+ this._processCodeScopes(element, scope);
1338
+ }
1339
+ super.processElementTree(element, scope);
1340
+ }
1341
+ /** Process code scope references */
1342
+ _processCodeScopes(element, scope) {
1343
+ const newScope = new ElementTreeWalkerScope(scope, element);
1344
+ // eslint-disable-next-line @typescript-eslint/no-deprecated
1345
+ this._iModel.withPreparedStatement(`
1346
+ SELECT ECInstanceId
1347
+ FROM bis.Element
1348
+ WHERE CodeScope.id=?
1349
+ AND Parent.id IS NULL
1350
+ `, (stmt) => {
1351
+ stmt.bindId(1, element);
1352
+ while (stmt.step() === DbResult.BE_SQLITE_ROW) {
1353
+ const elementId = stmt.getValue(0).getId();
1354
+ this.processElementTree(elementId, newScope);
1355
+ }
1356
+ });
1357
+ }
1358
+ }
1359
+ // Actual test begins here
1360
+ let iModelDb;
1361
+ function createTestIModelWithScopedPhysicalObject() {
1362
+ const pathForEmpty = IModelTestUtils.prepareOutputFile("ECReferenceTypesCache", "empty.bim");
1363
+ const testIModelDb = SnapshotDb.createEmpty(pathForEmpty, {
1364
+ rootSubject: { name: "empty " },
1365
+ });
1366
+ const subjectId = Subject.insert(testIModelDb, IModel.rootSubjectId, "Subject", "Subject Description");
1367
+ const physicalModelId = PhysicalModel.insert(testIModelDb, subjectId, "Physical");
1368
+ const definitionModelId = DefinitionModel.insert(testIModelDb, subjectId, "Definition");
1369
+ const spatialCategoryId = IModelTestUtils.insertSpatialCategory(testIModelDb, definitionModelId, "SpatialCategory", ColorDef.green);
1370
+ const physicalObjectProps5 = {
1371
+ classFullName: PhysicalObject.classFullName,
1372
+ model: physicalModelId,
1373
+ category: spatialCategoryId,
1374
+ code: Code.createEmpty(),
1375
+ userLabel: "ScopingElement",
1376
+ };
1377
+ const scopingElement = testIModelDb.elements.insertElement(physicalObjectProps5);
1378
+ const childElement = {
1379
+ classFullName: PhysicalObject.classFullName,
1380
+ model: physicalModelId,
1381
+ category: spatialCategoryId,
1382
+ code: { spec: "0x1", scope: scopingElement },
1383
+ userLabel: "ScopedElement",
1384
+ };
1385
+ testIModelDb.elements.insertElement(childElement);
1386
+ testIModelDb.saveChanges();
1387
+ return testIModelDb;
1388
+ }
1389
+ beforeEach(async () => {
1390
+ iModelDb = createTestIModelWithScopedPhysicalObject();
1391
+ });
1392
+ afterEach(async () => {
1393
+ iModelDb.close();
1394
+ });
1395
+ it("Failing while using createQueryReader()", async () => {
1396
+ const sql = `
1397
+ SELECT ECInstanceId
1398
+ FROM ${PhysicalObject.classFullName}
1399
+ `;
1400
+ const reader = iModelDb.createQueryReader(sql, undefined, { usePrimaryConn: true });
1401
+ const elementTreeDeleter = new TestElementCascadingDeleter(iModelDb);
1402
+ await reader.step(); // step to initialize reader
1403
+ const firstId = reader.current[0];
1404
+ elementTreeDeleter.deleteNormalElements(firstId);
1405
+ await reader.step(); // step to initialize reader
1406
+ const secondId = reader.current[0];
1407
+ // This is because ecsqlreader built using createQueryReader caches results and so when it tries to access the second element, it is already deleted from the database and it throws "Not Found" error.
1408
+ expect(() => elementTreeDeleter.deleteNormalElements(secondId)).to.throw();
1409
+ });
1410
+ it("Passing while using withQueryReader()", async () => {
1411
+ const sql = `
1412
+ SELECT ECInstanceId
1413
+ FROM ${PhysicalObject.classFullName}
1414
+ `;
1415
+ iModelDb.withQueryReader(sql, (reader) => {
1416
+ const elementTreeDeleter = new TestElementCascadingDeleter(iModelDb);
1417
+ let cntSteps = 0;
1418
+ while (reader.step()) {
1419
+ const id = reader.current[0];
1420
+ elementTreeDeleter.deleteNormalElements(id);
1421
+ cntSteps++;
1422
+ }
1423
+ assert.equal(cntSteps, 1);
1424
+ });
1425
+ });
1426
+ });
1427
+ //# sourceMappingURL=QueryReaders.test.js.map