@itwin/core-backend 5.1.0-dev.4 → 5.1.0-dev.41

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 (284) hide show
  1. package/CHANGELOG.md +109 -1
  2. package/lib/cjs/BackendHubAccess.d.ts +1 -1
  3. package/lib/cjs/BackendHubAccess.js +1 -1
  4. package/lib/cjs/BackendHubAccess.js.map +1 -1
  5. package/lib/cjs/BisCoreSchema.js +1 -1
  6. package/lib/cjs/BisCoreSchema.js.map +1 -1
  7. package/lib/cjs/BriefcaseManager.d.ts +10 -2
  8. package/lib/cjs/BriefcaseManager.d.ts.map +1 -1
  9. package/lib/cjs/BriefcaseManager.js +12 -0
  10. package/lib/cjs/BriefcaseManager.js.map +1 -1
  11. package/lib/cjs/Category.d.ts +4 -4
  12. package/lib/cjs/Category.js +4 -4
  13. package/lib/cjs/Category.js.map +1 -1
  14. package/lib/cjs/ChangesetECAdaptor.d.ts +67 -8
  15. package/lib/cjs/ChangesetECAdaptor.d.ts.map +1 -1
  16. package/lib/cjs/ChangesetECAdaptor.js +248 -33
  17. package/lib/cjs/ChangesetECAdaptor.js.map +1 -1
  18. package/lib/cjs/ClassRegistry.d.ts +1 -1
  19. package/lib/cjs/ClassRegistry.js +1 -1
  20. package/lib/cjs/ClassRegistry.js.map +1 -1
  21. package/lib/cjs/CloudSqlite.js +1 -1
  22. package/lib/cjs/CloudSqlite.js.map +1 -1
  23. package/lib/cjs/CodeSpecs.d.ts +1 -1
  24. package/lib/cjs/CodeSpecs.js +1 -1
  25. package/lib/cjs/CodeSpecs.js.map +1 -1
  26. package/lib/cjs/DisplayStyle.d.ts +4 -4
  27. package/lib/cjs/DisplayStyle.js +3 -3
  28. package/lib/cjs/DisplayStyle.js.map +1 -1
  29. package/lib/cjs/ECDb.d.ts +4 -4
  30. package/lib/cjs/ECDb.d.ts.map +1 -1
  31. package/lib/cjs/ECDb.js +4 -4
  32. package/lib/cjs/ECDb.js.map +1 -1
  33. package/lib/cjs/ECSqlStatement.d.ts +15 -6
  34. package/lib/cjs/ECSqlStatement.d.ts.map +1 -1
  35. package/lib/cjs/ECSqlStatement.js +18 -4
  36. package/lib/cjs/ECSqlStatement.js.map +1 -1
  37. package/lib/cjs/Element.d.ts +51 -51
  38. package/lib/cjs/Element.js +51 -51
  39. package/lib/cjs/Element.js.map +1 -1
  40. package/lib/cjs/ElementAspect.d.ts +8 -8
  41. package/lib/cjs/ElementAspect.d.ts.map +1 -1
  42. package/lib/cjs/ElementAspect.js +8 -8
  43. package/lib/cjs/ElementAspect.js.map +1 -1
  44. package/lib/cjs/Entity.d.ts +3 -3
  45. package/lib/cjs/Entity.js +2 -2
  46. package/lib/cjs/Entity.js.map +1 -1
  47. package/lib/cjs/ExportGraphics.d.ts +54 -8
  48. package/lib/cjs/ExportGraphics.d.ts.map +1 -1
  49. package/lib/cjs/ExportGraphics.js +158 -59
  50. package/lib/cjs/ExportGraphics.js.map +1 -1
  51. package/lib/cjs/GeographicCRSServices.d.ts +6 -2
  52. package/lib/cjs/GeographicCRSServices.d.ts.map +1 -1
  53. package/lib/cjs/GeographicCRSServices.js +1 -1
  54. package/lib/cjs/GeographicCRSServices.js.map +1 -1
  55. package/lib/cjs/IModelDb.d.ts +23 -21
  56. package/lib/cjs/IModelDb.d.ts.map +1 -1
  57. package/lib/cjs/IModelDb.js +57 -31
  58. package/lib/cjs/IModelDb.js.map +1 -1
  59. package/lib/cjs/IModelElementCloneContext.d.ts +1 -1
  60. package/lib/cjs/IModelElementCloneContext.d.ts.map +1 -1
  61. package/lib/cjs/IModelElementCloneContext.js +1 -1
  62. package/lib/cjs/IModelElementCloneContext.js.map +1 -1
  63. package/lib/cjs/IModelHost.d.ts +2 -2
  64. package/lib/cjs/IModelHost.js +2 -2
  65. package/lib/cjs/IModelHost.js.map +1 -1
  66. package/lib/cjs/Material.d.ts +1 -1
  67. package/lib/cjs/Material.js +1 -1
  68. package/lib/cjs/Material.js.map +1 -1
  69. package/lib/cjs/Model.d.ts +22 -22
  70. package/lib/cjs/Model.js +22 -22
  71. package/lib/cjs/Model.js.map +1 -1
  72. package/lib/cjs/SQLiteDb.d.ts +1 -1
  73. package/lib/cjs/SQLiteDb.js +1 -1
  74. package/lib/cjs/SQLiteDb.js.map +1 -1
  75. package/lib/cjs/SqliteStatement.d.ts +1 -1
  76. package/lib/cjs/SqliteStatement.d.ts.map +1 -1
  77. package/lib/cjs/SqliteStatement.js +1 -1
  78. package/lib/cjs/SqliteStatement.js.map +1 -1
  79. package/lib/cjs/Texture.d.ts +1 -1
  80. package/lib/cjs/Texture.js +1 -1
  81. package/lib/cjs/Texture.js.map +1 -1
  82. package/lib/cjs/TxnManager.d.ts +4 -4
  83. package/lib/cjs/TxnManager.js +1 -1
  84. package/lib/cjs/TxnManager.js.map +1 -1
  85. package/lib/cjs/ViewDefinition.d.ts +40 -14
  86. package/lib/cjs/ViewDefinition.d.ts.map +1 -1
  87. package/lib/cjs/ViewDefinition.js +42 -14
  88. package/lib/cjs/ViewDefinition.js.map +1 -1
  89. package/lib/cjs/annotations/FrameGeometry.d.ts +52 -0
  90. package/lib/cjs/annotations/FrameGeometry.d.ts.map +1 -0
  91. package/lib/cjs/annotations/FrameGeometry.js +250 -0
  92. package/lib/cjs/annotations/FrameGeometry.js.map +1 -0
  93. package/lib/cjs/{TextAnnotationElement.d.ts → annotations/TextAnnotationElement.d.ts} +6 -11
  94. package/lib/cjs/annotations/TextAnnotationElement.d.ts.map +1 -0
  95. package/lib/cjs/{TextAnnotationElement.js → annotations/TextAnnotationElement.js} +20 -26
  96. package/lib/cjs/annotations/TextAnnotationElement.js.map +1 -0
  97. package/lib/cjs/annotations/TextAnnotationGeometry.d.ts +31 -0
  98. package/lib/cjs/annotations/TextAnnotationGeometry.d.ts.map +1 -0
  99. package/lib/cjs/annotations/TextAnnotationGeometry.js +83 -0
  100. package/lib/cjs/annotations/TextAnnotationGeometry.js.map +1 -0
  101. package/lib/cjs/annotations/TextBlockGeometry.d.ts +16 -0
  102. package/lib/cjs/annotations/TextBlockGeometry.d.ts.map +1 -0
  103. package/lib/cjs/{TextAnnotationGeometry.js → annotations/TextBlockGeometry.js} +11 -68
  104. package/lib/cjs/annotations/TextBlockGeometry.js.map +1 -0
  105. package/lib/cjs/{TextAnnotationLayout.d.ts → annotations/TextBlockLayout.d.ts} +19 -7
  106. package/lib/cjs/annotations/TextBlockLayout.d.ts.map +1 -0
  107. package/lib/cjs/{TextAnnotationLayout.js → annotations/TextBlockLayout.js} +19 -7
  108. package/lib/cjs/annotations/TextBlockLayout.js.map +1 -0
  109. package/lib/cjs/core-backend.d.ts +5 -3
  110. package/lib/cjs/core-backend.d.ts.map +1 -1
  111. package/lib/cjs/core-backend.js +25 -6
  112. package/lib/cjs/core-backend.js.map +1 -1
  113. package/lib/cjs/rpc-impl/IModelReadRpcImpl.d.ts +1 -1
  114. package/lib/cjs/rpc-impl/IModelReadRpcImpl.js +1 -1
  115. package/lib/cjs/rpc-impl/IModelReadRpcImpl.js.map +1 -1
  116. package/lib/cjs/rpc-impl/RpcBriefcaseUtility.d.ts +2 -2
  117. package/lib/cjs/rpc-impl/RpcBriefcaseUtility.js.map +1 -1
  118. package/lib/cjs/rpc-impl/SnapshotIModelRpcImpl.d.ts +1 -1
  119. package/lib/cjs/rpc-impl/SnapshotIModelRpcImpl.js +1 -1
  120. package/lib/cjs/rpc-impl/SnapshotIModelRpcImpl.js.map +1 -1
  121. package/lib/esm/BackendHubAccess.d.ts +1 -1
  122. package/lib/esm/BackendHubAccess.js +1 -1
  123. package/lib/esm/BackendHubAccess.js.map +1 -1
  124. package/lib/esm/BisCoreSchema.js +1 -1
  125. package/lib/esm/BisCoreSchema.js.map +1 -1
  126. package/lib/esm/BriefcaseManager.d.ts +10 -2
  127. package/lib/esm/BriefcaseManager.d.ts.map +1 -1
  128. package/lib/esm/BriefcaseManager.js +12 -0
  129. package/lib/esm/BriefcaseManager.js.map +1 -1
  130. package/lib/esm/Category.d.ts +4 -4
  131. package/lib/esm/Category.js +4 -4
  132. package/lib/esm/Category.js.map +1 -1
  133. package/lib/esm/ChangesetECAdaptor.d.ts +67 -8
  134. package/lib/esm/ChangesetECAdaptor.d.ts.map +1 -1
  135. package/lib/esm/ChangesetECAdaptor.js +248 -33
  136. package/lib/esm/ChangesetECAdaptor.js.map +1 -1
  137. package/lib/esm/ClassRegistry.d.ts +1 -1
  138. package/lib/esm/ClassRegistry.js +1 -1
  139. package/lib/esm/ClassRegistry.js.map +1 -1
  140. package/lib/esm/CloudSqlite.js +1 -1
  141. package/lib/esm/CloudSqlite.js.map +1 -1
  142. package/lib/esm/CodeSpecs.d.ts +1 -1
  143. package/lib/esm/CodeSpecs.js +1 -1
  144. package/lib/esm/CodeSpecs.js.map +1 -1
  145. package/lib/esm/DisplayStyle.d.ts +4 -4
  146. package/lib/esm/DisplayStyle.js +3 -3
  147. package/lib/esm/DisplayStyle.js.map +1 -1
  148. package/lib/esm/ECDb.d.ts +4 -4
  149. package/lib/esm/ECDb.d.ts.map +1 -1
  150. package/lib/esm/ECDb.js +4 -4
  151. package/lib/esm/ECDb.js.map +1 -1
  152. package/lib/esm/ECSqlStatement.d.ts +15 -6
  153. package/lib/esm/ECSqlStatement.d.ts.map +1 -1
  154. package/lib/esm/ECSqlStatement.js +18 -4
  155. package/lib/esm/ECSqlStatement.js.map +1 -1
  156. package/lib/esm/Element.d.ts +51 -51
  157. package/lib/esm/Element.js +51 -51
  158. package/lib/esm/Element.js.map +1 -1
  159. package/lib/esm/ElementAspect.d.ts +8 -8
  160. package/lib/esm/ElementAspect.d.ts.map +1 -1
  161. package/lib/esm/ElementAspect.js +8 -8
  162. package/lib/esm/ElementAspect.js.map +1 -1
  163. package/lib/esm/Entity.d.ts +3 -3
  164. package/lib/esm/Entity.js +2 -2
  165. package/lib/esm/Entity.js.map +1 -1
  166. package/lib/esm/ExportGraphics.d.ts +54 -8
  167. package/lib/esm/ExportGraphics.d.ts.map +1 -1
  168. package/lib/esm/ExportGraphics.js +156 -58
  169. package/lib/esm/ExportGraphics.js.map +1 -1
  170. package/lib/esm/GeographicCRSServices.d.ts +6 -2
  171. package/lib/esm/GeographicCRSServices.d.ts.map +1 -1
  172. package/lib/esm/GeographicCRSServices.js +1 -1
  173. package/lib/esm/GeographicCRSServices.js.map +1 -1
  174. package/lib/esm/IModelDb.d.ts +23 -21
  175. package/lib/esm/IModelDb.d.ts.map +1 -1
  176. package/lib/esm/IModelDb.js +58 -32
  177. package/lib/esm/IModelDb.js.map +1 -1
  178. package/lib/esm/IModelElementCloneContext.d.ts +1 -1
  179. package/lib/esm/IModelElementCloneContext.d.ts.map +1 -1
  180. package/lib/esm/IModelElementCloneContext.js +1 -1
  181. package/lib/esm/IModelElementCloneContext.js.map +1 -1
  182. package/lib/esm/IModelHost.d.ts +2 -2
  183. package/lib/esm/IModelHost.js +2 -2
  184. package/lib/esm/IModelHost.js.map +1 -1
  185. package/lib/esm/Material.d.ts +1 -1
  186. package/lib/esm/Material.js +1 -1
  187. package/lib/esm/Material.js.map +1 -1
  188. package/lib/esm/Model.d.ts +22 -22
  189. package/lib/esm/Model.js +22 -22
  190. package/lib/esm/Model.js.map +1 -1
  191. package/lib/esm/SQLiteDb.d.ts +1 -1
  192. package/lib/esm/SQLiteDb.js +1 -1
  193. package/lib/esm/SQLiteDb.js.map +1 -1
  194. package/lib/esm/SqliteStatement.d.ts +1 -1
  195. package/lib/esm/SqliteStatement.d.ts.map +1 -1
  196. package/lib/esm/SqliteStatement.js +1 -1
  197. package/lib/esm/SqliteStatement.js.map +1 -1
  198. package/lib/esm/Texture.d.ts +1 -1
  199. package/lib/esm/Texture.js +1 -1
  200. package/lib/esm/Texture.js.map +1 -1
  201. package/lib/esm/TxnManager.d.ts +4 -4
  202. package/lib/esm/TxnManager.js +1 -1
  203. package/lib/esm/TxnManager.js.map +1 -1
  204. package/lib/esm/ViewDefinition.d.ts +40 -14
  205. package/lib/esm/ViewDefinition.d.ts.map +1 -1
  206. package/lib/esm/ViewDefinition.js +42 -14
  207. package/lib/esm/ViewDefinition.js.map +1 -1
  208. package/lib/esm/annotations/FrameGeometry.d.ts +52 -0
  209. package/lib/esm/annotations/FrameGeometry.d.ts.map +1 -0
  210. package/lib/esm/annotations/FrameGeometry.js +245 -0
  211. package/lib/esm/annotations/FrameGeometry.js.map +1 -0
  212. package/lib/esm/{TextAnnotationElement.d.ts → annotations/TextAnnotationElement.d.ts} +6 -11
  213. package/lib/esm/annotations/TextAnnotationElement.d.ts.map +1 -0
  214. package/lib/esm/{TextAnnotationElement.js → annotations/TextAnnotationElement.js} +22 -28
  215. package/lib/esm/annotations/TextAnnotationElement.js.map +1 -0
  216. package/lib/esm/annotations/TextAnnotationGeometry.d.ts +31 -0
  217. package/lib/esm/annotations/TextAnnotationGeometry.d.ts.map +1 -0
  218. package/lib/esm/annotations/TextAnnotationGeometry.js +80 -0
  219. package/lib/esm/annotations/TextAnnotationGeometry.js.map +1 -0
  220. package/lib/esm/annotations/TextBlockGeometry.d.ts +16 -0
  221. package/lib/esm/annotations/TextBlockGeometry.d.ts.map +1 -0
  222. package/lib/esm/{TextAnnotationGeometry.js → annotations/TextBlockGeometry.js} +11 -68
  223. package/lib/esm/annotations/TextBlockGeometry.js.map +1 -0
  224. package/lib/esm/{TextAnnotationLayout.d.ts → annotations/TextBlockLayout.d.ts} +19 -7
  225. package/lib/esm/annotations/TextBlockLayout.d.ts.map +1 -0
  226. package/lib/esm/{TextAnnotationLayout.js → annotations/TextBlockLayout.js} +19 -7
  227. package/lib/esm/annotations/TextBlockLayout.js.map +1 -0
  228. package/lib/esm/core-backend.d.ts +5 -3
  229. package/lib/esm/core-backend.d.ts.map +1 -1
  230. package/lib/esm/core-backend.js +25 -3
  231. package/lib/esm/core-backend.js.map +1 -1
  232. package/lib/esm/rpc-impl/IModelReadRpcImpl.d.ts +1 -1
  233. package/lib/esm/rpc-impl/IModelReadRpcImpl.js +1 -1
  234. package/lib/esm/rpc-impl/IModelReadRpcImpl.js.map +1 -1
  235. package/lib/esm/rpc-impl/RpcBriefcaseUtility.d.ts +2 -2
  236. package/lib/esm/rpc-impl/RpcBriefcaseUtility.js.map +1 -1
  237. package/lib/esm/rpc-impl/SnapshotIModelRpcImpl.d.ts +1 -1
  238. package/lib/esm/rpc-impl/SnapshotIModelRpcImpl.js +1 -1
  239. package/lib/esm/rpc-impl/SnapshotIModelRpcImpl.js.map +1 -1
  240. package/lib/esm/test/TestUtils.d.ts +1 -1
  241. package/lib/esm/test/TestUtils.d.ts.map +1 -1
  242. package/lib/esm/test/TestUtils.js +1 -1
  243. package/lib/esm/test/TestUtils.js.map +1 -1
  244. package/lib/esm/test/annotations/TextAnnotation.test.js +190 -1025
  245. package/lib/esm/test/annotations/TextAnnotation.test.js.map +1 -1
  246. package/lib/esm/test/annotations/TextBlock.test.d.ts +2 -0
  247. package/lib/esm/test/annotations/TextBlock.test.d.ts.map +1 -0
  248. package/lib/esm/test/annotations/TextBlock.test.js +969 -0
  249. package/lib/esm/test/annotations/TextBlock.test.js.map +1 -0
  250. package/lib/esm/test/ecdb/ECDb.test.js +29 -8
  251. package/lib/esm/test/ecdb/ECDb.test.js.map +1 -1
  252. package/lib/esm/test/ecdb/ECSqlStatement.test.js +192 -0
  253. package/lib/esm/test/ecdb/ECSqlStatement.test.js.map +1 -1
  254. package/lib/esm/test/imodel/IModel.test.js +228 -5
  255. package/lib/esm/test/imodel/IModel.test.js.map +1 -1
  256. package/lib/esm/test/misc/GeoServices.test.js +23 -9
  257. package/lib/esm/test/misc/GeoServices.test.js.map +1 -1
  258. package/lib/esm/test/standalone/ChangesetReader.test.js +451 -136
  259. package/lib/esm/test/standalone/ChangesetReader.test.js.map +1 -1
  260. package/lib/esm/test/standalone/ExportGraphics.test.js +53 -1
  261. package/lib/esm/test/standalone/ExportGraphics.test.js.map +1 -1
  262. package/lib/esm/test/standalone/GeometryStream.test.js +49 -1
  263. package/lib/esm/test/standalone/GeometryStream.test.js.map +1 -1
  264. package/lib/esm/test/standalone/IModelLimits.test.d.ts +2 -0
  265. package/lib/esm/test/standalone/IModelLimits.test.d.ts.map +1 -0
  266. package/lib/esm/test/standalone/IModelLimits.test.js +103 -0
  267. package/lib/esm/test/standalone/IModelLimits.test.js.map +1 -0
  268. package/lib/esm/test/standalone/SnapshotDb.test.js +19 -1
  269. package/lib/esm/test/standalone/SnapshotDb.test.js.map +1 -1
  270. package/package.json +13 -13
  271. package/lib/cjs/TextAnnotationElement.d.ts.map +0 -1
  272. package/lib/cjs/TextAnnotationElement.js.map +0 -1
  273. package/lib/cjs/TextAnnotationGeometry.d.ts +0 -32
  274. package/lib/cjs/TextAnnotationGeometry.d.ts.map +0 -1
  275. package/lib/cjs/TextAnnotationGeometry.js.map +0 -1
  276. package/lib/cjs/TextAnnotationLayout.d.ts.map +0 -1
  277. package/lib/cjs/TextAnnotationLayout.js.map +0 -1
  278. package/lib/esm/TextAnnotationElement.d.ts.map +0 -1
  279. package/lib/esm/TextAnnotationElement.js.map +0 -1
  280. package/lib/esm/TextAnnotationGeometry.d.ts +0 -32
  281. package/lib/esm/TextAnnotationGeometry.d.ts.map +0 -1
  282. package/lib/esm/TextAnnotationGeometry.js.map +0 -1
  283. package/lib/esm/TextAnnotationLayout.d.ts.map +0 -1
  284. package/lib/esm/TextAnnotationLayout.js.map +0 -1
