@plures/praxis 0.2.1 → 1.0.1

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 (486) hide show
  1. package/README.md +191 -64
  2. package/core/codegen/docs-generator.ts +808 -0
  3. package/core/codegen/index.ts +27 -0
  4. package/core/codegen/ts-generator.ts +15 -0
  5. package/core/db-adapter/index.ts +52 -0
  6. package/core/db-adapter/sync-engine.ts +450 -0
  7. package/core/logic-engine/engine.ts +12 -0
  8. package/core/logic-engine/index.ts +16 -0
  9. package/core/logic-engine/protocol.ts +16 -0
  10. package/core/logic-engine/psf-adapter.ts +269 -0
  11. package/core/logic-engine/rules.ts +16 -0
  12. package/core/schema-engine/compiler.ts +431 -0
  13. package/core/schema-engine/generator.ts +635 -0
  14. package/core/schema-engine/index.ts +18 -0
  15. package/core/schema-engine/psf.ts +664 -0
  16. package/core/schema-engine/types.ts +63 -0
  17. package/core/schema-engine/validator.ts +541 -0
  18. package/dist/core/codegen/docs-generator.d.ts +123 -0
  19. package/dist/core/codegen/docs-generator.d.ts.map +1 -0
  20. package/dist/core/codegen/docs-generator.js +674 -0
  21. package/dist/core/codegen/docs-generator.js.map +1 -0
  22. package/dist/core/codegen/index.d.ts +11 -0
  23. package/dist/core/codegen/index.d.ts.map +1 -0
  24. package/dist/core/codegen/index.js +13 -0
  25. package/dist/core/codegen/index.js.map +1 -0
  26. package/dist/core/codegen/ts-generator.d.ts +8 -0
  27. package/dist/core/codegen/ts-generator.d.ts.map +1 -0
  28. package/dist/core/codegen/ts-generator.js +8 -0
  29. package/dist/core/codegen/ts-generator.js.map +1 -0
  30. package/dist/core/db-adapter/index.d.ts +18 -0
  31. package/dist/core/db-adapter/index.d.ts.map +1 -0
  32. package/dist/core/db-adapter/index.js +23 -0
  33. package/dist/core/db-adapter/index.js.map +1 -0
  34. package/dist/core/db-adapter/sync-engine.d.ts +180 -0
  35. package/dist/core/db-adapter/sync-engine.d.ts.map +1 -0
  36. package/dist/core/db-adapter/sync-engine.js +342 -0
  37. package/dist/core/db-adapter/sync-engine.js.map +1 -0
  38. package/dist/core/logic-engine/engine.d.ts +8 -0
  39. package/dist/core/logic-engine/engine.d.ts.map +1 -0
  40. package/dist/core/logic-engine/engine.js +8 -0
  41. package/dist/core/logic-engine/engine.js.map +1 -0
  42. package/dist/core/logic-engine/index.d.ts +16 -0
  43. package/dist/core/logic-engine/index.d.ts.map +1 -0
  44. package/dist/core/logic-engine/index.js +16 -0
  45. package/dist/core/logic-engine/index.js.map +1 -0
  46. package/dist/core/logic-engine/protocol.d.ts +7 -0
  47. package/dist/core/logic-engine/protocol.d.ts.map +1 -0
  48. package/dist/core/logic-engine/protocol.js +7 -0
  49. package/dist/core/logic-engine/protocol.js.map +1 -0
  50. package/dist/core/logic-engine/psf-adapter.d.ts +88 -0
  51. package/dist/core/logic-engine/psf-adapter.d.ts.map +1 -0
  52. package/dist/core/logic-engine/psf-adapter.js +207 -0
  53. package/dist/core/logic-engine/psf-adapter.js.map +1 -0
  54. package/dist/core/logic-engine/rules.d.ts +7 -0
  55. package/dist/core/logic-engine/rules.d.ts.map +1 -0
  56. package/dist/core/logic-engine/rules.js +7 -0
  57. package/dist/core/logic-engine/rules.js.map +1 -0
  58. package/dist/core/schema-engine/compiler.d.ts +198 -0
  59. package/dist/core/schema-engine/compiler.d.ts.map +1 -0
  60. package/dist/core/schema-engine/compiler.js +262 -0
  61. package/dist/core/schema-engine/compiler.js.map +1 -0
  62. package/dist/core/schema-engine/generator.d.ts +115 -0
  63. package/dist/core/schema-engine/generator.d.ts.map +1 -0
  64. package/dist/core/schema-engine/generator.js +506 -0
  65. package/dist/core/schema-engine/generator.js.map +1 -0
  66. package/dist/core/schema-engine/index.d.ts +18 -0
  67. package/dist/core/schema-engine/index.d.ts.map +1 -0
  68. package/dist/core/schema-engine/index.js +18 -0
  69. package/dist/core/schema-engine/index.js.map +1 -0
  70. package/dist/core/schema-engine/psf.d.ts +612 -0
  71. package/dist/core/schema-engine/psf.d.ts.map +1 -0
  72. package/dist/core/schema-engine/psf.js +45 -0
  73. package/dist/core/schema-engine/psf.js.map +1 -0
  74. package/dist/core/schema-engine/types.d.ts +10 -0
  75. package/dist/core/schema-engine/types.d.ts.map +1 -0
  76. package/dist/core/schema-engine/types.js +7 -0
  77. package/dist/core/schema-engine/types.js.map +1 -0
  78. package/dist/core/schema-engine/validator.d.ts +140 -0
  79. package/dist/core/schema-engine/validator.d.ts.map +1 -0
  80. package/dist/core/schema-engine/validator.js +407 -0
  81. package/dist/core/schema-engine/validator.js.map +1 -0
  82. package/dist/src/adapters/cli.d.ts.map +1 -0
  83. package/dist/src/adapters/cli.js.map +1 -0
  84. package/dist/src/cli/commands/auth.d.ts.map +1 -0
  85. package/dist/src/cli/commands/auth.js.map +1 -0
  86. package/dist/src/cli/commands/build.d.ts +23 -0
  87. package/dist/src/cli/commands/build.d.ts.map +1 -0
  88. package/dist/src/cli/commands/build.js +162 -0
  89. package/dist/src/cli/commands/build.js.map +1 -0
  90. package/dist/src/cli/commands/canvas.d.ts +23 -0
  91. package/dist/src/cli/commands/canvas.d.ts.map +1 -0
  92. package/dist/src/cli/commands/canvas.js +215 -0
  93. package/dist/src/cli/commands/canvas.js.map +1 -0
  94. package/dist/src/cli/commands/cloud.d.ts.map +1 -0
  95. package/dist/src/cli/commands/cloud.js.map +1 -0
  96. package/dist/src/cli/commands/create.d.ts +21 -0
  97. package/dist/src/cli/commands/create.d.ts.map +1 -0
  98. package/dist/src/cli/commands/create.js +621 -0
  99. package/dist/src/cli/commands/create.js.map +1 -0
  100. package/dist/src/cli/commands/dev.d.ts +21 -0
  101. package/dist/src/cli/commands/dev.d.ts.map +1 -0
  102. package/dist/src/cli/commands/dev.js +71 -0
  103. package/dist/src/cli/commands/dev.js.map +1 -0
  104. package/dist/src/cli/commands/generate.d.ts.map +1 -0
  105. package/dist/src/cli/commands/generate.js.map +1 -0
  106. package/dist/src/cli/commands/orchestrate.d.ts +44 -0
  107. package/dist/src/cli/commands/orchestrate.d.ts.map +1 -0
  108. package/dist/src/cli/commands/orchestrate.js +150 -0
  109. package/dist/src/cli/commands/orchestrate.js.map +1 -0
  110. package/dist/{cli → src/cli}/index.d.ts.map +1 -1
  111. package/dist/{cli → src/cli}/index.js +53 -21
  112. package/dist/src/cli/index.js.map +1 -0
  113. package/dist/src/cloud/auth.d.ts.map +1 -0
  114. package/dist/src/cloud/auth.js.map +1 -0
  115. package/dist/src/cloud/billing.d.ts.map +1 -0
  116. package/dist/src/cloud/billing.js.map +1 -0
  117. package/dist/src/cloud/client.d.ts.map +1 -0
  118. package/dist/src/cloud/client.js.map +1 -0
  119. package/dist/src/cloud/index.d.ts.map +1 -0
  120. package/dist/src/cloud/index.js.map +1 -0
  121. package/dist/src/cloud/marketplace.d.ts.map +1 -0
  122. package/dist/src/cloud/marketplace.js.map +1 -0
  123. package/dist/src/cloud/provisioning.d.ts.map +1 -0
  124. package/dist/src/cloud/provisioning.js.map +1 -0
  125. package/dist/src/cloud/relay/endpoints.d.ts.map +1 -0
  126. package/dist/src/cloud/relay/endpoints.js.map +1 -0
  127. package/dist/src/cloud/relay/health/index.d.ts.map +1 -0
  128. package/dist/src/cloud/relay/health/index.js.map +1 -0
  129. package/dist/src/cloud/relay/stats/index.d.ts.map +1 -0
  130. package/dist/src/cloud/relay/stats/index.js.map +1 -0
  131. package/dist/src/cloud/relay/sync/index.d.ts.map +1 -0
  132. package/dist/src/cloud/relay/sync/index.js.map +1 -0
  133. package/dist/src/cloud/relay/usage/index.d.ts.map +1 -0
  134. package/dist/src/cloud/relay/usage/index.js.map +1 -0
  135. package/dist/src/cloud/sponsors.d.ts.map +1 -0
  136. package/dist/src/cloud/sponsors.js.map +1 -0
  137. package/dist/src/cloud/types.d.ts.map +1 -0
  138. package/dist/src/cloud/types.js.map +1 -0
  139. package/dist/src/components/index.d.ts.map +1 -0
  140. package/dist/src/components/index.js.map +1 -0
  141. package/dist/src/core/actors.d.ts.map +1 -0
  142. package/dist/src/core/actors.js.map +1 -0
  143. package/dist/src/core/component/generator.d.ts.map +1 -0
  144. package/dist/{core → src/core}/component/generator.js +45 -3
  145. package/dist/src/core/component/generator.js.map +1 -0
  146. package/dist/src/core/engine.d.ts.map +1 -0
  147. package/dist/src/core/engine.js.map +1 -0
  148. package/dist/src/core/introspection.d.ts.map +1 -0
  149. package/dist/src/core/introspection.js.map +1 -0
  150. package/dist/src/core/logic/generator.d.ts.map +1 -0
  151. package/dist/{core → src/core}/logic/generator.js +35 -4
  152. package/dist/src/core/logic/generator.js.map +1 -0
  153. package/dist/src/core/pluresdb/adapter.d.ts +72 -0
  154. package/dist/src/core/pluresdb/adapter.d.ts.map +1 -0
  155. package/dist/src/core/pluresdb/adapter.js +73 -0
  156. package/dist/src/core/pluresdb/adapter.js.map +1 -0
  157. package/dist/src/core/pluresdb/generator.d.ts.map +1 -0
  158. package/dist/{core → src/core}/pluresdb/generator.js +33 -4
  159. package/dist/src/core/pluresdb/generator.js.map +1 -0
  160. package/dist/src/core/pluresdb/index.d.ts +15 -0
  161. package/dist/src/core/pluresdb/index.d.ts.map +1 -0
  162. package/dist/src/core/pluresdb/index.js +11 -0
  163. package/dist/src/core/pluresdb/index.js.map +1 -0
  164. package/dist/src/core/pluresdb/schema-registry.d.ts +104 -0
  165. package/dist/src/core/pluresdb/schema-registry.d.ts.map +1 -0
  166. package/dist/src/core/pluresdb/schema-registry.js +130 -0
  167. package/dist/src/core/pluresdb/schema-registry.js.map +1 -0
  168. package/dist/src/core/pluresdb/store.d.ts +199 -0
  169. package/dist/src/core/pluresdb/store.d.ts.map +1 -0
  170. package/dist/src/core/pluresdb/store.js +344 -0
  171. package/dist/src/core/pluresdb/store.js.map +1 -0
  172. package/dist/src/core/protocol.d.ts.map +1 -0
  173. package/dist/src/core/protocol.js.map +1 -0
  174. package/dist/src/core/rules.d.ts.map +1 -0
  175. package/dist/src/core/rules.js.map +1 -0
  176. package/dist/src/core/schema/loader.d.ts.map +1 -0
  177. package/dist/src/core/schema/loader.js.map +1 -0
  178. package/dist/src/core/schema/normalize.d.ts.map +1 -0
  179. package/dist/src/core/schema/normalize.js.map +1 -0
  180. package/dist/src/core/schema/types.d.ts.map +1 -0
  181. package/dist/src/core/schema/types.js.map +1 -0
  182. package/dist/src/dsl/index.d.ts.map +1 -0
  183. package/dist/src/dsl/index.js.map +1 -0
  184. package/dist/src/dsl.d.ts.map +1 -0
  185. package/dist/src/dsl.js.map +1 -0
  186. package/dist/src/examples/advanced-todo/index.d.ts.map +1 -0
  187. package/dist/src/examples/advanced-todo/index.js.map +1 -0
  188. package/dist/src/examples/auth-basic/index.d.ts.map +1 -0
  189. package/dist/src/examples/auth-basic/index.js.map +1 -0
  190. package/dist/src/examples/cart/index.d.ts.map +1 -0
  191. package/dist/src/examples/cart/index.js.map +1 -0
  192. package/dist/src/examples/hero-ecommerce/index.d.ts.map +1 -0
  193. package/dist/src/examples/hero-ecommerce/index.js.map +1 -0
  194. package/dist/src/examples/svelte-counter/index.d.ts.map +1 -0
  195. package/dist/src/examples/svelte-counter/index.js.map +1 -0
  196. package/dist/src/flows.d.ts.map +1 -0
  197. package/dist/src/flows.js.map +1 -0
  198. package/dist/{index.d.ts → src/index.d.ts} +12 -2
  199. package/dist/src/index.d.ts.map +1 -0
  200. package/dist/{index.js → src/index.js} +6 -1
  201. package/dist/src/index.js.map +1 -0
  202. package/dist/src/integrations/code-canvas.d.ts +265 -0
  203. package/dist/src/integrations/code-canvas.d.ts.map +1 -0
  204. package/dist/src/integrations/code-canvas.js +451 -0
  205. package/dist/src/integrations/code-canvas.js.map +1 -0
  206. package/dist/src/integrations/pluresdb.d.ts +117 -0
  207. package/dist/src/integrations/pluresdb.d.ts.map +1 -0
  208. package/dist/src/integrations/pluresdb.js +117 -0
  209. package/dist/src/integrations/pluresdb.js.map +1 -0
  210. package/dist/src/integrations/state-docs.d.ts +191 -0
  211. package/dist/src/integrations/state-docs.d.ts.map +1 -0
  212. package/dist/src/integrations/state-docs.js +515 -0
  213. package/dist/src/integrations/state-docs.js.map +1 -0
  214. package/dist/src/integrations/svelte.d.ts.map +1 -0
  215. package/dist/src/integrations/svelte.js.map +1 -0
  216. package/dist/src/integrations/tauri.d.ts +360 -0
  217. package/dist/src/integrations/tauri.d.ts.map +1 -0
  218. package/dist/src/integrations/tauri.js +278 -0
  219. package/dist/src/integrations/tauri.js.map +1 -0
  220. package/dist/src/integrations/unum.d.ts +159 -0
  221. package/dist/src/integrations/unum.d.ts.map +1 -0
  222. package/dist/src/integrations/unum.js +240 -0
  223. package/dist/src/integrations/unum.js.map +1 -0
  224. package/dist/src/registry.d.ts.map +1 -0
  225. package/dist/src/registry.js.map +1 -0
  226. package/dist/{runtime → src/runtime}/terminal-adapter.d.ts +58 -7
  227. package/dist/src/runtime/terminal-adapter.d.ts.map +1 -0
  228. package/dist/src/runtime/terminal-adapter.js +239 -0
  229. package/dist/src/runtime/terminal-adapter.js.map +1 -0
  230. package/dist/src/step.d.ts.map +1 -0
  231. package/dist/src/step.js.map +1 -0
  232. package/dist/src/types.d.ts.map +1 -0
  233. package/dist/{cloud → src}/types.js.map +1 -1
  234. package/dist/tools/cli/commands/index.d.ts +7 -0
  235. package/dist/tools/cli/commands/index.d.ts.map +1 -0
  236. package/dist/tools/cli/commands/index.js +7 -0
  237. package/dist/tools/cli/commands/index.js.map +1 -0
  238. package/dist/tools/cli/index.d.ts +8 -0
  239. package/dist/tools/cli/index.d.ts.map +1 -0
  240. package/dist/tools/cli/index.js +9 -0
  241. package/dist/tools/cli/index.js.map +1 -0
  242. package/dist/tools/watcher/index.d.ts +105 -0
  243. package/dist/tools/watcher/index.d.ts.map +1 -0
  244. package/dist/tools/watcher/index.js +213 -0
  245. package/dist/tools/watcher/index.js.map +1 -0
  246. package/dist/ui/canvas/canvas-projection.d.ts +78 -0
  247. package/dist/ui/canvas/canvas-projection.d.ts.map +1 -0
  248. package/dist/ui/canvas/canvas-projection.js +416 -0
  249. package/dist/ui/canvas/canvas-projection.js.map +1 -0
  250. package/dist/ui/canvas/canvas-state.d.ts +200 -0
  251. package/dist/ui/canvas/canvas-state.d.ts.map +1 -0
  252. package/dist/ui/canvas/canvas-state.js +464 -0
  253. package/dist/ui/canvas/canvas-state.js.map +1 -0
  254. package/dist/ui/canvas/components/index.d.ts +95 -0
  255. package/dist/ui/canvas/components/index.d.ts.map +1 -0
  256. package/dist/ui/canvas/components/index.js +19 -0
  257. package/dist/ui/canvas/components/index.js.map +1 -0
  258. package/dist/ui/canvas/index.d.ts +32 -0
  259. package/dist/ui/canvas/index.d.ts.map +1 -0
  260. package/dist/ui/canvas/index.js +32 -0
  261. package/dist/ui/canvas/index.js.map +1 -0
  262. package/dist/ui/svelte-generator/index.d.ts +9 -0
  263. package/dist/ui/svelte-generator/index.d.ts.map +1 -0
  264. package/dist/ui/svelte-generator/index.js +11 -0
  265. package/dist/ui/svelte-generator/index.js.map +1 -0
  266. package/dist/ui/svelte-generator/psf-generator.d.ts +128 -0
  267. package/dist/ui/svelte-generator/psf-generator.d.ts.map +1 -0
  268. package/dist/ui/svelte-generator/psf-generator.js +506 -0
  269. package/dist/ui/svelte-generator/psf-generator.js.map +1 -0
  270. package/docs/README.md +155 -0
  271. package/docs/core/building-extensions.md +553 -0
  272. package/docs/core/cli-usage.md +498 -0
  273. package/docs/core/code-canvas-sync.md +468 -0
  274. package/docs/core/logic-engine.md +566 -0
  275. package/docs/core/pluresdb-integration.md +646 -0
  276. package/docs/core/schema-model.md +414 -0
  277. package/docs/core/ui-generation.md +580 -0
  278. package/docs/core/what-is-praxis.md +240 -0
  279. package/docs/tutorials/README.md +84 -0
  280. package/docs/tutorials/ecommerce-cart.md +631 -0
  281. package/docs/tutorials/first-app.md +529 -0
  282. package/docs/tutorials/form-builder.md +620 -0
  283. package/docs/tutorials/todo-pluresdb.md +589 -0
  284. package/package.json +16 -16
  285. package/src/__tests__/canvas-components.test.ts +450 -0
  286. package/src/__tests__/cli-create.test.ts +178 -0
  287. package/src/__tests__/code-canvas-integration.test.ts +277 -0
  288. package/src/__tests__/docs-generator.test.ts +181 -0
  289. package/src/__tests__/generators.test.ts +3 -2
  290. package/src/__tests__/pluresdb.test.ts +457 -0
  291. package/src/__tests__/psf-schema-engine.test.ts +450 -0
  292. package/src/__tests__/state-docs-integration.test.ts +297 -0
  293. package/src/__tests__/tauri-integration.test.ts +298 -0
  294. package/src/__tests__/terminal-node.test.ts +1 -1
  295. package/src/__tests__/unum-integration.test.ts +142 -0
  296. package/src/cli/commands/build.ts +203 -0
  297. package/src/cli/commands/canvas.ts +246 -0
  298. package/src/cli/commands/create.ts +666 -0
  299. package/src/cli/commands/dev.ts +95 -0
  300. package/src/cli/commands/orchestrate.ts +212 -0
  301. package/src/cli/index.ts +48 -21
  302. package/src/core/component/generator.ts +45 -3
  303. package/src/core/logic/generator.ts +39 -4
  304. package/src/core/pluresdb/adapter.ts +117 -0
  305. package/src/core/pluresdb/generator.ts +33 -4
  306. package/src/core/pluresdb/index.ts +37 -0
  307. package/src/core/pluresdb/schema-registry.ts +162 -0
  308. package/src/core/pluresdb/store.ts +446 -0
  309. package/src/index.ts +109 -0
  310. package/src/integrations/code-canvas.ts +717 -0
  311. package/src/integrations/pluresdb.ts +140 -29
  312. package/src/integrations/state-docs.ts +710 -0
  313. package/src/integrations/tauri.ts +638 -0
  314. package/src/integrations/unum.ts +395 -0
  315. package/src/runtime/terminal-adapter.ts +184 -23
  316. package/dist/adapters/cli.d.ts.map +0 -1
  317. package/dist/adapters/cli.js.map +0 -1
  318. package/dist/cli/commands/auth.d.ts.map +0 -1
  319. package/dist/cli/commands/auth.js.map +0 -1
  320. package/dist/cli/commands/cloud.d.ts.map +0 -1
  321. package/dist/cli/commands/cloud.js.map +0 -1
  322. package/dist/cli/commands/generate.d.ts.map +0 -1
  323. package/dist/cli/commands/generate.js.map +0 -1
  324. package/dist/cli/index.js.map +0 -1
  325. package/dist/cloud/auth.d.ts.map +0 -1
  326. package/dist/cloud/auth.js.map +0 -1
  327. package/dist/cloud/billing.d.ts.map +0 -1
  328. package/dist/cloud/billing.js.map +0 -1
  329. package/dist/cloud/client.d.ts.map +0 -1
  330. package/dist/cloud/client.js.map +0 -1
  331. package/dist/cloud/index.d.ts.map +0 -1
  332. package/dist/cloud/index.js.map +0 -1
  333. package/dist/cloud/marketplace.d.ts.map +0 -1
  334. package/dist/cloud/marketplace.js.map +0 -1
  335. package/dist/cloud/provisioning.d.ts.map +0 -1
  336. package/dist/cloud/provisioning.js.map +0 -1
  337. package/dist/cloud/relay/endpoints.d.ts.map +0 -1
  338. package/dist/cloud/relay/endpoints.js.map +0 -1
  339. package/dist/cloud/relay/health/index.d.ts.map +0 -1
  340. package/dist/cloud/relay/health/index.js.map +0 -1
  341. package/dist/cloud/relay/stats/index.d.ts.map +0 -1
  342. package/dist/cloud/relay/stats/index.js.map +0 -1
  343. package/dist/cloud/relay/sync/index.d.ts.map +0 -1
  344. package/dist/cloud/relay/sync/index.js.map +0 -1
  345. package/dist/cloud/relay/usage/index.d.ts.map +0 -1
  346. package/dist/cloud/relay/usage/index.js.map +0 -1
  347. package/dist/cloud/sponsors.d.ts.map +0 -1
  348. package/dist/cloud/sponsors.js.map +0 -1
  349. package/dist/cloud/types.d.ts.map +0 -1
  350. package/dist/components/index.d.ts.map +0 -1
  351. package/dist/components/index.js.map +0 -1
  352. package/dist/core/actors.d.ts.map +0 -1
  353. package/dist/core/actors.js.map +0 -1
  354. package/dist/core/component/generator.d.ts.map +0 -1
  355. package/dist/core/component/generator.js.map +0 -1
  356. package/dist/core/engine.d.ts.map +0 -1
  357. package/dist/core/engine.js.map +0 -1
  358. package/dist/core/introspection.d.ts.map +0 -1
  359. package/dist/core/introspection.js.map +0 -1
  360. package/dist/core/logic/generator.d.ts.map +0 -1
  361. package/dist/core/logic/generator.js.map +0 -1
  362. package/dist/core/pluresdb/generator.d.ts.map +0 -1
  363. package/dist/core/pluresdb/generator.js.map +0 -1
  364. package/dist/core/protocol.d.ts.map +0 -1
  365. package/dist/core/protocol.js.map +0 -1
  366. package/dist/core/rules.d.ts.map +0 -1
  367. package/dist/core/rules.js.map +0 -1
  368. package/dist/core/schema/loader.d.ts.map +0 -1
  369. package/dist/core/schema/loader.js.map +0 -1
  370. package/dist/core/schema/normalize.d.ts.map +0 -1
  371. package/dist/core/schema/normalize.js.map +0 -1
  372. package/dist/core/schema/types.d.ts.map +0 -1
  373. package/dist/core/schema/types.js.map +0 -1
  374. package/dist/dsl/index.d.ts.map +0 -1
  375. package/dist/dsl/index.js.map +0 -1
  376. package/dist/dsl.d.ts.map +0 -1
  377. package/dist/dsl.js.map +0 -1
  378. package/dist/examples/advanced-todo/index.d.ts.map +0 -1
  379. package/dist/examples/advanced-todo/index.js.map +0 -1
  380. package/dist/examples/auth-basic/index.d.ts.map +0 -1
  381. package/dist/examples/auth-basic/index.js.map +0 -1
  382. package/dist/examples/cart/index.d.ts.map +0 -1
  383. package/dist/examples/cart/index.js.map +0 -1
  384. package/dist/examples/hero-ecommerce/index.d.ts.map +0 -1
  385. package/dist/examples/hero-ecommerce/index.js.map +0 -1
  386. package/dist/examples/svelte-counter/index.d.ts.map +0 -1
  387. package/dist/examples/svelte-counter/index.js.map +0 -1
  388. package/dist/flows.d.ts.map +0 -1
  389. package/dist/flows.js.map +0 -1
  390. package/dist/index.d.ts.map +0 -1
  391. package/dist/index.js.map +0 -1
  392. package/dist/integrations/pluresdb.d.ts +0 -56
  393. package/dist/integrations/pluresdb.d.ts.map +0 -1
  394. package/dist/integrations/pluresdb.js +0 -46
  395. package/dist/integrations/pluresdb.js.map +0 -1
  396. package/dist/integrations/svelte.d.ts.map +0 -1
  397. package/dist/integrations/svelte.js.map +0 -1
  398. package/dist/registry.d.ts.map +0 -1
  399. package/dist/registry.js.map +0 -1
  400. package/dist/runtime/terminal-adapter.d.ts.map +0 -1
  401. package/dist/runtime/terminal-adapter.js +0 -113
  402. package/dist/runtime/terminal-adapter.js.map +0 -1
  403. package/dist/step.d.ts.map +0 -1
  404. package/dist/step.js.map +0 -1
  405. package/dist/types.d.ts.map +0 -1
  406. package/dist/types.js.map +0 -1
  407. /package/dist/{adapters → src/adapters}/cli.d.ts +0 -0
  408. /package/dist/{adapters → src/adapters}/cli.js +0 -0
  409. /package/dist/{cli → src/cli}/commands/auth.d.ts +0 -0
  410. /package/dist/{cli → src/cli}/commands/auth.js +0 -0
  411. /package/dist/{cli → src/cli}/commands/cloud.d.ts +0 -0
  412. /package/dist/{cli → src/cli}/commands/cloud.js +0 -0
  413. /package/dist/{cli → src/cli}/commands/generate.d.ts +0 -0
  414. /package/dist/{cli → src/cli}/commands/generate.js +0 -0
  415. /package/dist/{cli → src/cli}/index.d.ts +0 -0
  416. /package/dist/{cloud → src/cloud}/auth.d.ts +0 -0
  417. /package/dist/{cloud → src/cloud}/auth.js +0 -0
  418. /package/dist/{cloud → src/cloud}/billing.d.ts +0 -0
  419. /package/dist/{cloud → src/cloud}/billing.js +0 -0
  420. /package/dist/{cloud → src/cloud}/client.d.ts +0 -0
  421. /package/dist/{cloud → src/cloud}/client.js +0 -0
  422. /package/dist/{cloud → src/cloud}/index.d.ts +0 -0
  423. /package/dist/{cloud → src/cloud}/index.js +0 -0
  424. /package/dist/{cloud → src/cloud}/marketplace.d.ts +0 -0
  425. /package/dist/{cloud → src/cloud}/marketplace.js +0 -0
  426. /package/dist/{cloud → src/cloud}/provisioning.d.ts +0 -0
  427. /package/dist/{cloud → src/cloud}/provisioning.js +0 -0
  428. /package/dist/{cloud → src/cloud}/relay/endpoints.d.ts +0 -0
  429. /package/dist/{cloud → src/cloud}/relay/endpoints.js +0 -0
  430. /package/dist/{cloud → src/cloud}/relay/health/index.d.ts +0 -0
  431. /package/dist/{cloud → src/cloud}/relay/health/index.js +0 -0
  432. /package/dist/{cloud → src/cloud}/relay/stats/index.d.ts +0 -0
  433. /package/dist/{cloud → src/cloud}/relay/stats/index.js +0 -0
  434. /package/dist/{cloud → src/cloud}/relay/sync/index.d.ts +0 -0
  435. /package/dist/{cloud → src/cloud}/relay/sync/index.js +0 -0
  436. /package/dist/{cloud → src/cloud}/relay/usage/index.d.ts +0 -0
  437. /package/dist/{cloud → src/cloud}/relay/usage/index.js +0 -0
  438. /package/dist/{cloud → src/cloud}/sponsors.d.ts +0 -0
  439. /package/dist/{cloud → src/cloud}/sponsors.js +0 -0
  440. /package/dist/{cloud → src/cloud}/types.d.ts +0 -0
  441. /package/dist/{cloud → src/cloud}/types.js +0 -0
  442. /package/dist/{components → src/components}/index.d.ts +0 -0
  443. /package/dist/{components → src/components}/index.js +0 -0
  444. /package/dist/{core → src/core}/actors.d.ts +0 -0
  445. /package/dist/{core → src/core}/actors.js +0 -0
  446. /package/dist/{core → src/core}/component/generator.d.ts +0 -0
  447. /package/dist/{core → src/core}/engine.d.ts +0 -0
  448. /package/dist/{core → src/core}/engine.js +0 -0
  449. /package/dist/{core → src/core}/introspection.d.ts +0 -0
  450. /package/dist/{core → src/core}/introspection.js +0 -0
  451. /package/dist/{core → src/core}/logic/generator.d.ts +0 -0
  452. /package/dist/{core → src/core}/pluresdb/generator.d.ts +0 -0
  453. /package/dist/{core → src/core}/protocol.d.ts +0 -0
  454. /package/dist/{core → src/core}/protocol.js +0 -0
  455. /package/dist/{core → src/core}/rules.d.ts +0 -0
  456. /package/dist/{core → src/core}/rules.js +0 -0
  457. /package/dist/{core → src/core}/schema/loader.d.ts +0 -0
  458. /package/dist/{core → src/core}/schema/loader.js +0 -0
  459. /package/dist/{core → src/core}/schema/normalize.d.ts +0 -0
  460. /package/dist/{core → src/core}/schema/normalize.js +0 -0
  461. /package/dist/{core → src/core}/schema/types.d.ts +0 -0
  462. /package/dist/{core → src/core}/schema/types.js +0 -0
  463. /package/dist/{dsl → src/dsl}/index.d.ts +0 -0
  464. /package/dist/{dsl → src/dsl}/index.js +0 -0
  465. /package/dist/{dsl.d.ts → src/dsl.d.ts} +0 -0
  466. /package/dist/{dsl.js → src/dsl.js} +0 -0
  467. /package/dist/{examples → src/examples}/advanced-todo/index.d.ts +0 -0
  468. /package/dist/{examples → src/examples}/advanced-todo/index.js +0 -0
  469. /package/dist/{examples → src/examples}/auth-basic/index.d.ts +0 -0
  470. /package/dist/{examples → src/examples}/auth-basic/index.js +0 -0
  471. /package/dist/{examples → src/examples}/cart/index.d.ts +0 -0
  472. /package/dist/{examples → src/examples}/cart/index.js +0 -0
  473. /package/dist/{examples → src/examples}/hero-ecommerce/index.d.ts +0 -0
  474. /package/dist/{examples → src/examples}/hero-ecommerce/index.js +0 -0
  475. /package/dist/{examples → src/examples}/svelte-counter/index.d.ts +0 -0
  476. /package/dist/{examples → src/examples}/svelte-counter/index.js +0 -0
  477. /package/dist/{flows.d.ts → src/flows.d.ts} +0 -0
  478. /package/dist/{flows.js → src/flows.js} +0 -0
  479. /package/dist/{integrations → src/integrations}/svelte.d.ts +0 -0
  480. /package/dist/{integrations → src/integrations}/svelte.js +0 -0
  481. /package/dist/{registry.d.ts → src/registry.d.ts} +0 -0
  482. /package/dist/{registry.js → src/registry.js} +0 -0
  483. /package/dist/{step.d.ts → src/step.d.ts} +0 -0
  484. /package/dist/{step.js → src/step.js} +0 -0
  485. /package/dist/{types.d.ts → src/types.d.ts} +0 -0
  486. /package/dist/{types.js → src/types.js} +0 -0
