@terra-graph/core 1.0.0-rc.4

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 (596) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +70 -0
  3. package/dist/cjs/Graph/Adapter.d.ts +8 -0
  4. package/dist/cjs/Graph/Adapter.js +5 -0
  5. package/dist/cjs/Graph/Adapters/DotAdapter.d.ts +17 -0
  6. package/dist/cjs/Graph/Adapters/DotAdapter.js +31 -0
  7. package/dist/cjs/Graph/Adapters/DotAdapter.test.d.ts +1 -0
  8. package/dist/cjs/Graph/Adapters/DotAdapter.test.js +45 -0
  9. package/dist/cjs/Graph/Adapters/GraphologyAdapter.d.ts +36 -0
  10. package/dist/cjs/Graph/Adapters/GraphologyAdapter.js +273 -0
  11. package/dist/cjs/Graph/Adapters/GraphologyAdapter.test.d.ts +1 -0
  12. package/dist/cjs/Graph/Adapters/GraphologyAdapter.test.js +561 -0
  13. package/dist/cjs/Graph/Adapters/index.d.ts +2 -0
  14. package/dist/cjs/Graph/Adapters/index.js +18 -0
  15. package/dist/cjs/Graph/GraphPlugin.d.ts +53 -0
  16. package/dist/cjs/Graph/GraphPlugin.js +223 -0
  17. package/dist/cjs/Graph/GraphPlugin.test.d.ts +1 -0
  18. package/dist/cjs/Graph/GraphPlugin.test.js +831 -0
  19. package/dist/cjs/Graph/GraphResolver.d.ts +21 -0
  20. package/dist/cjs/Graph/GraphResolver.js +80 -0
  21. package/dist/cjs/Graph/GraphResolver.test.d.ts +1 -0
  22. package/dist/cjs/Graph/GraphResolver.test.js +273 -0
  23. package/dist/cjs/Graph/Importer.d.ts +7 -0
  24. package/dist/cjs/Graph/Importer.js +2 -0
  25. package/dist/cjs/Graph/Importers/TerraformDotImporter.d.ts +12 -0
  26. package/dist/cjs/Graph/Importers/TerraformDotImporter.js +245 -0
  27. package/dist/cjs/Graph/Importers/TerraformDotImporter.test.d.ts +1 -0
  28. package/dist/cjs/Graph/Importers/TerraformDotImporter.test.js +343 -0
  29. package/dist/cjs/Graph/Importers/index.d.ts +1 -0
  30. package/dist/cjs/Graph/Importers/index.js +17 -0
  31. package/dist/cjs/Graph/Operations/Matchers/NodeMatchFn.d.ts +3 -0
  32. package/dist/cjs/Graph/Operations/Matchers/NodeMatchFn.js +2 -0
  33. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/NodeQuery.d.ts +21 -0
  34. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/NodeQuery.js +143 -0
  35. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/NodeQuery.test.d.ts +1 -0
  36. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/NodeQuery.test.js +308 -0
  37. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/QuerySchema.d.ts +155 -0
  38. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/QuerySchema.js +67 -0
  39. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/QuerySchema.test.d.ts +1 -0
  40. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/QuerySchema.test.js +51 -0
  41. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/index.d.ts +2 -0
  42. package/dist/cjs/Graph/Operations/Matchers/NodeQuery/index.js +18 -0
  43. package/dist/cjs/Graph/Operations/Matchers/index.d.ts +2 -0
  44. package/dist/cjs/Graph/Operations/Matchers/index.js +18 -0
  45. package/dist/cjs/Graph/Operations/Operations.d.ts +21 -0
  46. package/dist/cjs/Graph/Operations/Operations.js +2 -0
  47. package/dist/cjs/Graph/Operations/index.d.ts +2 -0
  48. package/dist/cjs/Graph/Operations/index.js +18 -0
  49. package/dist/cjs/Graph/Profile.d.ts +55 -0
  50. package/dist/cjs/Graph/Profile.js +223 -0
  51. package/dist/cjs/Graph/Profile.test.d.ts +1 -0
  52. package/dist/cjs/Graph/Profile.test.js +841 -0
  53. package/dist/cjs/Graph/ProfileRegistry.d.ts +18 -0
  54. package/dist/cjs/Graph/ProfileRegistry.js +61 -0
  55. package/dist/cjs/Graph/ProfileRegistry.test.d.ts +1 -0
  56. package/dist/cjs/Graph/ProfileRegistry.test.js +98 -0
  57. package/dist/cjs/Graph/Renderer.d.ts +9 -0
  58. package/dist/cjs/Graph/Renderer.js +2 -0
  59. package/dist/cjs/Graph/Renderers/DotRenderer.d.ts +27 -0
  60. package/dist/cjs/Graph/Renderers/DotRenderer.js +186 -0
  61. package/dist/cjs/Graph/Renderers/DotRenderer.test.d.ts +1 -0
  62. package/dist/cjs/Graph/Renderers/DotRenderer.test.js +1143 -0
  63. package/dist/cjs/Graph/Renderers/JsonRenderer.d.ts +5 -0
  64. package/dist/cjs/Graph/Renderers/JsonRenderer.js +13 -0
  65. package/dist/cjs/Graph/Renderers/JsonRenderer.test.d.ts +1 -0
  66. package/dist/cjs/Graph/Renderers/JsonRenderer.test.js +29 -0
  67. package/dist/cjs/Graph/Renderers/RendererRegistry.d.ts +15 -0
  68. package/dist/cjs/Graph/Renderers/RendererRegistry.js +33 -0
  69. package/dist/cjs/Graph/Renderers/RendererRegistry.test.d.ts +1 -0
  70. package/dist/cjs/Graph/Renderers/RendererRegistry.test.js +39 -0
  71. package/dist/cjs/Graph/Renderers/TgNodeLabel.d.ts +11 -0
  72. package/dist/cjs/Graph/Renderers/TgNodeLabel.js +43 -0
  73. package/dist/cjs/Graph/Renderers/TgNodeLabel.test.d.ts +1 -0
  74. package/dist/cjs/Graph/Renderers/TgNodeLabel.test.js +76 -0
  75. package/dist/cjs/Graph/Renderers/index.d.ts +4 -0
  76. package/dist/cjs/Graph/Renderers/index.js +20 -0
  77. package/dist/cjs/Graph/RuleError.d.ts +12 -0
  78. package/dist/cjs/Graph/RuleError.js +19 -0
  79. package/dist/cjs/Graph/RuleError.test.d.ts +1 -0
  80. package/dist/cjs/Graph/RuleError.test.js +25 -0
  81. package/dist/cjs/Graph/Rules/Edge/AlignNodes.d.ts +7 -0
  82. package/dist/cjs/Graph/Rules/Edge/AlignNodes.js +39 -0
  83. package/dist/cjs/Graph/Rules/Edge/AlignNodes.test.d.ts +1 -0
  84. package/dist/cjs/Graph/Rules/Edge/AlignNodes.test.js +194 -0
  85. package/dist/cjs/Graph/Rules/Edge/EdgeDirectionSemantic.d.ts +8 -0
  86. package/dist/cjs/Graph/Rules/Edge/EdgeDirectionSemantic.js +78 -0
  87. package/dist/cjs/Graph/Rules/Edge/EdgeDirectionSemantic.test.d.ts +1 -0
  88. package/dist/cjs/Graph/Rules/Edge/EdgeDirectionSemantic.test.js +454 -0
  89. package/dist/cjs/Graph/Rules/Edge/EdgeDotProperties.d.ts +9 -0
  90. package/dist/cjs/Graph/Rules/Edge/EdgeDotProperties.js +50 -0
  91. package/dist/cjs/Graph/Rules/Edge/EdgeDotProperties.test.d.ts +1 -0
  92. package/dist/cjs/Graph/Rules/Edge/EdgeDotProperties.test.js +333 -0
  93. package/dist/cjs/Graph/Rules/Edge/EdgeLegend.d.ts +8 -0
  94. package/dist/cjs/Graph/Rules/Edge/EdgeLegend.js +47 -0
  95. package/dist/cjs/Graph/Rules/Edge/EdgeLegend.test.d.ts +1 -0
  96. package/dist/cjs/Graph/Rules/Edge/EdgeLegend.test.js +186 -0
  97. package/dist/cjs/Graph/Rules/Edge/EdgeReverse.d.ts +6 -0
  98. package/dist/cjs/Graph/Rules/Edge/EdgeReverse.js +30 -0
  99. package/dist/cjs/Graph/Rules/Edge/EdgeReverse.test.d.ts +1 -0
  100. package/dist/cjs/Graph/Rules/Edge/EdgeReverse.test.js +134 -0
  101. package/dist/cjs/Graph/Rules/Edge/EdgeSemanticLegend.d.ts +8 -0
  102. package/dist/cjs/Graph/Rules/Edge/EdgeSemanticLegend.js +72 -0
  103. package/dist/cjs/Graph/Rules/Edge/EdgeSemanticLegend.test.d.ts +1 -0
  104. package/dist/cjs/Graph/Rules/Edge/EdgeSemanticLegend.test.js +511 -0
  105. package/dist/cjs/Graph/Rules/Edge/ExplicitEdge.d.ts +6 -0
  106. package/dist/cjs/Graph/Rules/Edge/ExplicitEdge.js +28 -0
  107. package/dist/cjs/Graph/Rules/Edge/ExplicitEdge.test.d.ts +1 -0
  108. package/dist/cjs/Graph/Rules/Edge/ExplicitEdge.test.js +125 -0
  109. package/dist/cjs/Graph/Rules/Edge/RemoveEdge.d.ts +6 -0
  110. package/dist/cjs/Graph/Rules/Edge/RemoveEdge.js +28 -0
  111. package/dist/cjs/Graph/Rules/Edge/RemoveEdge.test.d.ts +1 -0
  112. package/dist/cjs/Graph/Rules/Edge/RemoveEdge.test.js +135 -0
  113. package/dist/cjs/Graph/Rules/Edge/index.d.ts +8 -0
  114. package/dist/cjs/Graph/Rules/Edge/index.js +24 -0
  115. package/dist/cjs/Graph/Rules/NamedRuleRegistry.d.ts +20 -0
  116. package/dist/cjs/Graph/Rules/NamedRuleRegistry.js +71 -0
  117. package/dist/cjs/Graph/Rules/NamedRuleRegistry.test.d.ts +1 -0
  118. package/dist/cjs/Graph/Rules/NamedRuleRegistry.test.js +243 -0
  119. package/dist/cjs/Graph/Rules/NamedRuleSetRegistry.d.ts +19 -0
  120. package/dist/cjs/Graph/Rules/NamedRuleSetRegistry.js +62 -0
  121. package/dist/cjs/Graph/Rules/NamedRuleSetRegistry.test.d.ts +1 -0
  122. package/dist/cjs/Graph/Rules/NamedRuleSetRegistry.test.js +80 -0
  123. package/dist/cjs/Graph/Rules/Node/ConvertNodeToEdge.d.ts +6 -0
  124. package/dist/cjs/Graph/Rules/Node/ConvertNodeToEdge.js +32 -0
  125. package/dist/cjs/Graph/Rules/Node/ConvertNodeToEdge.test.d.ts +1 -0
  126. package/dist/cjs/Graph/Rules/Node/ConvertNodeToEdge.test.js +152 -0
  127. package/dist/cjs/Graph/Rules/Node/NodeDotProperties.d.ts +9 -0
  128. package/dist/cjs/Graph/Rules/Node/NodeDotProperties.js +43 -0
  129. package/dist/cjs/Graph/Rules/Node/NodeDotProperties.test.d.ts +1 -0
  130. package/dist/cjs/Graph/Rules/Node/NodeDotProperties.test.js +226 -0
  131. package/dist/cjs/Graph/Rules/Node/NodeProperties.d.ts +12 -0
  132. package/dist/cjs/Graph/Rules/Node/NodeProperties.js +81 -0
  133. package/dist/cjs/Graph/Rules/Node/NodeProperties.test.d.ts +1 -0
  134. package/dist/cjs/Graph/Rules/Node/NodeProperties.test.js +371 -0
  135. package/dist/cjs/Graph/Rules/Node/RemoveLeafChain.d.ts +12 -0
  136. package/dist/cjs/Graph/Rules/Node/RemoveLeafChain.js +82 -0
  137. package/dist/cjs/Graph/Rules/Node/RemoveLeafChain.test.d.ts +1 -0
  138. package/dist/cjs/Graph/Rules/Node/RemoveLeafChain.test.js +399 -0
  139. package/dist/cjs/Graph/Rules/Node/RemoveNode.d.ts +6 -0
  140. package/dist/cjs/Graph/Rules/Node/RemoveNode.js +14 -0
  141. package/dist/cjs/Graph/Rules/Node/RemoveNode.test.d.ts +1 -0
  142. package/dist/cjs/Graph/Rules/Node/RemoveNode.test.js +33 -0
  143. package/dist/cjs/Graph/Rules/Node/RemoveNodeAndReconnectEdges.d.ts +6 -0
  144. package/dist/cjs/Graph/Rules/Node/RemoveNodeAndReconnectEdges.js +38 -0
  145. package/dist/cjs/Graph/Rules/Node/RemoveNodeAndReconnectEdges.test.d.ts +1 -0
  146. package/dist/cjs/Graph/Rules/Node/RemoveNodeAndReconnectEdges.test.js +113 -0
  147. package/dist/cjs/Graph/Rules/Node/index.d.ts +6 -0
  148. package/dist/cjs/Graph/Rules/Node/index.js +22 -0
  149. package/dist/cjs/Graph/Rules/Rule.d.ts +40 -0
  150. package/dist/cjs/Graph/Rules/Rule.js +91 -0
  151. package/dist/cjs/Graph/Rules/Rule.test.d.ts +1 -0
  152. package/dist/cjs/Graph/Rules/Rule.test.js +127 -0
  153. package/dist/cjs/Graph/Rules/RuleConfig.d.ts +20 -0
  154. package/dist/cjs/Graph/Rules/RuleConfig.js +2 -0
  155. package/dist/cjs/Graph/Rules/RulePlan.d.ts +27 -0
  156. package/dist/cjs/Graph/Rules/RulePlan.js +28 -0
  157. package/dist/cjs/Graph/Rules/RuleSet.d.ts +25 -0
  158. package/dist/cjs/Graph/Rules/RuleSet.js +89 -0
  159. package/dist/cjs/Graph/Rules/RuleSet.test.d.ts +1 -0
  160. package/dist/cjs/Graph/Rules/RuleSet.test.js +222 -0
  161. package/dist/cjs/Graph/Rules/index.d.ts +8 -0
  162. package/dist/cjs/Graph/Rules/index.js +24 -0
  163. package/dist/cjs/Graph/Rules/registerAll.d.ts +14 -0
  164. package/dist/cjs/Graph/Rules/registerAll.js +16 -0
  165. package/dist/cjs/Graph/Serialization/Registry.d.ts +5 -0
  166. package/dist/cjs/Graph/Serialization/Registry.js +2 -0
  167. package/dist/cjs/Graph/Serialization/index.d.ts +1 -0
  168. package/dist/cjs/Graph/Serialization/index.js +17 -0
  169. package/dist/cjs/Graph/TgGraph.d.ts +82 -0
  170. package/dist/cjs/Graph/TgGraph.js +55 -0
  171. package/dist/cjs/Graph/TgGraph.test.d.ts +1 -0
  172. package/dist/cjs/Graph/TgGraph.test.js +61 -0
  173. package/dist/cjs/Graph/index.d.ts +15 -0
  174. package/dist/cjs/Graph/index.js +31 -0
  175. package/dist/cjs/Output/ArtifactTransformer/DotCliArtifactTransformer.d.ts +25 -0
  176. package/dist/cjs/Output/ArtifactTransformer/DotCliArtifactTransformer.js +86 -0
  177. package/dist/cjs/Output/ArtifactTransformer/DotCliArtifactTransformer.test.d.ts +1 -0
  178. package/dist/cjs/Output/ArtifactTransformer/DotCliArtifactTransformer.test.js +200 -0
  179. package/dist/cjs/Output/ArtifactTransformer/index.d.ts +1 -0
  180. package/dist/cjs/Output/ArtifactTransformer/index.js +17 -0
  181. package/dist/cjs/Output/ArtifactTransformer.d.ts +7 -0
  182. package/dist/cjs/Output/ArtifactTransformer.js +2 -0
  183. package/dist/cjs/Output/ArtifactTransformerFactory/DefaultArtifactTransformerFactory.d.ts +17 -0
  184. package/dist/cjs/Output/ArtifactTransformerFactory/DefaultArtifactTransformerFactory.js +78 -0
  185. package/dist/cjs/Output/ArtifactTransformerFactory/DefaultArtifactTransformerFactory.test.d.ts +1 -0
  186. package/dist/cjs/Output/ArtifactTransformerFactory/DefaultArtifactTransformerFactory.test.js +80 -0
  187. package/dist/cjs/Output/ArtifactTransformerFactory/OclifTransformerFlagParser.d.ts +9 -0
  188. package/dist/cjs/Output/ArtifactTransformerFactory/OclifTransformerFlagParser.js +80 -0
  189. package/dist/cjs/Output/ArtifactTransformerFactory/OclifTransformerFlagParser.test.d.ts +1 -0
  190. package/dist/cjs/Output/ArtifactTransformerFactory/OclifTransformerFlagParser.test.js +156 -0
  191. package/dist/cjs/Output/ArtifactTransformerFactory/index.d.ts +2 -0
  192. package/dist/cjs/Output/ArtifactTransformerFactory/index.js +18 -0
  193. package/dist/cjs/Output/ArtifactTransformerFactory.d.ts +10 -0
  194. package/dist/cjs/Output/ArtifactTransformerFactory.js +2 -0
  195. package/dist/cjs/Output/ArtifactWriter/FileArtifactWriter.d.ts +9 -0
  196. package/dist/cjs/Output/ArtifactWriter/FileArtifactWriter.js +25 -0
  197. package/dist/cjs/Output/ArtifactWriter/FileArtifactWriter.test.d.ts +1 -0
  198. package/dist/cjs/Output/ArtifactWriter/FileArtifactWriter.test.js +77 -0
  199. package/dist/cjs/Output/ArtifactWriter/StdoutArtifactWriter.d.ts +6 -0
  200. package/dist/cjs/Output/ArtifactWriter/StdoutArtifactWriter.js +17 -0
  201. package/dist/cjs/Output/ArtifactWriter/StdoutArtifactWriter.test.d.ts +1 -0
  202. package/dist/cjs/Output/ArtifactWriter/StdoutArtifactWriter.test.js +83 -0
  203. package/dist/cjs/Output/ArtifactWriter/index.d.ts +2 -0
  204. package/dist/cjs/Output/ArtifactWriter/index.js +18 -0
  205. package/dist/cjs/Output/ArtifactWriter.d.ts +8 -0
  206. package/dist/cjs/Output/ArtifactWriter.js +2 -0
  207. package/dist/cjs/Output/RenderPipeline.d.ts +12 -0
  208. package/dist/cjs/Output/RenderPipeline.js +17 -0
  209. package/dist/cjs/Output/RenderPipeline.test.d.ts +1 -0
  210. package/dist/cjs/Output/RenderPipeline.test.js +80 -0
  211. package/dist/cjs/Output/index.d.ts +7 -0
  212. package/dist/cjs/Output/index.js +23 -0
  213. package/dist/cjs/Runtime/RuntimeCatalog.d.ts +25 -0
  214. package/dist/cjs/Runtime/RuntimeCatalog.js +51 -0
  215. package/dist/cjs/Runtime/RuntimeCatalog.test.d.ts +1 -0
  216. package/dist/cjs/Runtime/RuntimeCatalog.test.js +165 -0
  217. package/dist/cjs/Runtime/RuntimeCatalogBuilder/RuntimeCatalogFromConfigBuilder.d.ts +5 -0
  218. package/dist/cjs/Runtime/RuntimeCatalogBuilder/RuntimeCatalogFromConfigBuilder.js +10 -0
  219. package/dist/cjs/Runtime/RuntimeCatalogBuilder/RuntimeCatalogFromConfigBuilder.test.d.ts +1 -0
  220. package/dist/cjs/Runtime/RuntimeCatalogBuilder/RuntimeCatalogFromConfigBuilder.test.js +31 -0
  221. package/dist/cjs/Runtime/RuntimeCatalogBuilder/index.d.ts +1 -0
  222. package/dist/cjs/Runtime/RuntimeCatalogBuilder/index.js +17 -0
  223. package/dist/cjs/Runtime/RuntimeCatalogBuilder.d.ts +11 -0
  224. package/dist/cjs/Runtime/RuntimeCatalogBuilder.js +2 -0
  225. package/dist/cjs/Runtime/RuntimeCatalogBuilder.test.d.ts +1 -0
  226. package/dist/cjs/Runtime/RuntimeCatalogBuilder.test.js +27 -0
  227. package/dist/cjs/Runtime/RuntimeCatalogLoader.d.ts +37 -0
  228. package/dist/cjs/Runtime/RuntimeCatalogLoader.js +106 -0
  229. package/dist/cjs/Runtime/RuntimeCatalogLoader.test.d.ts +1 -0
  230. package/dist/cjs/Runtime/RuntimeCatalogLoader.test.js +454 -0
  231. package/dist/cjs/Runtime/RuntimeConfigLoader.d.ts +33 -0
  232. package/dist/cjs/Runtime/RuntimeConfigLoader.js +93 -0
  233. package/dist/cjs/Runtime/RuntimeConfigLoader.test.d.ts +1 -0
  234. package/dist/cjs/Runtime/RuntimeConfigLoader.test.js +345 -0
  235. package/dist/cjs/Runtime/RuntimeConfigParser/JsonRuntimeConfigParser.d.ts +5 -0
  236. package/dist/cjs/Runtime/RuntimeConfigParser/JsonRuntimeConfigParser.js +16 -0
  237. package/dist/cjs/Runtime/RuntimeConfigParser/JsonRuntimeConfigParser.test.d.ts +1 -0
  238. package/dist/cjs/Runtime/RuntimeConfigParser/JsonRuntimeConfigParser.test.js +22 -0
  239. package/dist/cjs/Runtime/RuntimeConfigParser/YamlRuntimeConfigParser.d.ts +5 -0
  240. package/dist/cjs/Runtime/RuntimeConfigParser/YamlRuntimeConfigParser.js +20 -0
  241. package/dist/cjs/Runtime/RuntimeConfigParser/YamlRuntimeConfigParser.test.d.ts +1 -0
  242. package/dist/cjs/Runtime/RuntimeConfigParser/YamlRuntimeConfigParser.test.js +31 -0
  243. package/dist/cjs/Runtime/RuntimeConfigParser/index.d.ts +2 -0
  244. package/dist/cjs/Runtime/RuntimeConfigParser/index.js +18 -0
  245. package/dist/cjs/Runtime/RuntimeConfigParser.d.ts +5 -0
  246. package/dist/cjs/Runtime/RuntimeConfigParser.js +6 -0
  247. package/dist/cjs/Runtime/RuntimeConfigParser.test.d.ts +1 -0
  248. package/dist/cjs/Runtime/RuntimeConfigParser.test.js +8 -0
  249. package/dist/cjs/Runtime/RuntimeConfigParserRegistry.d.ts +9 -0
  250. package/dist/cjs/Runtime/RuntimeConfigParserRegistry.js +36 -0
  251. package/dist/cjs/Runtime/RuntimeConfigParserRegistry.test.d.ts +1 -0
  252. package/dist/cjs/Runtime/RuntimeConfigParserRegistry.test.js +53 -0
  253. package/dist/cjs/Runtime/RuntimeConfigSource/FileRuntimeConfigSource.d.ts +7 -0
  254. package/dist/cjs/Runtime/RuntimeConfigSource/FileRuntimeConfigSource.js +21 -0
  255. package/dist/cjs/Runtime/RuntimeConfigSource/FileRuntimeConfigSource.test.d.ts +1 -0
  256. package/dist/cjs/Runtime/RuntimeConfigSource/FileRuntimeConfigSource.test.js +40 -0
  257. package/dist/cjs/Runtime/RuntimeConfigSource/InMemoryRuntimeConfigSource.d.ts +8 -0
  258. package/dist/cjs/Runtime/RuntimeConfigSource/InMemoryRuntimeConfigSource.js +21 -0
  259. package/dist/cjs/Runtime/RuntimeConfigSource/InMemoryRuntimeConfigSource.test.d.ts +1 -0
  260. package/dist/cjs/Runtime/RuntimeConfigSource/InMemoryRuntimeConfigSource.test.js +21 -0
  261. package/dist/cjs/Runtime/RuntimeConfigSource/YamlRuntimeConfigSource.d.ts +6 -0
  262. package/dist/cjs/Runtime/RuntimeConfigSource/YamlRuntimeConfigSource.js +17 -0
  263. package/dist/cjs/Runtime/RuntimeConfigSource/YamlRuntimeConfigSource.test.d.ts +1 -0
  264. package/dist/cjs/Runtime/RuntimeConfigSource/YamlRuntimeConfigSource.test.js +37 -0
  265. package/dist/cjs/Runtime/RuntimeConfigSource/index.d.ts +3 -0
  266. package/dist/cjs/Runtime/RuntimeConfigSource/index.js +19 -0
  267. package/dist/cjs/Runtime/RuntimeConfigSource.d.ts +10 -0
  268. package/dist/cjs/Runtime/RuntimeConfigSource.js +20 -0
  269. package/dist/cjs/Runtime/RuntimeConfigSource.test.d.ts +1 -0
  270. package/dist/cjs/Runtime/RuntimeConfigSource.test.js +23 -0
  271. package/dist/cjs/Runtime/RuntimeConfigValidator/ZodRuntimeConfigValidator.d.ts +5 -0
  272. package/dist/cjs/Runtime/RuntimeConfigValidator/ZodRuntimeConfigValidator.js +77 -0
  273. package/dist/cjs/Runtime/RuntimeConfigValidator/ZodRuntimeConfigValidator.test.d.ts +1 -0
  274. package/dist/cjs/Runtime/RuntimeConfigValidator/ZodRuntimeConfigValidator.test.js +62 -0
  275. package/dist/cjs/Runtime/RuntimeConfigValidator/index.d.ts +1 -0
  276. package/dist/cjs/Runtime/RuntimeConfigValidator/index.js +17 -0
  277. package/dist/cjs/Runtime/RuntimeConfigValidator.d.ts +4 -0
  278. package/dist/cjs/Runtime/RuntimeConfigValidator.js +2 -0
  279. package/dist/cjs/Runtime/RuntimeConfigValidator.test.d.ts +1 -0
  280. package/dist/cjs/Runtime/RuntimeConfigValidator.test.js +40 -0
  281. package/dist/cjs/Runtime/RuntimeProvider.d.ts +5 -0
  282. package/dist/cjs/Runtime/RuntimeProvider.js +2 -0
  283. package/dist/cjs/Runtime/RuntimeProvider.test.d.ts +1 -0
  284. package/dist/cjs/Runtime/RuntimeProvider.test.js +12 -0
  285. package/dist/cjs/Runtime/RuntimeProviderLoader/ModuleRuntimeProviderLoader.d.ts +14 -0
  286. package/dist/cjs/Runtime/RuntimeProviderLoader/ModuleRuntimeProviderLoader.js +87 -0
  287. package/dist/cjs/Runtime/RuntimeProviderLoader/ModuleRuntimeProviderLoader.test.d.ts +1 -0
  288. package/dist/cjs/Runtime/RuntimeProviderLoader/ModuleRuntimeProviderLoader.test.js +148 -0
  289. package/dist/cjs/Runtime/RuntimeProviderLoader/index.d.ts +1 -0
  290. package/dist/cjs/Runtime/RuntimeProviderLoader/index.js +17 -0
  291. package/dist/cjs/Runtime/RuntimeProviderLoader.d.ts +8 -0
  292. package/dist/cjs/Runtime/RuntimeProviderLoader.js +2 -0
  293. package/dist/cjs/Runtime/RuntimeProviderLoader.test.d.ts +1 -0
  294. package/dist/cjs/Runtime/RuntimeProviderLoader.test.js +25 -0
  295. package/dist/cjs/Runtime/index.d.ts +15 -0
  296. package/dist/cjs/Runtime/index.js +31 -0
  297. package/dist/cjs/index.d.ts +3 -0
  298. package/dist/cjs/index.js +19 -0
  299. package/dist/cjs/package.json +1 -0
  300. package/dist/esm/Graph/Adapter.d.ts +8 -0
  301. package/dist/esm/Graph/Adapter.js +4 -0
  302. package/dist/esm/Graph/Adapters/DotAdapter.d.ts +17 -0
  303. package/dist/esm/Graph/Adapters/DotAdapter.js +27 -0
  304. package/dist/esm/Graph/Adapters/DotAdapter.test.d.ts +1 -0
  305. package/dist/esm/Graph/Adapters/DotAdapter.test.js +43 -0
  306. package/dist/esm/Graph/Adapters/GraphologyAdapter.d.ts +36 -0
  307. package/dist/esm/Graph/Adapters/GraphologyAdapter.js +269 -0
  308. package/dist/esm/Graph/Adapters/GraphologyAdapter.test.d.ts +1 -0
  309. package/dist/esm/Graph/Adapters/GraphologyAdapter.test.js +559 -0
  310. package/dist/esm/Graph/Adapters/index.d.ts +2 -0
  311. package/dist/esm/Graph/Adapters/index.js +2 -0
  312. package/dist/esm/Graph/GraphPlugin.d.ts +53 -0
  313. package/dist/esm/Graph/GraphPlugin.js +217 -0
  314. package/dist/esm/Graph/GraphPlugin.test.d.ts +1 -0
  315. package/dist/esm/Graph/GraphPlugin.test.js +829 -0
  316. package/dist/esm/Graph/GraphResolver.d.ts +21 -0
  317. package/dist/esm/Graph/GraphResolver.js +76 -0
  318. package/dist/esm/Graph/GraphResolver.test.d.ts +1 -0
  319. package/dist/esm/Graph/GraphResolver.test.js +271 -0
  320. package/dist/esm/Graph/Importer.d.ts +7 -0
  321. package/dist/esm/Graph/Importer.js +1 -0
  322. package/dist/esm/Graph/Importers/TerraformDotImporter.d.ts +12 -0
  323. package/dist/esm/Graph/Importers/TerraformDotImporter.js +238 -0
  324. package/dist/esm/Graph/Importers/TerraformDotImporter.test.d.ts +1 -0
  325. package/dist/esm/Graph/Importers/TerraformDotImporter.test.js +338 -0
  326. package/dist/esm/Graph/Importers/index.d.ts +1 -0
  327. package/dist/esm/Graph/Importers/index.js +1 -0
  328. package/dist/esm/Graph/Operations/Matchers/NodeMatchFn.d.ts +3 -0
  329. package/dist/esm/Graph/Operations/Matchers/NodeMatchFn.js +1 -0
  330. package/dist/esm/Graph/Operations/Matchers/NodeQuery/NodeQuery.d.ts +21 -0
  331. package/dist/esm/Graph/Operations/Matchers/NodeQuery/NodeQuery.js +139 -0
  332. package/dist/esm/Graph/Operations/Matchers/NodeQuery/NodeQuery.test.d.ts +1 -0
  333. package/dist/esm/Graph/Operations/Matchers/NodeQuery/NodeQuery.test.js +306 -0
  334. package/dist/esm/Graph/Operations/Matchers/NodeQuery/QuerySchema.d.ts +155 -0
  335. package/dist/esm/Graph/Operations/Matchers/NodeQuery/QuerySchema.js +64 -0
  336. package/dist/esm/Graph/Operations/Matchers/NodeQuery/QuerySchema.test.d.ts +1 -0
  337. package/dist/esm/Graph/Operations/Matchers/NodeQuery/QuerySchema.test.js +49 -0
  338. package/dist/esm/Graph/Operations/Matchers/NodeQuery/index.d.ts +2 -0
  339. package/dist/esm/Graph/Operations/Matchers/NodeQuery/index.js +2 -0
  340. package/dist/esm/Graph/Operations/Matchers/index.d.ts +2 -0
  341. package/dist/esm/Graph/Operations/Matchers/index.js +2 -0
  342. package/dist/esm/Graph/Operations/Operations.d.ts +21 -0
  343. package/dist/esm/Graph/Operations/Operations.js +1 -0
  344. package/dist/esm/Graph/Operations/index.d.ts +2 -0
  345. package/dist/esm/Graph/Operations/index.js +2 -0
  346. package/dist/esm/Graph/Profile.d.ts +55 -0
  347. package/dist/esm/Graph/Profile.js +219 -0
  348. package/dist/esm/Graph/Profile.test.d.ts +1 -0
  349. package/dist/esm/Graph/Profile.test.js +839 -0
  350. package/dist/esm/Graph/ProfileRegistry.d.ts +18 -0
  351. package/dist/esm/Graph/ProfileRegistry.js +57 -0
  352. package/dist/esm/Graph/ProfileRegistry.test.d.ts +1 -0
  353. package/dist/esm/Graph/ProfileRegistry.test.js +96 -0
  354. package/dist/esm/Graph/Renderer.d.ts +9 -0
  355. package/dist/esm/Graph/Renderer.js +1 -0
  356. package/dist/esm/Graph/Renderers/DotRenderer.d.ts +27 -0
  357. package/dist/esm/Graph/Renderers/DotRenderer.js +179 -0
  358. package/dist/esm/Graph/Renderers/DotRenderer.test.d.ts +1 -0
  359. package/dist/esm/Graph/Renderers/DotRenderer.test.js +1141 -0
  360. package/dist/esm/Graph/Renderers/JsonRenderer.d.ts +5 -0
  361. package/dist/esm/Graph/Renderers/JsonRenderer.js +9 -0
  362. package/dist/esm/Graph/Renderers/JsonRenderer.test.d.ts +1 -0
  363. package/dist/esm/Graph/Renderers/JsonRenderer.test.js +27 -0
  364. package/dist/esm/Graph/Renderers/RendererRegistry.d.ts +15 -0
  365. package/dist/esm/Graph/Renderers/RendererRegistry.js +29 -0
  366. package/dist/esm/Graph/Renderers/RendererRegistry.test.d.ts +1 -0
  367. package/dist/esm/Graph/Renderers/RendererRegistry.test.js +37 -0
  368. package/dist/esm/Graph/Renderers/TgNodeLabel.d.ts +11 -0
  369. package/dist/esm/Graph/Renderers/TgNodeLabel.js +39 -0
  370. package/dist/esm/Graph/Renderers/TgNodeLabel.test.d.ts +1 -0
  371. package/dist/esm/Graph/Renderers/TgNodeLabel.test.js +74 -0
  372. package/dist/esm/Graph/Renderers/index.d.ts +4 -0
  373. package/dist/esm/Graph/Renderers/index.js +4 -0
  374. package/dist/esm/Graph/RuleError.d.ts +12 -0
  375. package/dist/esm/Graph/RuleError.js +14 -0
  376. package/dist/esm/Graph/RuleError.test.d.ts +1 -0
  377. package/dist/esm/Graph/RuleError.test.js +23 -0
  378. package/dist/esm/Graph/Rules/Edge/AlignNodes.d.ts +7 -0
  379. package/dist/esm/Graph/Rules/Edge/AlignNodes.js +35 -0
  380. package/dist/esm/Graph/Rules/Edge/AlignNodes.test.d.ts +1 -0
  381. package/dist/esm/Graph/Rules/Edge/AlignNodes.test.js +192 -0
  382. package/dist/esm/Graph/Rules/Edge/EdgeDirectionSemantic.d.ts +8 -0
  383. package/dist/esm/Graph/Rules/Edge/EdgeDirectionSemantic.js +74 -0
  384. package/dist/esm/Graph/Rules/Edge/EdgeDirectionSemantic.test.d.ts +1 -0
  385. package/dist/esm/Graph/Rules/Edge/EdgeDirectionSemantic.test.js +452 -0
  386. package/dist/esm/Graph/Rules/Edge/EdgeDotProperties.d.ts +9 -0
  387. package/dist/esm/Graph/Rules/Edge/EdgeDotProperties.js +46 -0
  388. package/dist/esm/Graph/Rules/Edge/EdgeDotProperties.test.d.ts +1 -0
  389. package/dist/esm/Graph/Rules/Edge/EdgeDotProperties.test.js +331 -0
  390. package/dist/esm/Graph/Rules/Edge/EdgeLegend.d.ts +8 -0
  391. package/dist/esm/Graph/Rules/Edge/EdgeLegend.js +43 -0
  392. package/dist/esm/Graph/Rules/Edge/EdgeLegend.test.d.ts +1 -0
  393. package/dist/esm/Graph/Rules/Edge/EdgeLegend.test.js +184 -0
  394. package/dist/esm/Graph/Rules/Edge/EdgeReverse.d.ts +6 -0
  395. package/dist/esm/Graph/Rules/Edge/EdgeReverse.js +26 -0
  396. package/dist/esm/Graph/Rules/Edge/EdgeReverse.test.d.ts +1 -0
  397. package/dist/esm/Graph/Rules/Edge/EdgeReverse.test.js +132 -0
  398. package/dist/esm/Graph/Rules/Edge/EdgeSemanticLegend.d.ts +8 -0
  399. package/dist/esm/Graph/Rules/Edge/EdgeSemanticLegend.js +68 -0
  400. package/dist/esm/Graph/Rules/Edge/EdgeSemanticLegend.test.d.ts +1 -0
  401. package/dist/esm/Graph/Rules/Edge/EdgeSemanticLegend.test.js +509 -0
  402. package/dist/esm/Graph/Rules/Edge/ExplicitEdge.d.ts +6 -0
  403. package/dist/esm/Graph/Rules/Edge/ExplicitEdge.js +24 -0
  404. package/dist/esm/Graph/Rules/Edge/ExplicitEdge.test.d.ts +1 -0
  405. package/dist/esm/Graph/Rules/Edge/ExplicitEdge.test.js +123 -0
  406. package/dist/esm/Graph/Rules/Edge/RemoveEdge.d.ts +6 -0
  407. package/dist/esm/Graph/Rules/Edge/RemoveEdge.js +24 -0
  408. package/dist/esm/Graph/Rules/Edge/RemoveEdge.test.d.ts +1 -0
  409. package/dist/esm/Graph/Rules/Edge/RemoveEdge.test.js +133 -0
  410. package/dist/esm/Graph/Rules/Edge/index.d.ts +8 -0
  411. package/dist/esm/Graph/Rules/Edge/index.js +8 -0
  412. package/dist/esm/Graph/Rules/NamedRuleRegistry.d.ts +20 -0
  413. package/dist/esm/Graph/Rules/NamedRuleRegistry.js +67 -0
  414. package/dist/esm/Graph/Rules/NamedRuleRegistry.test.d.ts +1 -0
  415. package/dist/esm/Graph/Rules/NamedRuleRegistry.test.js +241 -0
  416. package/dist/esm/Graph/Rules/NamedRuleSetRegistry.d.ts +19 -0
  417. package/dist/esm/Graph/Rules/NamedRuleSetRegistry.js +58 -0
  418. package/dist/esm/Graph/Rules/NamedRuleSetRegistry.test.d.ts +1 -0
  419. package/dist/esm/Graph/Rules/NamedRuleSetRegistry.test.js +78 -0
  420. package/dist/esm/Graph/Rules/Node/ConvertNodeToEdge.d.ts +6 -0
  421. package/dist/esm/Graph/Rules/Node/ConvertNodeToEdge.js +28 -0
  422. package/dist/esm/Graph/Rules/Node/ConvertNodeToEdge.test.d.ts +1 -0
  423. package/dist/esm/Graph/Rules/Node/ConvertNodeToEdge.test.js +150 -0
  424. package/dist/esm/Graph/Rules/Node/NodeDotProperties.d.ts +9 -0
  425. package/dist/esm/Graph/Rules/Node/NodeDotProperties.js +39 -0
  426. package/dist/esm/Graph/Rules/Node/NodeDotProperties.test.d.ts +1 -0
  427. package/dist/esm/Graph/Rules/Node/NodeDotProperties.test.js +224 -0
  428. package/dist/esm/Graph/Rules/Node/NodeProperties.d.ts +12 -0
  429. package/dist/esm/Graph/Rules/Node/NodeProperties.js +77 -0
  430. package/dist/esm/Graph/Rules/Node/NodeProperties.test.d.ts +1 -0
  431. package/dist/esm/Graph/Rules/Node/NodeProperties.test.js +369 -0
  432. package/dist/esm/Graph/Rules/Node/RemoveLeafChain.d.ts +12 -0
  433. package/dist/esm/Graph/Rules/Node/RemoveLeafChain.js +78 -0
  434. package/dist/esm/Graph/Rules/Node/RemoveLeafChain.test.d.ts +1 -0
  435. package/dist/esm/Graph/Rules/Node/RemoveLeafChain.test.js +397 -0
  436. package/dist/esm/Graph/Rules/Node/RemoveNode.d.ts +6 -0
  437. package/dist/esm/Graph/Rules/Node/RemoveNode.js +10 -0
  438. package/dist/esm/Graph/Rules/Node/RemoveNode.test.d.ts +1 -0
  439. package/dist/esm/Graph/Rules/Node/RemoveNode.test.js +31 -0
  440. package/dist/esm/Graph/Rules/Node/RemoveNodeAndReconnectEdges.d.ts +6 -0
  441. package/dist/esm/Graph/Rules/Node/RemoveNodeAndReconnectEdges.js +34 -0
  442. package/dist/esm/Graph/Rules/Node/RemoveNodeAndReconnectEdges.test.d.ts +1 -0
  443. package/dist/esm/Graph/Rules/Node/RemoveNodeAndReconnectEdges.test.js +111 -0
  444. package/dist/esm/Graph/Rules/Node/index.d.ts +6 -0
  445. package/dist/esm/Graph/Rules/Node/index.js +6 -0
  446. package/dist/esm/Graph/Rules/Rule.d.ts +40 -0
  447. package/dist/esm/Graph/Rules/Rule.js +85 -0
  448. package/dist/esm/Graph/Rules/Rule.test.d.ts +1 -0
  449. package/dist/esm/Graph/Rules/Rule.test.js +125 -0
  450. package/dist/esm/Graph/Rules/RuleConfig.d.ts +20 -0
  451. package/dist/esm/Graph/Rules/RuleConfig.js +1 -0
  452. package/dist/esm/Graph/Rules/RulePlan.d.ts +27 -0
  453. package/dist/esm/Graph/Rules/RulePlan.js +22 -0
  454. package/dist/esm/Graph/Rules/RuleSet.d.ts +25 -0
  455. package/dist/esm/Graph/Rules/RuleSet.js +85 -0
  456. package/dist/esm/Graph/Rules/RuleSet.test.d.ts +1 -0
  457. package/dist/esm/Graph/Rules/RuleSet.test.js +220 -0
  458. package/dist/esm/Graph/Rules/index.d.ts +8 -0
  459. package/dist/esm/Graph/Rules/index.js +8 -0
  460. package/dist/esm/Graph/Rules/registerAll.d.ts +14 -0
  461. package/dist/esm/Graph/Rules/registerAll.js +14 -0
  462. package/dist/esm/Graph/Serialization/Registry.d.ts +5 -0
  463. package/dist/esm/Graph/Serialization/Registry.js +1 -0
  464. package/dist/esm/Graph/Serialization/index.d.ts +1 -0
  465. package/dist/esm/Graph/Serialization/index.js +1 -0
  466. package/dist/esm/Graph/TgGraph.d.ts +82 -0
  467. package/dist/esm/Graph/TgGraph.js +46 -0
  468. package/dist/esm/Graph/TgGraph.test.d.ts +1 -0
  469. package/dist/esm/Graph/TgGraph.test.js +59 -0
  470. package/dist/esm/Graph/index.d.ts +15 -0
  471. package/dist/esm/Graph/index.js +15 -0
  472. package/dist/esm/Output/ArtifactTransformer/DotCliArtifactTransformer.d.ts +25 -0
  473. package/dist/esm/Output/ArtifactTransformer/DotCliArtifactTransformer.js +82 -0
  474. package/dist/esm/Output/ArtifactTransformer/DotCliArtifactTransformer.test.d.ts +1 -0
  475. package/dist/esm/Output/ArtifactTransformer/DotCliArtifactTransformer.test.js +198 -0
  476. package/dist/esm/Output/ArtifactTransformer/index.d.ts +1 -0
  477. package/dist/esm/Output/ArtifactTransformer/index.js +1 -0
  478. package/dist/esm/Output/ArtifactTransformer.d.ts +7 -0
  479. package/dist/esm/Output/ArtifactTransformer.js +1 -0
  480. package/dist/esm/Output/ArtifactTransformerFactory/DefaultArtifactTransformerFactory.d.ts +17 -0
  481. package/dist/esm/Output/ArtifactTransformerFactory/DefaultArtifactTransformerFactory.js +74 -0
  482. package/dist/esm/Output/ArtifactTransformerFactory/DefaultArtifactTransformerFactory.test.d.ts +1 -0
  483. package/dist/esm/Output/ArtifactTransformerFactory/DefaultArtifactTransformerFactory.test.js +78 -0
  484. package/dist/esm/Output/ArtifactTransformerFactory/OclifTransformerFlagParser.d.ts +9 -0
  485. package/dist/esm/Output/ArtifactTransformerFactory/OclifTransformerFlagParser.js +76 -0
  486. package/dist/esm/Output/ArtifactTransformerFactory/OclifTransformerFlagParser.test.d.ts +1 -0
  487. package/dist/esm/Output/ArtifactTransformerFactory/OclifTransformerFlagParser.test.js +154 -0
  488. package/dist/esm/Output/ArtifactTransformerFactory/index.d.ts +2 -0
  489. package/dist/esm/Output/ArtifactTransformerFactory/index.js +2 -0
  490. package/dist/esm/Output/ArtifactTransformerFactory.d.ts +10 -0
  491. package/dist/esm/Output/ArtifactTransformerFactory.js +1 -0
  492. package/dist/esm/Output/ArtifactWriter/FileArtifactWriter.d.ts +9 -0
  493. package/dist/esm/Output/ArtifactWriter/FileArtifactWriter.js +21 -0
  494. package/dist/esm/Output/ArtifactWriter/FileArtifactWriter.test.d.ts +1 -0
  495. package/dist/esm/Output/ArtifactWriter/FileArtifactWriter.test.js +75 -0
  496. package/dist/esm/Output/ArtifactWriter/StdoutArtifactWriter.d.ts +6 -0
  497. package/dist/esm/Output/ArtifactWriter/StdoutArtifactWriter.js +13 -0
  498. package/dist/esm/Output/ArtifactWriter/StdoutArtifactWriter.test.d.ts +1 -0
  499. package/dist/esm/Output/ArtifactWriter/StdoutArtifactWriter.test.js +81 -0
  500. package/dist/esm/Output/ArtifactWriter/index.d.ts +2 -0
  501. package/dist/esm/Output/ArtifactWriter/index.js +2 -0
  502. package/dist/esm/Output/ArtifactWriter.d.ts +8 -0
  503. package/dist/esm/Output/ArtifactWriter.js +1 -0
  504. package/dist/esm/Output/RenderPipeline.d.ts +12 -0
  505. package/dist/esm/Output/RenderPipeline.js +13 -0
  506. package/dist/esm/Output/RenderPipeline.test.d.ts +1 -0
  507. package/dist/esm/Output/RenderPipeline.test.js +78 -0
  508. package/dist/esm/Output/index.d.ts +7 -0
  509. package/dist/esm/Output/index.js +7 -0
  510. package/dist/esm/Runtime/RuntimeCatalog.d.ts +25 -0
  511. package/dist/esm/Runtime/RuntimeCatalog.js +47 -0
  512. package/dist/esm/Runtime/RuntimeCatalog.test.d.ts +1 -0
  513. package/dist/esm/Runtime/RuntimeCatalog.test.js +163 -0
  514. package/dist/esm/Runtime/RuntimeCatalogBuilder/RuntimeCatalogFromConfigBuilder.d.ts +5 -0
  515. package/dist/esm/Runtime/RuntimeCatalogBuilder/RuntimeCatalogFromConfigBuilder.js +6 -0
  516. package/dist/esm/Runtime/RuntimeCatalogBuilder/RuntimeCatalogFromConfigBuilder.test.d.ts +1 -0
  517. package/dist/esm/Runtime/RuntimeCatalogBuilder/RuntimeCatalogFromConfigBuilder.test.js +29 -0
  518. package/dist/esm/Runtime/RuntimeCatalogBuilder/index.d.ts +1 -0
  519. package/dist/esm/Runtime/RuntimeCatalogBuilder/index.js +1 -0
  520. package/dist/esm/Runtime/RuntimeCatalogBuilder.d.ts +11 -0
  521. package/dist/esm/Runtime/RuntimeCatalogBuilder.js +1 -0
  522. package/dist/esm/Runtime/RuntimeCatalogBuilder.test.d.ts +1 -0
  523. package/dist/esm/Runtime/RuntimeCatalogBuilder.test.js +25 -0
  524. package/dist/esm/Runtime/RuntimeCatalogLoader.d.ts +37 -0
  525. package/dist/esm/Runtime/RuntimeCatalogLoader.js +102 -0
  526. package/dist/esm/Runtime/RuntimeCatalogLoader.test.d.ts +1 -0
  527. package/dist/esm/Runtime/RuntimeCatalogLoader.test.js +452 -0
  528. package/dist/esm/Runtime/RuntimeConfigLoader.d.ts +33 -0
  529. package/dist/esm/Runtime/RuntimeConfigLoader.js +89 -0
  530. package/dist/esm/Runtime/RuntimeConfigLoader.test.d.ts +1 -0
  531. package/dist/esm/Runtime/RuntimeConfigLoader.test.js +343 -0
  532. package/dist/esm/Runtime/RuntimeConfigParser/JsonRuntimeConfigParser.d.ts +5 -0
  533. package/dist/esm/Runtime/RuntimeConfigParser/JsonRuntimeConfigParser.js +12 -0
  534. package/dist/esm/Runtime/RuntimeConfigParser/JsonRuntimeConfigParser.test.d.ts +1 -0
  535. package/dist/esm/Runtime/RuntimeConfigParser/JsonRuntimeConfigParser.test.js +20 -0
  536. package/dist/esm/Runtime/RuntimeConfigParser/YamlRuntimeConfigParser.d.ts +5 -0
  537. package/dist/esm/Runtime/RuntimeConfigParser/YamlRuntimeConfigParser.js +16 -0
  538. package/dist/esm/Runtime/RuntimeConfigParser/YamlRuntimeConfigParser.test.d.ts +1 -0
  539. package/dist/esm/Runtime/RuntimeConfigParser/YamlRuntimeConfigParser.test.js +29 -0
  540. package/dist/esm/Runtime/RuntimeConfigParser/index.d.ts +2 -0
  541. package/dist/esm/Runtime/RuntimeConfigParser/index.js +2 -0
  542. package/dist/esm/Runtime/RuntimeConfigParser.d.ts +5 -0
  543. package/dist/esm/Runtime/RuntimeConfigParser.js +2 -0
  544. package/dist/esm/Runtime/RuntimeConfigParser.test.d.ts +1 -0
  545. package/dist/esm/Runtime/RuntimeConfigParser.test.js +6 -0
  546. package/dist/esm/Runtime/RuntimeConfigParserRegistry.d.ts +9 -0
  547. package/dist/esm/Runtime/RuntimeConfigParserRegistry.js +32 -0
  548. package/dist/esm/Runtime/RuntimeConfigParserRegistry.test.d.ts +1 -0
  549. package/dist/esm/Runtime/RuntimeConfigParserRegistry.test.js +51 -0
  550. package/dist/esm/Runtime/RuntimeConfigSource/FileRuntimeConfigSource.d.ts +7 -0
  551. package/dist/esm/Runtime/RuntimeConfigSource/FileRuntimeConfigSource.js +17 -0
  552. package/dist/esm/Runtime/RuntimeConfigSource/FileRuntimeConfigSource.test.d.ts +1 -0
  553. package/dist/esm/Runtime/RuntimeConfigSource/FileRuntimeConfigSource.test.js +38 -0
  554. package/dist/esm/Runtime/RuntimeConfigSource/InMemoryRuntimeConfigSource.d.ts +8 -0
  555. package/dist/esm/Runtime/RuntimeConfigSource/InMemoryRuntimeConfigSource.js +17 -0
  556. package/dist/esm/Runtime/RuntimeConfigSource/InMemoryRuntimeConfigSource.test.d.ts +1 -0
  557. package/dist/esm/Runtime/RuntimeConfigSource/InMemoryRuntimeConfigSource.test.js +19 -0
  558. package/dist/esm/Runtime/RuntimeConfigSource/YamlRuntimeConfigSource.d.ts +6 -0
  559. package/dist/esm/Runtime/RuntimeConfigSource/YamlRuntimeConfigSource.js +13 -0
  560. package/dist/esm/Runtime/RuntimeConfigSource/YamlRuntimeConfigSource.test.d.ts +1 -0
  561. package/dist/esm/Runtime/RuntimeConfigSource/YamlRuntimeConfigSource.test.js +35 -0
  562. package/dist/esm/Runtime/RuntimeConfigSource/index.d.ts +3 -0
  563. package/dist/esm/Runtime/RuntimeConfigSource/index.js +3 -0
  564. package/dist/esm/Runtime/RuntimeConfigSource.d.ts +10 -0
  565. package/dist/esm/Runtime/RuntimeConfigSource.js +15 -0
  566. package/dist/esm/Runtime/RuntimeConfigSource.test.d.ts +1 -0
  567. package/dist/esm/Runtime/RuntimeConfigSource.test.js +21 -0
  568. package/dist/esm/Runtime/RuntimeConfigValidator/ZodRuntimeConfigValidator.d.ts +5 -0
  569. package/dist/esm/Runtime/RuntimeConfigValidator/ZodRuntimeConfigValidator.js +73 -0
  570. package/dist/esm/Runtime/RuntimeConfigValidator/ZodRuntimeConfigValidator.test.d.ts +1 -0
  571. package/dist/esm/Runtime/RuntimeConfigValidator/ZodRuntimeConfigValidator.test.js +60 -0
  572. package/dist/esm/Runtime/RuntimeConfigValidator/index.d.ts +1 -0
  573. package/dist/esm/Runtime/RuntimeConfigValidator/index.js +1 -0
  574. package/dist/esm/Runtime/RuntimeConfigValidator.d.ts +4 -0
  575. package/dist/esm/Runtime/RuntimeConfigValidator.js +1 -0
  576. package/dist/esm/Runtime/RuntimeConfigValidator.test.d.ts +1 -0
  577. package/dist/esm/Runtime/RuntimeConfigValidator.test.js +39 -0
  578. package/dist/esm/Runtime/RuntimeProvider.d.ts +5 -0
  579. package/dist/esm/Runtime/RuntimeProvider.js +1 -0
  580. package/dist/esm/Runtime/RuntimeProvider.test.d.ts +1 -0
  581. package/dist/esm/Runtime/RuntimeProvider.test.js +11 -0
  582. package/dist/esm/Runtime/RuntimeProviderLoader/ModuleRuntimeProviderLoader.d.ts +14 -0
  583. package/dist/esm/Runtime/RuntimeProviderLoader/ModuleRuntimeProviderLoader.js +50 -0
  584. package/dist/esm/Runtime/RuntimeProviderLoader/ModuleRuntimeProviderLoader.test.d.ts +1 -0
  585. package/dist/esm/Runtime/RuntimeProviderLoader/ModuleRuntimeProviderLoader.test.js +146 -0
  586. package/dist/esm/Runtime/RuntimeProviderLoader/index.d.ts +1 -0
  587. package/dist/esm/Runtime/RuntimeProviderLoader/index.js +1 -0
  588. package/dist/esm/Runtime/RuntimeProviderLoader.d.ts +8 -0
  589. package/dist/esm/Runtime/RuntimeProviderLoader.js +1 -0
  590. package/dist/esm/Runtime/RuntimeProviderLoader.test.d.ts +1 -0
  591. package/dist/esm/Runtime/RuntimeProviderLoader.test.js +24 -0
  592. package/dist/esm/Runtime/index.d.ts +15 -0
  593. package/dist/esm/Runtime/index.js +15 -0
  594. package/dist/esm/index.d.ts +3 -0
  595. package/dist/esm/index.js +3 -0
  596. package/package.json +110 -0
