testeranto 0.189.0 → 0.197.0

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 (632) hide show
  1. package/ALL_LICENSES.txt +11246 -0
  2. package/LICENSE +21 -0
  3. package/default-project.json +44 -0
  4. package/design-editor/DesignEditor.tsx +247 -0
  5. package/design-editor/index.ts +2 -0
  6. package/design-editor/server.ts +121 -0
  7. package/design-editor/types.ts +16 -0
  8. package/designs/default-project.json +210 -0
  9. package/dist/common/design-editor/DesignEditor.js +239 -0
  10. package/dist/common/design-editor/index.js +18 -0
  11. package/dist/common/design-editor/server.js +98 -0
  12. package/dist/common/design-editor/types.js +2 -0
  13. package/dist/common/src/App.js +11 -1
  14. package/dist/common/src/PM/PM_WithEslintAndTsc.js +8 -1
  15. package/dist/common/src/PM/base.js +1 -0
  16. package/dist/common/src/PM/main.js +370 -4
  17. package/dist/common/src/PM/node.js +4 -2
  18. package/dist/common/src/PM/pure.js +15 -57
  19. package/dist/common/src/PM/web.js +5 -3
  20. package/dist/common/src/Pure.test.js +46 -78
  21. package/dist/common/src/ReportServer.js +8 -2
  22. package/dist/common/src/build.js +1 -1
  23. package/dist/common/src/components/DesignEditorPage.js +169 -0
  24. package/dist/common/src/components/pure/AppFrame.js +62 -13
  25. package/dist/common/src/components/pure/ModalContent.test/implementation.js +13 -11
  26. package/dist/common/src/components/pure/ModalContent.test/index.js +48 -2
  27. package/dist/common/src/components/pure/ModalContent.test/specification.js +2 -2
  28. package/dist/common/src/components/pure/NavBar.js +9 -10
  29. package/dist/common/src/components/pure/ProcessManager.js +112 -0
  30. package/dist/common/src/components/pure/ProcessManagerView.js +237 -0
  31. package/dist/common/src/components/pure/ProjectPageView.test/implementation.js +134 -106
  32. package/dist/common/src/components/pure/ProjectsPageView.js +18 -12
  33. package/dist/common/src/components/pure/SettingsButton.js +4 -74
  34. package/dist/common/src/components/pure/SingleProcessView.js +214 -0
  35. package/dist/common/src/components/pure/TestPageView.js +457 -78
  36. package/dist/common/src/components/pure/TestPageView.test/implementation.js +90 -135
  37. package/dist/common/src/components/stateful/FeaturesReporter.js +1 -1
  38. package/dist/common/src/components/stateful/FileTree.js +40 -0
  39. package/dist/common/src/components/stateful/ProcessManagerPage.js +112 -0
  40. package/dist/common/src/components/stateful/ProjectPage.js +6 -5
  41. package/dist/common/src/components/stateful/ProjectsPage.js +32 -6
  42. package/dist/common/src/components/stateful/SettingsPage.js +72 -0
  43. package/dist/common/src/components/stateful/SingleProcessPage.js +147 -0
  44. package/dist/common/src/components/stateful/TestPage.js +104 -8
  45. package/dist/common/src/components/stateful/TextEditorPage.js +154 -0
  46. package/dist/common/src/esbuildConfigs/inputFilesPlugin.js +3 -4
  47. package/dist/common/src/lib/BaseSuite.js +6 -3
  48. package/dist/common/src/lib/BaseSuite.test/mock.js +17 -30
  49. package/dist/common/src/lib/BaseSuite.test/test.js +33 -31
  50. package/dist/common/src/lib/abstractBase.js +28 -8
  51. package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.adapter.js +12 -6
  52. package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.implementation.js +12 -12
  53. package/dist/common/src/lib/basebuilder.js +1 -9
  54. package/dist/common/src/lib/classBuilder.js +3 -3
  55. package/dist/common/src/lib/core.js +3 -5
  56. package/dist/common/src/lib/index.js +11 -14
  57. package/dist/common/src/lib/pmProxy.js +37 -14
  58. package/dist/common/src/lib/pmProxy.test/adapter.js +12 -2
  59. package/dist/common/src/lib/pmProxy.test/implementation.js +73 -43
  60. package/dist/common/src/lib/pmProxy.test/specification.js +3 -0
  61. package/dist/common/src/utils/api.js +44 -33
  62. package/dist/common/src/utils/logFiles.js +48 -22
  63. package/dist/common/src/utils/makePrompt.js +5 -4
  64. package/dist/common/testeranto.config.js +15 -13
  65. package/dist/common/tsconfig.common.tsbuildinfo +1 -1
  66. package/dist/module/design-editor/DesignEditor.js +203 -0
  67. package/dist/module/design-editor/index.js +2 -0
  68. package/dist/module/design-editor/server.js +92 -0
  69. package/dist/module/src/App.js +11 -1
  70. package/dist/module/src/PM/PM_WithEslintAndTsc.js +8 -1
  71. package/dist/module/src/PM/base.js +1 -0
  72. package/dist/module/src/PM/main.js +370 -4
  73. package/dist/module/src/PM/node.js +4 -2
  74. package/dist/module/src/PM/pure.js +15 -57
  75. package/dist/module/src/PM/web.js +5 -3
  76. package/dist/module/src/Pure.test.js +46 -78
  77. package/dist/module/src/ReportServer.js +8 -2
  78. package/dist/module/src/build.js +1 -1
  79. package/dist/module/src/components/DesignEditorPage.js +132 -0
  80. package/dist/module/src/components/pure/AppFrame.js +30 -11
  81. package/dist/module/src/components/pure/ModalContent.test/implementation.js +13 -11
  82. package/dist/module/src/components/pure/ModalContent.test/index.js +48 -2
  83. package/dist/module/src/components/pure/ModalContent.test/specification.js +2 -2
  84. package/dist/module/src/components/pure/NavBar.js +10 -11
  85. package/dist/module/src/components/pure/ProcessManager.js +75 -0
  86. package/dist/module/src/components/pure/ProcessManagerView.js +200 -0
  87. package/dist/module/src/components/pure/ProjectPageView.test/implementation.js +134 -106
  88. package/dist/module/src/components/pure/ProjectsPageView.js +20 -14
  89. package/dist/module/src/components/pure/SettingsButton.js +5 -42
  90. package/dist/module/src/components/pure/SingleProcessView.js +214 -0
  91. package/dist/module/src/components/pure/TestPageView.js +425 -76
  92. package/dist/module/src/components/pure/TestPageView.test/implementation.js +90 -135
  93. package/dist/module/src/components/stateful/FeaturesReporter.js +1 -1
  94. package/dist/module/src/components/stateful/FileTree.js +33 -0
  95. package/dist/module/src/components/stateful/ProcessManagerPage.js +75 -0
  96. package/dist/module/src/components/stateful/ProjectPage.js +6 -5
  97. package/dist/module/src/components/stateful/ProjectsPage.js +32 -6
  98. package/dist/module/src/components/stateful/SettingsPage.js +35 -0
  99. package/dist/module/src/components/stateful/SingleProcessPage.js +110 -0
  100. package/dist/module/src/components/stateful/TestPage.js +104 -8
  101. package/dist/module/src/components/stateful/TextEditorPage.js +117 -0
  102. package/dist/module/src/esbuildConfigs/inputFilesPlugin.js +3 -4
  103. package/dist/module/src/lib/BaseSuite.js +6 -3
  104. package/dist/module/src/lib/BaseSuite.test/mock.js +17 -30
  105. package/dist/module/src/lib/BaseSuite.test/test.js +33 -31
  106. package/dist/module/src/lib/abstractBase.js +28 -8
  107. package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.adapter.js +12 -6
  108. package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.implementation.js +12 -12
  109. package/dist/module/src/lib/basebuilder.js +1 -9
  110. package/dist/module/src/lib/classBuilder.js +3 -3
  111. package/dist/module/src/lib/core.js +3 -5
  112. package/dist/module/src/lib/index.js +11 -14
  113. package/dist/module/src/lib/pmProxy.js +37 -14
  114. package/dist/module/src/lib/pmProxy.test/adapter.js +12 -2
  115. package/dist/module/src/lib/pmProxy.test/implementation.js +73 -43
  116. package/dist/module/src/lib/pmProxy.test/specification.js +3 -0
  117. package/dist/module/src/utils/api.js +45 -34
  118. package/dist/module/src/utils/logFiles.js +45 -20
  119. package/dist/module/src/utils/makePrompt.js +5 -4
  120. package/dist/module/testeranto.config.js +15 -13
  121. package/dist/module/tsconfig.module.tsbuildinfo +1 -1
  122. package/dist/prebuild/App.css +54 -513
  123. package/dist/prebuild/App.js +13296 -2438
  124. package/dist/prebuild/ReportServer.mjs +104 -6
  125. package/dist/prebuild/build.mjs +8 -5
  126. package/dist/prebuild/run.mjs +389 -37
  127. package/dist/types/design-editor/DesignEditor.d.ts +18 -0
  128. package/dist/types/design-editor/server.d.ts +1 -0
  129. package/dist/types/{PM → src/PM}/index.d.ts +1 -1
  130. package/dist/types/{PM → src/PM}/main.d.ts +19 -0
  131. package/dist/types/{PM → src/PM}/pure.d.ts +7 -7
  132. package/dist/types/{Pure.test.d.ts → src/Pure.test.d.ts} +13 -1
  133. package/dist/types/src/components/DesignEditorPage.d.ts +1 -0
  134. package/dist/types/{components → src/components}/pure/AppFrame.d.ts +3 -1
  135. package/dist/types/{components/pure/ProjectPageView.test → src/components/pure/ModalContent.test}/index.d.ts +2 -1
  136. package/dist/types/{components → src/components}/pure/NavBar.d.ts +4 -0
  137. package/dist/types/src/components/pure/ProcessManager.d.ts +8 -0
  138. package/dist/types/src/components/pure/ProcessManagerView.d.ts +20 -0
  139. package/dist/types/{components → src/components}/pure/ProjectsPageView.d.ts +1 -1
  140. package/dist/types/src/components/pure/SettingsButton.d.ts +2 -0
  141. package/dist/types/{components → src/components}/pure/TestPageView.test/implementation.d.ts +3 -2
  142. package/dist/types/src/components/pure/TestPageView.test/index.d.ts +3 -0
  143. package/dist/types/src/components/stateful/FileTree.d.ts +8 -0
  144. package/dist/types/src/components/stateful/ProcessManagerPage.d.ts +2 -0
  145. package/dist/types/src/components/stateful/SettingsPage.d.ts +2 -0
  146. package/dist/types/src/components/stateful/SingleProcessPage.d.ts +2 -0
  147. package/dist/types/src/components/stateful/TextEditorPage.d.ts +1 -0
  148. package/dist/types/{lib → src/lib}/BaseSuite.test/mock.d.ts +3 -3
  149. package/dist/types/{lib → src/lib}/basebuilder.d.ts +1 -1
  150. package/dist/types/{lib → src/lib}/index.d.ts +1 -1
  151. package/dist/types/{lib → src/lib}/pmProxy.test/mockPMBase.d.ts +1 -1
  152. package/dist/types/src/run.d.ts +1 -0
  153. package/dist/types/src/utils/logFiles.d.ts +71 -0
  154. package/dist/types/tsconfig.types.tsbuildinfo +1 -1
  155. package/docs/test-page-components.md +91 -0
  156. package/package.json +27 -8
  157. package/src/App.tsx +11 -0
  158. package/src/PM/PM_WithEslintAndTsc.ts +9 -4
  159. package/src/PM/base.ts +1 -0
  160. package/src/PM/index.ts +1 -1
  161. package/src/PM/main.ts +424 -8
  162. package/src/PM/node.ts +5 -2
  163. package/src/PM/pure.ts +23 -61
  164. package/src/PM/web.ts +7 -3
  165. package/src/Pure.test.ts +63 -99
  166. package/src/README.md +20 -1
  167. package/src/ReportServer.ts +10 -3
  168. package/src/app.scss +169 -0
  169. package/src/build.ts +5 -1
  170. package/src/components/DesignEditorPage.tsx +169 -0
  171. package/src/components/pure/AppFrame.tsx +121 -16
  172. package/src/components/pure/ModalContent.test/implementation.tsx +14 -12
  173. package/src/components/pure/ModalContent.test/index.tsx +58 -6
  174. package/src/components/pure/ModalContent.test/specification.ts +2 -2
  175. package/src/components/pure/NavBar.tsx +31 -15
  176. package/src/components/pure/ProcessManager.tsx +117 -0
  177. package/src/components/pure/ProcessManagerView.tsx +414 -0
  178. package/src/components/pure/ProjectPageView.test/implementation.tsx +136 -106
  179. package/src/components/pure/ProjectPageView.test/index.tsx +0 -2
  180. package/src/components/pure/ProjectsPageView.tsx +41 -31
  181. package/src/components/pure/SettingsButton.tsx +7 -62
  182. package/src/components/pure/SingleProcessView.tsx +235 -0
  183. package/src/components/pure/TestPageView.test/implementation.ts +115 -147
  184. package/src/components/pure/TestPageView.test/specification.ts +0 -1
  185. package/src/components/pure/TestPageView.tsx +821 -100
  186. package/src/components/stateful/FeaturesReporter.tsx +1 -1
  187. package/src/components/stateful/FileTree.tsx +66 -0
  188. package/src/components/stateful/ProcessManagerPage.tsx +108 -0
  189. package/src/components/stateful/ProjectPage.tsx +6 -5
  190. package/src/components/stateful/ProjectsPage.tsx +36 -7
  191. package/src/components/stateful/SettingsPage.tsx +82 -0
  192. package/src/components/stateful/SingleProcessPage.tsx +155 -0
  193. package/src/components/stateful/TestPage.tsx +128 -20
  194. package/src/components/stateful/TextEditorPage.tsx +170 -0
  195. package/src/esbuildConfigs/inputFilesPlugin.ts +3 -4
  196. package/src/lib/BaseSuite.test/mock.ts +20 -41
  197. package/src/lib/BaseSuite.test/test.ts +38 -42
  198. package/src/lib/BaseSuite.ts +6 -3
  199. package/src/lib/abstractBase.ts +33 -14
  200. package/src/lib/baseBuilder.test/baseBuilder.test.adapter.ts +14 -7
  201. package/src/lib/baseBuilder.test/baseBuilder.test.implementation.ts +15 -14
  202. package/src/lib/basebuilder.ts +4 -9
  203. package/src/lib/classBuilder.ts +8 -10
  204. package/src/lib/core.ts +3 -19
  205. package/src/lib/index.ts +19 -19
  206. package/src/lib/pmProxy.test/adapter.ts +10 -2
  207. package/src/lib/pmProxy.test/implementation.ts +108 -57
  208. package/src/lib/pmProxy.test/mockPMBase.ts +1 -1
  209. package/src/lib/pmProxy.test/specification.ts +11 -0
  210. package/src/lib/pmProxy.ts +40 -15
  211. package/src/style.scss +3 -502
  212. package/src/templates/frontpage.html +317 -40
  213. package/src/templates/frontpage.md +79 -0
  214. package/src/themes.scss +40 -8
  215. package/src/utils/api.ts +47 -44
  216. package/src/utils/logFiles.ts +57 -23
  217. package/src/utils/makePrompt.ts +5 -4
  218. package/stargazers.txt +15 -0
  219. package/stargzers.js +68 -0
  220. package/testeranto/App.css +54 -513
  221. package/testeranto/App.js +13296 -2438
  222. package/testeranto/bundles/node/core/{chunk-L67RWZ4W.mjs → chunk-4CSH4UJE.mjs} +89 -116
  223. package/testeranto/bundles/node/core/{chunk-JBB5E3XJ.mjs → chunk-4JTDLQVA.mjs} +4 -9
  224. package/testeranto/bundles/node/core/chunk-C3APFDUV.mjs +70 -0
  225. package/testeranto/bundles/node/core/src/lib/BaseSuite.test/node.test.mjs +30 -42
  226. package/testeranto/bundles/node/core/src/lib/baseBuilder.test/baseBuilder.test.node.mjs +27 -31
  227. package/testeranto/bundles/node/core/src/lib/classBuilder.test/classBuilder.test.mjs +4 -16
  228. package/testeranto/bundles/node/core/src/lib/core.test/core.test.mjs +16 -27
  229. package/testeranto/bundles/node/core/src/lib/pmProxy.test/index.mjs +468 -517
  230. package/testeranto/bundles/pure/core/{chunk-KHJ35R7C.mjs → chunk-62UVCSQC.mjs} +97 -72
  231. package/testeranto/bundles/pure/core/src/Pure.test.mjs +56 -74
  232. package/testeranto/bundles/pure/core/src/lib/BaseSuite.test/pure.test.mjs +39 -66
  233. package/testeranto/bundles/pure/core/src/lib/baseBuilder.test/baseBuilder.test.pure.mjs +25 -19
  234. package/testeranto/metafiles/node/core.json +2906 -0
  235. package/testeranto/{bundles/pure/core/metafile.json → metafiles/pure/core.json} +66 -81
  236. package/testeranto/metafiles/web/core.json +546 -0
  237. package/testeranto/reports/core/config.json +0 -24
  238. package/testeranto/reports/core/src/Pure.test/pure/prompt.txt +1 -1
  239. package/testeranto/reports/core/src/Pure.test/pure/type_errors.txt +59 -94
  240. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/error.log +2 -55
  241. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/info.log +0 -2
  242. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/error.log +3 -33
  243. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/info.log +0 -4
  244. package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/error.log +3 -0
  245. package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/info.log +0 -2
  246. package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/prompt.txt +2 -2
  247. package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/type_errors.txt +38 -90
  248. package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/prompt.txt +1 -1
  249. package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/type_errors.txt +38 -90
  250. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/error.log +2 -0
  251. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/lint_errors.txt +10 -0
  252. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/prompt.txt +3 -3
  253. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/stdout.log +6 -2
  254. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/tests.json +4 -4
  255. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/type_errors.txt +22 -45
  256. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/lint_errors.txt +10 -0
  257. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/prompt.txt +1 -1
  258. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/type_errors.txt +22 -45
  259. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/error.log +2 -0
  260. package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/prompt.txt +4 -4
  261. package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/tests.json +10 -10
  262. package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/type_errors.txt +38 -90
  263. package/testeranto/reports/core/src/lib/core.test/core.test/node/prompt.txt +4 -4
  264. package/testeranto/reports/core/src/lib/core.test/core.test/node/type_errors.txt +5 -24
  265. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/lint_errors.txt +6 -14
  266. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/prompt.txt +3 -3
  267. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/stderr.log +88 -0
  268. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/stdout.log +10 -0
  269. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/tests.json +33 -43
  270. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/type_errors.txt +17 -43
  271. package/testeranto/reports/core/summary.json +15 -51
  272. package/testeranto/reportsweb_build_errors +546 -0
  273. package/testeranto.config.ts +16 -13
  274. package/tsc.log +37 -16
  275. package/tsconfig.json +3 -2
  276. package/CNAME +0 -1
  277. package/README.html +0 -302
  278. package/dist/common/src/PM/layers/base/PM_Base.js +0 -1
  279. package/dist/common/src/PM/layers/base/components/PageOperations.js +0 -1
  280. package/dist/common/src/PM/layers/base/components/PageOperations.testeranto.js +0 -1
  281. package/dist/common/src/PM/layers/linting/components/Linter.js +0 -1
  282. package/dist/common/src/PM/layers/linting/components/TypeChecker.js +0 -1
  283. package/dist/common/src/PM/layers/main/components/SidecarManager.js +0 -1
  284. package/dist/common/src/PM/layers/main/components/TestRunner.js +0 -1
  285. package/dist/module/src/PM/layers/base/PM_Base.js +0 -1
  286. package/dist/module/src/PM/layers/base/components/PageOperations.js +0 -1
  287. package/dist/module/src/PM/layers/base/components/PageOperations.testeranto.js +0 -1
  288. package/dist/module/src/PM/layers/linting/components/Linter.js +0 -1
  289. package/dist/module/src/PM/layers/linting/components/TypeChecker.js +0 -1
  290. package/dist/module/src/PM/layers/main/components/SidecarManager.js +0 -1
  291. package/dist/module/src/PM/layers/main/components/TestRunner.js +0 -1
  292. package/dist/tsconfig.tsbuildinfo +0 -1
  293. package/dist/types/PM/layers/base/components/PageOperations.d.ts +0 -0
  294. package/dist/types/PM/layers/base/components/PageOperations.testeranto.d.ts +0 -0
  295. package/dist/types/PM/layers/linting/components/Linter.d.ts +0 -0
  296. package/dist/types/PM/layers/linting/components/TypeChecker.d.ts +0 -0
  297. package/dist/types/PM/layers/main/components/SidecarManager.d.ts +0 -0
  298. package/dist/types/PM/layers/main/components/TestRunner.d.ts +0 -0
  299. package/dist/types/components/pure/SettingsButton.d.ts +0 -3
  300. package/dist/types/components/pure/TestPageView.test/index.d.ts +0 -32
  301. package/dist/types/utils/logFiles.d.ts +0 -7
  302. package/docs.html +0 -590
  303. package/example.css +0 -351
  304. package/index.html +0 -138
  305. package/scripts/compile-docs.js +0 -150
  306. package/smil30/SMIL-anim.mod.xsd +0 -163
  307. package/smil30/SMIL-control.mod.xsd +0 -73
  308. package/smil30/SMIL-layout.mod.xsd +0 -149
  309. package/smil30/SMIL-link.mod.xsd +0 -145
  310. package/smil30/SMIL-media.mod.xsd +0 -1646
  311. package/smil30/SMIL-metainformation.mod.xsd +0 -45
  312. package/smil30/SMIL-smiltext.mod.xsd +0 -353
  313. package/smil30/SMIL-state.mod.xsd +0 -133
  314. package/smil30/SMIL-struct.mod.xsd +0 -70
  315. package/smil30/SMIL-timing.mod.xsd +0 -105
  316. package/smil30/SMIL-transition.mod.xsd +0 -229
  317. package/smil30/SMIL.xsd +0 -63
  318. package/smil30/its.xsd +0 -42
  319. package/smil30/smil-attribs-1.mod.xsd +0 -610
  320. package/smil30/smil-datatypes-1.mod.xsd +0 -72
  321. package/smil30/smil-framework-1.mod.xsd +0 -45
  322. package/smil30/xml.xsd +0 -16
  323. package/src/App.scss +0 -123
  324. package/src/PM/layers/base/PM_Base.ts +0 -0
  325. package/src/PM/layers/base/components/PageOperations.testeranto.ts +0 -0
  326. package/src/PM/layers/base/components/PageOperations.ts +0 -0
  327. package/src/PM/layers/linting/components/Linter.ts +0 -0
  328. package/src/PM/layers/linting/components/TypeChecker.ts +0 -0
  329. package/src/PM/layers/main/components/SidecarManager.ts +0 -0
  330. package/src/PM/layers/main/components/TestRunner.ts +0 -0
  331. package/src/fonts.scss +0 -55
  332. package/style.css +0 -12175
  333. package/testeranto/bundles/node/core/chunk-ZQRRQYS4.mjs +0 -92
  334. package/testeranto/bundles/node/core/metafile.json +0 -5735
  335. package/testeranto/bundles/node/core/src/mothership/test.mjs +0 -24588
  336. package/testeranto/bundles/web/core/MPLUSRounded1c-Black-O75GP5JI.ttf +0 -0
  337. package/testeranto/bundles/web/core/MPLUSRounded1c-Bold-R524Q5BH.ttf +0 -0
  338. package/testeranto/bundles/web/core/MPLUSRounded1c-ExtraBold-C6GRMYVT.ttf +0 -0
  339. package/testeranto/bundles/web/core/MPLUSRounded1c-Light-WKN65Y2C.ttf +0 -0
  340. package/testeranto/bundles/web/core/MPLUSRounded1c-Medium-ZC4DWL7C.ttf +0 -0
  341. package/testeranto/bundles/web/core/MPLUSRounded1c-Regular-DT6EKZ3S.ttf +0 -0
  342. package/testeranto/bundles/web/core/MPLUSRounded1c-Thin-YWDNVG6M.ttf +0 -0
  343. package/testeranto/bundles/web/core/chunk-BADF3AZF.mjs +0 -108
  344. package/testeranto/bundles/web/core/chunk-BXV27S2S.mjs +0 -6252
  345. package/testeranto/bundles/web/core/chunk-EIYZKF2C.mjs +0 -223
  346. package/testeranto/bundles/web/core/chunk-FNXFUNA7.mjs +0 -28528
  347. package/testeranto/bundles/web/core/chunk-LU364HVS.mjs +0 -3311
  348. package/testeranto/bundles/web/core/chunk-QWII7WIM.mjs +0 -2281
  349. package/testeranto/bundles/web/core/chunk-VAYOSMXI.mjs +0 -21775
  350. package/testeranto/bundles/web/core/metafile.json +0 -18227
  351. package/testeranto/bundles/web/core/src/components/pure/AppFrame.test/index.css +0 -12105
  352. package/testeranto/bundles/web/core/src/components/pure/AppFrame.test/index.html +0 -15
  353. package/testeranto/bundles/web/core/src/components/pure/AppFrame.test/index.mjs +0 -517
  354. package/testeranto/bundles/web/core/src/components/pure/FeaturesReporterView.test/index.mjs +0 -166
  355. package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.css +0 -12105
  356. package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.html +0 -15
  357. package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.mjs +0 -93
  358. package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.css +0 -12105
  359. package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.mjs +0 -343
  360. package/testeranto/bundles/web/core/src/components/pure/TestPageView.test/index.css +0 -12105
  361. package/testeranto/bundles/web/core/src/components/pure/TestPageView.test/index.mjs +0 -483
  362. package/testeranto/bundles/web/core/src/lib/BaseSuite.test/web.test.mjs +0 -394
  363. package/testeranto/bundles/web/core/src/lib/baseBuilder.test/baseBuilder.test.web.mjs +0 -256
  364. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/debug.log +0 -0
  365. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/error.log +0 -22
  366. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/exit.log +0 -1
  367. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/info.log +0 -4
  368. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/lint_errors.txt +0 -2
  369. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/message.txt +0 -17
  370. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/prompt.txt +0 -18
  371. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/tests.json +0 -57
  372. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/type_errors.txt +0 -55
  373. package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/warn.log +0 -0
  374. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/lint_errors.txt +0 -0
  375. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/message.txt +0 -17
  376. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/prompt.txt +0 -16
  377. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/suite-0/given-basicRender/then-4/butThen/features-reporter.png +0 -0
  378. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/tests.json +0 -76
  379. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/type_errors.txt +0 -80
  380. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/debug.log +0 -0
  381. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/error.log +0 -0
  382. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/exit.log +0 -0
  383. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/info.log +0 -4
  384. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/lint_errors.txt +0 -0
  385. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/message.txt +0 -17
  386. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/prompt.txt +0 -15
  387. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/suite-0/given-basicRender/then-2/butThen/modal-content.png +0 -0
  388. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/tests.json +0 -42
  389. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/type_errors.txt +0 -65
  390. package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/warn.log +0 -0
  391. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/lint_errors.txt +0 -2
  392. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/message.txt +0 -17
  393. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/prompt.txt +0 -16
  394. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/suite-0/given-basicRender/then-6/butThen/happy-state.png +0 -0
  395. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/suite-0/given-errorHandling/then-1/butThen/error-state.png +0 -0
  396. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/tests.json +0 -99
  397. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/type_errors.txt +0 -91
  398. package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/lint_errors.txt +0 -0
  399. package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/message.txt +0 -17
  400. package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/prompt.txt +0 -18
  401. package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/tests.json +0 -69
  402. package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/type_errors.txt +0 -111
  403. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/lint_errors.txt +0 -0
  404. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/message.txt +0 -17
  405. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/prompt.txt +0 -15
  406. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/tests.json +0 -31
  407. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/type_errors.txt +0 -113
  408. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/lint_errors.txt +0 -0
  409. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/message.txt +0 -17
  410. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/prompt.txt +0 -17
  411. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/suite-0/given-testInitialization/then-0/butThen/hello.txt +0 -1
  412. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/suite-0/given-testInitialization/then-1/butThen/artifact_test.txt +0 -1
  413. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/tests.json +0 -71
  414. package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/type_errors.txt +0 -65
  415. package/testeranto/reports/core/src/mothership/test/node/exit.log +0 -1
  416. package/testeranto/reports/core/src/mothership/test/node/lint_errors.txt +0 -0
  417. package/testeranto/reports/core/src/mothership/test/node/message.txt +0 -17
  418. package/testeranto/reports/core/src/mothership/test/node/prompt.txt +0 -14
  419. package/testeranto/reports/core/src/mothership/test/node/stderr.log +0 -27
  420. package/testeranto/reports/core/src/mothership/test/node/stdout.log +0 -8
  421. package/testeranto/reports/core/src/mothership/test/node/tests.json +0 -36
  422. package/testeranto/reports/core/src/mothership/test/node/type_errors.txt +0 -38
  423. package/videos/download-smil-xsd.sh +0 -29
  424. package/videos/project0/index.md +0 -72
  425. package/videos/project0/narration.json +0 -7
  426. package/videos/project0/narration.ssml +0 -58
  427. package/videos/project0/package.json +0 -21
  428. package/videos/project0/presentation.smil +0 -25
  429. package/videos/project0/smil30/SMIL-anim.mod.xsd +0 -163
  430. package/videos/project0/smil30/SMIL-anim.mod.xsd.1 +0 -163
  431. package/videos/project0/smil30/SMIL-anim.mod.xsd.2 +0 -163
  432. package/videos/project0/smil30/SMIL-control.mod.xsd +0 -73
  433. package/videos/project0/smil30/SMIL-control.mod.xsd.1 +0 -73
  434. package/videos/project0/smil30/SMIL-control.mod.xsd.2 +0 -73
  435. package/videos/project0/smil30/SMIL-layout.mod.xsd +0 -149
  436. package/videos/project0/smil30/SMIL-layout.mod.xsd.1 +0 -149
  437. package/videos/project0/smil30/SMIL-layout.mod.xsd.2 +0 -149
  438. package/videos/project0/smil30/SMIL-link.mod.xsd +0 -145
  439. package/videos/project0/smil30/SMIL-link.mod.xsd.1 +0 -145
  440. package/videos/project0/smil30/SMIL-link.mod.xsd.2 +0 -145
  441. package/videos/project0/smil30/SMIL-media.mod.xsd +0 -1646
  442. package/videos/project0/smil30/SMIL-media.mod.xsd.1 +0 -1646
  443. package/videos/project0/smil30/SMIL-media.mod.xsd.2 +0 -1646
  444. package/videos/project0/smil30/SMIL-metainformation.mod.xsd +0 -45
  445. package/videos/project0/smil30/SMIL-metainformation.mod.xsd.1 +0 -45
  446. package/videos/project0/smil30/SMIL-metainformation.mod.xsd.2 +0 -45
  447. package/videos/project0/smil30/SMIL-smiltext.mod.xsd +0 -353
  448. package/videos/project0/smil30/SMIL-smiltext.mod.xsd.1 +0 -353
  449. package/videos/project0/smil30/SMIL-smiltext.mod.xsd.2 +0 -353
  450. package/videos/project0/smil30/SMIL-state.mod.xsd +0 -133
  451. package/videos/project0/smil30/SMIL-state.mod.xsd.1 +0 -133
  452. package/videos/project0/smil30/SMIL-state.mod.xsd.2 +0 -133
  453. package/videos/project0/smil30/SMIL-struct.mod.xsd +0 -70
  454. package/videos/project0/smil30/SMIL-struct.mod.xsd.1 +0 -70
  455. package/videos/project0/smil30/SMIL-struct.mod.xsd.2 +0 -70
  456. package/videos/project0/smil30/SMIL-timing.mod.xsd +0 -105
  457. package/videos/project0/smil30/SMIL-timing.mod.xsd.1 +0 -105
  458. package/videos/project0/smil30/SMIL-timing.mod.xsd.2 +0 -105
  459. package/videos/project0/smil30/SMIL-transition.mod.xsd +0 -229
  460. package/videos/project0/smil30/SMIL-transition.mod.xsd.1 +0 -229
  461. package/videos/project0/smil30/SMIL-transition.mod.xsd.2 +0 -229
  462. package/videos/project0/smil30/SMIL.xsd +0 -63
  463. package/videos/project0/smil30/SMIL.xsd.1 +0 -63
  464. package/videos/project0/smil30/SMIL.xsd.2 +0 -63
  465. package/videos/project0/smil30/its.xsd +0 -42
  466. package/videos/project0/smil30/its.xsd.1 +0 -42
  467. package/videos/project0/smil30/its.xsd.2 +0 -42
  468. package/videos/project0/smil30/smil-attribs-1.mod.xsd +0 -610
  469. package/videos/project0/smil30/smil-attribs-1.mod.xsd.1 +0 -610
  470. package/videos/project0/smil30/smil-attribs-1.mod.xsd.2 +0 -610
  471. package/videos/project0/smil30/smil-datatypes-1.mod.xsd +0 -72
  472. package/videos/project0/smil30/smil-datatypes-1.mod.xsd.1 +0 -72
  473. package/videos/project0/smil30/smil-datatypes-1.mod.xsd.2 +0 -72
  474. package/videos/project0/smil30/smil-framework-1.mod.xsd +0 -45
  475. package/videos/project0/smil30/smil-framework-1.mod.xsd.1 +0 -45
  476. package/videos/project0/smil30/smil-framework-1.mod.xsd.2 +0 -45
  477. package/videos/project0/smil30/smil-profile-model-1.mod.xsd +0 -1331
  478. package/videos/project0/smil30/smil-profile-model-1.mod.xsd.1 +0 -1331
  479. package/videos/project0/smil30/smil-qname-1.mod.xsd +0 -121
  480. package/videos/project0/smil30/smil-qname-1.mod.xsd.1 +0 -121
  481. package/videos/project0/smil30/xml.xsd +0 -16
  482. package/videos/project0/smil30/xml.xsd.1 +0 -16
  483. package/videos/project0/smil30/xml.xsd.2 +0 -16
  484. package/videos/project0/smil30.xsd +0 -137
  485. package/videos/project0/src/audio/metadata.json +0 -5
  486. package/videos/project0/src/audio/narration.mp3 +0 -0
  487. package/videos/project0/src/motion-canvas.d.ts +0 -1
  488. package/videos/project0/src/project.meta +0 -31
  489. package/videos/project0/src/project.ts +0 -13
  490. package/videos/project0/src/scenes/example.meta +0 -5
  491. package/videos/project0/src/scenes/scene1.meta +0 -3
  492. package/videos/project0/src/scenes/scene1.tsx +0 -129
  493. package/videos/project0/src/scenes/scene2.tsx +0 -132
  494. package/videos/project0/src/scenes/scene3.meta +0 -26
  495. package/videos/project0/src/scenes/scene3.tsx +0 -188
  496. package/videos/project0/tsconfig.json +0 -4
  497. package/videos/project0/vite.config.ts +0 -10
  498. package/videos/trash/output/project.mp4 +0 -0
  499. package/videos/trash/text.mp4 +0 -0
  500. package/videos/trash/video/project.tsx +0 -549
  501. package/videos/trash/video/render.ts +0 -15
  502. package/videos/trash/vite.config.ts +0 -10
  503. package/videos/tts.js +0 -109
  504. /package/dist/{types/ReportServer.d.ts → module/design-editor/types.js} +0 -0
  505. /package/dist/types/{App.d.ts → src/App.d.ts} +0 -0
  506. /package/dist/types/{CoreTypes.d.ts → src/CoreTypes.d.ts} +0 -0
  507. /package/dist/types/{Init.d.ts → src/Init.d.ts} +0 -0
  508. /package/dist/types/{Node.d.ts → src/Node.d.ts} +0 -0
  509. /package/dist/types/{NodeSidecar.d.ts → src/NodeSidecar.d.ts} +0 -0
  510. /package/dist/types/{PM → src/PM}/PM_WithEslintAndTsc.d.ts +0 -0
  511. /package/dist/types/{PM → src/PM}/__tests__/nodeSidecar.testeranto.d.ts +0 -0
  512. /package/dist/types/{PM → src/PM}/__tests__/pureSidecar.testeranto.d.ts +0 -0
  513. /package/dist/types/{PM → src/PM}/__tests__/webSidecar.testeranto.d.ts +0 -0
  514. /package/dist/types/{PM → src/PM}/base.d.ts +0 -0
  515. /package/dist/types/{PM → src/PM}/node.d.ts +0 -0
  516. /package/dist/types/{PM → src/PM}/nodeSidecar.d.ts +0 -0
  517. /package/dist/types/{PM → src/PM}/pureSidecar.d.ts +0 -0
  518. /package/dist/types/{PM → src/PM}/sidecar.d.ts +0 -0
  519. /package/dist/types/{PM → src/PM}/types.d.ts +0 -0
  520. /package/dist/types/{PM → src/PM}/web.d.ts +0 -0
  521. /package/dist/types/{PM → src/PM}/webSidecar.d.ts +0 -0
  522. /package/dist/types/{Pure.d.ts → src/Pure.d.ts} +0 -0
  523. /package/dist/types/{PureSidecar.d.ts → src/PureSidecar.d.ts} +0 -0
  524. /package/dist/types/{build.d.ts → src/ReportServer.d.ts} +0 -0
  525. /package/dist/types/{ReportServer.test.ts → src/ReportServer.test.ts}/index.d.ts +0 -0
  526. /package/dist/types/{ReportServerLib.d.ts → src/ReportServerLib.d.ts} +0 -0
  527. /package/dist/types/{Types.d.ts → src/Types.d.ts} +0 -0
  528. /package/dist/types/{Web.d.ts → src/Web.d.ts} +0 -0
  529. /package/dist/types/{WebSidecar.d.ts → src/WebSidecar.d.ts} +0 -0
  530. /package/dist/types/{init-docs.d.ts → src/build.d.ts} +0 -0
  531. /package/dist/types/{components → src/components}/SunriseAnimation.d.ts +0 -0
  532. /package/dist/types/{components → src/components}/SunriseAnimation.test/implementation.d.ts +0 -0
  533. /package/dist/types/{components → src/components}/SunriseAnimation.test/index.d.ts +0 -0
  534. /package/dist/types/{components → src/components}/SunriseAnimation.test/interface.d.ts +0 -0
  535. /package/dist/types/{components → src/components}/SunriseAnimation.test/specification.d.ts +0 -0
  536. /package/dist/types/{components → src/components}/SunriseAnimation.test/types.d.ts +0 -0
  537. /package/dist/types/{components → src/components}/TestStatusBadge.d.ts +0 -0
  538. /package/dist/types/{components → src/components}/pure/AppFrame.test/implementation.d.ts +0 -0
  539. /package/dist/types/{components → src/components}/pure/AppFrame.test/index.d.ts +0 -0
  540. /package/dist/types/{components → src/components}/pure/AppFrame.test/specification.d.ts +0 -0
  541. /package/dist/types/{components → src/components}/pure/AppFrame.test/types.d.ts +0 -0
  542. /package/dist/types/{components → src/components}/pure/FeaturesReporterView.d.ts +0 -0
  543. /package/dist/types/{components → src/components}/pure/FeaturesReporterView.test/implementation.d.ts +0 -0
  544. /package/dist/types/{components → src/components}/pure/FeaturesReporterView.test/index.d.ts +0 -0
  545. /package/dist/types/{components → src/components}/pure/FeaturesReporterView.test/specification.d.ts +0 -0
  546. /package/dist/types/{components → src/components}/pure/FeaturesReporterView.test/types.d.ts +0 -0
  547. /package/dist/types/{components → src/components}/pure/ModalContent.d.ts +0 -0
  548. /package/dist/types/{components → src/components}/pure/ModalContent.test/implementation.d.ts +0 -0
  549. /package/dist/types/{components → src/components}/pure/ModalContent.test/specification.d.ts +0 -0
  550. /package/dist/types/{components → src/components}/pure/ModalContent.test/types.d.ts +0 -0
  551. /package/dist/types/{components → src/components}/pure/ProjectPageView.d.ts +0 -0
  552. /package/dist/types/{components → src/components}/pure/ProjectPageView.test/implementation.d.ts +0 -0
  553. /package/dist/types/{components/pure/ModalContent.test → src/components/pure/ProjectPageView.test}/index.d.ts +0 -0
  554. /package/dist/types/{components → src/components}/pure/ProjectPageView.test/specification.d.ts +0 -0
  555. /package/dist/types/{components → src/components}/pure/ProjectPageView.test/types.d.ts +0 -0
  556. /package/dist/types/{PM/layers/base/PM_Base.d.ts → src/components/pure/SingleProcessView.d.ts} +0 -0
  557. /package/dist/types/{components → src/components}/pure/TestPageView.d.ts +0 -0
  558. /package/dist/types/{components → src/components}/pure/TestPageView.test/specification.d.ts +0 -0
  559. /package/dist/types/{components → src/components}/pure/TestPageView.test/types.d.ts +0 -0
  560. /package/dist/types/{components → src/components}/pure/ThemeCard.d.ts +0 -0
  561. /package/dist/types/{components → src/components}/stateful/FeaturesReporter.d.ts +0 -0
  562. /package/dist/types/{components → src/components}/stateful/ProjectPage.d.ts +0 -0
  563. /package/dist/types/{components → src/components}/stateful/ProjectsPage.d.ts +0 -0
  564. /package/dist/types/{components → src/components}/stateful/TestPage.d.ts +0 -0
  565. /package/dist/types/{defaultConfig.d.ts → src/defaultConfig.d.ts} +0 -0
  566. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/consoleDetectorPlugin.d.ts +0 -0
  567. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/eslint-formatter-testeranto.d.ts +0 -0
  568. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/featuresPlugin.d.ts +0 -0
  569. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/index.d.ts +0 -0
  570. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/inputFilesPlugin.d.ts +0 -0
  571. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/nativeImportDetectorPlugin.d.ts +0 -0
  572. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/node.d.ts +0 -0
  573. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/pure.d.ts +0 -0
  574. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/rebuildPlugin.d.ts +0 -0
  575. /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/web.d.ts +0 -0
  576. /package/dist/types/{run.d.ts → src/init-docs.d.ts} +0 -0
  577. /package/dist/types/{lib → src/lib}/BaseSuite.d.ts +0 -0
  578. /package/dist/types/{lib → src/lib}/BaseSuite.test/node.test.d.ts +0 -0
  579. /package/dist/types/{lib → src/lib}/BaseSuite.test/pure.test.d.ts +0 -0
  580. /package/dist/types/{lib → src/lib}/BaseSuite.test/test.d.ts +0 -0
  581. /package/dist/types/{lib → src/lib}/BaseSuite.test/web.test.d.ts +0 -0
  582. /package/dist/types/{lib → src/lib}/Sidecar.d.ts +0 -0
  583. /package/dist/types/{lib → src/lib}/abstractBase.d.ts +0 -0
  584. /package/dist/types/{lib → src/lib}/abstractBase.test/MockGiven.d.ts +0 -0
  585. /package/dist/types/{lib → src/lib}/abstractBase.test/MockThen.d.ts +0 -0
  586. /package/dist/types/{lib → src/lib}/abstractBase.test/MockWhen.d.ts +0 -0
  587. /package/dist/types/{lib → src/lib}/abstractBase.test/adapter.d.ts +0 -0
  588. /package/dist/types/{lib → src/lib}/abstractBase.test/implementation.d.ts +0 -0
  589. /package/dist/types/{lib → src/lib}/abstractBase.test/index.d.ts +0 -0
  590. /package/dist/types/{lib → src/lib}/abstractBase.test/specification.d.ts +0 -0
  591. /package/dist/types/{lib → src/lib}/abstractBase.test/types.d.ts +0 -0
  592. /package/dist/types/{lib → src/lib}/baseBuilder.test/baseBuilder.test.adapter.d.ts +0 -0
  593. /package/dist/types/{lib → src/lib}/baseBuilder.test/baseBuilder.test.implementation.d.ts +0 -0
  594. /package/dist/types/{lib → src/lib}/baseBuilder.test/baseBuilder.test.mock.d.ts +0 -0
  595. /package/dist/types/{lib → src/lib}/baseBuilder.test/baseBuilder.test.node.d.ts +0 -0
  596. /package/dist/types/{lib → src/lib}/baseBuilder.test/baseBuilder.test.pure.d.ts +0 -0
  597. /package/dist/types/{lib → src/lib}/baseBuilder.test/baseBuilder.test.specification.d.ts +0 -0
  598. /package/dist/types/{lib → src/lib}/baseBuilder.test/baseBuilder.test.types.d.ts +0 -0
  599. /package/dist/types/{lib → src/lib}/baseBuilder.test/baseBuilder.test.web.d.ts +0 -0
  600. /package/dist/types/{lib → src/lib}/classBuilder.d.ts +0 -0
  601. /package/dist/types/{lib → src/lib}/classBuilder.test/classBuilder.test.adapter.d.ts +0 -0
  602. /package/dist/types/{lib → src/lib}/classBuilder.test/classBuilder.test.d.ts +0 -0
  603. /package/dist/types/{lib → src/lib}/classBuilder.test/classBuilder.test.implementation.d.ts +0 -0
  604. /package/dist/types/{lib → src/lib}/classBuilder.test/classBuilder.test.specification.d.ts +0 -0
  605. /package/dist/types/{lib → src/lib}/classBuilder.test/classBuilder.test.types.d.ts +0 -0
  606. /package/dist/types/{lib → src/lib}/classBuilder.test/mock.d.ts +0 -0
  607. /package/dist/types/{lib → src/lib}/core.d.ts +0 -0
  608. /package/dist/types/{lib → src/lib}/core.test/MockCore.d.ts +0 -0
  609. /package/dist/types/{lib → src/lib}/core.test/core.test.adapter.d.ts +0 -0
  610. /package/dist/types/{lib → src/lib}/core.test/core.test.d.ts +0 -0
  611. /package/dist/types/{lib → src/lib}/core.test/core.test.implementation.d.ts +0 -0
  612. /package/dist/types/{lib → src/lib}/core.test/core.test.specification.d.ts +0 -0
  613. /package/dist/types/{lib → src/lib}/core.test/core.test.types.d.ts +0 -0
  614. /package/dist/types/{lib → src/lib}/mocks.test.d.ts +0 -0
  615. /package/dist/types/{lib → src/lib}/pmProxy.d.ts +0 -0
  616. /package/dist/types/{lib → src/lib}/pmProxy.test/adapter.d.ts +0 -0
  617. /package/dist/types/{lib → src/lib}/pmProxy.test/implementation.d.ts +0 -0
  618. /package/dist/types/{lib → src/lib}/pmProxy.test/index.d.ts +0 -0
  619. /package/dist/types/{lib → src/lib}/pmProxy.test/mockPM.d.ts +0 -0
  620. /package/dist/types/{lib → src/lib}/pmProxy.test/specification.d.ts +0 -0
  621. /package/dist/types/{lib → src/lib}/pmProxy.test/types.d.ts +0 -0
  622. /package/dist/types/{lib → src/lib}/types.d.ts +0 -0
  623. /package/dist/types/{mothership → src/mothership}/index.d.ts +0 -0
  624. /package/dist/types/{mothership → src/mothership}/test.d.ts +0 -0
  625. /package/dist/types/{types → src/types}/features.d.ts +0 -0
  626. /package/dist/types/{utils → src/utils}/api.d.ts +0 -0
  627. /package/dist/types/{utils → src/utils}/buildTemplates.d.ts +0 -0
  628. /package/dist/types/{utils → src/utils}/featureUtils.d.ts +0 -0
  629. /package/dist/types/{utils → src/utils}/makePrompt.d.ts +0 -0
  630. /package/dist/types/{utils → src/utils}/queue.d.ts +0 -0
  631. /package/dist/types/{utils.d.ts → src/utils.d.ts} +0 -0
  632. /package/dist/types/{web.html.d.ts → src/web.html.d.ts} +0 -0