@@ -0,0 +1,297 @@
1
+ /**
2
+ * State-Docs Integration Tests
3
+ */
4
+
5
+ import { describe, it, expect } from "vitest";
6
+ import {
7
+ createStateDocsGenerator,
8
+ generateDocs,
9
+ StateDocsGenerator,
10
+ } from "../integrations/state-docs.js";
11
+ import type { PraxisSchema } from "../core/schema/types.js";
12
+
13
+ describe("State-Docs Integration", () => {
14
+ const testSchema: PraxisSchema = {
15
+ version: "1.0.0",
16
+ name: "TestProject",
17
+ description: "A test project for documentation generation",
18
+ models: [
19
+ {
20
+ name: "User",
21
+ description: "User model",
22
+ fields: [
23
+ { name: "id", type: "string", description: "User ID" },
24
+ { name: "name", type: "string", description: "User name" },
25
+ { name: "email", type: "string", description: "Email address", optional: true },
26
+ ],
27
+ },
28
+ {
29
+ name: "Post",
30
+ description: "Blog post model",
31
+ fields: [
32
+ { name: "id", type: "string" },
33
+ { name: "title", type: "string" },
34
+ { name: "content", type: "string" },
35
+ { name: "authorId", type: "string" },
36
+ ],
37
+ },
38
+ ],
39
+ components: [
40
+ {
41
+ name: "UserProfile",
42
+ type: "display",
43
+ description: "User profile display component",
44
+ model: "User",
45
+ },
46
+ {
47
+ name: "PostEditor",
48
+ type: "form",
49
+ description: "Post editing form",
50
+ model: "Post",
51
+ },
52
+ ],
53
+ logic: [
54
+ {
55
+ id: "auth-logic",
56
+ description: "Authentication logic module",
57
+ events: [
58
+ { tag: "Login", payload: { username: "string", password: "string" }, description: "User login event" },
59
+ { tag: "Logout", payload: { userId: "string" }, description: "User logout event" },
60
+ ],
61
+ facts: [
62
+ { tag: "UserLoggedIn", payload: { userId: "string", timestamp: "number" }, description: "User is logged in" },
63
+ ],
64
+ rules: [
65
+ { id: "process-login", description: "Process login request", then: "validateCredentials()" },
66
+ ],
67
+ constraints: [
68
+ { id: "valid-session", description: "Session must be valid", check: "session.isValid()", message: "Invalid session" },
69
+ ],
70
+ },
71
+ ],
72
+ };
73
+
74
+ describe("createStateDocsGenerator", () => {
75
+ it("should create a generator with default config", () => {
76
+ const generator = createStateDocsGenerator({
77
+ projectTitle: "Test Project",
78
+ });
79
+
80
+ expect(generator).toBeInstanceOf(StateDocsGenerator);
81
+ });
82
+
83
+ it("should create a generator with custom config", () => {
84
+ const generator = createStateDocsGenerator({
85
+ projectTitle: "Test Project",
86
+ target: "./custom-docs",
87
+ visualization: {
88
+ format: "mermaid",
89
+ theme: "dark",
90
+ },
91
+ template: {
92
+ toc: true,
93
+ timestamp: false,
94
+ },
95
+ });
96
+
97
+ expect(generator).toBeInstanceOf(StateDocsGenerator);
98
+ });
99
+ });
100
+
101
+ describe("generateFromSchema", () => {
102
+ it("should generate documentation from schema", () => {
103
+ const generator = createStateDocsGenerator({
104
+ projectTitle: "Test Project",
105
+ });
106
+
107
+ const docs = generator.generateFromSchema(testSchema);
108
+
109
+ expect(docs).toBeDefined();
110
+ expect(docs.length).toBeGreaterThan(0);
111
+ });
112
+
113
+ it("should generate README", () => {
114
+ const generator = createStateDocsGenerator({
115
+ projectTitle: "Test Project",
116
+ });
117
+
118
+ const docs = generator.generateFromSchema(testSchema);
119
+ const readme = docs.find(d => d.path.endsWith("README.md"));
120
+
121
+ expect(readme).toBeDefined();
122
+ expect(readme?.type).toBe("markdown");
123
+ expect(readme?.content).toContain("TestProject");
124
+ });
125
+
126
+ it("should generate models documentation", () => {
127
+ const generator = createStateDocsGenerator({
128
+ projectTitle: "Test Project",
129
+ });
130
+
131
+ const docs = generator.generateFromSchema(testSchema);
132
+ const modelsDocs = docs.find(d => d.path.endsWith("models.md"));
133
+
134
+ expect(modelsDocs).toBeDefined();
135
+ expect(modelsDocs?.content).toContain("User");
136
+ expect(modelsDocs?.content).toContain("Post");
137
+ });
138
+
139
+ it("should generate components documentation", () => {
140
+ const generator = createStateDocsGenerator({
141
+ projectTitle: "Test Project",
142
+ });
143
+
144
+ const docs = generator.generateFromSchema(testSchema);
145
+ const componentsDocs = docs.find(d => d.path.endsWith("components.md"));
146
+
147
+ expect(componentsDocs).toBeDefined();
148
+ expect(componentsDocs?.content).toContain("UserProfile");
149
+ expect(componentsDocs?.content).toContain("PostEditor");
150
+ });
151
+
152
+ it("should generate logic documentation", () => {
153
+ const generator = createStateDocsGenerator({
154
+ projectTitle: "Test Project",
155
+ });
156
+
157
+ const docs = generator.generateFromSchema(testSchema);
158
+ const logicDocs = docs.find(d => d.path.includes("auth-logic.md"));
159
+
160
+ expect(logicDocs).toBeDefined();
161
+ expect(logicDocs?.content).toContain("Login");
162
+ expect(logicDocs?.content).toContain("Logout");
163
+ });
164
+
165
+ it("should generate Mermaid diagrams", () => {
166
+ const generator = createStateDocsGenerator({
167
+ projectTitle: "Test Project",
168
+ });
169
+
170
+ const docs = generator.generateFromSchema(testSchema);
171
+ const mermaidDocs = docs.filter(d => d.type === "mermaid");
172
+
173
+ expect(mermaidDocs.length).toBeGreaterThan(0);
174
+ expect(mermaidDocs[0].content).toContain("stateDiagram-v2");
175
+ });
176
+
177
+ it("should include table of contents when enabled", () => {
178
+ const generator = createStateDocsGenerator({
179
+ projectTitle: "Test Project",
180
+ template: { toc: true },
181
+ });
182
+
183
+ const docs = generator.generateFromSchema(testSchema);
184
+ const readme = docs.find(d => d.path.endsWith("README.md"));
185
+
186
+ expect(readme?.content).toContain("Table of Contents");
187
+ });
188
+
189
+ it("should include timestamp when enabled", () => {
190
+ const generator = createStateDocsGenerator({
191
+ projectTitle: "Test Project",
192
+ template: { timestamp: true },
193
+ });
194
+
195
+ const docs = generator.generateFromSchema(testSchema);
196
+ const readme = docs.find(d => d.path.endsWith("README.md"));
197
+
198
+ expect(readme?.content).toContain("Generated on");
199
+ });
200
+
201
+ it("should include statistics", () => {
202
+ const generator = createStateDocsGenerator({
203
+ projectTitle: "Test Project",
204
+ });
205
+
206
+ const docs = generator.generateFromSchema(testSchema);
207
+ const readme = docs.find(d => d.path.endsWith("README.md"));
208
+
209
+ expect(readme?.content).toContain("Statistics");
210
+ expect(readme?.content).toContain("Models");
211
+ expect(readme?.content).toContain("Components");
212
+ });
213
+ });
214
+
215
+ describe("generateDocs (convenience function)", () => {
216
+ it("should generate docs directly from schema", () => {
217
+ const docs = generateDocs(testSchema, {
218
+ projectTitle: "Quick Project",
219
+ });
220
+
221
+ expect(docs).toBeDefined();
222
+ expect(docs.length).toBeGreaterThan(0);
223
+ });
224
+ });
225
+
226
+ describe("generateFromModule", () => {
227
+ it("should generate documentation from a Praxis module", () => {
228
+ const generator = createStateDocsGenerator({
229
+ projectTitle: "Test Project",
230
+ });
231
+
232
+ const docs = generator.generateFromModule({
233
+ rules: [
234
+ {
235
+ id: "test-rule",
236
+ description: "A test rule",
237
+ impl: () => [],
238
+ },
239
+ ],
240
+ constraints: [
241
+ {
242
+ id: "test-constraint",
243
+ description: "A test constraint",
244
+ impl: () => true,
245
+ },
246
+ ],
247
+ });
248
+
249
+ expect(docs.length).toBe(3); // rules.md, constraints.md, state-diagram.mmd
250
+ });
251
+
252
+ it("should generate rules documentation from module", () => {
253
+ const generator = createStateDocsGenerator({
254
+ projectTitle: "Test Project",
255
+ });
256
+
257
+ const docs = generator.generateFromModule({
258
+ rules: [
259
+ {
260
+ id: "auth.login",
261
+ description: "Process user login",
262
+ impl: () => [],
263
+ },
264
+ ],
265
+ constraints: [],
266
+ });
267
+
268
+ const rulesDocs = docs.find(d => d.path.endsWith("rules.md"));
269
+ expect(rulesDocs).toBeDefined();
270
+ expect(rulesDocs?.content).toContain("auth.login");
271
+ expect(rulesDocs?.content).toContain("Process user login");
272
+ });
273
+
274
+ it("should generate constraints documentation from module", () => {
275
+ const generator = createStateDocsGenerator({
276
+ projectTitle: "Test Project",
277
+ });
278
+
279
+ const docs = generator.generateFromModule({
280
+ rules: [],
281
+ constraints: [
282
+ {
283
+ id: "user.valid",
284
+ description: "User must be valid",
285
+ impl: () => true,
286
+ meta: { errorMessage: "User is invalid" },
287
+ },
288
+ ],
289
+ });
290
+
291
+ const constraintsDocs = docs.find(d => d.path.endsWith("constraints.md"));
292
+ expect(constraintsDocs).toBeDefined();
293
+ expect(constraintsDocs?.content).toContain("user.valid");
294
+ expect(constraintsDocs?.content).toContain("User must be valid");
295
+ });
296
+ });
297
+ });
@@ -0,0 +1,298 @@
1
+ /**
2
+ * Tauri Integration Tests
3
+ */
4
+
5
+ import { describe, it, expect, beforeEach } from "vitest";
6
+ import {
7
+ createMockTauriBridge,
8
+ createTauriPraxisAdapter,
9
+ attachTauriToEngine,
10
+ generateTauriConfig,
11
+ } from "../integrations/tauri.js";
12
+ import { createPraxisEngine, PraxisRegistry } from "../index.js";
13
+
14
+ describe("Tauri Integration", () => {
15
+ describe("createMockTauriBridge", () => {
16
+ it("should create a mock bridge", () => {
17
+ const bridge = createMockTauriBridge();
18
+
19
+ expect(bridge).toBeDefined();
20
+ expect(bridge.app.name).toBe("Mock App");
21
+ expect(bridge.app.tauriVersion).toBe("mock");
22
+ });
23
+
24
+ it("should provide file system operations", async () => {
25
+ const bridge = createMockTauriBridge();
26
+
27
+ // Write and read text file
28
+ await bridge.fs.writeTextFile("/test.txt", "Hello, World!");
29
+ const content = await bridge.fs.readTextFile("/test.txt");
30
+
31
+ expect(content).toBe("Hello, World!");
32
+ });
33
+
34
+ it("should check file existence", async () => {
35
+ const bridge = createMockTauriBridge();
36
+
37
+ await bridge.fs.writeTextFile("/exists.txt", "content");
38
+
39
+ expect(await bridge.fs.exists("/exists.txt")).toBe(true);
40
+ expect(await bridge.fs.exists("/not-exists.txt")).toBe(false);
41
+ });
42
+
43
+ it("should remove files", async () => {
44
+ const bridge = createMockTauriBridge();
45
+
46
+ await bridge.fs.writeTextFile("/to-remove.txt", "content");
47
+ expect(await bridge.fs.exists("/to-remove.txt")).toBe(true);
48
+
49
+ await bridge.fs.remove("/to-remove.txt");
50
+ expect(await bridge.fs.exists("/to-remove.txt")).toBe(false);
51
+ });
52
+
53
+ it("should rename files", async () => {
54
+ const bridge = createMockTauriBridge();
55
+
56
+ await bridge.fs.writeTextFile("/old.txt", "content");
57
+ await bridge.fs.rename("/old.txt", "/new.txt");
58
+
59
+ expect(await bridge.fs.exists("/old.txt")).toBe(false);
60
+ expect(await bridge.fs.exists("/new.txt")).toBe(true);
61
+ expect(await bridge.fs.readTextFile("/new.txt")).toBe("content");
62
+ });
63
+
64
+ it("should handle binary files", async () => {
65
+ const bridge = createMockTauriBridge();
66
+ const data = new Uint8Array([1, 2, 3, 4, 5]);
67
+
68
+ await bridge.fs.writeFile("/binary.bin", data);
69
+ const read = await bridge.fs.readFile("/binary.bin");
70
+
71
+ expect(read).toEqual(data);
72
+ });
73
+
74
+ it("should invoke commands", async () => {
75
+ const bridge = createMockTauriBridge();
76
+ const result = await bridge.invoke("test-command", { arg: "value" });
77
+
78
+ expect(result).toBeNull(); // Mock returns null
79
+ });
80
+
81
+ it("should emit and listen to events", async () => {
82
+ const bridge = createMockTauriBridge();
83
+
84
+ const received: unknown[] = [];
85
+ await bridge.listen("test-event", (event) => {
86
+ received.push(event.payload);
87
+ });
88
+
89
+ await bridge.emit("test-event", { data: "test" });
90
+
91
+ expect(received.length).toBe(1);
92
+ expect(received[0]).toEqual({ data: "test" });
93
+ });
94
+
95
+ it("should provide notification API", async () => {
96
+ const bridge = createMockTauriBridge();
97
+
98
+ const permission = await bridge.notification.checkPermission();
99
+ expect(permission).toBe("granted");
100
+
101
+ // Should not throw
102
+ await bridge.notification.send({ title: "Test", body: "Body" });
103
+ });
104
+
105
+ it("should check for updates", async () => {
106
+ const bridge = createMockTauriBridge();
107
+
108
+ const update = await bridge.checkForUpdates();
109
+ expect(update).toBeNull(); // Mock returns null
110
+ });
111
+ });
112
+
113
+ describe("createTauriPraxisAdapter", () => {
114
+ it("should create an adapter", () => {
115
+ const bridge = createMockTauriBridge();
116
+ const adapter = createTauriPraxisAdapter({ bridge });
117
+
118
+ expect(adapter).toBeDefined();
119
+ expect(adapter.getStatePath()).toBe("praxis-state.json");
120
+ expect(adapter.getEventsPath()).toBe("praxis-events.json");
121
+ });
122
+
123
+ it("should use custom paths", () => {
124
+ const bridge = createMockTauriBridge();
125
+ const adapter = createTauriPraxisAdapter({
126
+ bridge,
127
+ statePath: "custom-state.json",
128
+ eventsPath: "custom-events.json",
129
+ });
130
+
131
+ expect(adapter.getStatePath()).toBe("custom-state.json");
132
+ expect(adapter.getEventsPath()).toBe("custom-events.json");
133
+ });
134
+
135
+ it("should save and load state", async () => {
136
+ const bridge = createMockTauriBridge();
137
+ const adapter = createTauriPraxisAdapter<{ count: number }>({ bridge });
138
+
139
+ await adapter.saveState({ count: 42 });
140
+ const loaded = await adapter.loadState();
141
+
142
+ expect(loaded).toEqual({ count: 42 });
143
+ });
144
+
145
+ it("should return null for missing state", async () => {
146
+ const bridge = createMockTauriBridge();
147
+ const adapter = createTauriPraxisAdapter<{ count: number }>({ bridge });
148
+
149
+ const loaded = await adapter.loadState();
150
+ expect(loaded).toBeNull();
151
+ });
152
+
153
+ it("should save and load events", async () => {
154
+ const bridge = createMockTauriBridge();
155
+ const adapter = createTauriPraxisAdapter({ bridge });
156
+
157
+ const events = [
158
+ { tag: "Event1", payload: { id: "1" } },
159
+ { tag: "Event2", payload: { id: "2" } },
160
+ ];
161
+
162
+ await adapter.saveEvents(events);
163
+ const loaded = await adapter.loadEvents();
164
+
165
+ expect(loaded).toEqual(events);
166
+ });
167
+
168
+ it("should return empty array for missing events", async () => {
169
+ const bridge = createMockTauriBridge();
170
+ const adapter = createTauriPraxisAdapter({ bridge });
171
+
172
+ const loaded = await adapter.loadEvents();
173
+ expect(loaded).toEqual([]);
174
+ });
175
+
176
+ it("should provide watch function", async () => {
177
+ const bridge = createMockTauriBridge();
178
+ const adapter = createTauriPraxisAdapter<{ count: number }>({ bridge });
179
+
180
+ const cleanup = await adapter.watchStateFile(() => {});
181
+ expect(cleanup).toBeInstanceOf(Function);
182
+ cleanup();
183
+ });
184
+ });
185
+
186
+ describe("attachTauriToEngine", () => {
187
+ it("should attach adapter to engine", () => {
188
+ const bridge = createMockTauriBridge();
189
+ const adapter = createTauriPraxisAdapter({ bridge });
190
+ const registry = new PraxisRegistry();
191
+ const engine = createPraxisEngine({
192
+ initialContext: { count: 0 },
193
+ registry,
194
+ });
195
+
196
+ const cleanup = attachTauriToEngine(engine, adapter, {
197
+ autoSave: true,
198
+ saveInterval: 1000,
199
+ });
200
+
201
+ expect(cleanup).toBeInstanceOf(Function);
202
+ cleanup();
203
+ });
204
+
205
+ it("should work without auto-save", () => {
206
+ const bridge = createMockTauriBridge();
207
+ const adapter = createTauriPraxisAdapter({ bridge });
208
+ const registry = new PraxisRegistry();
209
+ const engine = createPraxisEngine({
210
+ initialContext: {},
211
+ registry,
212
+ });
213
+
214
+ const cleanup = attachTauriToEngine(engine, adapter, {
215
+ autoSave: false,
216
+ });
217
+
218
+ expect(cleanup).toBeInstanceOf(Function);
219
+ cleanup();
220
+ });
221
+ });
222
+
223
+ describe("generateTauriConfig", () => {
224
+ it("should generate basic config", () => {
225
+ const config = generateTauriConfig({
226
+ name: "My App",
227
+ version: "1.0.0",
228
+ identifier: "com.example.myapp",
229
+ });
230
+
231
+ expect(config.productName).toBe("My App");
232
+ expect(config.version).toBe("1.0.0");
233
+ expect(config.identifier).toBe("com.example.myapp");
234
+ });
235
+
236
+ it("should include window config", () => {
237
+ const config = generateTauriConfig({
238
+ name: "My App",
239
+ version: "1.0.0",
240
+ identifier: "com.example.myapp",
241
+ window: {
242
+ title: "My Window",
243
+ width: 1024,
244
+ height: 768,
245
+ resizable: true,
246
+ center: true,
247
+ },
248
+ });
249
+
250
+ const app = config.app as { windows: Array<{ title: string; width: number; height: number }> };
251
+ expect(app.windows[0].title).toBe("My Window");
252
+ expect(app.windows[0].width).toBe(1024);
253
+ expect(app.windows[0].height).toBe(768);
254
+ });
255
+
256
+ it("should include security config", () => {
257
+ const config = generateTauriConfig({
258
+ name: "My App",
259
+ version: "1.0.0",
260
+ identifier: "com.example.myapp",
261
+ security: {
262
+ csp: "default-src 'self'; script-src 'self'",
263
+ devTools: true,
264
+ },
265
+ });
266
+
267
+ const app = config.app as { security: { csp: string; devtools: boolean } };
268
+ expect(app.security.csp).toBe("default-src 'self'; script-src 'self'");
269
+ expect(app.security.devtools).toBe(true);
270
+ });
271
+
272
+ it("should include plugins", () => {
273
+ const config = generateTauriConfig({
274
+ name: "My App",
275
+ version: "1.0.0",
276
+ identifier: "com.example.myapp",
277
+ plugins: [
278
+ { name: "shell", config: { open: true } },
279
+ { name: "fs", config: { scope: ["$APP/*"] } },
280
+ ],
281
+ });
282
+
283
+ const plugins = config.plugins as Record<string, unknown>;
284
+ expect(plugins.shell).toEqual({ open: true });
285
+ expect(plugins.fs).toEqual({ scope: ["$APP/*"] });
286
+ });
287
+
288
+ it("should have $schema", () => {
289
+ const config = generateTauriConfig({
290
+ name: "My App",
291
+ version: "1.0.0",
292
+ identifier: "com.example.myapp",
293
+ });
294
+
295
+ expect(config.$schema).toContain("tauri-config-schema");
296
+ });
297
+ });
298
+ });
@@ -290,7 +290,7 @@ orchestration:
290
290
 
291
291
  expect(result).toBeDefined();
292
292
  expect(result.command).toBe('echo hello');
293
- expect(result.output).toContain('echo hello');
293
+ expect(result.output).toContain('hello');
294
294
  expect(result.exitCode).toBe(0);
295
295
  expect(result.timestamp).toBeGreaterThan(0);
296
296