@itwin/core-backend 5.0.0-dev.113 → 5.0.0-dev.115
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +8 -1
- package/lib/cjs/BriefcaseManager.d.ts +10 -2
- package/lib/cjs/BriefcaseManager.d.ts.map +1 -1
- package/lib/cjs/BriefcaseManager.js +12 -0
- package/lib/cjs/BriefcaseManager.js.map +1 -1
- package/lib/cjs/ExportGraphics.d.ts +54 -8
- package/lib/cjs/ExportGraphics.d.ts.map +1 -1
- package/lib/cjs/ExportGraphics.js +158 -59
- package/lib/cjs/ExportGraphics.js.map +1 -1
- package/lib/cjs/IModelDb.d.ts.map +1 -1
- package/lib/cjs/IModelDb.js +3 -0
- package/lib/cjs/IModelDb.js.map +1 -1
- package/lib/esm/BriefcaseManager.d.ts +10 -2
- package/lib/esm/BriefcaseManager.d.ts.map +1 -1
- package/lib/esm/BriefcaseManager.js +12 -0
- package/lib/esm/BriefcaseManager.js.map +1 -1
- package/lib/esm/ExportGraphics.d.ts +54 -8
- package/lib/esm/ExportGraphics.d.ts.map +1 -1
- package/lib/esm/ExportGraphics.js +156 -58
- package/lib/esm/ExportGraphics.js.map +1 -1
- package/lib/esm/IModelDb.d.ts.map +1 -1
- package/lib/esm/IModelDb.js +3 -0
- package/lib/esm/IModelDb.js.map +1 -1
- package/lib/esm/test/standalone/ExportGraphics.test.js +53 -1
- package/lib/esm/test/standalone/ExportGraphics.test.js.map +1 -1
- package/lib/esm/test/standalone/IModelLimits.test.d.ts +2 -0
- package/lib/esm/test/standalone/IModelLimits.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/IModelLimits.test.js +103 -0
- package/lib/esm/test/standalone/IModelLimits.test.js.map +1 -0
- package/lib/esm/test/standalone/SnapshotDb.test.js +19 -1
- package/lib/esm/test/standalone/SnapshotDb.test.js.map +1 -1
- package/package.json +12 -12
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
/*---------------------------------------------------------------------------------------------
|
|
2
|
+
* Copyright (c) Bentley Systems, Incorporated. All rights reserved.
|
|
3
|
+
* See LICENSE.md in the project root for license terms and full copyright notice.
|
|
4
|
+
*--------------------------------------------------------------------------------------------*/
|
|
5
|
+
import { Code, IModel, SubCategoryAppearance } from "@itwin/core-common";
|
|
6
|
+
import * as chai from "chai";
|
|
7
|
+
import { assert } from "chai";
|
|
8
|
+
import * as chaiAsPromised from "chai-as-promised";
|
|
9
|
+
import { HubWrappers, KnownTestLocations } from "..";
|
|
10
|
+
import { ChannelControl, IModelHost, SpatialCategory } from "../../core-backend";
|
|
11
|
+
import { HubMock } from "../../internal/HubMock";
|
|
12
|
+
import { IModelTestUtils, TestUserType } from "../IModelTestUtils";
|
|
13
|
+
chai.use(chaiAsPromised);
|
|
14
|
+
describe("imodel limits", function () {
|
|
15
|
+
const ctx = {
|
|
16
|
+
accessTokens: {
|
|
17
|
+
user1: "",
|
|
18
|
+
user2: "",
|
|
19
|
+
user3: "",
|
|
20
|
+
},
|
|
21
|
+
iModelId: "",
|
|
22
|
+
iTwinId: "",
|
|
23
|
+
modelId: "",
|
|
24
|
+
spatialCategoryId: "",
|
|
25
|
+
iModelName: "TestIModel",
|
|
26
|
+
rootSubject: "TestSubject",
|
|
27
|
+
openBriefcase: async (user, noLock) => {
|
|
28
|
+
const b = await HubWrappers.downloadAndOpenBriefcase({ accessToken: ctx.accessTokens[user], iTwinId: ctx.iTwinId, iModelId: ctx.iModelId, noLock });
|
|
29
|
+
b.channels.addAllowedChannel(ChannelControl.sharedChannelName);
|
|
30
|
+
return b;
|
|
31
|
+
},
|
|
32
|
+
openB1: async (noLock) => { return ctx.openBriefcase("user1", noLock); },
|
|
33
|
+
openB2: async (noLock) => { return ctx.openBriefcase("user2", noLock); },
|
|
34
|
+
openB3: async (noLock) => { return ctx.openBriefcase("user3", noLock); },
|
|
35
|
+
};
|
|
36
|
+
before(async () => {
|
|
37
|
+
await IModelHost.startup();
|
|
38
|
+
HubMock.startup("PullMergeMethod", KnownTestLocations.outputDir);
|
|
39
|
+
});
|
|
40
|
+
after(async () => {
|
|
41
|
+
HubMock.shutdown();
|
|
42
|
+
});
|
|
43
|
+
beforeEach(async () => {
|
|
44
|
+
ctx.iTwinId = HubMock.iTwinId;
|
|
45
|
+
ctx.accessTokens.user1 = await HubWrappers.getAccessToken(TestUserType.SuperManager);
|
|
46
|
+
ctx.accessTokens.user2 = await HubWrappers.getAccessToken(TestUserType.Regular);
|
|
47
|
+
ctx.accessTokens.user3 = await HubWrappers.getAccessToken(TestUserType.Super);
|
|
48
|
+
ctx.iModelId = await HubMock.createNewIModel({ accessToken: ctx.accessTokens.user1, iTwinId: ctx.iTwinId, iModelName: ctx.iModelName, description: ctx.rootSubject });
|
|
49
|
+
assert.isNotEmpty(ctx.iModelId);
|
|
50
|
+
const b1 = await ctx.openB1(true);
|
|
51
|
+
await b1.locks.acquireLocks({ shared: IModel.dictionaryId });
|
|
52
|
+
[, ctx.modelId] = IModelTestUtils.createAndInsertPhysicalPartitionAndModel(b1, IModelTestUtils.getUniqueModelCode(b1, "newPhysicalModel"), true);
|
|
53
|
+
const dictionary = b1.models.getModel(IModel.dictionaryId);
|
|
54
|
+
const newCategoryCode = IModelTestUtils.getUniqueSpatialCategoryCode(dictionary, "ThisTestSpatialCategory");
|
|
55
|
+
ctx.spatialCategoryId = SpatialCategory.insert(dictionary.iModel, dictionary.id, newCategoryCode.value, new SubCategoryAppearance({ color: 0xff0000 }));
|
|
56
|
+
b1.saveChanges();
|
|
57
|
+
await b1.pushChanges({ description: "" });
|
|
58
|
+
b1.close();
|
|
59
|
+
});
|
|
60
|
+
it("apply changes where max columns for class is used", async () => {
|
|
61
|
+
const b1 = await ctx.openB1(true);
|
|
62
|
+
const b2 = await ctx.openB2(true);
|
|
63
|
+
// Import schema into b1 but do not push it.
|
|
64
|
+
const createSchema = (additionProps) => {
|
|
65
|
+
const schema = [
|
|
66
|
+
`<?xml version="1.0" encoding="UTF-8"?>`,
|
|
67
|
+
`<ECSchema schemaName="TestSchema1" alias="ts" version="01.00.00" xmlns="http://www.bentley.com/schemas/Bentley.ECXML.3.1">`,
|
|
68
|
+
` <ECSchemaReference name="BisCore" version="01.00.00" alias="bis"/>`,
|
|
69
|
+
` <ECEntityClass typeName="Pipe1">`,
|
|
70
|
+
` <BaseClass>bis:GeometricElement3d</BaseClass>`,
|
|
71
|
+
];
|
|
72
|
+
for (let i = 0; i < additionProps; i++) {
|
|
73
|
+
schema.push(` <ECProperty propertyName="p${i}" typeName="int" />`);
|
|
74
|
+
}
|
|
75
|
+
schema.push(...[
|
|
76
|
+
` </ECEntityClass>`,
|
|
77
|
+
`</ECSchema>`
|
|
78
|
+
]);
|
|
79
|
+
return schema.join("\n");
|
|
80
|
+
};
|
|
81
|
+
const schemaThatMaxOutColumnsLimit = 2030;
|
|
82
|
+
await b1.importSchemaStrings([createSchema(schemaThatMaxOutColumnsLimit)]);
|
|
83
|
+
b1.saveChanges();
|
|
84
|
+
await b1.pushChanges({ description: "import schema" });
|
|
85
|
+
const elementProps = {
|
|
86
|
+
classFullName: "TestSchema1:Pipe1",
|
|
87
|
+
model: ctx.modelId,
|
|
88
|
+
category: ctx.spatialCategoryId,
|
|
89
|
+
code: Code.createEmpty(),
|
|
90
|
+
};
|
|
91
|
+
const el = b1.elements.createElement(elementProps);
|
|
92
|
+
b1.elements.insertElement(el.toJSON());
|
|
93
|
+
b1.saveChanges();
|
|
94
|
+
await b1.pushChanges({ description: "add element" });
|
|
95
|
+
// Error applying changeset with id [22f762181d236dfe25bb32e38ed3b7509e975deb]: failed to apply changes
|
|
96
|
+
// Expression depth is 2001 where current limit is 2000
|
|
97
|
+
await b2.pullChanges();
|
|
98
|
+
b1.close();
|
|
99
|
+
b2.close();
|
|
100
|
+
HubMock.shutdown();
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
//# sourceMappingURL=IModelLimits.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IModelLimits.test.js","sourceRoot":"","sources":["../../../../src/test/standalone/IModelLimits.test.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n\nimport {\n Code,\n GeometricElement3dProps,\n IModel, SubCategoryAppearance\n} from \"@itwin/core-common\";\nimport * as chai from \"chai\";\nimport { assert } from \"chai\";\nimport * as chaiAsPromised from \"chai-as-promised\";\nimport { HubWrappers, KnownTestLocations } from \"..\";\nimport {\n ChannelControl,\n DictionaryModel,\n IModelHost,\n SpatialCategory\n} from \"../../core-backend\";\nimport { HubMock } from \"../../internal/HubMock\";\nimport { IModelTestUtils, TestUserType } from \"../IModelTestUtils\";\nimport { Suite } from \"mocha\";\nchai.use(chaiAsPromised);\n\ndescribe(\"imodel limits\", function (this: Suite) {\n const ctx = {\n accessTokens: {\n user1: \"\",\n user2: \"\",\n user3: \"\",\n },\n iModelId: \"\",\n iTwinId: \"\",\n modelId: \"\",\n spatialCategoryId: \"\",\n iModelName: \"TestIModel\",\n rootSubject: \"TestSubject\",\n openBriefcase: async (user: \"user1\" | \"user2\" | \"user3\", noLock?: true) => {\n const b = await HubWrappers.downloadAndOpenBriefcase({ accessToken: ctx.accessTokens[user], iTwinId: ctx.iTwinId, iModelId: ctx.iModelId, noLock });\n b.channels.addAllowedChannel(ChannelControl.sharedChannelName);\n return b;\n },\n openB1: async (noLock?: true) => { return ctx.openBriefcase(\"user1\", noLock); },\n openB2: async (noLock?: true) => { return ctx.openBriefcase(\"user2\", noLock); },\n openB3: async (noLock?: true) => { return ctx.openBriefcase(\"user3\", noLock); },\n }\n\n before(async () => {\n await IModelHost.startup();\n HubMock.startup(\"PullMergeMethod\", KnownTestLocations.outputDir);\n });\n\n after(async () => {\n HubMock.shutdown()\n });\n\n beforeEach(async () => {\n ctx.iTwinId = HubMock.iTwinId;\n ctx.accessTokens.user1 = await HubWrappers.getAccessToken(TestUserType.SuperManager);\n ctx.accessTokens.user2 = await HubWrappers.getAccessToken(TestUserType.Regular);\n ctx.accessTokens.user3 = await HubWrappers.getAccessToken(TestUserType.Super);\n ctx.iModelId = await HubMock.createNewIModel({ accessToken: ctx.accessTokens.user1, iTwinId: ctx.iTwinId, iModelName: ctx.iModelName, description: ctx.rootSubject });\n assert.isNotEmpty(ctx.iModelId);\n const b1 = await ctx.openB1(true);\n await b1.locks.acquireLocks({ shared: IModel.dictionaryId });\n [, ctx.modelId] = IModelTestUtils.createAndInsertPhysicalPartitionAndModel(\n b1,\n IModelTestUtils.getUniqueModelCode(b1, \"newPhysicalModel\"),\n true);\n const dictionary: DictionaryModel = b1.models.getModel<DictionaryModel>(IModel.dictionaryId);\n const newCategoryCode = IModelTestUtils.getUniqueSpatialCategoryCode(dictionary, \"ThisTestSpatialCategory\");\n ctx.spatialCategoryId = SpatialCategory.insert(\n dictionary.iModel,\n dictionary.id,\n newCategoryCode.value,\n new SubCategoryAppearance({ color: 0xff0000 }),\n );\n b1.saveChanges();\n await b1.pushChanges({ description: \"\" });\n b1.close();\n });\n\n it(\"apply changes where max columns for class is used\", async () => {\n const b1 = await ctx.openB1(true);\n const b2 = await ctx.openB2(true);\n\n // Import schema into b1 but do not push it.\n const createSchema = (additionProps: number) => {\n const schema = [\n `<?xml version=\"1.0\" encoding=\"UTF-8\"?>`,\n `<ECSchema schemaName=\"TestSchema1\" alias=\"ts\" version=\"01.00.00\" xmlns=\"http://www.bentley.com/schemas/Bentley.ECXML.3.1\">`,\n ` <ECSchemaReference name=\"BisCore\" version=\"01.00.00\" alias=\"bis\"/>`,\n ` <ECEntityClass typeName=\"Pipe1\">`,\n ` <BaseClass>bis:GeometricElement3d</BaseClass>`,\n ];\n\n for (let i = 0; i < additionProps; i++) {\n schema.push(` <ECProperty propertyName=\"p${i}\" typeName=\"int\" />`);\n }\n\n schema.push(...[\n ` </ECEntityClass>`,\n `</ECSchema>`\n ]);\n return schema.join(\"\\n\");\n }\n\n const schemaThatMaxOutColumnsLimit = 2030;\n\n await b1.importSchemaStrings([createSchema(schemaThatMaxOutColumnsLimit)]);\n b1.saveChanges();\n await b1.pushChanges({ description: \"import schema\" });\n\n const elementProps: GeometricElement3dProps = {\n classFullName: \"TestSchema1:Pipe1\",\n model: ctx.modelId,\n category: ctx.spatialCategoryId,\n code: Code.createEmpty(),\n };\n const el = b1.elements.createElement(elementProps);\n b1.elements.insertElement(el.toJSON());\n b1.saveChanges();\n await b1.pushChanges({ description: \"add element\" });\n\n // Error applying changeset with id [22f762181d236dfe25bb32e38ed3b7509e975deb]: failed to apply changes\n // Expression depth is 2001 where current limit is 2000\n await b2.pullChanges();\n\n b1.close();\n b2.close();\n\n HubMock.shutdown();\n });\n});\n"]}
|
|
@@ -5,12 +5,16 @@
|
|
|
5
5
|
import { expect } from "chai";
|
|
6
6
|
import * as sinon from "sinon";
|
|
7
7
|
import { CheckpointManager, V2CheckpointManager } from "../../CheckpointManager";
|
|
8
|
-
import { IModelDb, SnapshotDb } from "../../IModelDb";
|
|
8
|
+
import { IModelDb, SnapshotDb, StandaloneDb } from "../../IModelDb";
|
|
9
9
|
import { Logger } from "@itwin/core-bentley";
|
|
10
10
|
import { IModelHost } from "../../IModelHost";
|
|
11
11
|
import { HubMock } from "../../internal/HubMock";
|
|
12
12
|
import { _hubAccess } from "../../internal/Symbols";
|
|
13
13
|
import { IModelTestUtils } from "../IModelTestUtils";
|
|
14
|
+
import { SpatialCategory } from "../../Category";
|
|
15
|
+
import { KnownTestLocations } from "../KnownTestLocations";
|
|
16
|
+
import * as path from "path";
|
|
17
|
+
import { IModelJsFs } from "../../IModelJsFs";
|
|
14
18
|
describe("SnapshotDb.refreshContainerForRpc", () => {
|
|
15
19
|
afterEach(() => sinon.restore());
|
|
16
20
|
const changeset = { id: "fakeChangeSetId", index: 10 };
|
|
@@ -42,6 +46,20 @@ describe("SnapshotDb.refreshContainerForRpc", () => {
|
|
|
42
46
|
getFilePath: () => "fakeFilePath",
|
|
43
47
|
clearECDbCache: () => { },
|
|
44
48
|
};
|
|
49
|
+
it("perform checkpoint", async () => {
|
|
50
|
+
const sourceFileName = path.join(KnownTestLocations.outputDir, "checkpoint1.bim");
|
|
51
|
+
if (IModelJsFs.existsSync(sourceFileName))
|
|
52
|
+
IModelJsFs.removeSync(sourceFileName);
|
|
53
|
+
const iModel = StandaloneDb.createEmpty(sourceFileName, {
|
|
54
|
+
rootSubject: { name: sourceFileName },
|
|
55
|
+
});
|
|
56
|
+
iModel.clearCaches();
|
|
57
|
+
iModel.performCheckpoint();
|
|
58
|
+
SpatialCategory.insert(iModel, IModelDb.dictionaryId, "spatial category", {});
|
|
59
|
+
// Use to throw error SQLITE_LOCKED
|
|
60
|
+
iModel.performCheckpoint();
|
|
61
|
+
iModel.close();
|
|
62
|
+
});
|
|
45
63
|
it("should restart default txn after inactivity", async () => {
|
|
46
64
|
const clock = sinon.useFakeTimers();
|
|
47
65
|
clock.setSystemTime(Date.parse("2021-01-01T00:00:00Z"));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SnapshotDb.test.js","sourceRoot":"","sources":["../../../../src/test/standalone/SnapshotDb.test.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n\nimport { expect } from \"chai\";\nimport * as sinon from \"sinon\";\nimport { ChangesetIdWithIndex } from \"@itwin/core-common\";\nimport { CheckpointManager, V2CheckpointManager } from \"../../CheckpointManager\";\nimport { IModelDb, SnapshotDb } from \"../../IModelDb\";\nimport { Logger } from \"@itwin/core-bentley\";\nimport { IModelHost } from \"../../IModelHost\";\nimport { HubMock } from \"../../internal/HubMock\";\nimport { _hubAccess, _nativeDb } from \"../../internal/Symbols\";\nimport { IModelTestUtils } from \"../IModelTestUtils\";\n\ndescribe(\"SnapshotDb.refreshContainerForRpc\", () => {\n afterEach(() => sinon.restore());\n\n const changeset: ChangesetIdWithIndex = { id: \"fakeChangeSetId\", index: 10 };\n const iTwinId = \"fakeIModelId\";\n const iModelId = \"fakeIModelId\";\n const makeToken = (date: string) => {\n const dateUri = encodeURIComponent(date);\n return `?sv=2018-03-28&st=${dateUri}&se=${dateUri}&sr=c&sp=rl&sig=bad`;\n };\n\n const mockCheckpointV2 = {\n accountName: \"testAccount\",\n containerId: \"imodelblocks-123\",\n sasToken: makeToken(\"2021-01-01T01:00:00Z\"),\n dbName: \"testDb\",\n storageType: \"azure?sas=1\",\n };\n\n const cloudContainer = { accessToken: mockCheckpointV2.sasToken };\n const fakeSnapshotDb: any = {\n cloudContainer,\n isReadonly: () => true,\n isOpen: () => true,\n getIModelId: () => iModelId,\n getITwinId: () => iTwinId,\n getCurrentChangeset: () => changeset,\n setIModelDb: () => { },\n closeIModel: () => { },\n restartDefaultTxn: () => { },\n closeFile: () => { },\n getFilePath: () => \"fakeFilePath\",\n clearECDbCache: () => { },\n };\n\n it(\"should restart default txn after inactivity\", async () => {\n const clock = sinon.useFakeTimers();\n clock.setSystemTime(Date.parse(\"2021-01-01T00:00:00Z\"));\n const defaultTxnSpy = sinon.spy(SnapshotDb.prototype, \"restartDefaultTxn\");\n sinon.stub(IModelHost, _hubAccess).get(() => HubMock);\n sinon.stub(V2CheckpointManager, \"attach\").callsFake(async () => {\n return { dbName: \"fakeDb\", container: cloudContainer } as any;\n });\n sinon.stub(IModelHost[_hubAccess], \"queryV2Checkpoint\").callsFake(async () => mockCheckpointV2);\n\n const openDgnDbStub = sinon.stub(SnapshotDb, \"openDgnDb\").returns(fakeSnapshotDb);\n sinon.stub(IModelDb.prototype, \"initializeIModelDb\" as any);\n sinon.stub(IModelDb.prototype, \"loadIModelSettings\" as any);\n sinon.stub(CheckpointManager, \"validateCheckpointGuids\").returns();\n\n const userAccessToken = \"token\";\n const checkpoint = await SnapshotDb.openCheckpointFromRpc({ accessToken: userAccessToken, iTwinId, iModelId, changeset, reattachSafetySeconds: 60 });\n expect(openDgnDbStub.calledOnce).to.be.true;\n expect(openDgnDbStub.firstCall.firstArg.path).to.equal(\"fakeDb\");\n\n const tenMinutes = 10 * 60 * 1000;\n\n // Test 20 minute timer activated when opening v2 checkpoint works.\n await clock.tickAsync(tenMinutes - 100);\n expect(defaultTxnSpy.callCount).equal(0);\n await clock.tickAsync(101);\n expect(defaultTxnSpy.callCount).equal(1);\n\n // Make sure timeout doesn't trigger more than once unless refreshContainer is called.\n await clock.tickAsync(tenMinutes + 100);\n expect(defaultTxnSpy.callCount).equal(1);\n await checkpoint.refreshContainerForRpc(\"\"); // activates timeout again by calling refresh on the timer.\n expect(defaultTxnSpy.callCount).equal(1);\n await clock.tickAsync(tenMinutes + 100);\n expect(defaultTxnSpy.callCount).equal(2);\n\n // Keep calling refreshContainer and make sure that restartDefaultTxn doesn't get called.\n await checkpoint.refreshContainerForRpc(\"\");\n await clock.tickAsync(tenMinutes - 100);\n await checkpoint.refreshContainerForRpc(\"\");\n await clock.tickAsync(tenMinutes - 100);\n expect(defaultTxnSpy.callCount).equal(2);\n\n // advance time past 20 minutes without refreshing container and make sure defaultTxn still restarts\n await clock.tickAsync(tenMinutes + 100);\n expect(defaultTxnSpy.callCount).equal(3);\n });\n\n it(\"should refresh checkpoint sasToken from RPC\", async () => {\n const clock = sinon.useFakeTimers();\n clock.setSystemTime(Date.parse(\"2021-01-01T00:00:00Z\"));\n\n sinon.stub(IModelHost, _hubAccess).get(() => HubMock);\n sinon.stub(V2CheckpointManager, \"attach\").callsFake(async () => {\n return { dbName: \"fakeDb\", container: cloudContainer } as any;\n });\n const queryStub = sinon.stub(IModelHost[_hubAccess], \"queryV2Checkpoint\").callsFake(async () => mockCheckpointV2);\n\n const openDgnDbStub = sinon.stub(SnapshotDb, \"openDgnDb\").returns(fakeSnapshotDb);\n sinon.stub(IModelDb.prototype, \"initializeIModelDb\" as any);\n sinon.stub(IModelDb.prototype, \"loadIModelSettings\" as any);\n sinon.stub(CheckpointManager, \"validateCheckpointGuids\").returns();\n\n const userAccessToken = \"token\";\n const checkpoint = await SnapshotDb.openCheckpointFromRpc({ accessToken: userAccessToken, iTwinId, iModelId, changeset, reattachSafetySeconds: 60 });\n expect(checkpoint.cloudContainer?.accessToken).equal(mockCheckpointV2.sasToken);\n expect(openDgnDbStub.calledOnce).to.be.true;\n expect(openDgnDbStub.firstCall.firstArg.path).to.equal(\"fakeDb\");\n\n const errorLogStub = sinon.stub(Logger, \"logError\").callsFake(() => { });\n const infoLogStub = sinon.stub(Logger, \"logInfo\").callsFake(() => { });\n\n clock.setSystemTime(Date.parse(\"2021-01-01T00:58:10Z\")); // within safety period\n void expect(checkpoint.refreshContainerForRpc(\"\")).to.be.fulfilled;\n expect(queryStub.callCount).equal(0, \"should not need reattach yet\");\n\n clock.setSystemTime(Date.parse(\"2021-01-01T00:59:10Z\")); // after safety period\n\n mockCheckpointV2.sasToken = makeToken(\"2021-01-01T02:00:00Z\");\n const attachPromise = checkpoint.refreshContainerForRpc(\"\");\n const promise2 = checkpoint.refreshContainerForRpc(\"\"); // gets copy of first promise\n const promise3 = checkpoint.refreshContainerForRpc(\"\"); // \"\n expect(queryStub.callCount).equal(1); // shouldn't need to attach since first call already started the process\n expect(infoLogStub.callCount).equal(1);\n expect(infoLogStub.args[0][1]).include(\"attempting to refresh\");\n expect(errorLogStub.callCount).equal(0);\n\n void expect(attachPromise).to.not.be.fulfilled;\n void expect(promise2).to.not.be.fulfilled;\n void expect(promise3).to.not.be.fulfilled;\n await attachPromise;\n void expect(attachPromise).to.be.fulfilled;\n void expect(promise2).to.be.fulfilled;\n void expect(promise3).to.be.fulfilled;\n expect(infoLogStub.callCount).equal(2);\n expect(infoLogStub.args[1][1]).include(\"refreshed checkpoint sasToken\");\n\n clock.setSystemTime(Date.parse(\"2021-01-01T03:00:00Z\"));\n mockCheckpointV2.sasToken = makeToken(\"2021-01-01T03:00:10Z\"); // an expiry within safety interval should cause error log\n await checkpoint.refreshContainerForRpc(\"\");\n expect(errorLogStub.callCount).equal(1);\n expect(errorLogStub.args[0][1]).include(\"timestamp that expires before safety interval\");\n\n queryStub.resetHistory();\n errorLogStub.resetHistory();\n infoLogStub.resetHistory();\n mockCheckpointV2.sasToken = makeToken(\"2021-01-01T04:00:10Z\"); // expiry after safety interval\n clock.setSystemTime(Date.parse(\"2021-01-01T03:00:02Z\"));\n // next call to reattach daemon should work fine and correct problem\n await checkpoint.refreshContainerForRpc(\"\");\n expect(queryStub.callCount).equal(1);\n expect(infoLogStub.callCount).equal(2);\n expect(errorLogStub.callCount).equal(0);\n });\n\n it(\"should not refreshContainer if SnapshotDb is not a checkpoint\", async () => {\n const clock = sinon.useFakeTimers();\n clock.setSystemTime(Date.parse(\"2021-01-01T00:00:00Z\"));\n sinon.stub(SnapshotDb, \"openDgnDb\").returns(fakeSnapshotDb);\n sinon.stub(CheckpointManager, \"validateCheckpointGuids\").returns();\n sinon.stub(IModelDb.prototype, \"initializeIModelDb\" as any);\n sinon.stub(IModelDb.prototype, \"loadIModelSettings\" as any);\n\n const snapshot = IModelTestUtils.openCheckpoint(\"fakeFilePath\", { iTwinId: \"fakeITwinId\", iModelId: \"fake1\", changeset });\n const nowStub = sinon.stub(Date, \"now\");\n await snapshot.refreshContainerForRpc(\"\");\n snapshot.close();\n expect(nowStub.called).to.be.false;\n nowStub.restore();\n });\n});\n"]}
|
|
1
|
+
{"version":3,"file":"SnapshotDb.test.js","sourceRoot":"","sources":["../../../../src/test/standalone/SnapshotDb.test.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAE/F,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACjF,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,QAAQ,CAAC,mCAAmC,EAAE,GAAG,EAAE;IACjD,SAAS,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;IAEjC,MAAM,SAAS,GAAyB,EAAE,EAAE,EAAE,iBAAiB,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;IAC7E,MAAM,OAAO,GAAG,cAAc,CAAC;IAC/B,MAAM,QAAQ,GAAG,cAAc,CAAC;IAChC,MAAM,SAAS,GAAG,CAAC,IAAY,EAAE,EAAE;QACjC,MAAM,OAAO,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC;QACzC,OAAO,qBAAqB,OAAO,OAAO,OAAO,qBAAqB,CAAC;IACzE,CAAC,CAAC;IAEF,MAAM,gBAAgB,GAAG;QACvB,WAAW,EAAE,aAAa;QAC1B,WAAW,EAAE,kBAAkB;QAC/B,QAAQ,EAAE,SAAS,CAAC,sBAAsB,CAAC;QAC3C,MAAM,EAAE,QAAQ;QAChB,WAAW,EAAE,aAAa;KAC3B,CAAC;IAEF,MAAM,cAAc,GAAG,EAAE,WAAW,EAAE,gBAAgB,CAAC,QAAQ,EAAE,CAAC;IAClE,MAAM,cAAc,GAAQ;QAC1B,cAAc;QACd,UAAU,EAAE,GAAG,EAAE,CAAC,IAAI;QACtB,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI;QAClB,WAAW,EAAE,GAAG,EAAE,CAAC,QAAQ;QAC3B,UAAU,EAAE,GAAG,EAAE,CAAC,OAAO;QACzB,mBAAmB,EAAE,GAAG,EAAE,CAAC,SAAS;QACpC,WAAW,EAAE,GAAG,EAAE,GAAG,CAAC;QACtB,WAAW,EAAE,GAAG,EAAE,GAAG,CAAC;QACtB,iBAAiB,EAAE,GAAG,EAAE,GAAG,CAAC;QAC5B,SAAS,EAAE,GAAG,EAAE,GAAG,CAAC;QACpB,WAAW,EAAE,GAAG,EAAE,CAAC,cAAc;QACjC,cAAc,EAAE,GAAG,EAAE,GAAG,CAAC;KAC1B,CAAC;IACF,EAAE,CAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE;QAClC,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,iBAAiB,CAAC,CAAC;QAClF,IAAI,UAAU,CAAC,UAAU,CAAC,cAAc,CAAC;YACvC,UAAU,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;QAExC,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,CAAC,cAAc,EAAE;YACtD,WAAW,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE;SACtC,CAAC,CAAC;QAEH,MAAM,CAAC,WAAW,EAAE,CAAC;QACrB,MAAM,CAAC,iBAAiB,EAAE,CAAC;QAE3B,eAAe,CAAC,MAAM,CACpB,MAAM,EACN,QAAQ,CAAC,YAAY,EACrB,kBAAkB,EAClB,EAAE,CACH,CAAC;QAEF,mCAAmC;QACnC,MAAM,CAAC,iBAAiB,EAAE,CAAC;QAC3B,MAAM,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC3D,MAAM,KAAK,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC;QACpC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC;QACxD,MAAM,aAAa,GAAG,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,SAAS,EAAE,mBAAmB,CAAC,CAAC;QAC3E,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC;QACtD,KAAK,CAAC,IAAI,CAAC,mBAAmB,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE;YAC7D,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAS,CAAC;QAChE,CAAC,CAAC,CAAC;QACH,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,mBAAmB,CAAC,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC,gBAAgB,CAAC,CAAC;QAEhG,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;QAClF,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,oBAA2B,CAAC,CAAC;QAC5D,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,oBAA2B,CAAC,CAAC;QAC5D,KAAK,CAAC,IAAI,CAAC,iBAAiB,EAAE,yBAAyB,CAAC,CAAC,OAAO,EAAE,CAAC;QAEnE,MAAM,eAAe,GAAG,OAAO,CAAC;QAChC,MAAM,UAAU,GAAG,MAAM,UAAU,CAAC,qBAAqB,CAAC,EAAE,WAAW,EAAE,eAAe,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,qBAAqB,EAAE,EAAE,EAAE,CAAC,CAAC;QACrJ,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC;QAC5C,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAEjE,MAAM,UAAU,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;QAElC,mEAAmE;QACnE,MAAM,KAAK,CAAC,SAAS,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC;QACxC,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAC3B,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAEzC,sFAAsF;QACtF,MAAM,KAAK,CAAC,SAAS,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC;QACxC,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC,CAAC,2DAA2D;QACxG,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,KAAK,CAAC,SAAS,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC;QACxC,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAEzC,yFAAyF;QACzF,MAAM,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QAC5C,MAAM,KAAK,CAAC,SAAS,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC;QACxC,MAAM,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QAC5C,MAAM,KAAK,CAAC,SAAS,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC;QACxC,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAEzC,oGAAoG;QACpG,MAAM,KAAK,CAAC,SAAS,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC;QACxC,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC3D,MAAM,KAAK,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC;QACpC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC;QAExD,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC;QACtD,KAAK,CAAC,IAAI,CAAC,mBAAmB,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE;YAC7D,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAS,CAAC;QAChE,CAAC,CAAC,CAAC;QACH,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,mBAAmB,CAAC,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC,gBAAgB,CAAC,CAAC;QAElH,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;QAClF,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,oBAA2B,CAAC,CAAC;QAC5D,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,oBAA2B,CAAC,CAAC;QAC5D,KAAK,CAAC,IAAI,CAAC,iBAAiB,EAAE,yBAAyB,CAAC,CAAC,OAAO,EAAE,CAAC;QAEnE,MAAM,eAAe,GAAG,OAAO,CAAC;QAChC,MAAM,UAAU,GAAG,MAAM,UAAU,CAAC,qBAAqB,CAAC,EAAE,WAAW,EAAE,eAAe,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,qBAAqB,EAAE,EAAE,EAAE,CAAC,CAAC;QACrJ,MAAM,CAAC,UAAU,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAChF,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC;QAC5C,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAEjE,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACzE,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAEvE,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,uBAAuB;QAChF,KAAK,MAAM,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC;QACnE,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,8BAA8B,CAAC,CAAC;QAErE,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,sBAAsB;QAE/E,gBAAgB,CAAC,QAAQ,GAAG,SAAS,CAAC,sBAAsB,CAAC,CAAC;QAC9D,MAAM,aAAa,GAAG,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QAC5D,MAAM,QAAQ,GAAG,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC,CAAC,6BAA6B;QACrF,MAAM,QAAQ,GAAG,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI;QAC5D,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,wEAAwE;QAC9G,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC;QAChE,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAExC,KAAK,MAAM,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,SAAS,CAAC;QAC/C,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,SAAS,CAAC;QAC1C,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,SAAS,CAAC;QAC1C,MAAM,aAAa,CAAC;QACpB,KAAK,MAAM,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC;QAC3C,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC;QACtC,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC;QACtC,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,+BAA+B,CAAC,CAAC;QAExE,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC;QACxD,gBAAgB,CAAC,QAAQ,GAAG,SAAS,CAAC,sBAAsB,CAAC,CAAC,CAAC,0DAA0D;QACzH,MAAM,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QAC5C,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,+CAA+C,CAAC,CAAC;QAEzF,SAAS,CAAC,YAAY,EAAE,CAAC;QACzB,YAAY,CAAC,YAAY,EAAE,CAAC;QAC5B,WAAW,CAAC,YAAY,EAAE,CAAC;QAC3B,gBAAgB,CAAC,QAAQ,GAAG,SAAS,CAAC,sBAAsB,CAAC,CAAC,CAAC,+BAA+B;QAC9F,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC;QACxD,oEAAoE;QACpE,MAAM,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QAC5C,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,KAAK,IAAI,EAAE;QAC7E,MAAM,KAAK,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC;QACpC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC;QACxD,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;QAC5D,KAAK,CAAC,IAAI,CAAC,iBAAiB,EAAE,yBAAyB,CAAC,CAAC,OAAO,EAAE,CAAC;QACnE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,oBAA2B,CAAC,CAAC;QAC5D,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,oBAA2B,CAAC,CAAC;QAE5D,MAAM,QAAQ,GAAG,eAAe,CAAC,cAAc,CAAC,cAAc,EAAE,EAAE,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;QAC1H,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACxC,MAAM,QAAQ,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QAC1C,QAAQ,CAAC,KAAK,EAAE,CAAC;QACjB,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC;QACnC,OAAO,CAAC,OAAO,EAAE,CAAC;IACpB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n\nimport { expect } from \"chai\";\nimport * as sinon from \"sinon\";\nimport { ChangesetIdWithIndex } from \"@itwin/core-common\";\nimport { CheckpointManager, V2CheckpointManager } from \"../../CheckpointManager\";\nimport { IModelDb, SnapshotDb, StandaloneDb } from \"../../IModelDb\";\nimport { Logger } from \"@itwin/core-bentley\";\nimport { IModelHost } from \"../../IModelHost\";\nimport { HubMock } from \"../../internal/HubMock\";\nimport { _hubAccess } from \"../../internal/Symbols\";\nimport { IModelTestUtils } from \"../IModelTestUtils\";\nimport { SpatialCategory } from \"../../Category\";\nimport { KnownTestLocations } from \"../KnownTestLocations\";\nimport * as path from \"path\";\nimport { IModelJsFs } from \"../../IModelJsFs\";\n\ndescribe(\"SnapshotDb.refreshContainerForRpc\", () => {\n afterEach(() => sinon.restore());\n\n const changeset: ChangesetIdWithIndex = { id: \"fakeChangeSetId\", index: 10 };\n const iTwinId = \"fakeIModelId\";\n const iModelId = \"fakeIModelId\";\n const makeToken = (date: string) => {\n const dateUri = encodeURIComponent(date);\n return `?sv=2018-03-28&st=${dateUri}&se=${dateUri}&sr=c&sp=rl&sig=bad`;\n };\n\n const mockCheckpointV2 = {\n accountName: \"testAccount\",\n containerId: \"imodelblocks-123\",\n sasToken: makeToken(\"2021-01-01T01:00:00Z\"),\n dbName: \"testDb\",\n storageType: \"azure?sas=1\",\n };\n\n const cloudContainer = { accessToken: mockCheckpointV2.sasToken };\n const fakeSnapshotDb: any = {\n cloudContainer,\n isReadonly: () => true,\n isOpen: () => true,\n getIModelId: () => iModelId,\n getITwinId: () => iTwinId,\n getCurrentChangeset: () => changeset,\n setIModelDb: () => { },\n closeIModel: () => { },\n restartDefaultTxn: () => { },\n closeFile: () => { },\n getFilePath: () => \"fakeFilePath\",\n clearECDbCache: () => { },\n };\n it(\"perform checkpoint\", async () => {\n const sourceFileName = path.join(KnownTestLocations.outputDir, \"checkpoint1.bim\");\n if (IModelJsFs.existsSync(sourceFileName))\n IModelJsFs.removeSync(sourceFileName);\n\n const iModel = StandaloneDb.createEmpty(sourceFileName, {\n rootSubject: { name: sourceFileName },\n });\n\n iModel.clearCaches();\n iModel.performCheckpoint();\n\n SpatialCategory.insert(\n iModel,\n IModelDb.dictionaryId,\n \"spatial category\",\n {}\n );\n\n // Use to throw error SQLITE_LOCKED\n iModel.performCheckpoint();\n iModel.close();\n });\n it(\"should restart default txn after inactivity\", async () => {\n const clock = sinon.useFakeTimers();\n clock.setSystemTime(Date.parse(\"2021-01-01T00:00:00Z\"));\n const defaultTxnSpy = sinon.spy(SnapshotDb.prototype, \"restartDefaultTxn\");\n sinon.stub(IModelHost, _hubAccess).get(() => HubMock);\n sinon.stub(V2CheckpointManager, \"attach\").callsFake(async () => {\n return { dbName: \"fakeDb\", container: cloudContainer } as any;\n });\n sinon.stub(IModelHost[_hubAccess], \"queryV2Checkpoint\").callsFake(async () => mockCheckpointV2);\n\n const openDgnDbStub = sinon.stub(SnapshotDb, \"openDgnDb\").returns(fakeSnapshotDb);\n sinon.stub(IModelDb.prototype, \"initializeIModelDb\" as any);\n sinon.stub(IModelDb.prototype, \"loadIModelSettings\" as any);\n sinon.stub(CheckpointManager, \"validateCheckpointGuids\").returns();\n\n const userAccessToken = \"token\";\n const checkpoint = await SnapshotDb.openCheckpointFromRpc({ accessToken: userAccessToken, iTwinId, iModelId, changeset, reattachSafetySeconds: 60 });\n expect(openDgnDbStub.calledOnce).to.be.true;\n expect(openDgnDbStub.firstCall.firstArg.path).to.equal(\"fakeDb\");\n\n const tenMinutes = 10 * 60 * 1000;\n\n // Test 20 minute timer activated when opening v2 checkpoint works.\n await clock.tickAsync(tenMinutes - 100);\n expect(defaultTxnSpy.callCount).equal(0);\n await clock.tickAsync(101);\n expect(defaultTxnSpy.callCount).equal(1);\n\n // Make sure timeout doesn't trigger more than once unless refreshContainer is called.\n await clock.tickAsync(tenMinutes + 100);\n expect(defaultTxnSpy.callCount).equal(1);\n await checkpoint.refreshContainerForRpc(\"\"); // activates timeout again by calling refresh on the timer.\n expect(defaultTxnSpy.callCount).equal(1);\n await clock.tickAsync(tenMinutes + 100);\n expect(defaultTxnSpy.callCount).equal(2);\n\n // Keep calling refreshContainer and make sure that restartDefaultTxn doesn't get called.\n await checkpoint.refreshContainerForRpc(\"\");\n await clock.tickAsync(tenMinutes - 100);\n await checkpoint.refreshContainerForRpc(\"\");\n await clock.tickAsync(tenMinutes - 100);\n expect(defaultTxnSpy.callCount).equal(2);\n\n // advance time past 20 minutes without refreshing container and make sure defaultTxn still restarts\n await clock.tickAsync(tenMinutes + 100);\n expect(defaultTxnSpy.callCount).equal(3);\n });\n\n it(\"should refresh checkpoint sasToken from RPC\", async () => {\n const clock = sinon.useFakeTimers();\n clock.setSystemTime(Date.parse(\"2021-01-01T00:00:00Z\"));\n\n sinon.stub(IModelHost, _hubAccess).get(() => HubMock);\n sinon.stub(V2CheckpointManager, \"attach\").callsFake(async () => {\n return { dbName: \"fakeDb\", container: cloudContainer } as any;\n });\n const queryStub = sinon.stub(IModelHost[_hubAccess], \"queryV2Checkpoint\").callsFake(async () => mockCheckpointV2);\n\n const openDgnDbStub = sinon.stub(SnapshotDb, \"openDgnDb\").returns(fakeSnapshotDb);\n sinon.stub(IModelDb.prototype, \"initializeIModelDb\" as any);\n sinon.stub(IModelDb.prototype, \"loadIModelSettings\" as any);\n sinon.stub(CheckpointManager, \"validateCheckpointGuids\").returns();\n\n const userAccessToken = \"token\";\n const checkpoint = await SnapshotDb.openCheckpointFromRpc({ accessToken: userAccessToken, iTwinId, iModelId, changeset, reattachSafetySeconds: 60 });\n expect(checkpoint.cloudContainer?.accessToken).equal(mockCheckpointV2.sasToken);\n expect(openDgnDbStub.calledOnce).to.be.true;\n expect(openDgnDbStub.firstCall.firstArg.path).to.equal(\"fakeDb\");\n\n const errorLogStub = sinon.stub(Logger, \"logError\").callsFake(() => { });\n const infoLogStub = sinon.stub(Logger, \"logInfo\").callsFake(() => { });\n\n clock.setSystemTime(Date.parse(\"2021-01-01T00:58:10Z\")); // within safety period\n void expect(checkpoint.refreshContainerForRpc(\"\")).to.be.fulfilled;\n expect(queryStub.callCount).equal(0, \"should not need reattach yet\");\n\n clock.setSystemTime(Date.parse(\"2021-01-01T00:59:10Z\")); // after safety period\n\n mockCheckpointV2.sasToken = makeToken(\"2021-01-01T02:00:00Z\");\n const attachPromise = checkpoint.refreshContainerForRpc(\"\");\n const promise2 = checkpoint.refreshContainerForRpc(\"\"); // gets copy of first promise\n const promise3 = checkpoint.refreshContainerForRpc(\"\"); // \"\n expect(queryStub.callCount).equal(1); // shouldn't need to attach since first call already started the process\n expect(infoLogStub.callCount).equal(1);\n expect(infoLogStub.args[0][1]).include(\"attempting to refresh\");\n expect(errorLogStub.callCount).equal(0);\n\n void expect(attachPromise).to.not.be.fulfilled;\n void expect(promise2).to.not.be.fulfilled;\n void expect(promise3).to.not.be.fulfilled;\n await attachPromise;\n void expect(attachPromise).to.be.fulfilled;\n void expect(promise2).to.be.fulfilled;\n void expect(promise3).to.be.fulfilled;\n expect(infoLogStub.callCount).equal(2);\n expect(infoLogStub.args[1][1]).include(\"refreshed checkpoint sasToken\");\n\n clock.setSystemTime(Date.parse(\"2021-01-01T03:00:00Z\"));\n mockCheckpointV2.sasToken = makeToken(\"2021-01-01T03:00:10Z\"); // an expiry within safety interval should cause error log\n await checkpoint.refreshContainerForRpc(\"\");\n expect(errorLogStub.callCount).equal(1);\n expect(errorLogStub.args[0][1]).include(\"timestamp that expires before safety interval\");\n\n queryStub.resetHistory();\n errorLogStub.resetHistory();\n infoLogStub.resetHistory();\n mockCheckpointV2.sasToken = makeToken(\"2021-01-01T04:00:10Z\"); // expiry after safety interval\n clock.setSystemTime(Date.parse(\"2021-01-01T03:00:02Z\"));\n // next call to reattach daemon should work fine and correct problem\n await checkpoint.refreshContainerForRpc(\"\");\n expect(queryStub.callCount).equal(1);\n expect(infoLogStub.callCount).equal(2);\n expect(errorLogStub.callCount).equal(0);\n });\n\n it(\"should not refreshContainer if SnapshotDb is not a checkpoint\", async () => {\n const clock = sinon.useFakeTimers();\n clock.setSystemTime(Date.parse(\"2021-01-01T00:00:00Z\"));\n sinon.stub(SnapshotDb, \"openDgnDb\").returns(fakeSnapshotDb);\n sinon.stub(CheckpointManager, \"validateCheckpointGuids\").returns();\n sinon.stub(IModelDb.prototype, \"initializeIModelDb\" as any);\n sinon.stub(IModelDb.prototype, \"loadIModelSettings\" as any);\n\n const snapshot = IModelTestUtils.openCheckpoint(\"fakeFilePath\", { iTwinId: \"fakeITwinId\", iModelId: \"fake1\", changeset });\n const nowStub = sinon.stub(Date, \"now\");\n await snapshot.refreshContainerForRpc(\"\");\n snapshot.close();\n expect(nowStub.called).to.be.false;\n nowStub.restore();\n });\n});\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@itwin/core-backend",
|
|
3
|
-
"version": "5.0.0-dev.
|
|
3
|
+
"version": "5.0.0-dev.115",
|
|
4
4
|
"description": "iTwin.js backend components",
|
|
5
5
|
"main": "lib/cjs/core-backend.js",
|
|
6
6
|
"module": "lib/esm/core-backend.js",
|
|
@@ -27,10 +27,10 @@
|
|
|
27
27
|
},
|
|
28
28
|
"peerDependencies": {
|
|
29
29
|
"@opentelemetry/api": "^1.0.4",
|
|
30
|
-
"@itwin/core-bentley": "5.0.0-dev.
|
|
31
|
-
"@itwin/core-
|
|
32
|
-
"@itwin/core-
|
|
33
|
-
"@itwin/ecschema-metadata": "5.0.0-dev.
|
|
30
|
+
"@itwin/core-bentley": "5.0.0-dev.115",
|
|
31
|
+
"@itwin/core-common": "5.0.0-dev.115",
|
|
32
|
+
"@itwin/core-geometry": "5.0.0-dev.115",
|
|
33
|
+
"@itwin/ecschema-metadata": "5.0.0-dev.115"
|
|
34
34
|
},
|
|
35
35
|
"peerDependenciesMeta": {
|
|
36
36
|
"@opentelemetry/api": {
|
|
@@ -72,16 +72,16 @@
|
|
|
72
72
|
"marked": "^14.1.3",
|
|
73
73
|
"sql-formatter": "^15.4.6",
|
|
74
74
|
"webpack": "^5.97.1",
|
|
75
|
-
"@itwin/
|
|
76
|
-
"@itwin/core-geometry": "5.0.0-dev.
|
|
77
|
-
"@itwin/
|
|
78
|
-
"@itwin/core-bentley": "5.0.0-dev.
|
|
79
|
-
"@itwin/core-common": "5.0.0-dev.113",
|
|
75
|
+
"@itwin/build-tools": "5.0.0-dev.115",
|
|
76
|
+
"@itwin/core-geometry": "5.0.0-dev.115",
|
|
77
|
+
"@itwin/ecsql-common": "5.0.0-dev.115",
|
|
78
|
+
"@itwin/core-bentley": "5.0.0-dev.115",
|
|
80
79
|
"internal-tools": "3.0.0-dev.69",
|
|
81
|
-
"@itwin/
|
|
80
|
+
"@itwin/core-common": "5.0.0-dev.115",
|
|
81
|
+
"@itwin/ecschema-metadata": "5.0.0-dev.115"
|
|
82
82
|
},
|
|
83
83
|
"dependencies": {
|
|
84
|
-
"@bentley/imodeljs-native": "5.0.
|
|
84
|
+
"@bentley/imodeljs-native": "5.0.104",
|
|
85
85
|
"@itwin/cloud-agnostic-core": "^2.2.4",
|
|
86
86
|
"@itwin/object-storage-azure": "^2.3.0",
|
|
87
87
|
"@itwin/object-storage-core": "^2.3.0",
|