@@ -1,16 +1,127 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
5
35
  Object.defineProperty(exports, "__esModule", { value: true });
6
36
  exports.TestPageView = void 0;
37
+ /* eslint-disable @typescript-eslint/no-unused-vars */
7
38
  /* eslint-disable @typescript-eslint/no-explicit-any */
8
- const react_1 = __importDefault(require("react"));
39
+ const react_1 = __importStar(require("react"));
9
40
  const react_bootstrap_1 = require("react-bootstrap");
41
+ const react_router_dom_1 = require("react-router-dom");
42
+ const logFiles_1 = require("../../utils/logFiles");
43
+ const react_bootstrap_2 = require("react-bootstrap");
44
+ const react_2 = require("@monaco-editor/react");
10
45
  const NavBar_1 = require("./NavBar");
11
46
  const TestStatusBadge_1 = require("../TestStatusBadge");
47
+ const FileTree = ({ data, onSelect, level = 0, selectedSourcePath }) => {
48
+ const [expanded, setExpanded] = (0, react_1.useState)({});
49
+ const toggleExpand = (path) => {
50
+ setExpanded((prev) => (Object.assign(Object.assign({}, prev), { [path]: !prev[path] })));
51
+ };
52
+ return (react_1.default.createElement("div", null, Object.entries(data).map(([name, node]) => {
53
+ const path = Object.keys(expanded).find((k) => k.endsWith(name)) || name;
54
+ const isExpanded = expanded[path];
55
+ if (node.__isFile) {
56
+ return (react_1.default.createElement(FileTreeItem, { key: name, name: name, isFile: true, level: level, isSelected: selectedSourcePath === path, onClick: () => onSelect(path, node.content) }));
57
+ }
58
+ else {
59
+ return (react_1.default.createElement("div", { key: name },
60
+ react_1.default.createElement("div", { className: "d-flex align-items-center py-1 text-dark", style: {
61
+ paddingLeft: `${level * 16}px`,
62
+ cursor: 'pointer',
63
+ fontSize: '0.875rem'
64
+ }, onClick: () => toggleExpand(path) },
65
+ react_1.default.createElement("i", { className: `bi ${isExpanded ? 'bi-folder2-open' : 'bi-folder'} me-1` }),
66
+ react_1.default.createElement("span", null, name)),
67
+ isExpanded && (react_1.default.createElement(FileTree, { data: node, onSelect: onSelect, level: level + 1, selectedSourcePath: selectedSourcePath }))));
68
+ }
69
+ })));
70
+ };
12
71
  const TestPageView = ({ projectName, testName, decodedTestPath, runtime, testsExist, errorCounts, logs, }) => {
13
- const [activeTab, setActiveTab] = react_1.default.useState('tests.json');
72
+ const navigate = (0, react_router_dom_1.useNavigate)();
73
+ const [showAiderModal, setShowAiderModal] = (0, react_1.useState)(false);
74
+ const [messageOption, setMessageOption] = (0, react_1.useState)('default');
75
+ const [customMessage, setCustomMessage] = (0, react_1.useState)(typeof logs['message.txt'] === 'string' ? logs['message.txt'] : 'make a script that prints hello');
76
+ const [showToast, setShowToast] = (0, react_1.useState)(false);
77
+ const [toastMessage, setToastMessage] = (0, react_1.useState)('');
78
+ const [toastVariant, setToastVariant] = (0, react_1.useState)('success');
79
+ const [ws, setWs] = (0, react_1.useState)(null);
80
+ const [expandedSections, setExpandedSections] = (0, react_1.useState)({
81
+ standardLogs: true,
82
+ runtimeLogs: true,
83
+ sourceFiles: true
84
+ });
85
+ const [isNavbarCollapsed, setIsNavbarCollapsed] = (0, react_1.useState)(false);
86
+ // Update customMessage when logs change
87
+ (0, react_1.useEffect)(() => {
88
+ if (typeof logs['message.txt'] === 'string' && logs['message.txt'].trim()) {
89
+ setCustomMessage(logs['message.txt']);
90
+ }
91
+ }, [logs]);
92
+ // Set up WebSocket connection
93
+ (0, react_1.useEffect)(() => {
94
+ const wsProtocol = window.location.protocol === 'https:' ? 'wss:' : 'ws:';
95
+ const wsUrl = `${wsProtocol}//${window.location.host}`;
96
+ const websocket = new WebSocket(wsUrl);
97
+ setWs(websocket);
98
+ return () => {
99
+ websocket.close();
100
+ };
101
+ }, []);
102
+ const [activeTab, setActiveTab] = react_1.default.useState("tests.json");
103
+ const [selectedFile, setSelectedFile] = (0, react_1.useState)(null);
104
+ const [selectedSourcePath, setSelectedSourcePath] = (0, react_1.useState)(null);
105
+ const [editorTheme, setEditorTheme] = (0, react_1.useState)("vs-dark");
106
+ // Determine language from file extension
107
+ const getLanguage = (path) => {
108
+ var _a;
109
+ const ext = (_a = path.split(".").pop()) === null || _a === void 0 ? void 0 : _a.toLowerCase();
110
+ switch (ext) {
111
+ case "ts":
112
+ return "typescript";
113
+ case "tsx":
114
+ return "typescript";
115
+ case "js":
116
+ return "javascript";
117
+ case "json":
118
+ return "json";
119
+ case "md":
120
+ return "markdown";
121
+ default:
122
+ return "plaintext";
123
+ }
124
+ };
14
125
  const renderTestResults = (testData) => {
15
126
  return (react_1.default.createElement("div", { className: "test-results" }, testData.givens.map((given, i) => (react_1.default.createElement("div", { key: i, className: "mb-4 card" },
16
127
  react_1.default.createElement("div", { className: "card-header bg-primary text-white" },
@@ -21,16 +132,21 @@ const TestPageView = ({ projectName, testName, decodedTestPath, runtime, testsEx
21
132
  given.name),
22
133
  given.features && given.features.length > 0 && (react_1.default.createElement("div", { className: "mt-1" },
23
134
  react_1.default.createElement("small", null, "Features:"),
24
- react_1.default.createElement("ul", { className: "list-unstyled" }, given.features.map((feature, fi) => (react_1.default.createElement("li", { key: fi }, feature.startsWith('http') ? (react_1.default.createElement("a", { href: feature, target: "_blank", rel: "noopener noreferrer", className: "text-white" }, new URL(feature).hostname)) : (react_1.default.createElement("span", { className: "text-white" }, feature))))))))),
135
+ react_1.default.createElement("ul", { className: "list-unstyled" }, given.features.map((feature, fi) => (react_1.default.createElement("li", { key: fi }, feature.startsWith("http") ? (react_1.default.createElement("a", { href: feature, target: "_blank", rel: "noopener noreferrer", className: "text-white" }, new URL(feature).hostname)) : (react_1.default.createElement("span", { className: "text-white" }, feature))))))))),
25
136
  given.artifacts && given.artifacts.length > 0 && (react_1.default.createElement("div", { className: "dropdown" },
26
137
  react_1.default.createElement("button", { className: "btn btn-sm btn-light dropdown-toggle", type: "button", "data-bs-toggle": "dropdown" },
27
138
  "Artifacts (",
28
139
  given.artifacts.length,
29
140
  ")"),
30
141
  react_1.default.createElement("ul", { className: "dropdown-menu dropdown-menu-end" }, given.artifacts.map((artifact, ai) => (react_1.default.createElement("li", { key: ai },
31
- react_1.default.createElement("a", { className: "dropdown-item", href: `reports/${projectName}/${testName.split('.').slice(0, -1).join('.')}/${runtime}/${artifact}`, target: "_blank", rel: "noopener noreferrer" }, artifact.split('/').pop()))))))))),
142
+ react_1.default.createElement("a", { className: "dropdown-item", href: `reports/${projectName}/${testName
143
+ .split(".")
144
+ .slice(0, -1)
145
+ .join(".")}/${runtime}/${artifact}`, target: "_blank", rel: "noopener noreferrer" }, artifact.split("/").pop()))))))))),
32
146
  react_1.default.createElement("div", { className: "card-body" },
33
- given.whens.map((when, j) => (react_1.default.createElement("div", { key: `w-${j}`, className: `p-3 mb-2 ${when.error ? 'bg-danger text-white' : 'bg-success text-white'}` },
147
+ given.whens.map((when, j) => (react_1.default.createElement("div", { key: `w-${j}`, className: `p-3 mb-2 ${when.error
148
+ ? "bg-danger text-white"
149
+ : "bg-success text-white"}` },
34
150
  react_1.default.createElement("div", { className: "d-flex justify-content-between align-items-start" },
35
151
  react_1.default.createElement("div", null,
36
152
  react_1.default.createElement("div", null,
@@ -39,13 +155,18 @@ const TestPageView = ({ projectName, testName, decodedTestPath, runtime, testsEx
39
155
  when.name,
40
156
  when.features && when.features.length > 0 && (react_1.default.createElement("div", { className: "mt-2" },
41
157
  react_1.default.createElement("small", null, "Features:"),
42
- react_1.default.createElement("ul", { className: "list-unstyled" }, when.features.map((feature, fi) => (react_1.default.createElement("li", { key: fi }, feature.startsWith('http') ? (react_1.default.createElement("a", { href: feature, target: "_blank", rel: "noopener noreferrer" }, new URL(feature).hostname)) : (feature))))))),
158
+ react_1.default.createElement("ul", { className: "list-unstyled" }, when.features.map((feature, fi) => (react_1.default.createElement("li", { key: fi }, feature.startsWith("http") ? (react_1.default.createElement("a", { href: feature, target: "_blank", rel: "noopener noreferrer" }, new URL(feature).hostname)) : (feature))))))),
43
159
  when.error && react_1.default.createElement("pre", { className: "mt-2" }, when.error))),
44
160
  when.artifacts && when.artifacts.length > 0 && (react_1.default.createElement("div", { className: "ms-3" },
45
161
  react_1.default.createElement("strong", null, "Artifacts:"),
46
162
  react_1.default.createElement("ul", { className: "list-unstyled" }, when.artifacts.map((artifact, ai) => (react_1.default.createElement("li", { key: ai },
47
- react_1.default.createElement("a", { href: `reports/${projectName}/${testName.split('.').slice(0, -1).join('.')}/${runtime}/${artifact}`, target: "_blank", className: "text-white", rel: "noopener noreferrer" }, artifact.split('/').pop()))))))))))),
48
- given.thens.map((then, k) => (react_1.default.createElement("div", { key: `t-${k}`, className: `p-3 mb-2 ${then.error ? 'bg-danger text-white' : 'bg-success text-white'}` },
163
+ react_1.default.createElement("a", { href: `reports/${projectName}/${testName
164
+ .split(".")
165
+ .slice(0, -1)
166
+ .join(".")}/${runtime}/${artifact}`, target: "_blank", className: "text-white", rel: "noopener noreferrer" }, artifact.split("/").pop()))))))))))),
167
+ given.thens.map((then, k) => (react_1.default.createElement("div", { key: `t-${k}`, className: `p-3 mb-2 ${then.error
168
+ ? "bg-danger text-white"
169
+ : "bg-success text-white"}` },
49
170
  react_1.default.createElement("div", { className: "d-flex justify-content-between align-items-start" },
50
171
  react_1.default.createElement("div", null,
51
172
  react_1.default.createElement("div", null,
@@ -54,81 +175,339 @@ const TestPageView = ({ projectName, testName, decodedTestPath, runtime, testsEx
54
175
  then.name,
55
176
  then.features && then.features.length > 0 && (react_1.default.createElement("div", { className: "mt-2" },
56
177
  react_1.default.createElement("small", null, "Features:"),
57
- react_1.default.createElement("ul", { className: "list-unstyled" }, then.features.map((feature, fi) => (react_1.default.createElement("li", { key: fi }, feature.startsWith('http') ? (react_1.default.createElement("a", { href: feature, target: "_blank", rel: "noopener noreferrer" }, new URL(feature).hostname)) : (feature))))))),
178
+ react_1.default.createElement("ul", { className: "list-unstyled" }, then.features.map((feature, fi) => (react_1.default.createElement("li", { key: fi }, feature.startsWith("http") ? (react_1.default.createElement("a", { href: feature, target: "_blank", rel: "noopener noreferrer" }, new URL(feature).hostname)) : (feature))))))),
58
179
  then.error && react_1.default.createElement("pre", { className: "mt-2" }, then.error))),
59
180
  then.artifacts && then.artifacts.length > 0 && (react_1.default.createElement("div", { className: "ms-3" },
60
181
  react_1.default.createElement("strong", null, "Artifacts:"),
61
182
  react_1.default.createElement("ul", { className: "list-unstyled" }, then.artifacts.map((artifact, ai) => (react_1.default.createElement("li", { key: ai },
62
- react_1.default.createElement("a", { href: `reports/${projectName}/${testName.split('.').slice(0, -1).join('.')}/${runtime}/${artifact}`, target: "_blank", className: "text-white", rel: "noopener noreferrer" }, artifact.split('/').pop())))))))))))))))));
183
+ react_1.default.createElement("a", { href: `reports/${projectName}/${testName
184
+ .split(".")
185
+ .slice(0, -1)
186
+ .join(".")}/${runtime}/${artifact}`, target: "_blank", className: "text-white", rel: "noopener noreferrer" }, artifact.split("/").pop())))))))))))))))));
63
187
  };
