@itwin/ecschema-locaters 4.0.0-dev.6 → 4.0.0-dev.61
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 +11 -1
- package/lib/cjs/SchemaFileLocater.d.ts +82 -82
- package/lib/cjs/SchemaFileLocater.js +212 -212
- package/lib/cjs/SchemaFileUtility.d.ts +17 -17
- package/lib/cjs/SchemaFileUtility.js +48 -48
- package/lib/cjs/SchemaJsonFileLocater.d.ts +33 -33
- package/lib/cjs/SchemaJsonFileLocater.js +90 -90
- package/lib/cjs/SchemaXmlFileLocater.d.ts +33 -33
- package/lib/cjs/SchemaXmlFileLocater.js +93 -93
- package/lib/cjs/StubSchemaXmlFileLocater.d.ts +69 -69
- package/lib/cjs/StubSchemaXmlFileLocater.js +177 -177
- package/lib/cjs/ecschema-locaters.d.ts +17 -17
- package/lib/cjs/ecschema-locaters.js +37 -33
- package/lib/cjs/ecschema-locaters.js.map +1 -1
- package/lib/cjs/test/SchemaFileUtility.test.d.ts +1 -1
- package/lib/cjs/test/SchemaFileUtility.test.js +56 -56
- package/lib/cjs/test/SchemaFileUtility.test.js.map +1 -1
- package/lib/cjs/test/SchemaJsonFileLocator.test.d.ts +1 -1
- package/lib/cjs/test/SchemaJsonFileLocator.test.js +119 -119
- package/lib/cjs/test/SchemaXmlFileLocator.test.d.ts +1 -1
- package/lib/cjs/test/SchemaXmlFileLocator.test.js +180 -180
- package/lib/cjs/test/StubSchemaXmlFileLocater.test.d.ts +1 -1
- package/lib/cjs/test/StubSchemaXmlFileLocater.test.js +170 -170
- package/package.json +7 -7
|
@@ -1,181 +1,181 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/*---------------------------------------------------------------------------------------------
|
|
3
|
-
* Copyright (c) Bentley Systems, Incorporated. All rights reserved.
|
|
4
|
-
* See LICENSE.md in the project root for license terms and full copyright notice.
|
|
5
|
-
*--------------------------------------------------------------------------------------------*/
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
const chai_1 = require("chai");
|
|
8
|
-
const path = require("path");
|
|
9
|
-
const ecschema_metadata_1 = require("@itwin/ecschema-metadata");
|
|
10
|
-
const SchemaXmlFileLocater_1 = require("../SchemaXmlFileLocater");
|
|
11
|
-
describe("SchemaXmlFileLocater tests:", () => {
|
|
12
|
-
let locater;
|
|
13
|
-
let context;
|
|
14
|
-
beforeEach(() => {
|
|
15
|
-
locater = new SchemaXmlFileLocater_1.SchemaXmlFileLocater();
|
|
16
|
-
locater.addSchemaSearchPath(path.join(__dirname, "assets"));
|
|
17
|
-
context = new ecschema_metadata_1.SchemaContext();
|
|
18
|
-
context.addLocater(locater);
|
|
19
|
-
});
|
|
20
|
-
it("locate valid schema with multiple references", async () => {
|
|
21
|
-
const schemaKey = new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 1);
|
|
22
|
-
const schema = await context.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact);
|
|
23
|
-
chai_1.assert.isDefined(schema);
|
|
24
|
-
chai_1.assert.strictEqual(schema.schemaKey.name, "SchemaA");
|
|
25
|
-
chai_1.assert.strictEqual(schema.schemaKey.version.toString(), "01.01.01");
|
|
26
|
-
});
|
|
27
|
-
it("locate valid schema with multiple references synchronously", () => {
|
|
28
|
-
const schemaKey = new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 1);
|
|
29
|
-
const schema = context.getSchemaSync(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact);
|
|
30
|
-
chai_1.assert.isDefined(schema);
|
|
31
|
-
chai_1.assert.strictEqual(schema.schemaKey.name, "SchemaA");
|
|
32
|
-
chai_1.assert.strictEqual(schema.schemaKey.version.toString(), "01.01.01");
|
|
33
|
-
});
|
|
34
|
-
it("getSchema called multiple times for same schema", async () => {
|
|
35
|
-
const schemaKey = new ecschema_metadata_1.SchemaKey("SchemaD", 4, 4, 4);
|
|
36
|
-
const locater1 = await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact, new ecschema_metadata_1.SchemaContext());
|
|
37
|
-
const locater2 = await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact, new ecschema_metadata_1.SchemaContext());
|
|
38
|
-
const context1 = await context.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact);
|
|
39
|
-
const context2 = await context.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact);
|
|
40
|
-
// locater should not cache, but context should cache
|
|
41
|
-
chai_1.assert.notEqual(locater1, locater2);
|
|
42
|
-
chai_1.assert.notEqual(locater1, context1);
|
|
43
|
-
chai_1.assert.strictEqual(context1, context2);
|
|
44
|
-
});
|
|
45
|
-
it("getSchema which does not exist, returns undefined", async () => {
|
|
46
|
-
const schemaKey = new ecschema_metadata_1.SchemaKey("DoesNotExist");
|
|
47
|
-
chai_1.assert.isUndefined(await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact, context));
|
|
48
|
-
});
|
|
49
|
-
it("loadSchema from file, bad schema tag, throws", async () => {
|
|
50
|
-
const schemaKey = new ecschema_metadata_1.SchemaKey("BadSchemaTag");
|
|
51
|
-
try {
|
|
52
|
-
await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Latest, context);
|
|
53
|
-
}
|
|
54
|
-
catch (e) {
|
|
55
|
-
const error = e;
|
|
56
|
-
chai_1.assert.strictEqual(error.errorNumber, ecschema_metadata_1.ECObjectsStatus.InvalidSchemaXML);
|
|
57
|
-
return;
|
|
58
|
-
}
|
|
59
|
-
chai_1.assert.fail(0, 1, "Expected ECObjects exception");
|
|
60
|
-
});
|
|
61
|
-
it("loadSchema from file, bad schema name tag, throws", async () => {
|
|
62
|
-
const schemaKey = new ecschema_metadata_1.SchemaKey("BadSchemaNameTag");
|
|
63
|
-
try {
|
|
64
|
-
await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Latest, context);
|
|
65
|
-
}
|
|
66
|
-
catch (e) {
|
|
67
|
-
const error = e;
|
|
68
|
-
chai_1.assert.strictEqual(error.errorNumber, ecschema_metadata_1.ECObjectsStatus.InvalidSchemaXML);
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
chai_1.assert.fail(0, 1, "Expected ECObjects exception");
|
|
72
|
-
});
|
|
73
|
-
it("loadSchema from file, bad schema version tag, throws", async () => {
|
|
74
|
-
const schemaKey = new ecschema_metadata_1.SchemaKey("BadSchemaVersionTag");
|
|
75
|
-
try {
|
|
76
|
-
await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Latest, context);
|
|
77
|
-
}
|
|
78
|
-
catch (e) {
|
|
79
|
-
const error = e;
|
|
80
|
-
chai_1.assert.strictEqual(error.errorNumber, ecschema_metadata_1.ECObjectsStatus.InvalidSchemaXML);
|
|
81
|
-
return;
|
|
82
|
-
}
|
|
83
|
-
chai_1.assert.fail(0, 1, "Expected ECObjects exception");
|
|
84
|
-
});
|
|
85
|
-
it("getSchema, full version, succeeds", async () => {
|
|
86
|
-
const stub = await locater.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.Exact, context);
|
|
87
|
-
chai_1.assert.isDefined(stub);
|
|
88
|
-
const key = stub.schemaKey;
|
|
89
|
-
chai_1.assert.strictEqual(key.name, "SchemaA");
|
|
90
|
-
chai_1.assert.strictEqual(key.version.toString(), "01.01.01");
|
|
91
|
-
});
|
|
92
|
-
it("getSchema, reference does not exist, throws.", async () => {
|
|
93
|
-
try {
|
|
94
|
-
await locater.getSchema(new ecschema_metadata_1.SchemaKey("RefDoesNotExist", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.Exact, context);
|
|
95
|
-
}
|
|
96
|
-
catch (e) {
|
|
97
|
-
const error = e;
|
|
98
|
-
chai_1.assert.strictEqual(error.errorNumber, ecschema_metadata_1.ECObjectsStatus.UnableToLocateSchema);
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
chai_1.assert.fail();
|
|
102
|
-
});
|
|
103
|
-
it("getSchema, references set", async () => {
|
|
104
|
-
const schemaA = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.Exact);
|
|
105
|
-
const schemaB = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaB", 2, 2, 2), ecschema_metadata_1.SchemaMatchType.Exact);
|
|
106
|
-
const schemaC = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaC", 3, 3, 3), ecschema_metadata_1.SchemaMatchType.Exact);
|
|
107
|
-
const schemaD = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaD", 4, 4, 4), ecschema_metadata_1.SchemaMatchType.Exact);
|
|
108
|
-
chai_1.assert.isDefined(schemaA);
|
|
109
|
-
chai_1.assert.strictEqual(schemaA.references.length, 2);
|
|
110
|
-
chai_1.assert.deepEqual(schemaA.references[0], schemaC);
|
|
111
|
-
chai_1.assert.deepEqual(schemaA.references[1], schemaB);
|
|
112
|
-
chai_1.assert.deepEqual(schemaA.references[0].references[0], schemaD);
|
|
113
|
-
chai_1.assert.deepEqual(schemaA.references[1].references[0], schemaC);
|
|
114
|
-
chai_1.assert.deepEqual(schemaA.references[1].references[1], schemaD);
|
|
115
|
-
});
|
|
116
|
-
it("getSchema, exact version, wrong minor, fails", async () => {
|
|
117
|
-
chai_1.assert.isUndefined(await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 2), ecschema_metadata_1.SchemaMatchType.Exact));
|
|
118
|
-
});
|
|
119
|
-
it("getSchema, latest, succeeds", async () => {
|
|
120
|
-
const stub = await locater.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 0), ecschema_metadata_1.SchemaMatchType.Latest, context);
|
|
121
|
-
chai_1.assert.isDefined(stub);
|
|
122
|
-
chai_1.assert.strictEqual(stub.schemaKey.name, "SchemaA");
|
|
123
|
-
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "02.00.02");
|
|
124
|
-
});
|
|
125
|
-
it("getSchema, latest write compatible, succeeds", async () => {
|
|
126
|
-
const stub = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 0), ecschema_metadata_1.SchemaMatchType.LatestWriteCompatible);
|
|
127
|
-
chai_1.assert.isDefined(stub);
|
|
128
|
-
chai_1.assert.strictEqual(stub.schemaKey.name, "SchemaA");
|
|
129
|
-
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "01.01.01");
|
|
130
|
-
});
|
|
131
|
-
it("getSchema, latest write compatible, write version wrong, fails", async () => {
|
|
132
|
-
chai_1.assert.isUndefined(await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 2, 0), ecschema_metadata_1.SchemaMatchType.LatestWriteCompatible));
|
|
133
|
-
});
|
|
134
|
-
it("getSchema, latest read compatible, succeeds", async () => {
|
|
135
|
-
const stub = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 0, 0), ecschema_metadata_1.SchemaMatchType.LatestReadCompatible);
|
|
136
|
-
chai_1.assert.isDefined(stub);
|
|
137
|
-
chai_1.assert.strictEqual(stub.schemaKey.name, "SchemaA");
|
|
138
|
-
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "01.01.01");
|
|
139
|
-
});
|
|
140
|
-
it("getSchema, latest read compatible, read version wrong, fails", async () => {
|
|
141
|
-
chai_1.assert.isUndefined(await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 2, 1, 1), ecschema_metadata_1.SchemaMatchType.LatestReadCompatible));
|
|
142
|
-
});
|
|
143
|
-
it("sync - should ignore commented out schema references", () => {
|
|
144
|
-
const stub = context.getSchemaSync(new ecschema_metadata_1.SchemaKey("RefCommentedOut", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.LatestReadCompatible);
|
|
145
|
-
chai_1.assert.isDefined(stub);
|
|
146
|
-
chai_1.assert.strictEqual(stub.schemaKey.name, "RefCommentedOut");
|
|
147
|
-
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "01.01.01");
|
|
148
|
-
});
|
|
149
|
-
it("async - should ignore commented out schema references", async () => {
|
|
150
|
-
const stub = await context.getSchema(new ecschema_metadata_1.SchemaKey("RefCommentedOut", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.LatestReadCompatible);
|
|
151
|
-
chai_1.assert.isDefined(stub);
|
|
152
|
-
chai_1.assert.strictEqual(stub.schemaKey.name, "RefCommentedOut");
|
|
153
|
-
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "01.01.01");
|
|
154
|
-
});
|
|
155
|
-
it("getSchemaKey, valid version and name, succeeds", () => {
|
|
156
|
-
const schemaXml = `<ECSchema schemaName="SchemaA" version="1.1.1"> </ECSchema>`;
|
|
157
|
-
const key = locater.getSchemaKey(schemaXml);
|
|
158
|
-
chai_1.assert.deepEqual(key, new ecschema_metadata_1.SchemaKey("SchemaA", new ecschema_metadata_1.ECVersion(1, 1, 1)));
|
|
159
|
-
});
|
|
160
|
-
it("getSchemaKey, invalid xml, throws", () => {
|
|
161
|
-
const schemaXml = `<ECSchemaBad schemaName="SchemaA" version="1.1.1"> </ECSchemaBad>`;
|
|
162
|
-
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find '<ECSchema>' tag in the given file`);
|
|
163
|
-
});
|
|
164
|
-
it("getSchemaKey, invalid schemaName attribute, throws", () => {
|
|
165
|
-
const schemaXml = `<ECSchema schemaNameBad="SchemaA" version="1.1.1"> </ECSchema>`;
|
|
166
|
-
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find the ECSchema 'schemaName' or 'version' tag in the given file`);
|
|
167
|
-
});
|
|
168
|
-
it("getSchemaKey, invalid schemaName, throws", () => {
|
|
169
|
-
const schemaXml = `<ECSchema version="1.1.1" schemaName=""> </ECSchema>`;
|
|
170
|
-
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find the ECSchema 'schemaName' or 'version' tag in the given file`);
|
|
171
|
-
});
|
|
172
|
-
it("getSchemaKey, invalid version attribute, throws", () => {
|
|
173
|
-
const schemaXml = `<ECSchema schemaName="SchemaA" versionBad="1.1.1"> </ECSchema>`;
|
|
174
|
-
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find the ECSchema 'schemaName' or 'version' tag in the given file`);
|
|
175
|
-
});
|
|
176
|
-
it("getSchemaKey, invalid version, throws", () => {
|
|
177
|
-
const schemaXml = `<ECSchema schemaName="SchemaA" version=""> </ECSchema>`;
|
|
178
|
-
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find the ECSchema 'schemaName' or 'version' tag in the given file`);
|
|
179
|
-
});
|
|
180
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
/*---------------------------------------------------------------------------------------------
|
|
3
|
+
* Copyright (c) Bentley Systems, Incorporated. All rights reserved.
|
|
4
|
+
* See LICENSE.md in the project root for license terms and full copyright notice.
|
|
5
|
+
*--------------------------------------------------------------------------------------------*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
const chai_1 = require("chai");
|
|
8
|
+
const path = require("path");
|
|
9
|
+
const ecschema_metadata_1 = require("@itwin/ecschema-metadata");
|
|
10
|
+
const SchemaXmlFileLocater_1 = require("../SchemaXmlFileLocater");
|
|
11
|
+
describe("SchemaXmlFileLocater tests:", () => {
|
|
12
|
+
let locater;
|
|
13
|
+
let context;
|
|
14
|
+
beforeEach(() => {
|
|
15
|
+
locater = new SchemaXmlFileLocater_1.SchemaXmlFileLocater();
|
|
16
|
+
locater.addSchemaSearchPath(path.join(__dirname, "assets"));
|
|
17
|
+
context = new ecschema_metadata_1.SchemaContext();
|
|
18
|
+
context.addLocater(locater);
|
|
19
|
+
});
|
|
20
|
+
it("locate valid schema with multiple references", async () => {
|
|
21
|
+
const schemaKey = new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 1);
|
|
22
|
+
const schema = await context.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact);
|
|
23
|
+
chai_1.assert.isDefined(schema);
|
|
24
|
+
chai_1.assert.strictEqual(schema.schemaKey.name, "SchemaA");
|
|
25
|
+
chai_1.assert.strictEqual(schema.schemaKey.version.toString(), "01.01.01");
|
|
26
|
+
});
|
|
27
|
+
it("locate valid schema with multiple references synchronously", () => {
|
|
28
|
+
const schemaKey = new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 1);
|
|
29
|
+
const schema = context.getSchemaSync(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact);
|
|
30
|
+
chai_1.assert.isDefined(schema);
|
|
31
|
+
chai_1.assert.strictEqual(schema.schemaKey.name, "SchemaA");
|
|
32
|
+
chai_1.assert.strictEqual(schema.schemaKey.version.toString(), "01.01.01");
|
|
33
|
+
});
|
|
34
|
+
it("getSchema called multiple times for same schema", async () => {
|
|
35
|
+
const schemaKey = new ecschema_metadata_1.SchemaKey("SchemaD", 4, 4, 4);
|
|
36
|
+
const locater1 = await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact, new ecschema_metadata_1.SchemaContext());
|
|
37
|
+
const locater2 = await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact, new ecschema_metadata_1.SchemaContext());
|
|
38
|
+
const context1 = await context.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact);
|
|
39
|
+
const context2 = await context.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact);
|
|
40
|
+
// locater should not cache, but context should cache
|
|
41
|
+
chai_1.assert.notEqual(locater1, locater2);
|
|
42
|
+
chai_1.assert.notEqual(locater1, context1);
|
|
43
|
+
chai_1.assert.strictEqual(context1, context2);
|
|
44
|
+
});
|
|
45
|
+
it("getSchema which does not exist, returns undefined", async () => {
|
|
46
|
+
const schemaKey = new ecschema_metadata_1.SchemaKey("DoesNotExist");
|
|
47
|
+
chai_1.assert.isUndefined(await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Exact, context));
|
|
48
|
+
});
|
|
49
|
+
it("loadSchema from file, bad schema tag, throws", async () => {
|
|
50
|
+
const schemaKey = new ecschema_metadata_1.SchemaKey("BadSchemaTag");
|
|
51
|
+
try {
|
|
52
|
+
await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Latest, context);
|
|
53
|
+
}
|
|
54
|
+
catch (e) {
|
|
55
|
+
const error = e;
|
|
56
|
+
chai_1.assert.strictEqual(error.errorNumber, ecschema_metadata_1.ECObjectsStatus.InvalidSchemaXML);
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
chai_1.assert.fail(0, 1, "Expected ECObjects exception");
|
|
60
|
+
});
|
|
61
|
+
it("loadSchema from file, bad schema name tag, throws", async () => {
|
|
62
|
+
const schemaKey = new ecschema_metadata_1.SchemaKey("BadSchemaNameTag");
|
|
63
|
+
try {
|
|
64
|
+
await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Latest, context);
|
|
65
|
+
}
|
|
66
|
+
catch (e) {
|
|
67
|
+
const error = e;
|
|
68
|
+
chai_1.assert.strictEqual(error.errorNumber, ecschema_metadata_1.ECObjectsStatus.InvalidSchemaXML);
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
chai_1.assert.fail(0, 1, "Expected ECObjects exception");
|
|
72
|
+
});
|
|
73
|
+
it("loadSchema from file, bad schema version tag, throws", async () => {
|
|
74
|
+
const schemaKey = new ecschema_metadata_1.SchemaKey("BadSchemaVersionTag");
|
|
75
|
+
try {
|
|
76
|
+
await locater.getSchema(schemaKey, ecschema_metadata_1.SchemaMatchType.Latest, context);
|
|
77
|
+
}
|
|
78
|
+
catch (e) {
|
|
79
|
+
const error = e;
|
|
80
|
+
chai_1.assert.strictEqual(error.errorNumber, ecschema_metadata_1.ECObjectsStatus.InvalidSchemaXML);
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
chai_1.assert.fail(0, 1, "Expected ECObjects exception");
|
|
84
|
+
});
|
|
85
|
+
it("getSchema, full version, succeeds", async () => {
|
|
86
|
+
const stub = await locater.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.Exact, context);
|
|
87
|
+
chai_1.assert.isDefined(stub);
|
|
88
|
+
const key = stub.schemaKey;
|
|
89
|
+
chai_1.assert.strictEqual(key.name, "SchemaA");
|
|
90
|
+
chai_1.assert.strictEqual(key.version.toString(), "01.01.01");
|
|
91
|
+
});
|
|
92
|
+
it("getSchema, reference does not exist, throws.", async () => {
|
|
93
|
+
try {
|
|
94
|
+
await locater.getSchema(new ecschema_metadata_1.SchemaKey("RefDoesNotExist", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.Exact, context);
|
|
95
|
+
}
|
|
96
|
+
catch (e) {
|
|
97
|
+
const error = e;
|
|
98
|
+
chai_1.assert.strictEqual(error.errorNumber, ecschema_metadata_1.ECObjectsStatus.UnableToLocateSchema);
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
chai_1.assert.fail();
|
|
102
|
+
});
|
|
103
|
+
it("getSchema, references set", async () => {
|
|
104
|
+
const schemaA = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.Exact);
|
|
105
|
+
const schemaB = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaB", 2, 2, 2), ecschema_metadata_1.SchemaMatchType.Exact);
|
|
106
|
+
const schemaC = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaC", 3, 3, 3), ecschema_metadata_1.SchemaMatchType.Exact);
|
|
107
|
+
const schemaD = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaD", 4, 4, 4), ecschema_metadata_1.SchemaMatchType.Exact);
|
|
108
|
+
chai_1.assert.isDefined(schemaA);
|
|
109
|
+
chai_1.assert.strictEqual(schemaA.references.length, 2);
|
|
110
|
+
chai_1.assert.deepEqual(schemaA.references[0], schemaC);
|
|
111
|
+
chai_1.assert.deepEqual(schemaA.references[1], schemaB);
|
|
112
|
+
chai_1.assert.deepEqual(schemaA.references[0].references[0], schemaD);
|
|
113
|
+
chai_1.assert.deepEqual(schemaA.references[1].references[0], schemaC);
|
|
114
|
+
chai_1.assert.deepEqual(schemaA.references[1].references[1], schemaD);
|
|
115
|
+
});
|
|
116
|
+
it("getSchema, exact version, wrong minor, fails", async () => {
|
|
117
|
+
chai_1.assert.isUndefined(await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 2), ecschema_metadata_1.SchemaMatchType.Exact));
|
|
118
|
+
});
|
|
119
|
+
it("getSchema, latest, succeeds", async () => {
|
|
120
|
+
const stub = await locater.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 0), ecschema_metadata_1.SchemaMatchType.Latest, context);
|
|
121
|
+
chai_1.assert.isDefined(stub);
|
|
122
|
+
chai_1.assert.strictEqual(stub.schemaKey.name, "SchemaA");
|
|
123
|
+
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "02.00.02");
|
|
124
|
+
});
|
|
125
|
+
it("getSchema, latest write compatible, succeeds", async () => {
|
|
126
|
+
const stub = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 1, 0), ecschema_metadata_1.SchemaMatchType.LatestWriteCompatible);
|
|
127
|
+
chai_1.assert.isDefined(stub);
|
|
128
|
+
chai_1.assert.strictEqual(stub.schemaKey.name, "SchemaA");
|
|
129
|
+
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "01.01.01");
|
|
130
|
+
});
|
|
131
|
+
it("getSchema, latest write compatible, write version wrong, fails", async () => {
|
|
132
|
+
chai_1.assert.isUndefined(await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 2, 0), ecschema_metadata_1.SchemaMatchType.LatestWriteCompatible));
|
|
133
|
+
});
|
|
134
|
+
it("getSchema, latest read compatible, succeeds", async () => {
|
|
135
|
+
const stub = await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 1, 0, 0), ecschema_metadata_1.SchemaMatchType.LatestReadCompatible);
|
|
136
|
+
chai_1.assert.isDefined(stub);
|
|
137
|
+
chai_1.assert.strictEqual(stub.schemaKey.name, "SchemaA");
|
|
138
|
+
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "01.01.01");
|
|
139
|
+
});
|
|
140
|
+
it("getSchema, latest read compatible, read version wrong, fails", async () => {
|
|
141
|
+
chai_1.assert.isUndefined(await context.getSchema(new ecschema_metadata_1.SchemaKey("SchemaA", 2, 1, 1), ecschema_metadata_1.SchemaMatchType.LatestReadCompatible));
|
|
142
|
+
});
|
|
143
|
+
it("sync - should ignore commented out schema references", () => {
|
|
144
|
+
const stub = context.getSchemaSync(new ecschema_metadata_1.SchemaKey("RefCommentedOut", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.LatestReadCompatible);
|
|
145
|
+
chai_1.assert.isDefined(stub);
|
|
146
|
+
chai_1.assert.strictEqual(stub.schemaKey.name, "RefCommentedOut");
|
|
147
|
+
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "01.01.01");
|
|
148
|
+
});
|
|
149
|
+
it("async - should ignore commented out schema references", async () => {
|
|
150
|
+
const stub = await context.getSchema(new ecschema_metadata_1.SchemaKey("RefCommentedOut", 1, 1, 1), ecschema_metadata_1.SchemaMatchType.LatestReadCompatible);
|
|
151
|
+
chai_1.assert.isDefined(stub);
|
|
152
|
+
chai_1.assert.strictEqual(stub.schemaKey.name, "RefCommentedOut");
|
|
153
|
+
chai_1.assert.strictEqual(stub.schemaKey.version.toString(), "01.01.01");
|
|
154
|
+
});
|
|
155
|
+
it("getSchemaKey, valid version and name, succeeds", () => {
|
|
156
|
+
const schemaXml = `<ECSchema schemaName="SchemaA" version="1.1.1"> </ECSchema>`;
|
|
157
|
+
const key = locater.getSchemaKey(schemaXml);
|
|
158
|
+
chai_1.assert.deepEqual(key, new ecschema_metadata_1.SchemaKey("SchemaA", new ecschema_metadata_1.ECVersion(1, 1, 1)));
|
|
159
|
+
});
|
|
160
|
+
it("getSchemaKey, invalid xml, throws", () => {
|
|
161
|
+
const schemaXml = `<ECSchemaBad schemaName="SchemaA" version="1.1.1"> </ECSchemaBad>`;
|
|
162
|
+
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find '<ECSchema>' tag in the given file`);
|
|
163
|
+
});
|
|
164
|
+
it("getSchemaKey, invalid schemaName attribute, throws", () => {
|
|
165
|
+
const schemaXml = `<ECSchema schemaNameBad="SchemaA" version="1.1.1"> </ECSchema>`;
|
|
166
|
+
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find the ECSchema 'schemaName' or 'version' tag in the given file`);
|
|
167
|
+
});
|
|
168
|
+
it("getSchemaKey, invalid schemaName, throws", () => {
|
|
169
|
+
const schemaXml = `<ECSchema version="1.1.1" schemaName=""> </ECSchema>`;
|
|
170
|
+
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find the ECSchema 'schemaName' or 'version' tag in the given file`);
|
|
171
|
+
});
|
|
172
|
+
it("getSchemaKey, invalid version attribute, throws", () => {
|
|
173
|
+
const schemaXml = `<ECSchema schemaName="SchemaA" versionBad="1.1.1"> </ECSchema>`;
|
|
174
|
+
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find the ECSchema 'schemaName' or 'version' tag in the given file`);
|
|
175
|
+
});
|
|
176
|
+
it("getSchemaKey, invalid version, throws", () => {
|
|
177
|
+
const schemaXml = `<ECSchema schemaName="SchemaA" version=""> </ECSchema>`;
|
|
178
|
+
(0, chai_1.expect)(() => locater.getSchemaKey(schemaXml)).to.throw(ecschema_metadata_1.ECObjectsError, `Could not find the ECSchema 'schemaName' or 'version' tag in the given file`);
|
|
179
|
+
});
|
|
180
|
+
});
|
|
181
181
|
//# sourceMappingURL=SchemaXmlFileLocator.test.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=StubSchemaXmlFileLocater.test.d.ts.map
|