@@ -751,9 +751,10 @@ describe("GeoServices", () => {
751
751
  describe("Verify list of CRS", async () => {
752
752
  const validationRange = 50;
753
753
  const validationRangeSmall = 10;
754
- const validateCRSList = async (expectedCount, allowedRange, extent) => {
755
- const listOfCRS = await getAvailableCoordinateReferenceSystems({ extent });
756
- // Check fields of returned CRS's
754
+ const validateCRSList = async (options) => {
755
+ const { expectedCount, allowedRange, extent, includeWorld } = options;
756
+ const listOfCRS = await getAvailableCoordinateReferenceSystems({ extent, includeWorld });
757
+ // Check fields of returned coordinate reference systems
757
758
  const extentRange = Range2d.fromJSON(extent);
758
759
  for (const crs of listOfCRS) {
759
760
  // Validate extent
@@ -777,22 +778,28 @@ describe("GeoServices", () => {
777
778
  assert.equal(crsExtentRange.high.y, expectedExtent.high.y);
778
779
  };
779
780
  it("should get all CRS", async () => {
780
- await validateCRSList(11975, validationRange);
781
+ await validateCRSList({ expectedCount: 12_332, allowedRange: validationRange, includeWorld: true });
782
+ });
783
+ it("should get all CRS, excluding world crs", async () => {
784
+ await validateCRSList({ expectedCount: 11_975, allowedRange: validationRange });
781
785
  });
782
786
  it("should return CRS that are in the specified range (1)", async () => {
783
787
  const extent = { low: { x: 60.1, y: 61.2 }, high: { x: 62.3, y: 63.4 } };
784
- await validateCRSList(82, validationRangeSmall, extent);
788
+ await validateCRSList({ expectedCount: 82, allowedRange: validationRangeSmall, extent });
789
+ await validateCRSList({ expectedCount: 439, allowedRange: validationRangeSmall, extent, includeWorld: true });
785
790
  });
786
791
  it("should return CRS that are in the specified range (2)", async () => {
787
792
  const extent = { low: { x: 0, y: 2 }, high: { x: 1, y: 3 } };
788
- await validateCRSList(67, validationRangeSmall, extent);
793
+ await validateCRSList({ expectedCount: 67, allowedRange: validationRangeSmall, extent });
794
+ await validateCRSList({ expectedCount: 424, allowedRange: validationRangeSmall, extent, includeWorld: true });
789
795
  });
790
796
  it("should return CRS that are in the specified range (3)", async () => {
791
797
  const extent = { low: { x: 0.3, y: 2.4 }, high: { x: 1.6, y: 3.77 } };
792
- await validateCRSList(62, validationRangeSmall, extent);
798
+ await validateCRSList({ expectedCount: 62, allowedRange: validationRangeSmall, extent });
799
+ await validateCRSList({ expectedCount: 419, allowedRange: validationRangeSmall, extent, includeWorld: true });
793
800
  });
794
801
  it("should retrieve the whole list of CRS and validate the properties for a few selected CRS.", async () => {
795
- const listOfCRS = await getAvailableCoordinateReferenceSystems({});
802
+ const listOfCRS = await getAvailableCoordinateReferenceSystems({ includeWorld: true });
796
803
  let nbFound = 0;
797
804
  for (const crs of listOfCRS) {
798
805
  switch (crs.name) {
@@ -820,9 +827,16 @@ describe("GeoServices", () => {
820
827
  assert.equal(crs.deprecated, false);
821
828
  validateExtent(Range2d.fromJSON({ low: { x: -71, y: 43.5 }, high: { x: -66, y: 48 } }), crs.crsExtent);
822
829
  break;
830
+ // world CRS
831
+ case "EPSG:4326":
832
+ nbFound++;
833
+ assert.equal(crs.description, "WGS 84");
834
+ assert.equal(crs.deprecated, false);
835
+ validateExtent(Range2d.fromJSON({ low: { x: -180, y: -90 }, high: { x: 180, y: 90 } }), crs.crsExtent);
836
+ break;
823
837
  }
824
838
  }
825
- assert.equal(nbFound, 4);
839
+ assert.equal(nbFound, 5);
826
840
  });
827
841
  });
828
842
  it("should not be able to interpret an invalid GeographicCRS", async () => {
@@ -1 +1 @@
1
- {"version":3,"file":"GeoServices.test.js","sourceRoot":"","sources":["../../../../src/test/misc/GeoServices.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 { assert } from \"chai\";\nimport {\n GeographicCRSInterpretRequestProps, GeographicCRSProps,\n} from \"@itwin/core-common\";\nimport { IModelNative } from \"../../internal/NativePlatform\";\nimport { Geometry, Range2d, Range2dProps } from \"@itwin/core-geometry\";\nimport { GeoCoordConfig } from \"../../GeoCoordConfig\";\nimport { getAvailableCoordinateReferenceSystems } from \"../../GeographicCRSServices\";\n\n// spell-checker: disable\n\ndescribe(\"GeoServices\", () => {\n before(() => {\n GeoCoordConfig.loadDefaultDatabases();\n });\n\n const completionTest = async (incompleteGCS: GeographicCRSProps, completeCRS: GeographicCRSProps) => {\n\n const requestProps: GeographicCRSInterpretRequestProps = { format: \"JSON\", geographicCRSDef: JSON.stringify(incompleteGCS) };\n const response = IModelNative.platform.GeoServices.getGeographicCRSInterpretation(requestProps);\n\n assert.isTrue(response.status === 0);\n\n assert.isTrue(response.geographicCRS !== undefined);\n if (response.geographicCRS !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS !== undefined && completeCRS.horizontalCRS !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.id === completeCRS.horizontalCRS!.id);\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection !== undefined && completeCRS.horizontalCRS!.projection !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.method === completeCRS.horizontalCRS!.projection!.method);\n if (completeCRS.horizontalCRS!.projection!.falseEasting !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.falseEasting !== undefined);\n assert.isTrue(Math.abs(response.geographicCRS.horizontalCRS!.projection!.falseEasting! - completeCRS.horizontalCRS!.projection!.falseEasting) < Geometry.smallMetricDistance);\n }\n if (completeCRS.horizontalCRS!.projection!.falseNorthing !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.falseNorthing !== undefined);\n assert.isTrue(Math.abs(response.geographicCRS.horizontalCRS!.projection!.falseNorthing! - completeCRS.horizontalCRS!.projection!.falseNorthing) < Geometry.smallMetricDistance);\n }\n\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum !== undefined && completeCRS.horizontalCRS!.datum !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.id === completeCRS.horizontalCRS!.datum!.id);\n\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.ellipsoid !== undefined && completeCRS.horizontalCRS!.datum!.ellipsoid !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.ellipsoid!.id === completeCRS.horizontalCRS!.datum!.ellipsoid!.id);\n\n if (response.geographicCRS.additionalTransform !== undefined) {\n assert.isTrue(completeCRS.additionalTransform !== undefined);\n assert.isTrue(response.geographicCRS.additionalTransform.helmert2DWithZOffset !== undefined);\n assert.isTrue(completeCRS.additionalTransform!.helmert2DWithZOffset !== undefined);\n\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.rotDeg - completeCRS.additionalTransform!.helmert2DWithZOffset!.rotDeg) < Geometry.smallAngleDegrees);\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.translationX - completeCRS.additionalTransform!.helmert2DWithZOffset!.translationX) < Geometry.smallMetricDistance);\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.translationY - completeCRS.additionalTransform!.helmert2DWithZOffset!.translationY) < Geometry.smallMetricDistance);\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.translationZ - completeCRS.additionalTransform!.helmert2DWithZOffset!.translationZ) < Geometry.smallMetricDistance);\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.scale - completeCRS.additionalTransform!.helmert2DWithZOffset!.scale) < Geometry.smallFraction);\n }\n\n assert.isTrue(response.geographicCRS.verticalCRS !== undefined && completeCRS.verticalCRS !== undefined);\n assert.isTrue(response.geographicCRS.verticalCRS!.id === completeCRS.verticalCRS!.id);\n }\n };\n\n describe(\"Interpret to completion an incomplete GeographicCRS\", async () => {\n\n it(\"should be able to interpret to completion britishNationalGridOld\", async () => {\n\n const britishNationalGridOld: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n deprecated: true,\n description: \"OSGB36 - Use OSGB-7P-2. Consider OSGB/OSTN15 instead\",\n ellipsoid: {\n description: \"Airy 1830\",\n equatorialRadius: 6377563.396,\n id: \"EPSG:7001\",\n polarRadius: 6356256.909237,\n source: \"EPSG, Version 6 [EPSG]\",\n },\n ellipsoidId: \"EPSG:7001\",\n id: \"EPSG:6277\",\n source: \"EPSG V6.12 operation EPSG:1314 [EPSG]\",\n transforms: [\n {\n method: \"PositionalVector\",\n positionalVector: {\n delta: {\n x: 446.448,\n y: -125.157,\n z: 542.06,\n },\n rotation: {\n x: 0.15,\n y: 0.247,\n z: 0.842,\n },\n scalePPM: -20.489,\n },\n sourceEllipsoid: {\n equatorialRadius: 6377563.396,\n id: \"EPSG:7001\",\n polarRadius: 6356256.909237,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n },\n }],\n },\n datumId: \"EPSG:6277\",\n deprecated: true,\n description: \"Use other variant - OSGB British National Grid\",\n extent: {\n northEast: {\n latitude: 60.84,\n longitude: 1.78,\n },\n southWest: {\n latitude: 49.96,\n longitude: -7.56,\n },\n },\n id: \"EPSG:27700\",\n projection: {\n centralMeridian: -2,\n falseEasting: 400000,\n falseNorthing: -100000,\n latitudeOfOrigin: 49,\n method: \"TransverseMercator\",\n scaleFactor: 0.999601272737422,\n },\n source: \"EPSG\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n };\n\n await completionTest({ horizontalCRS: { id: \"EPSG:27700\" }, verticalCRS: { id: \"ELLIPSOID\" } }, britishNationalGridOld);\n });\n\n it(\"should be able to interpret to completion EWRGCS\", async () => {\n\n const EWRGCS: GeographicCRSProps = {\n horizontalCRS: {\n id: \"EPSG:27700\",\n description: \"OSGB 1936 / British National Grid\",\n source: \"EPSG V6 [Large and medium scale topographic mapping and engin]\",\n datumId: \"EPSG:6277\",\n datum: {\n id: \"EPSG:6277\",\n description: \"OSGB36 - Use OSGB-7P-2. Consider OSGB/OSTN15 instead\",\n deprecated: true,\n source: \"EPSG V6.12 operation EPSG:1314 [EPSG]\",\n ellipsoidId: \"EPSG:7001\",\n ellipsoid: {\n equatorialRadius: 6377563.396,\n polarRadius: 6356256.909237,\n id: \"EPSG:7001\",\n description: \"Airy 1830\",\n source: \"EPSG, Version 6 [EPSG]\",\n },\n transforms: [\n {\n method: \"PositionalVector\",\n sourceEllipsoid: {\n equatorialRadius: 6377563.396,\n polarRadius: 6356256.909237,\n id: \"EPSG:7001\",\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n polarRadius: 6356752.3142,\n id: \"WGS84\",\n },\n positionalVector: {\n delta: {\n x: 446.448,\n y: -125.157,\n z: 542.06,\n },\n rotation: {\n x: 0.15,\n y: 0.247,\n z: 0.842,\n },\n scalePPM: -20.489,\n },\n }],\n },\n unit: \"Meter\",\n projection: {\n method: \"TransverseMercator\",\n falseEasting: 400000,\n falseNorthing: -100000,\n centralMeridian: -2,\n latitudeOfOrigin: 49,\n scaleFactor: 0.999601272737422,\n },\n extent: {\n southWest: {\n latitude: 49.96,\n longitude: -7.56,\n },\n northEast: {\n latitude: 60.84,\n longitude: 1.78,\n },\n },\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n additionalTransform: {\n helmert2DWithZOffset: {\n translationX: 284597.3343,\n translationY: 79859.4651,\n translationZ: 0,\n rotDeg: 0.5263624458992088,\n scale: 0.9996703340508721,\n },\n },\n };\n\n await completionTest({ horizontalCRS: { id: \"EPSG:27700\" }, verticalCRS: { id: \"ELLIPSOID\" }, additionalTransform: { helmert2DWithZOffset: { translationX: 284597.3343, translationY: 79859.4651, translationZ: 0, rotDeg: 0.5263624458992088, scale: 0.9996703340508721 } } }, EWRGCS);\n });\n\n it(\"should be able to interpret to completion UTM27Z10\", async () => {\n\n const UTM27Z10: GeographicCRSProps = {\n horizontalCRS: {\n datum: {\n description: \"North American Datum of 1927 (US48, AK, HI, and Canada)\",\n ellipsoid: {\n description: \"Clarke 1866, Benoit Ratio\",\n epsg: 7008,\n equatorialRadius: 6378206.4,\n id: \"CLRK66\",\n polarRadius: 6356583.8,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"CLRK66\",\n epsg: 6267,\n id: \"NAD27\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n gridFile: {\n files: [\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/conus.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/alaska.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/prvi.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/hawaii.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stgeorge.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stlrnc.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stpaul.l?s\",\n format: \"NADCON\",\n }],\n },\n method: \"GridFiles\",\n sourceEllipsoid: {\n equatorialRadius: 6378206.4,\n id: \"CLRK66\",\n polarRadius: 6356583.8,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"GRS1980\",\n polarRadius: 6356752.314140348,\n },\n }],\n },\n datumId: \"NAD27\",\n description: \"UTM with NAD27 datum, Zone 10, Meter; Central Meridian 123d W\",\n epsg: 26710,\n extent: {\n northEast: {\n latitude: 84,\n longitude: -119.5,\n },\n southWest: {\n latitude: -1,\n longitude: -126.5,\n },\n },\n id: \"UTM27-10\",\n projection: {\n hemisphere: \"North\",\n method: \"UniversalTransverseMercator\",\n zoneNumber: 10,\n },\n source: \"Snyder, J.P, 1987, Map Projections - A Working Manual\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"NGVD29\",\n },\n };\n\n await completionTest({ horizontalCRS: { id: \"UTM27-10\" }, verticalCRS: { id: \"NGVD29\" } }, UTM27Z10);\n });\n\n it(\"should be able to interpret to completion UTM27Z10B\", async () => {\n\n const UTM27Z10B: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"North American Datum of 1927 (US48, AK, HI, and Canada)\",\n ellipsoid: {\n description: \"Clarke 1866, Benoit Ratio\",\n epsg: 7008,\n equatorialRadius: 6378206.4,\n id: \"CLRK66\",\n polarRadius: 6356583.8,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"CLRK66\",\n epsg: 6267,\n id: \"NAD27\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n gridFile: {\n files: [\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/conus.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/alaska.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/prvi.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/hawaii.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stgeorge.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stlrnc.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stpaul.l?s\",\n format: \"NADCON\",\n },\n ],\n },\n method: \"GridFiles\",\n sourceEllipsoid: {\n equatorialRadius: 6378206.4,\n id: \"CLRK66\",\n polarRadius: 6356583.8,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"GRS1980\",\n polarRadius: 6356752.314140348,\n },\n },\n ],\n },\n datumId: \"NAD27\",\n description: \"NAD27 / UTM zone 10N\",\n epsg: 26710,\n extent: {\n northEast: {\n latitude: 77,\n longitude: -120,\n },\n southWest: {\n latitude: 34.4,\n longitude: -126,\n },\n },\n id: \"EPSG:26710\",\n projection: {\n centralMeridian: -123,\n falseEasting: 500000,\n falseNorthing: 0,\n latitudeOfOrigin: 0,\n method: \"TransverseMercator\",\n scaleFactor: 0.9996,\n },\n source: \"EPSG V6 [Large and medium scale topographic mapping and engin]\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"NGVD29\",\n },\n };\n\n await completionTest({ horizontalCRS: { epsg: 26710 }, verticalCRS: { id: \"NGVD29\" } }, UTM27Z10B);\n });\n });\n\n describe(\"Interpretation of WKT GeographicCRS\", async () => {\n const interpretWKTTest = async (testWKT: string, completeCRS: GeographicCRSProps) => {\n\n const requestProps: GeographicCRSInterpretRequestProps = { format: \"WKT\", geographicCRSDef: testWKT };\n const response = IModelNative.platform.GeoServices.getGeographicCRSInterpretation(requestProps);\n\n assert.isTrue(response.status === 0);\n\n assert.isTrue(response.geographicCRS !== undefined);\n if (response.geographicCRS !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS !== undefined && completeCRS.horizontalCRS !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.id === completeCRS.horizontalCRS!.id);\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection !== undefined && completeCRS.horizontalCRS!.projection !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.method === completeCRS.horizontalCRS!.projection!.method);\n if (completeCRS.horizontalCRS!.projection!.falseEasting !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.falseEasting !== undefined);\n assert.isTrue(Math.abs(response.geographicCRS.horizontalCRS!.projection!.falseEasting! - completeCRS.horizontalCRS!.projection!.falseEasting) < Geometry.smallMetricDistance);\n }\n if (completeCRS.horizontalCRS!.projection!.falseNorthing !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.falseNorthing !== undefined);\n assert.isTrue(Math.abs(response.geographicCRS.horizontalCRS!.projection!.falseNorthing! - completeCRS.horizontalCRS!.projection!.falseNorthing) < Geometry.smallMetricDistance);\n }\n\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum !== undefined && completeCRS.horizontalCRS!.datum !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.id === completeCRS.horizontalCRS!.datum!.id);\n\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.ellipsoid !== undefined && completeCRS.horizontalCRS!.datum!.ellipsoid !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.ellipsoid!.id === completeCRS.horizontalCRS!.datum!.ellipsoid!.id);\n\n assert.isTrue(response.geographicCRS.verticalCRS !== undefined && completeCRS.verticalCRS !== undefined);\n assert.isTrue(response.geographicCRS.verticalCRS!.id === completeCRS.verticalCRS!.id);\n\n // WKTs cannot define an additional transform\n assert.isTrue(response.geographicCRS.additionalTransform === undefined);\n }\n };\n\n it(\"should be able to interpret airportGrid2007 WKT\", async () => {\n const airportGrid2007: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"Heathrow T5 Datum\",\n ellipsoid: {\n description: \"Airy, 1830\",\n epsg: 7001,\n equatorialRadius: 6377563.396,\n id: \"AIRY30\",\n polarRadius: 6356256.909,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"AIRY30\",\n id: \"HeathrowT5\",\n source: \"Bentley Client\",\n transforms: [\n {\n method: \"PositionalVector\",\n positionalVector: {\n delta: {\n x: 358.398212181898,\n y: -213.702844870731,\n z: 495.318319769716,\n },\n rotation: {\n x: 668.806139320047,\n y: -4.72664217602752,\n z: 719.671097181396,\n },\n scalePPM: -6.26386076385543,\n },\n sourceEllipsoid: {\n equatorialRadius: 6377563.396,\n id: \"AIRY30\",\n polarRadius: 6356256.909,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n },\n },\n ],\n },\n datumId: \"HeathrowT5\",\n description: \"AirportGrid2007\",\n id: \"AirportGrid2007\",\n projection: {\n centralMeridian: -0.41832591666666674,\n falseEasting: 7334.81,\n falseNorthing: 5637.423,\n latitudeOfOrigin: 51.47011065555556,\n method: \"TransverseMercator\",\n scaleFactor: 0.999995,\n },\n source: \"WKT\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n };\n\n await interpretWKTTest('PROJCS[\"AirportGrid2007\", GEOGCS[\"HeathrowT5.LL\",DATUM[\"Heathrow T5\", SPHEROID[\"AIRY30\",6377563.396,299.32496127],358.398,-213.7028,495.3183,-668.80613932004700,4.72664217602752,-719.67109718139600,-6.26386076385543],PRIMEM[\"Greenwich\",0],UNIT[\"Decimal Degree\",0.017453292519943295]],PROJECTION[\"Transverse Mercator\"],PARAMETER[\"latitude_of_origin\",51.470110655555558],PARAMETER[\"central_meridian\",-0.41832591666666669],PARAMETER[\"scale_factor\",0.999995],PARAMETER[\"false_easting\",7334.810],PARAMETER[\"false_northing\",5637.423],UNIT[\"Meter\",1.00000000000000]]', airportGrid2007);\n });\n\n it(\"should be able to interpret denmarkED50 WKT\", async () => {\n\n const denmarkED50: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"European 1950, Denmark, for System 34\",\n ellipsoid: {\n description: \"Hayford, 1924 (aka 1909); same as International 1924\",\n epsg: 7022,\n equatorialRadius: 6378388,\n id: \"HAYFORD\",\n polarRadius: 6356911.9461279465,\n source: \"Snyder, J.P., 1987, Map Projections - A Working Manual\",\n },\n ellipsoidId: \"HAYFORD\",\n id: \"ED50-DK34\",\n source: \"KMSTrans, by Kort-og Matrikelstyrelsen (Nov 1999)\",\n transforms: [\n {\n method: \"PositionalVector\",\n positionalVector: {\n delta: {\n x: -81.0703,\n y: -89.3603,\n z: -115.7526,\n },\n rotation: {\n x: 0.48488,\n y: 0.02436,\n z: 0.41321,\n },\n scalePPM: -0.540645,\n },\n sourceEllipsoid: {\n equatorialRadius: 6378388,\n id: \"HAYFORD\",\n polarRadius: 6356911.9461279465,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n },\n },\n ],\n },\n datumId: \"ED50-DK34\",\n description: \"DummyName\",\n extent: {\n northEast: {\n latitude: 90,\n longitude: 180,\n },\n southWest: {\n latitude: -90,\n longitude: -180,\n },\n },\n id: \"DummyName\",\n projection: {\n method: \"None\",\n },\n source: \"Extracted from WKT string; description field carries WKT name.\",\n unit: \"Degree\",\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n };\n\n await interpretWKTTest('GEOGCS[ \"DummyName\", DATUM [\"European 1950 (Denmark)\", SPHEROID [\"International 1924\", 6378388, 297],-81.0703, -89.3603, -115.7526, .48488, .02436, .41321, -.540645], PRIMEM [ \"Greenwich\", 0.000000 ], UNIT [\"Decimal Degree\", 0.01745329251994330]]', denmarkED50);\n });\n\n it(\"should be able to interpret californiaStateZone2 WKT\", async () => {\n\n const californiaStateZone2: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"North American Datum of 1983\",\n ellipsoid: {\n description: \"Geodetic Reference System of 1980\",\n epsg: 7019,\n equatorialRadius: 6378137,\n id: \"GRS1980\",\n polarRadius: 6356752.314140348,\n source: \"Stem, L.E., Jan 1989, State Plane Coordinate System of 1983\",\n },\n ellipsoidId: \"GRS1980\",\n epsg: 6269,\n id: \"NAD83\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n method: \"None\",\n },\n ],\n },\n datumId: \"NAD83\",\n description: \"NAD_1983_StatePlane_California_II_FIPS_0402_Feet\",\n id: \"NAD_1983_StatePlane_Cal\",\n projection: {\n falseEasting: 6561666.666666666,\n falseNorthing: 1640416.666666667,\n latitudeOfOrigin: 37.66666666666666,\n longitudeOfOrigin: -122,\n method: \"LambertConformalConicTwoParallels\",\n standardParallel1: 38.33333333333334,\n standardParallel2: 39.83333333333334,\n },\n source: \"WKT\",\n unit: \"USSurveyFoot\",\n },\n verticalCRS: {\n id: \"NAVD88\",\n },\n };\n\n await interpretWKTTest('PROJCS[\"NAD_1983_StatePlane_California_II_FIPS_0402_Feet\",GEOGCS[\"GCS_North_American_1983\",DATUM[\"D_North_American_1983\",SPHEROID[\"GRS_1980\",6378137,298.257222101]],PRIMEM[\"Greenwich\",0],UNIT[\"Degree\",0.017453292519943295]],PROJECTION[\"Lambert_Conformal_Conic\"],PARAMETER[\"False_Easting\",6561666.666666666],PARAMETER[\"False_Northing\",1640416.666666667],PARAMETER[\"Central_Meridian\",-122],PARAMETER[\"Standard_Parallel_1\",38.33333333333334],PARAMETER[\"Standard_Parallel_2\",39.83333333333334],PARAMETER[\"Latitude_Of_Origin\",37.66666666666666],UNIT[\"Foot_US\",0.30480060960121924]]', californiaStateZone2);\n });\n\n it(\"should be able to interpret utm84Zone34S WKT\", async () => {\n\n const utm84Zone34S: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"World Geodetic System of 1984\",\n ellipsoid: {\n description: \"World Geodetic System of 1984, GEM 10C\",\n epsg: 7030,\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"WGS84\",\n epsg: 6326,\n id: \"WGS84\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n method: \"None\",\n },\n ],\n },\n datumId: \"WGS84\",\n description: \"WGS 84 / UTM zone 34S\",\n id: \"WGS 84 / UTM zone 34S\",\n projection: {\n centralMeridian: 20.999999999999982,\n falseEasting: 500000,\n falseNorthing: 10000000,\n latitudeOfOrigin: 0,\n method: \"TransverseMercator\",\n scaleFactor: 0.9996,\n },\n source: \"WKT\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n };\n\n await interpretWKTTest('PROJCS[\"WGS 84 / UTM zone 34S\", GEOGCS [ \"WGS 84\", DATUM [\"World Geodetic System 1984 (EPSG ID 6326)\", SPHEROID [\"WGS 84 (EPSG ID 7030)\", 6378137, 298.257223563]], PRIMEM [ \"Greenwich\", 0.000000 ], UNIT [\"Decimal Degree\", 0.01745329251994328]], PROJECTION [\"UTM zone 34S (EPSG OP 16134)\"], PARAMETER [\"Latitude_Of_Origin\", 0], PARAMETER [\"Central_Meridian\", 21], PARAMETER [\"Scale_Factor\", .9996], PARAMETER [\"False_Easting\", 500000], PARAMETER [\"False_Northing\", 10000000], UNIT [\"Meter\", 1]]', utm84Zone34S);\n });\n\n it(\"should be able to interpret utm84Zone32NGeoid WKT\", async () => {\n\n const utm84Zone32NGeoid: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"World Geodetic System of 1984\",\n ellipsoid: {\n description: \"World Geodetic System of 1984, GEM 10C\",\n epsg: 7030,\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"WGS84\",\n epsg: 6326,\n id: \"WGS84\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n method: \"None\",\n },\n ],\n },\n datumId: \"WGS84\",\n description: \"WGS 84 / UTM zone32N\",\n id: \"WGS 84 / UTM zone32N\",\n projection: {\n centralMeridian: 9,\n falseEasting: 500000,\n falseNorthing: 0,\n latitudeOfOrigin: 0,\n method: \"TransverseMercator\",\n scaleFactor: 0.9996,\n },\n source: \"WKT\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"GEOID\",\n },\n };\n\n await interpretWKTTest('COMPD_CS[\"WGS 84 / UTM zone 32N + EGM96 geoid height\",PROJCS[\"WGS 84 / UTM zone32N\",GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",\"7030\"]],AUTHORITY[\"EPSG\",\"6326\"]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",\"8901\"]],UNIT[\"degree\",0.0174532925199433,AUTHORITY[\"EPSG\",\"9122\"]],AUTHORITY[\"EPSG\",\"4326\"]],PROJECTION[\"Transverse_Mercator\"],PARAMETER[\"latitude_of_origin\",0],PARAMETER[\"central_meridian\",9],PARAMETER[\"scale_factor\",0.9996],PARAMETER[\"false_easting\",500000],PARAMETER[\"false_northing\",0],UNIT[\"metre\",1,AUTHORITY[\"EPSG\",\"9001\"]],AXIS[\"Easting\",EAST],AXIS[\"Northing\",NORTH],AUTHORITY[\"EPSG\",\"32632\"]],VERT_CS[\"EGM96 geoid height\",VERT_DATUM[\"EGM96 geoid\",2005,EXTENSION[\"PROJ4_GRIDS\",\"egm96_15.gtx\"],AUTHORITY[\"EPSG\",\"5171\"]],UNIT[\"metre\",1,AUTHORITY[\"EPSG\",\"9001\"]],AXIS[\"Up\",UP],AUTHORITY[\"EPSG\",\"5773\"]]]', utm84Zone32NGeoid);\n });\n it(\"should be able to interpret utm84Zone18NGeoid WKT\", async () => {\n\n const utm84Zone18NGeoid: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"World Geodetic System of 1984\",\n ellipsoid: {\n description: \"World Geodetic System of 1984, GEM 10C\",\n epsg: 7030,\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"WGS84\",\n epsg: 6326,\n id: \"WGS84\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n method: \"None\",\n },\n ],\n },\n datumId: \"WGS84\",\n description: \"UTM84-18N\",\n id: \"UTM84-18N\",\n projection: {\n hemisphere: \"North\",\n method: \"UniversalTransverseMercator\",\n zoneNumber: 18,\n },\n source: \"WKT\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"GEOID\",\n },\n };\n\n await interpretWKTTest('COMPD_CS[\"UTM84-18N\",PROJCS[\"UTM84-18N\",GEOGCS[\"LL84\",DATUM[\"WGS84\",SPHEROID[\"WGS84\",6378137.000,298.25722293]],PRIMEM[\"Greenwich\",0],UNIT[\"Degree\",0.017453292519943295]],PROJECTION[\"Universal Transverse Mercator System\"],PARAMETER[\"UTM Zone Number (1 - 60)\",18.0],PARAMETER[\"Hemisphere, North or South\",1.0],UNIT[\"Meter\",1.00000000000000]],VERT_CS[\"Geoid Height\",VERT_DATUM[\"EGM96 geoid\",2005],UNIT[\"METER\",1.000000]]]', utm84Zone18NGeoid);\n });\n });\n\n describe(\"Verify list of CRS\", async () => {\n const validationRange = 50;\n const validationRangeSmall = 10;\n\n const validateCRSList = async (expectedCount: number, allowedRange: number, extent?: Range2dProps): Promise<void> => {\n const listOfCRS = await getAvailableCoordinateReferenceSystems({ extent });\n\n // Check fields of returned CRS's\n const extentRange: Range2d = Range2d.fromJSON(extent);\n for (const crs of listOfCRS) {\n // Validate extent\n if (extent !== undefined) {\n const crsExtentRange: Range2d = Range2d.fromJSON(crs.crsExtent);\n const intersects = extentRange.intersectsRange(crsExtentRange);\n assert.isTrue(intersects);\n }\n\n // These fields should always be present\n assert.isTrue(crs.name !== undefined);\n assert.isTrue(crs.description !== undefined);\n assert.isTrue(crs.deprecated === true || crs.deprecated === false);\n }\n\n assert.isTrue(listOfCRS.length > expectedCount - allowedRange && listOfCRS.length < expectedCount + allowedRange);\n };\n\n const validateExtent = (expectedExtent: Range2d, crsExtent: Range2dProps) => {\n const crsExtentRange: Range2d = Range2d.fromJSON(crsExtent);\n assert.equal(crsExtentRange.low.x, expectedExtent.low.x);\n assert.equal(crsExtentRange.low.y, expectedExtent.low.y);\n assert.equal(crsExtentRange.high.x, expectedExtent.high.x);\n assert.equal(crsExtentRange.high.y, expectedExtent.high.y);\n };\n\n it(\"should get all CRS\", async () => {\n await validateCRSList(11975, validationRange);\n });\n\n it(\"should return CRS that are in the specified range (1)\", async () => {\n const extent: Range2dProps = { low: { x: 60.1, y: 61.2 }, high: { x: 62.3, y: 63.4 } };\n await validateCRSList(82, validationRangeSmall, extent);\n });\n\n it(\"should return CRS that are in the specified range (2)\", async () => {\n const extent: Range2dProps = { low: { x: 0, y: 2 }, high: { x: 1, y: 3 } };\n await validateCRSList(67, validationRangeSmall, extent);\n });\n\n it(\"should return CRS that are in the specified range (3)\", async () => {\n const extent: Range2dProps = { low: { x: 0.3, y: 2.4 }, high: { x: 1.6, y: 3.77 } };\n await validateCRSList(62, validationRangeSmall, extent);\n });\n\n it(\"should retrieve the whole list of CRS and validate the properties for a few selected CRS.\", async () => {\n const listOfCRS = await getAvailableCoordinateReferenceSystems({});\n let nbFound = 0;\n for (const crs of listOfCRS) {\n switch (crs.name) {\n case \"3TM111-83\":\n nbFound++;\n assert.equal(crs.description, \"Use NAD83-AB/3TM-111 instead.\");\n assert.equal(crs.deprecated, true);\n validateExtent(Range2d.fromJSON({ low: { x: -113, y: 48 }, high: { x: -109, y: 84 } }), crs.crsExtent);\n break;\n case \"NAD27-CAN.MTM-1\":\n nbFound++;\n assert.equal(crs.description, \"NAD27 / MTM zone 1\");\n assert.equal(crs.deprecated, false);\n validateExtent(Range2d.fromJSON({ low: { x: -54.5, y: 45 }, high: { x: -50.5, y: 55 } }), crs.crsExtent);\n break;\n case \"AL83-EF\":\n nbFound++;\n assert.equal(crs.description, \"NAD83 Alabama State Plane, East Zone, US Foot\");\n assert.equal(crs.deprecated, false);\n validateExtent(Range2d.fromJSON({ low: { x: -87.5, y: 30 }, high: { x: -84, y: 35.75 } }), crs.crsExtent);\n break;\n case \"ME-E\":\n nbFound++;\n assert.equal(crs.description, \"NAD27 Maine State Plane, East Zone(1801), US Foot\");\n assert.equal(crs.deprecated, false);\n validateExtent(Range2d.fromJSON({ low: { x: -71, y: 43.5 }, high: { x: -66, y: 48 } }), crs.crsExtent);\n break;\n }\n }\n assert.equal(nbFound, 4);\n });\n });\n\n it(\"should not be able to interpret an invalid GeographicCRS\", async () => {\n\n const interpretInvalidTest = async (formatCRS: \"WKT\" | \"JSON\", testInvalid: string) => {\n\n const requestProps: GeographicCRSInterpretRequestProps = { format: formatCRS, geographicCRSDef: testInvalid };\n const response = IModelNative.platform.GeoServices.getGeographicCRSInterpretation(requestProps);\n\n // At the moment return codes are not really error specific (we mostly return 32768) so we do not validate\n // actual error code for now.\n assert.isFalse(response.status === 0);\n };\n\n // WKT Without datum or projection clause\n await interpretInvalidTest(\"WKT\", 'PROJCS[\"AirportGrid2007\", GEOGCS[\"HeathrowT5.LL\",PRIMEM[\"Greenwich\",0],UNIT[\"Decimal Degree\",0.017453292519943295]],UNIT[\"Meter\",1.00000000000000]]');\n\n // Plain garbage\n await interpretInvalidTest(\"WKT\", \"Some invalid content\");\n\n // Format is JSON but content is WKT\n await interpretInvalidTest(\"JSON\", 'GEOGCS[ \"Longitude / Latitude (ED 50 Denmark)\", DATUM [\"European 1950 (Denmark)\", SPHEROID [\"International 1924\", 6378388, 297],-81.0703, -89.3603, -115.7526, .48488, .02436, .41321, -.540645], PRIMEM [ \"Greenwich\", 0.000000 ], UNIT [\"Decimal Degree\", 0.01745329251994330]]');\n\n // Vertical datum invalid for horizontal definition\n await interpretInvalidTest(\"JSON\", '{ horizontalCRS: { id: \"EPSG:27700\" }, verticalCRS: { id: \"NAVD29\" } }');\n\n // No horizontal CRS\n await interpretInvalidTest(\"JSON\", '{ verticalCRS: { id: \"NAVD29\" } }');\n\n // Unknown identifier\n await interpretInvalidTest(\"JSON\", '{ horizontalCRS: { id: \"UNKNOWN\" }, verticalCRS: { id: \"NAVD29\" } }');\n });\n});\n"]}
1
+ {"version":3,"file":"GeoServices.test.js","sourceRoot":"","sources":["../../../../src/test/misc/GeoServices.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 { assert } from \"chai\";\nimport {\n GeographicCRSInterpretRequestProps, GeographicCRSProps,\n} from \"@itwin/core-common\";\nimport { IModelNative } from \"../../internal/NativePlatform\";\nimport { Geometry, Range2d, Range2dProps } from \"@itwin/core-geometry\";\nimport { GeoCoordConfig } from \"../../GeoCoordConfig\";\nimport { getAvailableCoordinateReferenceSystems } from \"../../GeographicCRSServices\";\n\n// spell-checker: disable\n\ndescribe(\"GeoServices\", () => {\n before(() => {\n GeoCoordConfig.loadDefaultDatabases();\n });\n\n const completionTest = async (incompleteGCS: GeographicCRSProps, completeCRS: GeographicCRSProps) => {\n\n const requestProps: GeographicCRSInterpretRequestProps = { format: \"JSON\", geographicCRSDef: JSON.stringify(incompleteGCS) };\n const response = IModelNative.platform.GeoServices.getGeographicCRSInterpretation(requestProps);\n\n assert.isTrue(response.status === 0);\n\n assert.isTrue(response.geographicCRS !== undefined);\n if (response.geographicCRS !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS !== undefined && completeCRS.horizontalCRS !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.id === completeCRS.horizontalCRS!.id);\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection !== undefined && completeCRS.horizontalCRS!.projection !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.method === completeCRS.horizontalCRS!.projection!.method);\n if (completeCRS.horizontalCRS!.projection!.falseEasting !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.falseEasting !== undefined);\n assert.isTrue(Math.abs(response.geographicCRS.horizontalCRS!.projection!.falseEasting! - completeCRS.horizontalCRS!.projection!.falseEasting) < Geometry.smallMetricDistance);\n }\n if (completeCRS.horizontalCRS!.projection!.falseNorthing !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.falseNorthing !== undefined);\n assert.isTrue(Math.abs(response.geographicCRS.horizontalCRS!.projection!.falseNorthing! - completeCRS.horizontalCRS!.projection!.falseNorthing) < Geometry.smallMetricDistance);\n }\n\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum !== undefined && completeCRS.horizontalCRS!.datum !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.id === completeCRS.horizontalCRS!.datum!.id);\n\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.ellipsoid !== undefined && completeCRS.horizontalCRS!.datum!.ellipsoid !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.ellipsoid!.id === completeCRS.horizontalCRS!.datum!.ellipsoid!.id);\n\n if (response.geographicCRS.additionalTransform !== undefined) {\n assert.isTrue(completeCRS.additionalTransform !== undefined);\n assert.isTrue(response.geographicCRS.additionalTransform.helmert2DWithZOffset !== undefined);\n assert.isTrue(completeCRS.additionalTransform!.helmert2DWithZOffset !== undefined);\n\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.rotDeg - completeCRS.additionalTransform!.helmert2DWithZOffset!.rotDeg) < Geometry.smallAngleDegrees);\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.translationX - completeCRS.additionalTransform!.helmert2DWithZOffset!.translationX) < Geometry.smallMetricDistance);\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.translationY - completeCRS.additionalTransform!.helmert2DWithZOffset!.translationY) < Geometry.smallMetricDistance);\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.translationZ - completeCRS.additionalTransform!.helmert2DWithZOffset!.translationZ) < Geometry.smallMetricDistance);\n assert.isTrue(Math.abs(response.geographicCRS.additionalTransform.helmert2DWithZOffset!.scale - completeCRS.additionalTransform!.helmert2DWithZOffset!.scale) < Geometry.smallFraction);\n }\n\n assert.isTrue(response.geographicCRS.verticalCRS !== undefined && completeCRS.verticalCRS !== undefined);\n assert.isTrue(response.geographicCRS.verticalCRS!.id === completeCRS.verticalCRS!.id);\n }\n };\n\n describe(\"Interpret to completion an incomplete GeographicCRS\", async () => {\n\n it(\"should be able to interpret to completion britishNationalGridOld\", async () => {\n\n const britishNationalGridOld: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n deprecated: true,\n description: \"OSGB36 - Use OSGB-7P-2. Consider OSGB/OSTN15 instead\",\n ellipsoid: {\n description: \"Airy 1830\",\n equatorialRadius: 6377563.396,\n id: \"EPSG:7001\",\n polarRadius: 6356256.909237,\n source: \"EPSG, Version 6 [EPSG]\",\n },\n ellipsoidId: \"EPSG:7001\",\n id: \"EPSG:6277\",\n source: \"EPSG V6.12 operation EPSG:1314 [EPSG]\",\n transforms: [\n {\n method: \"PositionalVector\",\n positionalVector: {\n delta: {\n x: 446.448,\n y: -125.157,\n z: 542.06,\n },\n rotation: {\n x: 0.15,\n y: 0.247,\n z: 0.842,\n },\n scalePPM: -20.489,\n },\n sourceEllipsoid: {\n equatorialRadius: 6377563.396,\n id: \"EPSG:7001\",\n polarRadius: 6356256.909237,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n },\n }],\n },\n datumId: \"EPSG:6277\",\n deprecated: true,\n description: \"Use other variant - OSGB British National Grid\",\n extent: {\n northEast: {\n latitude: 60.84,\n longitude: 1.78,\n },\n southWest: {\n latitude: 49.96,\n longitude: -7.56,\n },\n },\n id: \"EPSG:27700\",\n projection: {\n centralMeridian: -2,\n falseEasting: 400000,\n falseNorthing: -100000,\n latitudeOfOrigin: 49,\n method: \"TransverseMercator\",\n scaleFactor: 0.999601272737422,\n },\n source: \"EPSG\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n };\n\n await completionTest({ horizontalCRS: { id: \"EPSG:27700\" }, verticalCRS: { id: \"ELLIPSOID\" } }, britishNationalGridOld);\n });\n\n it(\"should be able to interpret to completion EWRGCS\", async () => {\n\n const EWRGCS: GeographicCRSProps = {\n horizontalCRS: {\n id: \"EPSG:27700\",\n description: \"OSGB 1936 / British National Grid\",\n source: \"EPSG V6 [Large and medium scale topographic mapping and engin]\",\n datumId: \"EPSG:6277\",\n datum: {\n id: \"EPSG:6277\",\n description: \"OSGB36 - Use OSGB-7P-2. Consider OSGB/OSTN15 instead\",\n deprecated: true,\n source: \"EPSG V6.12 operation EPSG:1314 [EPSG]\",\n ellipsoidId: \"EPSG:7001\",\n ellipsoid: {\n equatorialRadius: 6377563.396,\n polarRadius: 6356256.909237,\n id: \"EPSG:7001\",\n description: \"Airy 1830\",\n source: \"EPSG, Version 6 [EPSG]\",\n },\n transforms: [\n {\n method: \"PositionalVector\",\n sourceEllipsoid: {\n equatorialRadius: 6377563.396,\n polarRadius: 6356256.909237,\n id: \"EPSG:7001\",\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n polarRadius: 6356752.3142,\n id: \"WGS84\",\n },\n positionalVector: {\n delta: {\n x: 446.448,\n y: -125.157,\n z: 542.06,\n },\n rotation: {\n x: 0.15,\n y: 0.247,\n z: 0.842,\n },\n scalePPM: -20.489,\n },\n }],\n },\n unit: \"Meter\",\n projection: {\n method: \"TransverseMercator\",\n falseEasting: 400000,\n falseNorthing: -100000,\n centralMeridian: -2,\n latitudeOfOrigin: 49,\n scaleFactor: 0.999601272737422,\n },\n extent: {\n southWest: {\n latitude: 49.96,\n longitude: -7.56,\n },\n northEast: {\n latitude: 60.84,\n longitude: 1.78,\n },\n },\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n additionalTransform: {\n helmert2DWithZOffset: {\n translationX: 284597.3343,\n translationY: 79859.4651,\n translationZ: 0,\n rotDeg: 0.5263624458992088,\n scale: 0.9996703340508721,\n },\n },\n };\n\n await completionTest({ horizontalCRS: { id: \"EPSG:27700\" }, verticalCRS: { id: \"ELLIPSOID\" }, additionalTransform: { helmert2DWithZOffset: { translationX: 284597.3343, translationY: 79859.4651, translationZ: 0, rotDeg: 0.5263624458992088, scale: 0.9996703340508721 } } }, EWRGCS);\n });\n\n it(\"should be able to interpret to completion UTM27Z10\", async () => {\n\n const UTM27Z10: GeographicCRSProps = {\n horizontalCRS: {\n datum: {\n description: \"North American Datum of 1927 (US48, AK, HI, and Canada)\",\n ellipsoid: {\n description: \"Clarke 1866, Benoit Ratio\",\n epsg: 7008,\n equatorialRadius: 6378206.4,\n id: \"CLRK66\",\n polarRadius: 6356583.8,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"CLRK66\",\n epsg: 6267,\n id: \"NAD27\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n gridFile: {\n files: [\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/conus.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/alaska.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/prvi.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/hawaii.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stgeorge.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stlrnc.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stpaul.l?s\",\n format: \"NADCON\",\n }],\n },\n method: \"GridFiles\",\n sourceEllipsoid: {\n equatorialRadius: 6378206.4,\n id: \"CLRK66\",\n polarRadius: 6356583.8,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"GRS1980\",\n polarRadius: 6356752.314140348,\n },\n }],\n },\n datumId: \"NAD27\",\n description: \"UTM with NAD27 datum, Zone 10, Meter; Central Meridian 123d W\",\n epsg: 26710,\n extent: {\n northEast: {\n latitude: 84,\n longitude: -119.5,\n },\n southWest: {\n latitude: -1,\n longitude: -126.5,\n },\n },\n id: \"UTM27-10\",\n projection: {\n hemisphere: \"North\",\n method: \"UniversalTransverseMercator\",\n zoneNumber: 10,\n },\n source: \"Snyder, J.P, 1987, Map Projections - A Working Manual\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"NGVD29\",\n },\n };\n\n await completionTest({ horizontalCRS: { id: \"UTM27-10\" }, verticalCRS: { id: \"NGVD29\" } }, UTM27Z10);\n });\n\n it(\"should be able to interpret to completion UTM27Z10B\", async () => {\n\n const UTM27Z10B: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"North American Datum of 1927 (US48, AK, HI, and Canada)\",\n ellipsoid: {\n description: \"Clarke 1866, Benoit Ratio\",\n epsg: 7008,\n equatorialRadius: 6378206.4,\n id: \"CLRK66\",\n polarRadius: 6356583.8,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"CLRK66\",\n epsg: 6267,\n id: \"NAD27\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n gridFile: {\n files: [\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/conus.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/alaska.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/prvi.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/hawaii.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stgeorge.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stlrnc.l?s\",\n format: \"NADCON\",\n },\n {\n direction: \"Direct\",\n fileName: \"./Usa/Nadcon/stpaul.l?s\",\n format: \"NADCON\",\n },\n ],\n },\n method: \"GridFiles\",\n sourceEllipsoid: {\n equatorialRadius: 6378206.4,\n id: \"CLRK66\",\n polarRadius: 6356583.8,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"GRS1980\",\n polarRadius: 6356752.314140348,\n },\n },\n ],\n },\n datumId: \"NAD27\",\n description: \"NAD27 / UTM zone 10N\",\n epsg: 26710,\n extent: {\n northEast: {\n latitude: 77,\n longitude: -120,\n },\n southWest: {\n latitude: 34.4,\n longitude: -126,\n },\n },\n id: \"EPSG:26710\",\n projection: {\n centralMeridian: -123,\n falseEasting: 500000,\n falseNorthing: 0,\n latitudeOfOrigin: 0,\n method: \"TransverseMercator\",\n scaleFactor: 0.9996,\n },\n source: \"EPSG V6 [Large and medium scale topographic mapping and engin]\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"NGVD29\",\n },\n };\n\n await completionTest({ horizontalCRS: { epsg: 26710 }, verticalCRS: { id: \"NGVD29\" } }, UTM27Z10B);\n });\n });\n\n describe(\"Interpretation of WKT GeographicCRS\", async () => {\n const interpretWKTTest = async (testWKT: string, completeCRS: GeographicCRSProps) => {\n\n const requestProps: GeographicCRSInterpretRequestProps = { format: \"WKT\", geographicCRSDef: testWKT };\n const response = IModelNative.platform.GeoServices.getGeographicCRSInterpretation(requestProps);\n\n assert.isTrue(response.status === 0);\n\n assert.isTrue(response.geographicCRS !== undefined);\n if (response.geographicCRS !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS !== undefined && completeCRS.horizontalCRS !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.id === completeCRS.horizontalCRS!.id);\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection !== undefined && completeCRS.horizontalCRS!.projection !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.method === completeCRS.horizontalCRS!.projection!.method);\n if (completeCRS.horizontalCRS!.projection!.falseEasting !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.falseEasting !== undefined);\n assert.isTrue(Math.abs(response.geographicCRS.horizontalCRS!.projection!.falseEasting! - completeCRS.horizontalCRS!.projection!.falseEasting) < Geometry.smallMetricDistance);\n }\n if (completeCRS.horizontalCRS!.projection!.falseNorthing !== undefined) {\n assert.isTrue(response.geographicCRS.horizontalCRS!.projection!.falseNorthing !== undefined);\n assert.isTrue(Math.abs(response.geographicCRS.horizontalCRS!.projection!.falseNorthing! - completeCRS.horizontalCRS!.projection!.falseNorthing) < Geometry.smallMetricDistance);\n }\n\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum !== undefined && completeCRS.horizontalCRS!.datum !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.id === completeCRS.horizontalCRS!.datum!.id);\n\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.ellipsoid !== undefined && completeCRS.horizontalCRS!.datum!.ellipsoid !== undefined);\n assert.isTrue(response.geographicCRS.horizontalCRS!.datum!.ellipsoid!.id === completeCRS.horizontalCRS!.datum!.ellipsoid!.id);\n\n assert.isTrue(response.geographicCRS.verticalCRS !== undefined && completeCRS.verticalCRS !== undefined);\n assert.isTrue(response.geographicCRS.verticalCRS!.id === completeCRS.verticalCRS!.id);\n\n // WKTs cannot define an additional transform\n assert.isTrue(response.geographicCRS.additionalTransform === undefined);\n }\n };\n\n it(\"should be able to interpret airportGrid2007 WKT\", async () => {\n const airportGrid2007: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"Heathrow T5 Datum\",\n ellipsoid: {\n description: \"Airy, 1830\",\n epsg: 7001,\n equatorialRadius: 6377563.396,\n id: \"AIRY30\",\n polarRadius: 6356256.909,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"AIRY30\",\n id: \"HeathrowT5\",\n source: \"Bentley Client\",\n transforms: [\n {\n method: \"PositionalVector\",\n positionalVector: {\n delta: {\n x: 358.398212181898,\n y: -213.702844870731,\n z: 495.318319769716,\n },\n rotation: {\n x: 668.806139320047,\n y: -4.72664217602752,\n z: 719.671097181396,\n },\n scalePPM: -6.26386076385543,\n },\n sourceEllipsoid: {\n equatorialRadius: 6377563.396,\n id: \"AIRY30\",\n polarRadius: 6356256.909,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n },\n },\n ],\n },\n datumId: \"HeathrowT5\",\n description: \"AirportGrid2007\",\n id: \"AirportGrid2007\",\n projection: {\n centralMeridian: -0.41832591666666674,\n falseEasting: 7334.81,\n falseNorthing: 5637.423,\n latitudeOfOrigin: 51.47011065555556,\n method: \"TransverseMercator\",\n scaleFactor: 0.999995,\n },\n source: \"WKT\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n };\n\n await interpretWKTTest('PROJCS[\"AirportGrid2007\", GEOGCS[\"HeathrowT5.LL\",DATUM[\"Heathrow T5\", SPHEROID[\"AIRY30\",6377563.396,299.32496127],358.398,-213.7028,495.3183,-668.80613932004700,4.72664217602752,-719.67109718139600,-6.26386076385543],PRIMEM[\"Greenwich\",0],UNIT[\"Decimal Degree\",0.017453292519943295]],PROJECTION[\"Transverse Mercator\"],PARAMETER[\"latitude_of_origin\",51.470110655555558],PARAMETER[\"central_meridian\",-0.41832591666666669],PARAMETER[\"scale_factor\",0.999995],PARAMETER[\"false_easting\",7334.810],PARAMETER[\"false_northing\",5637.423],UNIT[\"Meter\",1.00000000000000]]', airportGrid2007);\n });\n\n it(\"should be able to interpret denmarkED50 WKT\", async () => {\n\n const denmarkED50: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"European 1950, Denmark, for System 34\",\n ellipsoid: {\n description: \"Hayford, 1924 (aka 1909); same as International 1924\",\n epsg: 7022,\n equatorialRadius: 6378388,\n id: \"HAYFORD\",\n polarRadius: 6356911.9461279465,\n source: \"Snyder, J.P., 1987, Map Projections - A Working Manual\",\n },\n ellipsoidId: \"HAYFORD\",\n id: \"ED50-DK34\",\n source: \"KMSTrans, by Kort-og Matrikelstyrelsen (Nov 1999)\",\n transforms: [\n {\n method: \"PositionalVector\",\n positionalVector: {\n delta: {\n x: -81.0703,\n y: -89.3603,\n z: -115.7526,\n },\n rotation: {\n x: 0.48488,\n y: 0.02436,\n z: 0.41321,\n },\n scalePPM: -0.540645,\n },\n sourceEllipsoid: {\n equatorialRadius: 6378388,\n id: \"HAYFORD\",\n polarRadius: 6356911.9461279465,\n },\n targetEllipsoid: {\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n },\n },\n ],\n },\n datumId: \"ED50-DK34\",\n description: \"DummyName\",\n extent: {\n northEast: {\n latitude: 90,\n longitude: 180,\n },\n southWest: {\n latitude: -90,\n longitude: -180,\n },\n },\n id: \"DummyName\",\n projection: {\n method: \"None\",\n },\n source: \"Extracted from WKT string; description field carries WKT name.\",\n unit: \"Degree\",\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n };\n\n await interpretWKTTest('GEOGCS[ \"DummyName\", DATUM [\"European 1950 (Denmark)\", SPHEROID [\"International 1924\", 6378388, 297],-81.0703, -89.3603, -115.7526, .48488, .02436, .41321, -.540645], PRIMEM [ \"Greenwich\", 0.000000 ], UNIT [\"Decimal Degree\", 0.01745329251994330]]', denmarkED50);\n });\n\n it(\"should be able to interpret californiaStateZone2 WKT\", async () => {\n\n const californiaStateZone2: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"North American Datum of 1983\",\n ellipsoid: {\n description: \"Geodetic Reference System of 1980\",\n epsg: 7019,\n equatorialRadius: 6378137,\n id: \"GRS1980\",\n polarRadius: 6356752.314140348,\n source: \"Stem, L.E., Jan 1989, State Plane Coordinate System of 1983\",\n },\n ellipsoidId: \"GRS1980\",\n epsg: 6269,\n id: \"NAD83\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n method: \"None\",\n },\n ],\n },\n datumId: \"NAD83\",\n description: \"NAD_1983_StatePlane_California_II_FIPS_0402_Feet\",\n id: \"NAD_1983_StatePlane_Cal\",\n projection: {\n falseEasting: 6561666.666666666,\n falseNorthing: 1640416.666666667,\n latitudeOfOrigin: 37.66666666666666,\n longitudeOfOrigin: -122,\n method: \"LambertConformalConicTwoParallels\",\n standardParallel1: 38.33333333333334,\n standardParallel2: 39.83333333333334,\n },\n source: \"WKT\",\n unit: \"USSurveyFoot\",\n },\n verticalCRS: {\n id: \"NAVD88\",\n },\n };\n\n await interpretWKTTest('PROJCS[\"NAD_1983_StatePlane_California_II_FIPS_0402_Feet\",GEOGCS[\"GCS_North_American_1983\",DATUM[\"D_North_American_1983\",SPHEROID[\"GRS_1980\",6378137,298.257222101]],PRIMEM[\"Greenwich\",0],UNIT[\"Degree\",0.017453292519943295]],PROJECTION[\"Lambert_Conformal_Conic\"],PARAMETER[\"False_Easting\",6561666.666666666],PARAMETER[\"False_Northing\",1640416.666666667],PARAMETER[\"Central_Meridian\",-122],PARAMETER[\"Standard_Parallel_1\",38.33333333333334],PARAMETER[\"Standard_Parallel_2\",39.83333333333334],PARAMETER[\"Latitude_Of_Origin\",37.66666666666666],UNIT[\"Foot_US\",0.30480060960121924]]', californiaStateZone2);\n });\n\n it(\"should be able to interpret utm84Zone34S WKT\", async () => {\n\n const utm84Zone34S: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"World Geodetic System of 1984\",\n ellipsoid: {\n description: \"World Geodetic System of 1984, GEM 10C\",\n epsg: 7030,\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"WGS84\",\n epsg: 6326,\n id: \"WGS84\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n method: \"None\",\n },\n ],\n },\n datumId: \"WGS84\",\n description: \"WGS 84 / UTM zone 34S\",\n id: \"WGS 84 / UTM zone 34S\",\n projection: {\n centralMeridian: 20.999999999999982,\n falseEasting: 500000,\n falseNorthing: 10000000,\n latitudeOfOrigin: 0,\n method: \"TransverseMercator\",\n scaleFactor: 0.9996,\n },\n source: \"WKT\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"ELLIPSOID\",\n },\n };\n\n await interpretWKTTest('PROJCS[\"WGS 84 / UTM zone 34S\", GEOGCS [ \"WGS 84\", DATUM [\"World Geodetic System 1984 (EPSG ID 6326)\", SPHEROID [\"WGS 84 (EPSG ID 7030)\", 6378137, 298.257223563]], PRIMEM [ \"Greenwich\", 0.000000 ], UNIT [\"Decimal Degree\", 0.01745329251994328]], PROJECTION [\"UTM zone 34S (EPSG OP 16134)\"], PARAMETER [\"Latitude_Of_Origin\", 0], PARAMETER [\"Central_Meridian\", 21], PARAMETER [\"Scale_Factor\", .9996], PARAMETER [\"False_Easting\", 500000], PARAMETER [\"False_Northing\", 10000000], UNIT [\"Meter\", 1]]', utm84Zone34S);\n });\n\n it(\"should be able to interpret utm84Zone32NGeoid WKT\", async () => {\n\n const utm84Zone32NGeoid: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"World Geodetic System of 1984\",\n ellipsoid: {\n description: \"World Geodetic System of 1984, GEM 10C\",\n epsg: 7030,\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"WGS84\",\n epsg: 6326,\n id: \"WGS84\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n method: \"None\",\n },\n ],\n },\n datumId: \"WGS84\",\n description: \"WGS 84 / UTM zone32N\",\n id: \"WGS 84 / UTM zone32N\",\n projection: {\n centralMeridian: 9,\n falseEasting: 500000,\n falseNorthing: 0,\n latitudeOfOrigin: 0,\n method: \"TransverseMercator\",\n scaleFactor: 0.9996,\n },\n source: \"WKT\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"GEOID\",\n },\n };\n\n await interpretWKTTest('COMPD_CS[\"WGS 84 / UTM zone 32N + EGM96 geoid height\",PROJCS[\"WGS 84 / UTM zone32N\",GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",\"7030\"]],AUTHORITY[\"EPSG\",\"6326\"]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",\"8901\"]],UNIT[\"degree\",0.0174532925199433,AUTHORITY[\"EPSG\",\"9122\"]],AUTHORITY[\"EPSG\",\"4326\"]],PROJECTION[\"Transverse_Mercator\"],PARAMETER[\"latitude_of_origin\",0],PARAMETER[\"central_meridian\",9],PARAMETER[\"scale_factor\",0.9996],PARAMETER[\"false_easting\",500000],PARAMETER[\"false_northing\",0],UNIT[\"metre\",1,AUTHORITY[\"EPSG\",\"9001\"]],AXIS[\"Easting\",EAST],AXIS[\"Northing\",NORTH],AUTHORITY[\"EPSG\",\"32632\"]],VERT_CS[\"EGM96 geoid height\",VERT_DATUM[\"EGM96 geoid\",2005,EXTENSION[\"PROJ4_GRIDS\",\"egm96_15.gtx\"],AUTHORITY[\"EPSG\",\"5171\"]],UNIT[\"metre\",1,AUTHORITY[\"EPSG\",\"9001\"]],AXIS[\"Up\",UP],AUTHORITY[\"EPSG\",\"5773\"]]]', utm84Zone32NGeoid);\n });\n it(\"should be able to interpret utm84Zone18NGeoid WKT\", async () => {\n\n const utm84Zone18NGeoid: GeographicCRSProps =\n {\n horizontalCRS: {\n datum: {\n description: \"World Geodetic System of 1984\",\n ellipsoid: {\n description: \"World Geodetic System of 1984, GEM 10C\",\n epsg: 7030,\n equatorialRadius: 6378137,\n id: \"WGS84\",\n polarRadius: 6356752.3142,\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n },\n ellipsoidId: \"WGS84\",\n epsg: 6326,\n id: \"WGS84\",\n source: \"US Defense Mapping Agency, TR-8350.2-B, December 1987\",\n transforms: [\n {\n method: \"None\",\n },\n ],\n },\n datumId: \"WGS84\",\n description: \"UTM84-18N\",\n id: \"UTM84-18N\",\n projection: {\n hemisphere: \"North\",\n method: \"UniversalTransverseMercator\",\n zoneNumber: 18,\n },\n source: \"WKT\",\n unit: \"Meter\",\n },\n verticalCRS: {\n id: \"GEOID\",\n },\n };\n\n await interpretWKTTest('COMPD_CS[\"UTM84-18N\",PROJCS[\"UTM84-18N\",GEOGCS[\"LL84\",DATUM[\"WGS84\",SPHEROID[\"WGS84\",6378137.000,298.25722293]],PRIMEM[\"Greenwich\",0],UNIT[\"Degree\",0.017453292519943295]],PROJECTION[\"Universal Transverse Mercator System\"],PARAMETER[\"UTM Zone Number (1 - 60)\",18.0],PARAMETER[\"Hemisphere, North or South\",1.0],UNIT[\"Meter\",1.00000000000000]],VERT_CS[\"Geoid Height\",VERT_DATUM[\"EGM96 geoid\",2005],UNIT[\"METER\",1.000000]]]', utm84Zone18NGeoid);\n });\n });\n\n describe(\"Verify list of CRS\", async () => {\n const validationRange = 50;\n const validationRangeSmall = 10;\n\n interface CRSValidationOptions {\n expectedCount: number;\n allowedRange: number;\n extent?: Range2dProps;\n includeWorld?: boolean;\n }\n\n const validateCRSList = async (options: CRSValidationOptions): Promise<void> => {\n const { expectedCount, allowedRange, extent, includeWorld } = options;\n const listOfCRS = await getAvailableCoordinateReferenceSystems({ extent, includeWorld });\n\n // Check fields of returned coordinate reference systems\n const extentRange: Range2d = Range2d.fromJSON(extent);\n for (const crs of listOfCRS) {\n // Validate extent\n if (extent !== undefined) {\n const crsExtentRange: Range2d = Range2d.fromJSON(crs.crsExtent);\n const intersects = extentRange.intersectsRange(crsExtentRange);\n assert.isTrue(intersects);\n }\n\n // These fields should always be present\n assert.isTrue(crs.name !== undefined);\n assert.isTrue(crs.description !== undefined);\n assert.isTrue(crs.deprecated === true || crs.deprecated === false);\n }\n\n assert.isTrue(listOfCRS.length > expectedCount - allowedRange && listOfCRS.length < expectedCount + allowedRange);\n };\n\n const validateExtent = (expectedExtent: Range2d, crsExtent: Range2dProps) => {\n const crsExtentRange: Range2d = Range2d.fromJSON(crsExtent);\n assert.equal(crsExtentRange.low.x, expectedExtent.low.x);\n assert.equal(crsExtentRange.low.y, expectedExtent.low.y);\n assert.equal(crsExtentRange.high.x, expectedExtent.high.x);\n assert.equal(crsExtentRange.high.y, expectedExtent.high.y);\n };\n\n it(\"should get all CRS\", async () => {\n await validateCRSList({expectedCount: 12_332, allowedRange: validationRange, includeWorld: true});\n });\n\n it(\"should get all CRS, excluding world crs\", async () => {\n await validateCRSList({expectedCount: 11_975, allowedRange: validationRange});\n })\n\n it(\"should return CRS that are in the specified range (1)\", async () => {\n const extent: Range2dProps = { low: { x: 60.1, y: 61.2 }, high: { x: 62.3, y: 63.4 } };\n await validateCRSList({expectedCount: 82, allowedRange: validationRangeSmall, extent});\n await validateCRSList({expectedCount: 439, allowedRange: validationRangeSmall, extent, includeWorld: true});\n });\n\n it(\"should return CRS that are in the specified range (2)\", async () => {\n const extent: Range2dProps = { low: { x: 0, y: 2 }, high: { x: 1, y: 3 } };\n await validateCRSList({expectedCount: 67, allowedRange: validationRangeSmall, extent});\n await validateCRSList({expectedCount: 424, allowedRange: validationRangeSmall, extent, includeWorld: true});\n });\n\n it(\"should return CRS that are in the specified range (3)\", async () => {\n const extent: Range2dProps = { low: { x: 0.3, y: 2.4 }, high: { x: 1.6, y: 3.77 } };\n await validateCRSList({expectedCount: 62, allowedRange: validationRangeSmall, extent});\n await validateCRSList({expectedCount: 419, allowedRange: validationRangeSmall, extent, includeWorld: true});\n });\n\n it(\"should retrieve the whole list of CRS and validate the properties for a few selected CRS.\", async () => {\n const listOfCRS = await getAvailableCoordinateReferenceSystems({includeWorld: true});\n let nbFound = 0;\n for (const crs of listOfCRS) {\n switch (crs.name) {\n case \"3TM111-83\":\n nbFound++;\n assert.equal(crs.description, \"Use NAD83-AB/3TM-111 instead.\");\n assert.equal(crs.deprecated, true);\n validateExtent(Range2d.fromJSON({ low: { x: -113, y: 48 }, high: { x: -109, y: 84 } }), crs.crsExtent);\n break;\n case \"NAD27-CAN.MTM-1\":\n nbFound++;\n assert.equal(crs.description, \"NAD27 / MTM zone 1\");\n assert.equal(crs.deprecated, false);\n validateExtent(Range2d.fromJSON({ low: { x: -54.5, y: 45 }, high: { x: -50.5, y: 55 } }), crs.crsExtent);\n break;\n case \"AL83-EF\":\n nbFound++;\n assert.equal(crs.description, \"NAD83 Alabama State Plane, East Zone, US Foot\");\n assert.equal(crs.deprecated, false);\n validateExtent(Range2d.fromJSON({ low: { x: -87.5, y: 30 }, high: { x: -84, y: 35.75 } }), crs.crsExtent);\n break;\n case \"ME-E\":\n nbFound++;\n assert.equal(crs.description, \"NAD27 Maine State Plane, East Zone(1801), US Foot\");\n assert.equal(crs.deprecated, false);\n validateExtent(Range2d.fromJSON({ low: { x: -71, y: 43.5 }, high: { x: -66, y: 48 } }), crs.crsExtent);\n break;\n\n // world CRS\n case \"EPSG:4326\":\n nbFound++;\n assert.equal(crs.description, \"WGS 84\");\n assert.equal(crs.deprecated, false);\n validateExtent(Range2d.fromJSON({ low: { x: -180, y: -90 }, high: { x: 180, y: 90 } }), crs.crsExtent);\n break;\n }\n }\n assert.equal(nbFound, 5);\n });\n });\n\n it(\"should not be able to interpret an invalid GeographicCRS\", async () => {\n\n const interpretInvalidTest = async (formatCRS: \"WKT\" | \"JSON\", testInvalid: string) => {\n\n const requestProps: GeographicCRSInterpretRequestProps = { format: formatCRS, geographicCRSDef: testInvalid };\n const response = IModelNative.platform.GeoServices.getGeographicCRSInterpretation(requestProps);\n\n // At the moment return codes are not really error specific (we mostly return 32768) so we do not validate\n // actual error code for now.\n assert.isFalse(response.status === 0);\n };\n\n // WKT Without datum or projection clause\n await interpretInvalidTest(\"WKT\", 'PROJCS[\"AirportGrid2007\", GEOGCS[\"HeathrowT5.LL\",PRIMEM[\"Greenwich\",0],UNIT[\"Decimal Degree\",0.017453292519943295]],UNIT[\"Meter\",1.00000000000000]]');\n\n // Plain garbage\n await interpretInvalidTest(\"WKT\", \"Some invalid content\");\n\n // Format is JSON but content is WKT\n await interpretInvalidTest(\"JSON\", 'GEOGCS[ \"Longitude / Latitude (ED 50 Denmark)\", DATUM [\"European 1950 (Denmark)\", SPHEROID [\"International 1924\", 6378388, 297],-81.0703, -89.3603, -115.7526, .48488, .02436, .41321, -.540645], PRIMEM [ \"Greenwich\", 0.000000 ], UNIT [\"Decimal Degree\", 0.01745329251994330]]');\n\n // Vertical datum invalid for horizontal definition\n await interpretInvalidTest(\"JSON\", '{ horizontalCRS: { id: \"EPSG:27700\" }, verticalCRS: { id: \"NAVD29\" } }');\n\n // No horizontal CRS\n await interpretInvalidTest(\"JSON\", '{ verticalCRS: { id: \"NAVD29\" } }');\n\n // Unknown identifier\n await interpretInvalidTest(\"JSON\", '{ horizontalCRS: { id: \"UNKNOWN\" }, verticalCRS: { id: \"NAVD29\" } }');\n });\n});\n"]}