64
- return (react_1.default.createElement(react_bootstrap_1.Container, { fluid: true, className: "px-0" },
188
+ console.log("Rendering TestPageView with logs:", {
189
+ logKeys: Object.keys(logs),
190
+ sourceFiles: logs.source_files ? Object.keys(logs.source_files) : null,
191
+ selectedFile,
192
+ activeTab,
193
+ });
194
+ return (react_1.default.createElement(react_bootstrap_2.Container, { fluid: true, className: "px-0" },
65
195
  react_1.default.createElement(NavBar_1.NavBar, { title: decodedTestPath, backLink: `/projects/${projectName}`, navItems: [
66
196
  {
67
- label: '',
197
+ label: "",
68
198
  badge: {
69
- variant: runtime === 'node' ? 'primary' :
70
- runtime === 'web' ? 'success' :
71
- 'info',
72
- text: runtime
199
+ variant: runtime === "node"
200
+ ? "primary"
201
+ : runtime === "web"
202
+ ? "success"
203
+ : "info",
204
+ text: runtime,
73
205
  },
74
- className: 'pe-none d-flex align-items-center gap-2'
75
- }
76
- ], rightContent: react_1.default.createElement(react_bootstrap_1.Button, { variant: "info", onClick: async () => {
77
- try {
78
- const promptPath = `testeranto/reports/${projectName}/${testName.split('.').slice(0, -1).join('.')}/${runtime}/prompt.txt`;
79
- const messagePath = `testeranto/reports/${projectName}/${testName.split('.').slice(0, -1).join('.')}/${runtime}/message.txt`;
80
- const command = `aider --load ${promptPath} --message-file ${messagePath}`;
81
- await navigator.clipboard.writeText(command);
82
- alert("Copied aider command to clipboard!");
83
- }
84
- catch (err) {
85
- alert("Failed to copy command to clipboard");
86
- console.error("Copy failed:", err);
87
- }
88
- }, className: "ms-2" }, "\uD83E\uDD16") }),
89
- react_1.default.createElement(react_bootstrap_1.Row, { className: "g-0" },
90
- react_1.default.createElement(react_bootstrap_1.Col, { sm: 3, className: "border-end" },
91
- react_1.default.createElement(react_bootstrap_1.Nav, { variant: "pills", className: "flex-column" }, Object.keys(logs).map((logName) => {
92
- var _a;
93
- const displayName = logName.replace('.json', '').replace(/_/g, ' ');
94
- let statusIndicator = null;
95
- // Add error indicators for specific log types
96
- if (logName === 'type_errors.txt' && errorCounts.typeErrors > 0) {
97
- statusIndicator = react_1.default.createElement("span", { className: "ms-1" },
98
- "\u274C ",
99
- errorCounts.typeErrors);
100
- }
101
- else if (logName === 'lint_errors.txt' && errorCounts.staticErrors > 0) {
102
- statusIndicator = react_1.default.createElement("span", { className: "ms-1" },
103
- "\u274C ",
104
- errorCounts.staticErrors);
105
- }
106
- else if (logName === 'stderr.log' && errorCounts.runTimeErrors > 0) {
107
- statusIndicator = react_1.default.createElement("span", { className: "ms-1" },
108
- "\u274C ",
109
- errorCounts.runTimeErrors);
110
- }
111
- else if (logName === 'exit.log' && ((_a = logs['exit.log']) === null || _a === void 0 ? void 0 : _a.trim()) !== '0') {
112
- statusIndicator = react_1.default.createElement("span", { className: "ms-1" }, "\u26A0\uFE0F");
113
- }
114
- else if (logName === 'tests.json' && logs['tests.json']) {
115
- statusIndicator = react_1.default.createElement("div", { className: "ms-1" },
116
- react_1.default.createElement(TestStatusBadge_1.TestStatusBadge, { testName: decodedTestPath, testsExist: testsExist, runTimeErrors: errorCounts.runTimeErrors, typeErrors: errorCounts.typeErrors, staticErrors: errorCounts.staticErrors, variant: "compact", className: "mt-1" }));
117
- }
118
- return (react_1.default.createElement(react_bootstrap_1.Nav.Item, { key: logName },
119
- react_1.default.createElement(react_bootstrap_1.Nav.Link, { eventKey: logName, active: activeTab === logName, onClick: () => setActiveTab(logName), className: "d-flex flex-column align-items-start" },
120
- react_1.default.createElement("div", { className: "d-flex justify-content-between w-100" },
121
- react_1.default.createElement("span", { className: "text-capitalize" }, displayName),
122
- statusIndicator))));
123
- }))),
124
- react_1.default.createElement(react_bootstrap_1.Col, { sm: 9 },
125
- react_1.default.createElement("div", { className: "p-3" }, !testsExist && activeTab === 'tests.json' ? (react_1.default.createElement(react_bootstrap_1.Alert, { variant: "danger" },
126
- react_1.default.createElement("h4", null, "Tests did not run to completion"),
127
- react_1.default.createElement("p", null, "The test results file (tests.json) was not found or could not be loaded."))) : activeTab === 'tests.json' && logs['tests.json'] ? (typeof logs['tests.json'] === 'string'
128
- ? renderTestResults(JSON.parse(logs['tests.json']))
129
- : renderTestResults(logs['tests.json'])) : logs[activeTab] ? (react_1.default.createElement("pre", { className: "bg-dark text-white p-3" },
130
- react_1.default.createElement("code", null, typeof logs[activeTab] === 'string'
131
- ? logs[activeTab]
132
- : JSON.stringify(logs[activeTab], null, 2)))) : (react_1.default.createElement(react_bootstrap_1.Alert, { variant: "info" }, "No content available for this log")))))));
206
+ className: "pe-none d-flex align-items-center gap-2",
207
+ },
208
+ ], rightContent: react_1.default.createElement(react_bootstrap_2.Button, { variant: "info", onClick: () => setShowAiderModal(true), className: "ms-2", title: "AI Assistant" }, "\uD83E\uDD16") }),
209
+ react_1.default.createElement(react_bootstrap_2.Modal, { show: showAiderModal, onHide: () => setShowAiderModal(false), size: "lg", onShow: () => setMessageOption('default') },
210
+ react_1.default.createElement(react_bootstrap_2.Modal.Header, { closeButton: true },
211
+ react_1.default.createElement(react_bootstrap_2.Modal.Title, null, "Aider")),
212
+ react_1.default.createElement(react_bootstrap_2.Modal.Body, null,
213
+ react_1.default.createElement("div", { className: "mb-3" },
214
+ react_1.default.createElement("div", { className: "form-check" },
215
+ react_1.default.createElement("input", { className: "form-check-input", type: "radio", name: "messageOption", id: "defaultMessage", value: "default", checked: messageOption === 'default', onChange: () => setMessageOption('default') }),
216
+ react_1.default.createElement("label", { className: "form-check-label", htmlFor: "defaultMessage" }, "Use default message.txt")),
217
+ react_1.default.createElement("div", { className: "form-check" },
218
+ react_1.default.createElement("input", { className: "form-check-input", type: "radio", name: "messageOption", id: "customMessage", value: "custom", checked: messageOption === 'custom', onChange: () => setMessageOption('custom') }),
219
+ react_1.default.createElement("label", { className: "form-check-label", htmlFor: "customMessage" }, "Use custom message")),
220
+ messageOption === 'custom' && (react_1.default.createElement("div", { className: "mt-2" },
221
+ react_1.default.createElement("textarea", { className: "form-control", rows: 8, placeholder: "Enter your custom message", value: customMessage, onChange: (e) => setCustomMessage(e.target.value), style: { minHeight: '500px' } }))))),
222
+ react_1.default.createElement(react_bootstrap_2.Modal.Footer, null,
223
+ react_1.default.createElement(react_bootstrap_2.Button, { variant: "primary", onClick: async () => {
224
+ try {
225
+ const promptPath = `testeranto/reports/${projectName}/${testName
226
+ .split(".")
227
+ .slice(0, -1)
228
+ .join(".")}/${runtime}/prompt.txt`;
229
+ let command = `aider --load ${promptPath}`;
230
+ if (messageOption === 'default') {
231
+ const messagePath = `testeranto/reports/${projectName}/${testName
232
+ .split(".")
233
+ .slice(0, -1)
234
+ .join(".")}/${runtime}/message.txt`;
235
+ command += ` --message-file ${messagePath}`;
236
+ }
237
+ else {
238
+ command += ` --message "${customMessage}"`;
239
+ }
240
+ // Send command to server via WebSocket
241
+ const ws = new WebSocket(`ws://${window.location.host}`);
242
+ ws.onopen = () => {
243
+ ws.send(JSON.stringify({
244
+ type: 'executeCommand',
245
+ command: command
246
+ }));
247
+ setToastMessage('Command sent to server');
248
+ setToastVariant('success');
249
+ setShowToast(true);
250
+ setShowAiderModal(false);
251
+ ws.close();
252
+ // Navigate to process manager page
253
+ setTimeout(() => {
254
+ navigate('/processes');
255
+ }, 1000);
256
+ };
257
+ ws.onerror = (error) => {
258
+ setToastMessage('Failed to connect to server');
259
+ setToastVariant('danger');
260
+ setShowToast(true);
261
+ };
262
+ }
263
+ catch (err) {
264
+ console.error("WebSocket error:", err);
265
+ setToastMessage('Error preparing command');
266
+ setToastVariant('danger');
267
+ setShowToast(true);
268
+ }
269
+ } }, "Run Aider Command"))),
270
+ react_1.default.createElement(react_bootstrap_2.Row, { className: "g-0" },
271
+ react_1.default.createElement(react_bootstrap_2.Col, { sm: 3, className: "border-end", style: {
272
+ height: "calc(100vh - 56px)",
273
+ overflow: "auto",
274
+ backgroundColor: '#f8f9fa'
275
+ } },
276
+ react_1.default.createElement("div", { className: "p-2 border-bottom" },
277
+ react_1.default.createElement("small", { className: "fw-bold text-muted" }, "EXPLORER")),
278
+ react_1.default.createElement("div", { className: "p-2" },
279
+ react_1.default.createElement("div", { className: "d-flex align-items-center text-muted mb-1", style: { cursor: 'pointer', fontSize: '0.875rem' }, onClick: () => setExpandedSections(prev => (Object.assign(Object.assign({}, prev), { standardLogs: !prev.standardLogs }))) },
280
+ react_1.default.createElement("i", { className: `bi bi-chevron-${expandedSections.standardLogs ? 'down' : 'right'} me-1` }),
281
+ react_1.default.createElement("span", null, "Standard Logs")),
282
+ expandedSections.standardLogs && (react_1.default.createElement("div", null, Object.values(logFiles_1.STANDARD_LOGS).map((logName) => {
283
+ const logContent = logs[logName];
284
+ const exists = logContent !== undefined &&
285
+ ((typeof logContent === "string" && logContent.trim() !== "") ||
286
+ (typeof logContent === "object" && Object.keys(logContent).length > 0));
287
+ return (react_1.default.createElement(FileTreeItem, { key: logName, name: logName, isFile: true, level: 1, isSelected: activeTab === logName, exists: exists, onClick: () => {
288
+ if (exists) {
289
+ setActiveTab(logName);
290
+ setSelectedFile({
291
+ path: logName,
292
+ content: typeof logContent === "string" ? logContent : JSON.stringify(logContent, null, 2),
293
+ language: logName.endsWith(".json") ? "json" : "plaintext",
294
+ });
295
+ }
296
+ else {
297
+ setActiveTab(logName);
298
+ setSelectedFile({
299
+ path: logName,
300
+ content: `// ${logName} not found or empty\nThis file was not generated during the test run.`,
301
+ language: "plaintext",
302
+ });
303
+ }
304
+ } }));
305
+ })))),
306
+ Object.values(logFiles_1.RUNTIME_SPECIFIC_LOGS[runtime]).length > 0 && (react_1.default.createElement("div", { className: "p-2" },
307
+ react_1.default.createElement("div", { className: "d-flex align-items-center text-muted mb-1", style: { cursor: 'pointer', fontSize: '0.875rem' }, onClick: () => setExpandedSections(prev => (Object.assign(Object.assign({}, prev), { runtimeLogs: !prev.runtimeLogs }))) },
308
+ react_1.default.createElement("i", { className: `bi bi-chevron-${expandedSections.runtimeLogs ? 'down' : 'right'} me-1` }),
309
+ react_1.default.createElement("span", null, "Runtime Logs")),
310
+ expandedSections.runtimeLogs && (react_1.default.createElement("div", null, Object.values(logFiles_1.RUNTIME_SPECIFIC_LOGS[runtime]).map((logName) => {
311
+ const logContent = logs[logName];
312
+ const exists = logContent !== undefined &&
313
+ ((typeof logContent === "string" && logContent.trim() !== "") ||
314
+ (typeof logContent === "object" && Object.keys(logContent).length > 0));
315
+ return (react_1.default.createElement(FileTreeItem, { key: logName, name: logName, isFile: true, level: 1, isSelected: activeTab === logName, exists: exists, onClick: () => {
316
+ if (exists) {
317
+ setActiveTab(logName);
318
+ setSelectedFile({
319
+ path: logName,
320
+ content: typeof logContent === "string" ? logContent : JSON.stringify(logContent, null, 2),
321
+ language: logName.endsWith(".json") ? "json" : "plaintext",
322
+ });
323
+ }
324
+ else {
325
+ setActiveTab(logName);
326
+ setSelectedFile({
327
+ path: logName,
328
+ content: `// ${logName} not found or empty\nThis file was not generated during the test run.`,
329
+ language: "plaintext",
330
+ });
331
+ }
332
+ } }));
333
+ }))))),
334
+ logs.source_files && (react_1.default.createElement("div", { className: "p-2" },
335
+ react_1.default.createElement("div", { className: "d-flex align-items-center text-muted mb-1", style: { cursor: 'pointer', fontSize: '0.875rem' }, onClick: () => setExpandedSections(prev => (Object.assign(Object.assign({}, prev), { sourceFiles: !prev.sourceFiles }))) },
336
+ react_1.default.createElement("i", { className: `bi bi-chevron-${expandedSections.sourceFiles ? 'down' : 'right'} me-1` }),
337
+ react_1.default.createElement("span", null, "Source Files")),
338
+ expandedSections.sourceFiles && (react_1.default.createElement("div", null,
339
+ react_1.default.createElement(FileTree, { data: logs.source_files, onSelect: (path, content) => {
340
+ setActiveTab("source_file");
341
+ setSelectedSourcePath(path);
342
+ setSelectedFile({
343
+ path,
344
+ content,
345
+ language: getLanguage(path),
346
+ });
347
+ }, level: 1, selectedSourcePath: selectedSourcePath })))))),
348
+ react_1.default.createElement(react_bootstrap_2.Col, { sm: 6, className: "border-end p-0", style: { height: "calc(100vh - 56px)", overflow: "hidden" } },
349
+ react_1.default.createElement(react_2.Editor, { height: "100%", path: (selectedFile === null || selectedFile === void 0 ? void 0 : selectedFile.path) || "empty", defaultLanguage: (selectedFile === null || selectedFile === void 0 ? void 0 : selectedFile.language) || "plaintext", value: (selectedFile === null || selectedFile === void 0 ? void 0 : selectedFile.content) || "// Select a file to view its contents", theme: editorTheme, options: {
350
+ minimap: { enabled: false },
351
+ fontSize: 14,
352
+ wordWrap: "on",
353
+ automaticLayout: true,
354
+ readOnly: !(selectedFile === null || selectedFile === void 0 ? void 0 : selectedFile.path.includes("source_files")),
355
+ } })),
356
+ react_1.default.createElement(react_bootstrap_2.Col, { sm: 3, className: "p-0 border-start", style: { height: "calc(100vh - 56px)", overflow: "auto" } },
357
+ react_1.default.createElement("div", { className: "p-3" },
358
+ (selectedFile === null || selectedFile === void 0 ? void 0 : selectedFile.path.endsWith("tests.json")) && (react_1.default.createElement("div", { className: "test-results-preview" }, typeof selectedFile.content === "string"
359
+ ? renderTestResults(JSON.parse(selectedFile.content))
360
+ : renderTestResults(selectedFile.content))),
361
+ (selectedFile === null || selectedFile === void 0 ? void 0 : selectedFile.path.match(/\.(png|jpg|jpeg|gif|svg)$/i)) && (react_1.default.createElement("div", { className: "text-center" },
362
+ react_1.default.createElement("img", { src: selectedFile.content, alt: selectedFile.path, className: "img-fluid", style: { maxHeight: '300px' } }),
363
+ react_1.default.createElement("div", { className: "mt-2" },
364
+ react_1.default.createElement("a", { href: selectedFile.content, target: "_blank", rel: "noopener noreferrer", className: "btn btn-sm btn-outline-primary" }, "Open Full Size")))),
365
+ (selectedFile === null || selectedFile === void 0 ? void 0 : selectedFile.path.endsWith(".json")) && !selectedFile.path.endsWith("tests.json") && (react_1.default.createElement("pre", { className: "bg-light p-2 small" },
366
+ react_1.default.createElement("code", null, selectedFile.content))),
367
+ (selectedFile === null || selectedFile === void 0 ? void 0 : selectedFile.path.includes("source_files")) && (react_1.default.createElement("div", null,
368
+ react_1.default.createElement("div", { className: "mb-2 small text-muted" },
369
+ react_1.default.createElement("i", { className: "bi bi-file-earmark-text me-1" }),
370
+ selectedFile.path.split('/').pop()),
371
+ react_1.default.createElement(react_bootstrap_2.Button, { variant: "outline-primary", size: "sm", className: "mb-2", onClick: () => {
372
+ // TODO: Add save functionality
373
+ alert("Save functionality will be implemented here");
374
+ } }, "Save Changes")))))),
375
+ react_1.default.createElement(react_bootstrap_1.ToastContainer, { position: "top-end", className: "p-3" },
376
+ react_1.default.createElement(react_bootstrap_1.Toast, { show: showToast, onClose: () => setShowToast(false), delay: 3000, autohide: true, bg: toastVariant },
377
+ react_1.default.createElement(react_bootstrap_1.Toast.Header, null,
378
+ react_1.default.createElement("strong", { className: "me-auto" }, "Command Status")),
379
+ react_1.default.createElement(react_bootstrap_1.Toast.Body, { className: "text-white" }, toastMessage)))));
133
380
  };