@@ -0,0 +1,839 @@
1
+ import { DotAdapter } from './Adapters/DotAdapter.js';
2
+ import { GraphologyAdapter } from './Adapters/GraphologyAdapter.js';
3
+ import { GraphPlugin, GraphPluginRegistry } from './GraphPlugin.js';
4
+ import { NodeQuery } from './Operations/Matchers/NodeQuery/NodeQuery.js';
5
+ import { Profile } from './Profile.js';
6
+ import { NamedRuleRegistry } from './Rules/NamedRuleRegistry.js';
7
+ import { NamedRuleSetRegistry } from './Rules/NamedRuleSetRegistry.js';
8
+ import { NodeRule } from './Rules/Rule.js';
9
+ import { RuleSet } from './Rules/RuleSet.js';
10
+ class AlwaysMatchRule extends NodeRule {
11
+ apply(nodeId, _node, graph) {
12
+ return graph.removeNode(nodeId);
13
+ }
14
+ }
15
+ NodeRule.register(AlwaysMatchRule);
16
+ const createAlwaysMatch = (query) => new AlwaysMatchRule({
17
+ node: (query ?? NodeQuery.from({ attr: { key: 'label', exists: true } })).getDsl(),
18
+ });
19
+ class RemoveLabelPlugin extends GraphPlugin {
20
+ constructor() {
21
+ super('test.remove_label', { label: 'default' });
22
+ }
23
+ build({ options, }) {
24
+ return {
25
+ namedRules: {
26
+ remove_label: createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: options.label } })),
27
+ },
28
+ namedRuleSets: {
29
+ remove_label_set: new RuleSet({
30
+ rules: [{ namedRule: 'remove_label' }],
31
+ }),
32
+ },
33
+ phases: [
34
+ {
35
+ phase: 'main',
36
+ rules: [{ namedRuleSet: 'remove_label_set' }],
37
+ },
38
+ ],
39
+ };
40
+ }
41
+ }
42
+ const pluginRegistry = new GraphPluginRegistry({
43
+ 'test.remove_label': new RemoveLabelPlugin(),
44
+ });
45
+ describe('Profile.serialize', () => {
46
+ it('shoud serialize rules and operations type', () => {
47
+ const profile = new Profile('my-profile', {
48
+ supports: GraphologyAdapter,
49
+ phases: [
50
+ {
51
+ phase: 'main',
52
+ rules: [
53
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', exists: true } })),
54
+ ],
55
+ },
56
+ ],
57
+ });
58
+ const json = profile.serialize();
59
+ expect(json).toEqual(expect.objectContaining({
60
+ name: 'my-profile',
61
+ supports: 'GraphologyAdapter',
62
+ phases: [
63
+ {
64
+ phase: 'main',
65
+ rules: [
66
+ {
67
+ id: 'AlwaysMatchRule',
68
+ config: {
69
+ node: { attr: { key: 'label', exists: true } },
70
+ },
71
+ },
72
+ ],
73
+ },
74
+ ],
75
+ usesProfiles: [],
76
+ }));
77
+ });
78
+ it('shoud serialize render options', () => {
79
+ const profile = new Profile('my-profile', {
80
+ supports: GraphologyAdapter,
81
+ render: {
82
+ options: {
83
+ graph: {
84
+ rankdir: 'TB',
85
+ },
86
+ },
87
+ },
88
+ phases: [],
89
+ });
90
+ const json = profile.serialize();
91
+ expect(json).toEqual(expect.objectContaining({
92
+ name: 'my-profile',
93
+ render: {
94
+ options: {
95
+ graph: {
96
+ rankdir: 'TB',
97
+ },
98
+ },
99
+ },
100
+ }));
101
+ });
102
+ it('shoud serialize render renderer', () => {
103
+ const profile = new Profile('my-profile', {
104
+ render: {
105
+ renderer: 'ui-json',
106
+ },
107
+ phases: [],
108
+ });
109
+ const json = profile.serialize();
110
+ expect(json).toEqual(expect.objectContaining({
111
+ name: 'my-profile',
112
+ render: {
113
+ renderer: 'ui-json',
114
+ },
115
+ }));
116
+ });
117
+ it('shoud serialize plugin references but not plugin-resolved phases', () => {
118
+ const profile = new Profile('my-profile', {
119
+ plugins: [
120
+ {
121
+ plugin: 'test.remove_label',
122
+ options: { label: 'plugin' },
123
+ },
124
+ ],
125
+ phases: [],
126
+ });
127
+ const json = profile.serialize();
128
+ expect(json.plugins).toStrictEqual([
129
+ {
130
+ plugin: 'test.remove_label',
131
+ options: { label: 'plugin' },
132
+ },
133
+ ]);
134
+ expect(json.phases).toStrictEqual([]);
135
+ });
136
+ it('shoud serialize named phases', () => {
137
+ const profile = new Profile('my-profile', {
138
+ phases: [
139
+ {
140
+ phase: 'cleanup',
141
+ rules: [
142
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'cleanup' } })),
143
+ ],
144
+ },
145
+ ],
146
+ });
147
+ const json = profile.serialize();
148
+ expect(json.phases).toStrictEqual([
149
+ {
150
+ phase: 'cleanup',
151
+ rules: [
152
+ {
153
+ id: 'AlwaysMatchRule',
154
+ config: { node: { attr: { key: 'label', eq: 'cleanup' } } },
155
+ },
156
+ ],
157
+ },
158
+ ]);
159
+ });
160
+ });
161
+ describe('Profile.deserialize', () => {
162
+ it('shoud deserialize rules', () => {
163
+ const profile = new Profile('my-profile', {
164
+ supports: GraphologyAdapter,
165
+ phases: [
166
+ {
167
+ phase: 'main',
168
+ rules: [
169
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', exists: true } })),
170
+ ],
171
+ },
172
+ ],
173
+ });
174
+ const json = profile.serialize();
175
+ const restored = Profile.deseriaize(json, {
176
+ GraphologyAdapter,
177
+ });
178
+ expect(restored.serialize()).toStrictEqual(json);
179
+ expect(restored.resolvePhases()).toHaveLength(1);
180
+ expect(restored.resolvePhases()[0]).toHaveLength(1);
181
+ });
182
+ it('shoud deserialize plugin references', () => {
183
+ const profile = new Profile('my-profile', {
184
+ plugins: [
185
+ {
186
+ plugin: 'test.remove_label',
187
+ options: { label: 'plugin' },
188
+ },
189
+ ],
190
+ });
191
+ const json = profile.serialize();
192
+ const restored = Profile.deseriaize(json);
193
+ expect(restored.serialize().plugins).toStrictEqual([
194
+ {
195
+ plugin: 'test.remove_label',
196
+ options: { label: 'plugin' },
197
+ },
198
+ ]);
199
+ });
200
+ it('shoud deserialize named phases', () => {
201
+ const profile = new Profile('my-profile', {
202
+ phases: [
203
+ {
204
+ phase: 'cleanup',
205
+ rules: [
206
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'cleanup' } })),
207
+ ],
208
+ },
209
+ ],
210
+ });
211
+ const json = profile.serialize();
212
+ const restored = Profile.deseriaize(json);
213
+ expect(restored.serialize().phases).toStrictEqual(json.phases);
214
+ });
215
+ it('shoud throw when deserializing unsupported phase names', () => {
216
+ expect(() => Profile.deseriaize({
217
+ name: 'invalid-profile',
218
+ phases: [
219
+ {
220
+ phase: 'invalid',
221
+ rules: [],
222
+ },
223
+ ],
224
+ })).toThrow("Profile.phases contains unsupported phase 'invalid'");
225
+ });
226
+ it('shoud throw when supports is not registered during deserialize', () => {
227
+ expect(() => Profile.deseriaize({
228
+ name: 'unsupported-profile',
229
+ supports: 'MissingAdapter',
230
+ })).toThrow("Profile.supports ('MissingAdapter') is not registered");
231
+ });
232
+ it('shoud default missing phases and used profiles during deserialize', () => {
233
+ const restored = Profile.deseriaize({
234
+ name: 'empty-profile',
235
+ });
236
+ expect(restored.serialize().phases).toEqual([]);
237
+ expect(restored.serialize().usesProfiles).toEqual([]);
238
+ });
239
+ });
240
+ describe('Profile.resolveRendererOptions', () => {
241
+ it('shoud return undefined when no renderer options are set', () => {
242
+ const profile = new Profile('empty', {});
243
+ expect(profile.resolveRendererOptions()).toBeUndefined();
244
+ });
245
+ it('shoud return own renderer options when set', () => {
246
+ const profile = new Profile('my-profile', {
247
+ render: {
248
+ options: {
249
+ graph: {
250
+ rankdir: 'LR',
251
+ },
252
+ },
253
+ },
254
+ });
255
+ expect(profile.resolveRendererOptions()).toEqual({
256
+ graph: {
257
+ rankdir: 'LR',
258
+ },
259
+ });
260
+ });
261
+ it('shoud resolve renderer options from used profiles', () => {
262
+ const child = new Profile('child', {
263
+ render: {
264
+ options: {
265
+ graph: {
266
+ rankdir: 'TB',
267
+ },
268
+ },
269
+ },
270
+ });
271
+ const parent = new Profile('parent', {}).use(child);
272
+ expect(parent.resolveRendererOptions()).toEqual({
273
+ graph: {
274
+ rankdir: 'TB',
275
+ },
276
+ });
277
+ });
278
+ it('shoud prefer own renderer options over inherited ones', () => {
279
+ const child = new Profile('child', {
280
+ render: {
281
+ options: {
282
+ graph: {
283
+ rankdir: 'TB',
284
+ },
285
+ },
286
+ },
287
+ });
288
+ const parent = new Profile('parent', {
289
+ render: {
290
+ options: {
291
+ graph: {
292
+ rankdir: 'LR',
293
+ },
294
+ },
295
+ },
296
+ }).use(child);
297
+ expect(parent.resolveRendererOptions()).toEqual({
298
+ graph: {
299
+ rankdir: 'LR',
300
+ },
301
+ });
302
+ });
303
+ });
304
+ describe('Profile.resolveRenderer', () => {
305
+ it('shoud return undefined when no renderer is set', () => {
306
+ const profile = new Profile('empty', {});
307
+ expect(profile.resolveRenderer()).toBeUndefined();
308
+ });
309
+ it('shoud return own renderer when set', () => {
310
+ const profile = new Profile('my-profile', {
311
+ render: {
312
+ renderer: 'ui-json',
313
+ },
314
+ });
315
+ expect(profile.resolveRenderer()).toBe('ui-json');
316
+ });
317
+ it('shoud resolve renderer from used profiles', () => {
318
+ const child = new Profile('child', {
319
+ render: {
320
+ renderer: 'dot',
321
+ },
322
+ });
323
+ const parent = new Profile('parent', {}).use(child);
324
+ expect(parent.resolveRenderer()).toBe('dot');
325
+ });
326
+ it('shoud prefer own renderer over inherited ones', () => {
327
+ const child = new Profile('child', {
328
+ render: {
329
+ renderer: 'dot',
330
+ },
331
+ });
332
+ const parent = new Profile('parent', {
333
+ render: {
334
+ renderer: 'ui-json',
335
+ },
336
+ }).use(child);
337
+ expect(parent.resolveRenderer()).toBe('ui-json');
338
+ });
339
+ });
340
+ describe('Profile.resolvePhases', () => {
341
+ it('shoud accept compatible supports declarations', () => {
342
+ const profile = new Profile('supported', {
343
+ supports: GraphologyAdapter,
344
+ phases: [],
345
+ });
346
+ expect(profile.resolvePhases()).toEqual([]);
347
+ });
348
+ it('shoud resolve plugin phases at runtime', () => {
349
+ const profile = new Profile('plugin-profile', {
350
+ plugins: [
351
+ {
352
+ plugin: 'test.remove_label',
353
+ options: { label: 'plugin' },
354
+ },
355
+ ],
356
+ });
357
+ const phases = profile.resolvePhases(undefined, undefined, pluginRegistry);
358
+ expect(phases).toHaveLength(1);
359
+ expect(phases[0]).toHaveLength(1);
360
+ expect(phases[0][0].serialize()).toEqual({
361
+ id: 'AlwaysMatchRule',
362
+ config: { node: { attr: { key: 'label', eq: 'plugin' } } },
363
+ });
364
+ });
365
+ it('shoud auto-prefix plugin named rules and named rule sets', () => {
366
+ class PrefixRulePlugin extends GraphPlugin {
367
+ constructor() {
368
+ super('plugin.prefix');
369
+ }
370
+ build() {
371
+ return {
372
+ namedRules: {
373
+ remove: {
374
+ id: 'AlwaysMatchRule',
375
+ config: {
376
+ node: { attr: { key: 'label', eq: 'prefixed' } },
377
+ },
378
+ },
379
+ },
380
+ namedRuleSets: {
381
+ wrapper: new RuleSet({
382
+ rules: [{ namedRule: 'remove' }],
383
+ }),
384
+ },
385
+ phases: [
386
+ {
387
+ phase: 'main',
388
+ rules: [{ namedRuleSet: 'wrapper' }],
389
+ },
390
+ ],
391
+ };
392
+ }
393
+ }
394
+ const registry = new GraphPluginRegistry({
395
+ 'plugin.prefix': new PrefixRulePlugin(),
396
+ });
397
+ const profile = new Profile('plugin-profile', {
398
+ plugins: [{ plugin: 'plugin.prefix' }],
399
+ });
400
+ const phases = profile.resolvePhases(undefined, undefined, registry);
401
+ expect(phases).toHaveLength(1);
402
+ expect(phases[0]).toHaveLength(1);
403
+ expect(phases[0][0].serialize()).toEqual({
404
+ id: 'AlwaysMatchRule',
405
+ config: { node: { attr: { key: 'label', eq: 'prefixed' } } },
406
+ });
407
+ });
408
+ it('shoud resolve plugin phases by named phase order', () => {
409
+ class CleanupPlugin extends GraphPlugin {
410
+ constructor() {
411
+ super('plugin.cleanup');
412
+ }
413
+ build() {
414
+ return {
415
+ namedRules: {
416
+ cleanup: {
417
+ id: 'AlwaysMatchRule',
418
+ config: {
419
+ node: { attr: { key: 'label', eq: 'plugin-cleanup' } },
420
+ },
421
+ },
422
+ },
423
+ phases: [
424
+ {
425
+ phase: 'cleanup',
426
+ rules: [{ namedRule: 'cleanup' }],
427
+ },
428
+ ],
429
+ };
430
+ }
431
+ }
432
+ const registry = new GraphPluginRegistry({
433
+ 'plugin.cleanup': new CleanupPlugin(),
434
+ });
435
+ const profile = new Profile('plugin-profile', {
436
+ plugins: [{ plugin: 'plugin.cleanup' }],
437
+ phases: [
438
+ {
439
+ phase: 'main',
440
+ rules: [
441
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'profile-main' } })),
442
+ ],
443
+ },
444
+ ],
445
+ });
446
+ const phases = profile.resolvePhases(undefined, undefined, registry);
447
+ expect(phases).toHaveLength(2);
448
+ expect(phases[0][0].serialize()).toEqual({
449
+ id: 'AlwaysMatchRule',
450
+ config: { node: { attr: { key: 'label', eq: 'profile-main' } } },
451
+ });
452
+ expect(phases[1][0].serialize()).toEqual({
453
+ id: 'AlwaysMatchRule',
454
+ config: { node: { attr: { key: 'label', eq: 'plugin-cleanup' } } },
455
+ });
456
+ });
457
+ it('shoud throw when plugins are used without a plugin registry', () => {
458
+ const profile = new Profile('plugin-profile', {
459
+ plugins: [{ plugin: 'test.remove_label' }],
460
+ });
461
+ expect(() => profile.resolvePhases()).toThrow("Profile 'plugin-profile' contains plugins but no GraphPluginRegistry was provided");
462
+ });
463
+ it('shoud throw when plugin prefixed names collide', () => {
464
+ const profile = new Profile('plugin-profile', {
465
+ plugins: [{ plugin: 'test.remove_label' }],
466
+ });
467
+ const namedRules = new NamedRuleRegistry({
468
+ 'test.remove_label.remove_label': {
469
+ id: 'AlwaysMatchRule',
470
+ config: { node: { any: true } },
471
+ },
472
+ });
473
+ expect(() => profile.resolvePhases(namedRules, undefined, pluginRegistry)).toThrow("GraphPlugin 'test.remove_label' named rule 'test.remove_label.remove_label' collides with an existing named rule");
474
+ });
475
+ it('shoud throw when a phase contains an unsupported phase name', () => {
476
+ const profile = new Profile('phase-profile', {
477
+ phases: [
478
+ {
479
+ phase: 'invalid',
480
+ rules: [],
481
+ },
482
+ ],
483
+ });
484
+ expect(() => profile.resolvePhases()).toThrow("Profile 'phase-profile' contains unsupported phase 'invalid'");
485
+ });
486
+ it('shoud throw when supports is incompatible across used profiles', () => {
487
+ const used = new Profile('used', {
488
+ supports: DotAdapter,
489
+ });
490
+ const profile = new Profile('current', {
491
+ supports: GraphologyAdapter,
492
+ }).use(used);
493
+ expect(() => profile.resolvePhases()).toThrow("Profile.supports conflict for ('GraphologyAdapter') (conflicting profiles: used)");
494
+ });
495
+ it('shoud resolve named rules when a registry is provided', () => {
496
+ const registry = new NamedRuleRegistry({
497
+ removeAlways: {
498
+ id: 'AlwaysMatchRule',
499
+ config: { node: { any: true } },
500
+ },
501
+ });
502
+ const profile = new Profile('named-profile', {
503
+ phases: [{ phase: 'main', rules: [{ namedRule: 'removeAlways' }] }],
504
+ });
505
+ const phases = profile.resolvePhases(registry);
506
+ expect(phases).toHaveLength(1);
507
+ expect(phases[0]).toHaveLength(1);
508
+ expect(phases[0][0].serialize()).toEqual({
509
+ id: 'AlwaysMatchRule',
510
+ config: { node: { any: true } },
511
+ });
512
+ });
513
+ it('shoud throw when named rules are used without a registry', () => {
514
+ const profile = new Profile('named-profile', {
515
+ phases: [{ phase: 'main', rules: [{ namedRule: 'removeAlways' }] }],
516
+ });
517
+ expect(() => profile.resolvePhases()).toThrow("Profile 'named-profile' contains named rules but no NamedRuleRegistry was provided");
518
+ });
519
+ it('shoud use current named rule definitions after deserialize', () => {
520
+ const profile = new Profile('named-profile', {
521
+ phases: [{ phase: 'main', rules: [{ namedRule: 'removeAlways' }] }],
522
+ });
523
+ const serialized = profile.serialize();
524
+ const restored = Profile.deseriaize(serialized);
525
+ const updatedRegistry = new NamedRuleRegistry({
526
+ removeAlways: {
527
+ id: 'AlwaysMatchRule',
528
+ config: {
529
+ node: { attr: { key: 'label', startsWith: 'data.' } },
530
+ },
531
+ },
532
+ });
533
+ const phases = restored.resolvePhases(updatedRegistry);
534
+ expect(phases[0][0].serialize()).toEqual({
535
+ id: 'AlwaysMatchRule',
536
+ config: { node: { attr: { key: 'label', startsWith: 'data.' } } },
537
+ });
538
+ });
539
+ it('shoud append own phases after used profile phases', () => {
540
+ const used = new Profile('used', {
541
+ phases: [
542
+ {
543
+ phase: 'main',
544
+ rules: [
545
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'used' } })),
546
+ ],
547
+ },
548
+ ],
549
+ });
550
+ const current = new Profile('current', {
551
+ usesProfiles: [used],
552
+ phases: [
553
+ {
554
+ phase: 'main',
555
+ rules: [
556
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'current' } })),
557
+ ],
558
+ },
559
+ ],
560
+ });
561
+ const phases = current.resolvePhases();
562
+ expect(phases).toHaveLength(2);
563
+ expect(phases[0][0].serialize()).toEqual({
564
+ id: 'AlwaysMatchRule',
565
+ config: { node: { attr: { key: 'label', eq: 'used' } } },
566
+ });
567
+ expect(phases[1][0].serialize()).toEqual({
568
+ id: 'AlwaysMatchRule',
569
+ config: { node: { attr: { key: 'label', eq: 'current' } } },
570
+ });
571
+ });
572
+ it('shoud resolve named rule sets when a rule set registry is provided', () => {
573
+ const namedRules = new NamedRuleRegistry({
574
+ removeUsed: {
575
+ id: 'AlwaysMatchRule',
576
+ config: { node: { attr: { key: 'label', eq: 'used' } } },
577
+ },
578
+ removeCurrent: {
579
+ id: 'AlwaysMatchRule',
580
+ config: { node: { attr: { key: 'label', eq: 'current' } } },
581
+ },
582
+ });
583
+ const namedRuleSets = new NamedRuleSetRegistry({
584
+ baseSet: new RuleSet({
585
+ rules: [{ namedRule: 'removeUsed' }],
586
+ }),
587
+ });
588
+ const profile = new Profile('named-set-profile', {
589
+ phases: [
590
+ {
591
+ phase: 'main',
592
+ rules: [{ namedRuleSet: 'baseSet' }, { namedRule: 'removeCurrent' }],
593
+ },
594
+ ],
595
+ });
596
+ const phases = profile.resolvePhases(namedRules, namedRuleSets);
597
+ expect(phases).toHaveLength(1);
598
+ expect(phases[0]).toHaveLength(2);
599
+ expect(phases[0][0].serialize()).toEqual({
600
+ id: 'AlwaysMatchRule',
601
+ config: { node: { attr: { key: 'label', eq: 'used' } } },
602
+ });
603
+ expect(phases[0][1].serialize()).toEqual({
604
+ id: 'AlwaysMatchRule',
605
+ config: { node: { attr: { key: 'label', eq: 'current' } } },
606
+ });
607
+ });
608
+ it('shoud resolve serialized rule entries', () => {
609
+ const profile = new Profile('serialized-profile', {
610
+ phases: [
611
+ {
612
+ phase: 'main',
613
+ rules: [
614
+ {
615
+ id: 'AlwaysMatchRule',
616
+ config: { node: { any: true } },
617
+ },
618
+ ],
619
+ },
620
+ ],
621
+ });
622
+ const phases = profile.resolvePhases();
623
+ expect(phases).toHaveLength(1);
624
+ expect(phases[0][0].serialize()).toEqual({
625
+ id: 'AlwaysMatchRule',
626
+ config: { node: { any: true } },
627
+ });
628
+ });
629
+ it('shoud throw when ordering phases with unsupported entries', () => {
630
+ const profile = new Profile('phase-profile', {});
631
+ expect(() => profile.orderPhaseEntries([{ phase: 'invalid', rules: [] }])).toThrow("Profile 'phase-profile' contains unsupported phase 'invalid'");
632
+ });
633
+ it('shoud throw when named rule sets resolve multiple phases', () => {
634
+ const profile = new Profile('multi-set-profile', {
635
+ phases: [{ phase: 'main', rules: [{ namedRuleSet: 'multi' }] }],
636
+ });
637
+ const namedRuleSets = {
638
+ resolve: () => ({
639
+ resolvePhases: () => [[], []],
640
+ }),
641
+ };
642
+ expect(() => profile.resolvePhases(undefined, namedRuleSets)).toThrow("Profile 'multi-set-profile' references namedRuleSet 'multi' with multiple phases, which cannot be inlined in a single phase");
643
+ });
644
+ it('shoud return empty rules when named rule sets resolve no phases', () => {
645
+ const profile = new Profile('empty-set-profile', {
646
+ phases: [{ phase: 'main', rules: [{ namedRuleSet: 'empty' }] }],
647
+ });
648
+ const namedRuleSets = {
649
+ resolve: () => ({
650
+ resolvePhases: () => [],
651
+ }),
652
+ };
653
+ const phases = profile.resolvePhases(undefined, namedRuleSets);
654
+ expect(phases).toEqual([[]]);
655
+ });
656
+ it('shoud handle missing phase buckets during ordering', () => {
657
+ const profile = new Profile('phase-profile', {});
658
+ const originalGet = Map.prototype.get;
659
+ Map.prototype.get = function (key) {
660
+ if (key === 'pre') {
661
+ return undefined;
662
+ }
663
+ return originalGet.call(this, key);
664
+ };
665
+ try {
666
+ const ordered = profile.orderPhaseEntries([]);
667
+ expect(ordered).toEqual([]);
668
+ }
669
+ finally {
670
+ Map.prototype.get = originalGet;
671
+ }
672
+ });
673
+ it('shoud throw when named rule sets are used without a rule set registry', () => {
674
+ const profile = new Profile('named-set-profile', {
675
+ phases: [{ phase: 'main', rules: [{ namedRuleSet: 'baseSet' }] }],
676
+ });
677
+ expect(() => profile.resolvePhases()).toThrow("Profile 'named-set-profile' contains named rule sets but no NamedRuleSetRegistry was provided");
678
+ });
679
+ it('shoud resolve nested named rule sets', () => {
680
+ const namedRules = new NamedRuleRegistry({
681
+ removeUsed: {
682
+ id: 'AlwaysMatchRule',
683
+ config: { node: { attr: { key: 'label', eq: 'used' } } },
684
+ },
685
+ removeCurrent: {
686
+ id: 'AlwaysMatchRule',
687
+ config: { node: { attr: { key: 'label', eq: 'current' } } },
688
+ },
689
+ });
690
+ const namedRuleSets = new NamedRuleSetRegistry({
691
+ baseSet: new RuleSet({
692
+ rules: [{ namedRule: 'removeUsed' }],
693
+ }),
694
+ wrapperSet: new RuleSet({
695
+ rules: [{ namedRuleSet: 'baseSet' }, { namedRule: 'removeCurrent' }],
696
+ }),
697
+ });
698
+ const profile = new Profile('named-set-profile', {
699
+ phases: [{ phase: 'main', rules: [{ namedRuleSet: 'wrapperSet' }] }],
700
+ });
701
+ const phases = profile.resolvePhases(namedRules, namedRuleSets);
702
+ expect(phases).toHaveLength(1);
703
+ expect(phases[0]).toHaveLength(2);
704
+ expect(phases[0][0].serialize()).toEqual({
705
+ id: 'AlwaysMatchRule',
706
+ config: { node: { attr: { key: 'label', eq: 'used' } } },
707
+ });
708
+ expect(phases[0][1].serialize()).toEqual({
709
+ id: 'AlwaysMatchRule',
710
+ config: { node: { attr: { key: 'label', eq: 'current' } } },
711
+ });
712
+ });
713
+ it('shoud order phases by named phase sequence', () => {
714
+ const profile = new Profile('phase-profile', {
715
+ phases: [
716
+ {
717
+ phase: 'cleanup',
718
+ rules: [
719
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'cleanup' } })),
720
+ ],
721
+ },
722
+ {
723
+ phase: 'normalize',
724
+ rules: [
725
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'normalize' } })),
726
+ ],
727
+ },
728
+ {
729
+ phase: 'main',
730
+ rules: [
731
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'main' } })),
732
+ ],
733
+ },
734
+ ],
735
+ });
736
+ const phases = profile.resolvePhases();
737
+ expect(phases).toHaveLength(3);
738
+ expect(phases[0][0].serialize()).toEqual({
739
+ id: 'AlwaysMatchRule',
740
+ config: { node: { attr: { key: 'label', eq: 'normalize' } } },
741
+ });
742
+ expect(phases[1][0].serialize()).toEqual({
743
+ id: 'AlwaysMatchRule',
744
+ config: { node: { attr: { key: 'label', eq: 'main' } } },
745
+ });
746
+ expect(phases[2][0].serialize()).toEqual({
747
+ id: 'AlwaysMatchRule',
748
+ config: { node: { attr: { key: 'label', eq: 'cleanup' } } },
749
+ });
750
+ });
751
+ it('shoud run inherited cleanup phases after main phases', () => {
752
+ const used = new Profile('used', {
753
+ phases: [
754
+ {
755
+ phase: 'cleanup',
756
+ rules: [
757
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'used-cleanup' } })),
758
+ ],
759
+ },
760
+ ],
761
+ });
762
+ const current = new Profile('current', {
763
+ usesProfiles: [used],
764
+ phases: [
765
+ {
766
+ phase: 'main',
767
+ rules: [
768
+ createAlwaysMatch(NodeQuery.from({ attr: { key: 'label', eq: 'current-main' } })),
769
+ ],
770
+ },
771
+ ],
772
+ });
773
+ const phases = current.resolvePhases();
774
+ expect(phases).toHaveLength(2);
775
+ expect(phases[0][0].serialize()).toEqual({
776
+ id: 'AlwaysMatchRule',
777
+ config: { node: { attr: { key: 'label', eq: 'current-main' } } },
778
+ });
779
+ expect(phases[1][0].serialize()).toEqual({
780
+ id: 'AlwaysMatchRule',
781
+ config: { node: { attr: { key: 'label', eq: 'used-cleanup' } } },
782
+ });
783
+ });
784
+ });
785
+ describe('Profile.usePlugin', () => {
786
+ it('shoud append plugin references immutably', () => {
787
+ const base = new Profile('plugin-profile', {});
788
+ const updated = base.usePlugin('test.remove_label', { label: 'plugin' });
789
+ expect(base.serialize().plugins ?? []).toHaveLength(0);
790
+ expect(updated.serialize().plugins).toStrictEqual([
791
+ { plugin: 'test.remove_label', options: { label: 'plugin' } },
792
+ ]);
793
+ });
794
+ });
795
+ describe('Profile.addPhases', () => {
796
+ it('shoud append phases immutably', () => {
797
+ const base = new Profile('base', {
798
+ phases: [{ phase: 'main', rules: [] }],
799
+ });
800
+ const updated = base.addPhases([{ phase: 'cleanup', rules: [] }]);
801
+ expect(base.serialize().phases).toHaveLength(1);
802
+ expect(updated.serialize().phases).toHaveLength(2);
803
+ });
804
+ });
805
+ describe('Profile.use', () => {
806
+ it('shoud append used profiles immutably', () => {
807
+ const base = new Profile('base', {});
808
+ const used = new Profile('used', {});
809
+ const updated = base.use(used);
810
+ expect(base.serialize().usesProfiles).toHaveLength(0);
811
+ expect(updated.serialize().usesProfiles).toHaveLength(1);
812
+ });
813
+ });
814
+ describe('Profile.serialize (plugins)', () => {
815
+ it('shoud omit plugins when none are configured', () => {
816
+ const profile = new Profile('empty', {});
817
+ expect(profile.serialize().plugins).toBeUndefined();
818
+ });
819
+ });
820
+ describe('Profile.resolvePhases (rule-like entries)', () => {
821
+ it('shoud resolve rules that provide a serialize function', () => {
822
+ const ruleLike = {
823
+ serialize: () => ({
824
+ id: 'AlwaysMatchRule',
825
+ config: { node: { any: true } },
826
+ }),
827
+ };
828
+ const profile = new Profile('rule-like', {
829
+ phases: [{ phase: 'main', rules: [ruleLike] }],
830
+ });
831
+ const phases = profile.resolvePhases();
832
+ expect(phases).toHaveLength(1);
833
+ expect(phases[0]).toHaveLength(1);
834
+ expect(phases[0][0].serialize()).toEqual({
835
+ id: 'AlwaysMatchRule',
836
+ config: { node: { any: true } },
837
+ });
838
+ });
839
+ });