134
381
  exports.TestPageView = TestPageView;
382
+ // Simple file tree item component
383
+ const FileTreeItem = ({ name, isFile, level, isSelected, exists = true, onClick }) => {
384
+ const displayName = name
385
+ .replace(".json", "")
386
+ .replace(".txt", "")
387
+ .replace(".log", "")
388
+ .replace(/_/g, " ")
389
+ .replace(/^std/, "Standard ")
390
+ .replace(/^exit/, "Exit Code")
391
+ .split('/').pop();
392
+ return (react_1.default.createElement("div", { className: `d-flex align-items-center py-1 ${isSelected ? 'text-primary fw-bold' : exists ? 'text-dark' : 'text-muted'}`, style: {
393
+ paddingLeft: `${level * 16}px`,
394
+ cursor: exists ? 'pointer' : 'not-allowed',
395
+ fontSize: '0.875rem',
396
+ opacity: exists ? 1 : 0.6
397
+ }, onClick: exists ? onClick : undefined, title: exists ? undefined : "File not found or empty" },
398
+ react_1.default.createElement("i", { className: `bi ${isFile ? (exists ? 'bi-file-earmark-text' : 'bi-file-earmark') : 'bi-folder'} me-1` }),
399
+ react_1.default.createElement("span", null, displayName),
400
+ !exists && (react_1.default.createElement("i", { className: "bi bi-question-circle ms-1", title: "File not found or empty" }))));
401
+ };
402
+ const ArtifactTree = ({ treeData, projectName, testName, runtime, onSelect, level = 0, basePath = '' }) => {
403
+ const [expanded, setExpanded] = (0, react_1.useState)({});
404
+ const toggleExpand = (path) => {
405
+ setExpanded(prev => (Object.assign(Object.assign({}, prev), { [path]: !prev[path] })));
406
+ };
407
+ return (react_1.default.createElement("ul", { className: "list-unstyled", style: { paddingLeft: `${level * 16}px` } }, Object.entries(treeData).map(([name, node]) => {
408
+ const fullPath = basePath ? `${basePath}/${name}` : name;
409
+ const isExpanded = expanded[fullPath];
410
+ if (node.__isFile) {
411
+ return (react_1.default.createElement("li", { key: fullPath, className: "py-1" },
412
+ react_1.default.createElement("a", { href: `reports/${projectName}/${testName
413
+ .split('.')
414
+ .slice(0, -1)
415
+ .join('.')}/${runtime}/${node.path}`, target: "_blank", rel: "noopener noreferrer", className: "text-decoration-none", onClick: (e) => {
416
+ e.preventDefault();
417
+ onSelect(node.path);
418
+ } },
419
+ react_1.default.createElement("i", { className: "bi bi-file-earmark-text me-2" }),
420
+ name)));
421
+ }
422
+ else {
423
+ return (react_1.default.createElement("li", { key: fullPath, className: "py-1" },
424
+ react_1.default.createElement("div", { className: "d-flex align-items-center" },
425
+ react_1.default.createElement("button", { className: "btn btn-link text-start p-0 text-decoration-none me-1", onClick: () => toggleExpand(fullPath) },
426
+ react_1.default.createElement("i", { className: `bi ${isExpanded ? 'bi-folder2-open' : 'bi-folder'} me-2` }),
427
+ name)),
428
+ isExpanded && (react_1.default.createElement(ArtifactTree, { treeData: node, projectName: projectName, testName: testName, runtime: runtime, onSelect: onSelect, level: level + 1, basePath: fullPath }))));
429
+ }
430
+ })));
431
+ };
432
+ const buildArtifactTree = (testData) => {
433
+ var _a;
434
+ const artifactPaths = new Set();
435
+ (_a = testData.givens) === null || _a === void 0 ? void 0 : _a.forEach((given) => {
436
+ var _a, _b, _c;
437
+ (_a = given.artifacts) === null || _a === void 0 ? void 0 : _a.forEach((artifact) => artifactPaths.add(artifact));
438
+ (_b = given.whens) === null || _b === void 0 ? void 0 : _b.forEach((when) => { var _a; return (_a = when.artifacts) === null || _a === void 0 ? void 0 : _a.forEach((artifact) => artifactPaths.add(artifact)); });
439
+ (_c = given.thens) === null || _c === void 0 ? void 0 : _c.forEach((then) => { var _a; return (_a = then.artifacts) === null || _a === void 0 ? void 0 : _a.forEach((artifact) => artifactPaths.add(artifact)); });
440
+ });
441
+ const sortedArtifacts = Array.from(artifactPaths).sort();
442
+ return sortedArtifacts.reduce((tree, artifactPath) => {
443
+ const parts = artifactPath.split('/');
444
+ let currentLevel = tree;
445
+ parts.forEach((part, i) => {
446
+ if (!currentLevel[part]) {
447
+ currentLevel[part] = i === parts.length - 1
448
+ ? { __isFile: true, path: artifactPath }
449
+ : {};
450
+ }
451
+ currentLevel = currentLevel[part];
452
+ });
453
+ return tree;
454
+ }, {});
455
+ };
456
+ const LogNavItem = ({ logName, logContent, activeTab, setActiveTab, setSelectedFile, errorCounts, decodedTestPath, testsExist, }) => {
457
+ const displayName = logName
458
+ .replace(".json", "")
459
+ .replace(".txt", "")
460
+ .replace(".log", "")
461
+ .replace(/_/g, " ")
462
+ .replace(/^std/, "Standard ")
463
+ .replace(/^exit/, "Exit Code");
464
+ const logValue = typeof logContent === "string" ? logContent.trim() : "";
465
+ let statusIndicator = null;
466
+ if (logName === logFiles_1.STANDARD_LOGS.TYPE_ERRORS &&
467
+ (errorCounts.typeErrors > 0 || (logValue && logValue !== "0"))) {
468
+ statusIndicator = (react_1.default.createElement("span", { className: "ms-1" },
469
+ "\u274C ",
470
+ errorCounts.typeErrors || (logValue ? 1 : 0)));
471
+ }
472
+ else if (logName === logFiles_1.STANDARD_LOGS.LINT_ERRORS &&
473
+ (errorCounts.staticErrors > 0 || (logValue && logValue !== "0"))) {
474
+ statusIndicator = (react_1.default.createElement("span", { className: "ms-1" },
475
+ "\u274C ",
476
+ errorCounts.staticErrors || (logValue ? 1 : 0)));
477
+ }
478
+ else if (logName === logFiles_1.RUNTIME_SPECIFIC_LOGS.node.STDERR &&
479
+ (errorCounts.runTimeErrors > 0 || (logValue && logValue !== "0"))) {
480
+ statusIndicator = (react_1.default.createElement("span", { className: "ms-1" },
481
+ "\u274C ",
482
+ errorCounts.runTimeErrors || (logValue ? 1 : 0)));
483
+ }
484
+ else if (logName === logFiles_1.STANDARD_LOGS.EXIT && logValue !== "0") {
485
+ statusIndicator = react_1.default.createElement("span", { className: "ms-1" },
486
+ "\u26A0\uFE0F ",
487
+ logValue);
488
+ }
489
+ else if (logName === logFiles_1.STANDARD_LOGS.TESTS && logValue) {
490
+ statusIndicator = (react_1.default.createElement("div", { className: "ms-1" },
491
+ react_1.default.createElement(TestStatusBadge_1.TestStatusBadge, { testName: decodedTestPath, testsExist: testsExist, runTimeErrors: errorCounts.runTimeErrors, typeErrors: errorCounts.typeErrors, staticErrors: errorCounts.staticErrors, variant: "compact", className: "mt-1" })));
492
+ }
493
+ return (react_1.default.createElement(react_bootstrap_2.Nav.Item, { key: logName },
494
+ react_1.default.createElement(react_bootstrap_2.Nav.Link, { eventKey: logName, active: activeTab === logName, onClick: () => {
495
+ setActiveTab(logName);
496
+ setSelectedFile({
497
+ path: logName,
498
+ content: typeof logContent === "string"
499
+ ? logContent
500
+ : JSON.stringify(logContent, null, 2),
501
+ language: logName.endsWith(".json")
502
+ ? "json"
503
+ : logName.endsWith(".txt")
504
+ ? "plaintext"
505
+ : logName.endsWith(".log")
506
+ ? "log"
507
+ : "plaintext",
508
+ });
509
+ }, className: "d-flex flex-column align-items-start" },
510
+ react_1.default.createElement("div", { className: "d-flex justify-content-between w-100" },
511
+ react_1.default.createElement("span", { className: "text-capitalize" }, displayName),
512
+ statusIndicator))));
513
+ };