testeranto 0.200.0 → 0.202.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 (376) hide show
  1. package/README.md +26 -1
  2. package/bundle.js +3 -2
  3. package/design-editor/DesignEditor.tsx +40 -241
  4. package/dist/common/design-editor/DesignEditor.js +33 -198
  5. package/dist/common/src/App.js +158 -16
  6. package/dist/common/src/PM/PM_WithBuild.js +135 -0
  7. package/dist/common/src/PM/PM_WithEslintAndTsc.js +79 -67
  8. package/dist/common/src/PM/PM_WithGit.js +517 -0
  9. package/dist/common/src/PM/PM_WithProcesses.js +519 -0
  10. package/dist/common/src/PM/PM_WithWebSocket.js +535 -0
  11. package/dist/common/src/PM/base.js +62 -0
  12. package/dist/common/src/PM/main.js +533 -1676
  13. package/dist/common/src/PM/metafileOutputs.js +78 -0
  14. package/dist/common/src/PM/node.js +0 -6
  15. package/dist/common/src/PM/pure.js +0 -8
  16. package/dist/common/src/PM/types.js +1 -0
  17. package/dist/common/src/PM/utils.js +210 -0
  18. package/dist/common/src/PM/web.js +0 -6
  19. package/dist/common/src/ReportServer.js +0 -10
  20. package/dist/common/src/ReportServerLib.js +0 -140
  21. package/dist/common/src/components/pure/AppFrame.js +68 -56
  22. package/dist/common/src/components/pure/ArtifactTree.js +80 -0
  23. package/dist/common/src/components/pure/BuildLogViewer.js +106 -0
  24. package/dist/common/src/components/pure/DebugEnv.js +30 -0
  25. package/dist/common/src/components/pure/FileTree.js +34 -0
  26. package/dist/common/src/components/pure/FileTreeItem.js +29 -0
  27. package/dist/common/src/components/pure/GitHubLoginButton.js +18 -0
  28. package/dist/common/src/components/pure/GitIntegrationView.js +342 -0
  29. package/dist/common/src/components/pure/ProcessManager.js +1 -0
  30. package/dist/common/src/components/pure/ProcessManagerView.js +73 -74
  31. package/dist/common/src/components/pure/ProjectPageView.js +4 -117
  32. package/dist/common/src/components/pure/Settings.js +121 -0
  33. package/dist/common/src/components/pure/Settings.test.js +34 -0
  34. package/dist/common/src/components/pure/SignIn.js +22 -0
  35. package/dist/common/src/components/pure/SingleProcessView.js +166 -213
  36. package/dist/common/src/components/pure/TestPageView.js +113 -368
  37. package/dist/common/src/components/pure/TestPageView_utils.js +117 -0
  38. package/dist/common/src/components/pure/TestTable.js +33 -0
  39. package/dist/common/src/components/pure/ToastNotification.js +14 -0
  40. package/dist/common/src/components/pure/UserProfile.js +27 -0
  41. package/dist/common/src/components/stateful/AuthCallbackPage.js +51 -0
  42. package/dist/common/src/components/stateful/FeaturesReporter.js +2 -1
  43. package/dist/common/src/components/stateful/FileTree.js +58 -39
  44. package/dist/common/src/components/stateful/GitIntegrationPage.js +12 -0
  45. package/dist/common/src/components/stateful/ProcessManagerPage.js +13 -15
  46. package/dist/common/src/components/stateful/ProjectPage.js +6 -5
  47. package/dist/common/src/components/stateful/ProjectsPage.js +17 -19
  48. package/dist/common/src/components/stateful/SingleProcessPage.js +16 -26
  49. package/dist/common/src/components/stateful/TestPage.js +7 -5
  50. package/dist/common/src/hooks/useGitMode.js +21 -0
  51. package/dist/common/src/lib/BaseSuite.test/mock.js +15 -8
  52. package/dist/common/src/lib/BaseSuite.test/test.js +56 -80
  53. package/dist/common/src/lib/Tiposkripto.js +24 -0
  54. package/dist/common/src/lib/Tiposkripto.test/MockTiposkripto.js +154 -10
  55. package/dist/common/src/lib/Tiposkripto.test/Tiposkripto.adapter.js +6 -12
  56. package/dist/common/src/lib/Tiposkripto.test/Tiposkripto.implementation.js +63 -23
  57. package/dist/common/src/lib/Tiposkripto.test/Tiposkripto.specification.js +14 -6
  58. package/dist/common/src/lib/pmProxy.test/specification.js +167 -52
  59. package/dist/common/src/services/FileService.js +505 -0
  60. package/dist/common/src/services/GitHubAuthService.js +184 -0
  61. package/dist/common/src/testeranto.js +38 -97
  62. package/dist/common/src/utils/api.js +12 -8
  63. package/dist/common/src/utils/gitTest.js +27 -0
  64. package/dist/common/src/utils.js +23 -13
  65. package/dist/common/testeranto.config.js +21 -17
  66. package/dist/common/tsconfig.common.tsbuildinfo +1 -1
  67. package/dist/module/design-editor/DesignEditor.js +33 -199
  68. package/dist/module/src/App.js +121 -15
  69. package/dist/module/src/PM/PM_WithBuild.js +128 -0
  70. package/dist/module/src/PM/PM_WithEslintAndTsc.js +79 -67
  71. package/dist/module/src/PM/PM_WithGit.js +477 -0
  72. package/dist/module/src/PM/PM_WithProcesses.js +479 -0
  73. package/dist/module/src/PM/PM_WithWebSocket.js +528 -0
  74. package/dist/module/src/PM/base.js +62 -0
  75. package/dist/module/src/PM/main.js +533 -1676
  76. package/dist/module/src/PM/metafileOutputs.js +78 -0
  77. package/dist/module/src/PM/node.js +0 -6
  78. package/dist/module/src/PM/pure.js +0 -8
  79. package/dist/module/src/PM/types.js +1 -1
  80. package/dist/module/src/PM/utils.js +196 -0
  81. package/dist/module/src/PM/web.js +0 -6
  82. package/dist/module/src/ReportServer.js +1 -9
  83. package/dist/module/src/ReportServerLib.js +1 -134
  84. package/dist/module/src/components/pure/AppFrame.js +66 -24
  85. package/dist/module/src/components/pure/ArtifactTree.js +80 -0
  86. package/dist/module/src/components/pure/BuildLogViewer.js +99 -0
  87. package/dist/module/src/components/pure/DebugEnv.js +23 -0
  88. package/dist/module/src/components/pure/FileTree.js +27 -0
  89. package/dist/module/src/components/pure/FileTreeItem.js +22 -0
  90. package/dist/module/src/components/pure/GitHubLoginButton.js +11 -0
  91. package/dist/module/src/components/pure/GitIntegrationView.js +305 -0
  92. package/dist/module/src/components/pure/ProcessManager.js +1 -0
  93. package/dist/module/src/components/pure/ProcessManagerView.js +74 -75
  94. package/dist/module/src/components/pure/ProjectPageView.js +5 -118
  95. package/dist/module/src/components/pure/Settings.js +84 -0
  96. package/dist/module/src/components/pure/Settings.test.js +29 -0
  97. package/dist/module/src/components/pure/SignIn.js +15 -0
  98. package/dist/module/src/components/pure/SingleProcessView.js +130 -214
  99. package/dist/module/src/components/pure/TestPageView.js +97 -352
  100. package/dist/module/src/components/pure/TestPageView_utils.js +109 -0
  101. package/dist/module/src/components/pure/TestTable.js +26 -0
  102. package/dist/module/src/components/pure/ToastNotification.js +7 -0
  103. package/dist/module/src/components/pure/UserProfile.js +20 -0
  104. package/dist/module/src/components/stateful/AuthCallbackPage.js +14 -0
  105. package/dist/module/src/components/stateful/FeaturesReporter.js +2 -1
  106. package/dist/module/src/components/stateful/FileTree.js +59 -33
  107. package/dist/module/src/components/stateful/GitIntegrationPage.js +5 -0
  108. package/dist/module/src/components/stateful/ProcessManagerPage.js +13 -15
  109. package/dist/module/src/components/stateful/ProjectPage.js +6 -5
  110. package/dist/module/src/components/stateful/ProjectsPage.js +16 -18
  111. package/dist/module/src/components/stateful/SingleProcessPage.js +16 -26
  112. package/dist/module/src/components/stateful/TestPage.js +8 -6
  113. package/dist/module/src/hooks/useGitMode.js +17 -0
  114. package/dist/module/src/lib/BaseSuite.test/mock.js +15 -8
  115. package/dist/module/src/lib/BaseSuite.test/test.js +56 -80
  116. package/dist/module/src/lib/Tiposkripto.js +24 -0
  117. package/dist/module/src/lib/Tiposkripto.test/MockTiposkripto.js +154 -10
  118. package/dist/module/src/lib/Tiposkripto.test/Tiposkripto.adapter.js +6 -12
  119. package/dist/module/src/lib/Tiposkripto.test/Tiposkripto.implementation.js +63 -23
  120. package/dist/module/src/lib/Tiposkripto.test/Tiposkripto.specification.js +14 -6
  121. package/dist/module/src/lib/pmProxy.test/specification.js +167 -52
  122. package/dist/module/src/services/FileService.js +468 -0
  123. package/dist/module/src/services/GitHubAuthService.js +180 -0
  124. package/dist/module/src/testeranto.js +38 -97
  125. package/dist/module/src/utils/api.js +10 -7
  126. package/dist/module/src/utils/gitTest.js +23 -0
  127. package/dist/module/src/utils.js +21 -12
  128. package/dist/module/testeranto.config.js +21 -17
  129. package/dist/module/tsconfig.module.tsbuildinfo +1 -1
  130. package/dist/prebuild/App.css +94 -121
  131. package/dist/prebuild/App.js +44601 -11225
  132. package/dist/prebuild/testeranto.mjs +4106 -0
  133. package/dist/types/design-editor/DesignEditor.d.ts +1 -18
  134. package/dist/types/src/App.d.ts +18 -0
  135. package/dist/types/src/PM/PM_WithBuild.d.ts +13 -0
  136. package/dist/types/src/PM/PM_WithEslintAndTsc.d.ts +2 -4
  137. package/dist/types/src/PM/PM_WithGit.d.ts +27 -0
  138. package/dist/types/src/PM/PM_WithProcesses.d.ts +29 -0
  139. package/dist/types/src/PM/PM_WithWebSocket.d.ts +108 -0
  140. package/dist/types/src/PM/base.d.ts +1 -1
  141. package/dist/types/src/PM/index.d.ts +0 -2
  142. package/dist/types/src/PM/main.d.ts +6 -77
  143. package/dist/types/src/PM/metafileOutputs.d.ts +0 -0
  144. package/dist/types/src/PM/node.d.ts +0 -2
  145. package/dist/types/src/PM/pure.d.ts +0 -2
  146. package/dist/types/src/PM/types.d.ts +118 -0
  147. package/dist/types/src/PM/utils.d.ts +35 -0
  148. package/dist/types/src/PM/web.d.ts +0 -2
  149. package/dist/types/src/Pure.d.ts +6 -1
  150. package/dist/types/src/ReportServer.d.ts +0 -1
  151. package/dist/types/src/ReportServerLib.d.ts +0 -1
  152. package/dist/types/src/Types.d.ts +1 -0
  153. package/dist/types/src/components/pure/ArtifactTree.d.ts +0 -0
  154. package/dist/types/src/components/pure/BuildLogViewer.d.ts +7 -0
  155. package/dist/types/src/components/pure/DebugEnv.d.ts +2 -0
  156. package/dist/types/src/components/pure/FileTree.d.ts +6 -0
  157. package/dist/types/src/components/pure/FileTreeItem.d.ts +8 -0
  158. package/dist/types/src/components/pure/GitHubLoginButton.d.ts +8 -0
  159. package/dist/types/src/components/pure/GitIntegrationView.d.ts +1 -0
  160. package/dist/types/src/components/pure/Settings.d.ts +1 -0
  161. package/dist/types/src/components/pure/Settings.test.d.ts +1 -0
  162. package/dist/types/src/components/pure/SignIn.d.ts +1 -0
  163. package/dist/types/src/components/pure/SingleProcessView.d.ts +10 -0
  164. package/dist/types/src/components/pure/TestPageView.d.ts +2 -1
  165. package/dist/types/src/components/pure/TestPageView_utils.d.ts +23 -0
  166. package/dist/types/src/components/pure/TestTable.d.ts +16 -0
  167. package/dist/types/src/components/pure/ToastNotification.d.ts +6 -0
  168. package/dist/types/src/components/pure/UserProfile.d.ts +2 -0
  169. package/dist/types/src/components/stateful/AuthCallbackPage.d.ts +2 -0
  170. package/dist/types/src/components/stateful/FileTree.d.ts +0 -8
  171. package/dist/types/src/components/stateful/GitIntegrationPage.d.ts +1 -0
  172. package/dist/types/src/hooks/useGitMode.d.ts +7 -0
  173. package/dist/types/src/lib/BaseSuite.test/mock.d.ts +2 -2
  174. package/dist/types/src/lib/BaseSuite.test/test.d.ts +4 -3
  175. package/dist/types/src/lib/Tiposkripto.d.ts +2 -0
  176. package/dist/types/src/lib/Tiposkripto.test/MockTiposkripto.d.ts +3 -0
  177. package/dist/types/src/lib/Tiposkripto.test/Tiposkripto.types.d.ts +5 -0
  178. package/dist/types/src/lib/index.d.ts +6 -0
  179. package/dist/types/src/services/FileService.d.ts +34 -0
  180. package/dist/types/src/services/GitHubAuthService.d.ts +32 -0
  181. package/dist/types/src/utils/api.d.ts +1 -0
  182. package/dist/types/src/utils/gitTest.d.ts +11 -0
  183. package/dist/types/src/utils.d.ts +3 -3
  184. package/dist/types/tsconfig.types.tsbuildinfo +1 -1
  185. package/example/__pycache__/Calculator.cpython-313.pyc +0 -0
  186. package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/README.md +187 -0
  187. package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/base_given.go +163 -0
  188. package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/base_suite.go +85 -0
  189. package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/base_then.go +21 -0
  190. package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/base_when.go +21 -0
  191. package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/golingvu.go +554 -0
  192. package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/test_adapter.go +33 -0
  193. package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/types.go +72 -0
  194. package/example/vendor/modules.txt +5 -0
  195. package/git-integration-plan.md +395 -0
  196. package/package.json +26 -14
  197. package/src/App.tsx +169 -18
  198. package/src/PM/PM_WithBuild.ts +171 -0
  199. package/src/PM/PM_WithEslintAndTsc.ts +109 -86
  200. package/src/PM/PM_WithGit.ts +585 -0
  201. package/src/PM/PM_WithProcesses.ts +639 -0
  202. package/src/PM/PM_WithWebSocket.ts +631 -0
  203. package/src/PM/base.ts +63 -1
  204. package/src/PM/index.ts +8 -5
  205. package/src/PM/main.ts +672 -2050
  206. package/src/PM/metafileOutputs.ts +90 -0
  207. package/src/PM/node.ts +18 -18
  208. package/src/PM/pure.ts +5 -13
  209. package/src/PM/types.ts +145 -0
  210. package/src/PM/utils.ts +256 -0
  211. package/src/PM/web.ts +8 -8
  212. package/src/README.md +122 -0
  213. package/src/ReportServer.ts +0 -12
  214. package/src/ReportServerLib.ts +0 -147
  215. package/src/Types.ts +1 -0
  216. package/src/app.scss +14 -164
  217. package/src/components/pure/AppFrame.tsx +237 -71
  218. package/src/components/pure/ArtifactTree.tsx +82 -0
  219. package/src/components/pure/BuildLogViewer.tsx +168 -0
  220. package/src/components/pure/DebugEnv.tsx +30 -0
  221. package/src/components/pure/FileTree.tsx +58 -0
  222. package/src/components/pure/FileTreeItem.tsx +49 -0
  223. package/src/components/pure/GitHubLoginButton.tsx +31 -0
  224. package/src/components/pure/GitIntegrationView.tsx +443 -0
  225. package/src/components/pure/ProcessManager.tsx +6 -5
  226. package/src/components/pure/ProcessManagerView.tsx +162 -166
  227. package/src/components/pure/ProjectPageView.tsx +6 -224
  228. package/src/components/pure/Settings.test.tsx +34 -0
  229. package/src/components/pure/Settings.tsx +163 -0
  230. package/src/components/pure/SignIn.tsx +33 -0
  231. package/src/components/pure/SingleProcessView.tsx +231 -235
  232. package/src/components/pure/TestPageView.test/specification.ts +1 -0
  233. package/src/components/pure/TestPageView.tsx +317 -826
  234. package/src/components/pure/TestPageView_utils.tsx +285 -0
  235. package/src/components/pure/TestTable.tsx +88 -0
  236. package/src/components/pure/ToastNotification.tsx +19 -0
  237. package/src/components/pure/UserProfile.tsx +44 -0
  238. package/src/components/stateful/AuthCallbackPage.tsx +21 -0
  239. package/src/components/stateful/FeaturesReporter.tsx +3 -1
  240. package/src/components/stateful/FileTree.tsx +58 -58
  241. package/src/components/stateful/GitIntegrationPage.tsx +8 -0
  242. package/src/components/stateful/ProcessManagerPage.tsx +13 -17
  243. package/src/components/stateful/ProjectPage.tsx +6 -5
  244. package/src/components/stateful/ProjectsPage.tsx +17 -19
  245. package/src/components/stateful/SVGEditor/CircleForm.tsx +68 -0
  246. package/src/components/stateful/SVGEditor/GroupForm.tsx +56 -0
  247. package/src/components/stateful/SVGEditor/RectForm.tsx +74 -0
  248. package/src/components/stateful/SVGEditor/SVGAttributeField.tsx +29 -0
  249. package/src/components/stateful/SVGEditor/SVGAttributesEditor.tsx +73 -0
  250. package/src/components/stateful/SVGEditor/SVGEditorControls.tsx +45 -0
  251. package/src/components/stateful/SVGEditor/SVGElementForm.tsx +45 -0
  252. package/src/components/stateful/SVGEditor/SVGPreview.tsx +225 -0
  253. package/src/components/stateful/SVGEditor/SVGTextEditor.tsx +166 -0
  254. package/src/components/stateful/SVGEditor/SVGTree.tsx +159 -0
  255. package/src/components/stateful/SVGEditor/SVGTypes.ts +36 -0
  256. package/src/components/stateful/SVGEditor/svg.xsd.xml +3038 -0
  257. package/src/components/stateful/SVGEditorPage.tsx +503 -0
  258. package/src/components/stateful/SingleProcessPage.tsx +18 -31
  259. package/src/components/stateful/TestPage.tsx +25 -22
  260. package/src/golingvu/golingvu.go +38 -2
  261. package/src/hooks/useGitMode.ts +20 -0
  262. package/src/lib/BaseSuite.test/mock.ts +16 -10
  263. package/src/lib/BaseSuite.test/test.ts +144 -103
  264. package/src/lib/Tiposkripto.test/MockTiposkripto.ts +178 -14
  265. package/src/lib/Tiposkripto.test/Tiposkripto.adapter.ts +9 -14
  266. package/src/lib/Tiposkripto.test/Tiposkripto.implementation.ts +78 -38
  267. package/src/lib/Tiposkripto.test/Tiposkripto.specification.ts +51 -9
  268. package/src/lib/Tiposkripto.test/Tiposkripto.types.ts +5 -0
  269. package/src/lib/Tiposkripto.ts +27 -0
  270. package/src/lib/index.ts +7 -0
  271. package/src/lib/pmProxy.test/specification.ts +168 -166
  272. package/src/pitono/PM/__pycache__/python.cpython-313.pyc +0 -0
  273. package/src/pitono/__pycache__/Pitono.cpython-313.pyc +0 -0
  274. package/src/pitono/__pycache__/__init__.cpython-313.pyc +0 -0
  275. package/src/pitono/__pycache__/base_given.cpython-313.pyc +0 -0
  276. package/src/pitono/__pycache__/base_suite.cpython-313.pyc +0 -0
  277. package/src/pitono/__pycache__/base_then.cpython-313.pyc +0 -0
  278. package/src/pitono/__pycache__/base_when.cpython-313.pyc +0 -0
  279. package/src/pitono/__pycache__/core_generator.cpython-313.pyc +0 -0
  280. package/src/pitono/__pycache__/simple_adapter.cpython-313.pyc +0 -0
  281. package/src/pitono/__pycache__/types.cpython-313.pyc +0 -0
  282. package/src/services/FileService.ts +542 -0
  283. package/src/services/GitHubAuthService.ts +240 -0
  284. package/src/testeranto.ts +62 -140
  285. package/src/utils/api.ts +15 -13
  286. package/src/utils/gitTest.ts +29 -0
  287. package/src/utils.ts +21 -12
  288. package/testeranto/App.css +94 -121
  289. package/testeranto/App.js +44601 -11225
  290. package/testeranto/bundles/golang/core/Calculator.golingvu.go +53 -0
  291. package/testeranto/bundles/golang/core/Calculator.golingvu.golingvu.go +53 -0
  292. package/testeranto/bundles/node/core/chunk-RIM6RECA.mjs +1170 -0
  293. package/testeranto/bundles/node/core/chunk-VXVF7WFO.mjs +4321 -0
  294. package/testeranto/bundles/node/core/example/Calculator.test.mjs +503 -0
  295. package/testeranto/bundles/node/core/src/lib/BaseSuite.test/node.test.mjs +94 -1231
  296. package/testeranto/bundles/node/core/src/lib/TipoSkripto.test/TipoSkripto.mjs +574 -0
  297. package/testeranto/bundles/node/core/src/lib/pmProxy.test/index.mjs +482 -0
  298. package/testeranto/bundles/pure/core/chunk-XYOCRDEQ.mjs +1080 -0
  299. package/testeranto/bundles/pure/core/src/Pure.test.mjs +410 -0
  300. package/testeranto/bundles/pure/core/src/lib/BaseSuite.test/pure.test.mjs +93 -1146
  301. package/testeranto/bundles/python/core/Calculator.pitono.test.py +24 -0
  302. package/testeranto/bundles/python/core/test_example.py +24 -0
  303. package/testeranto/bundles/web/core/MPLUSRounded1c-Black-O75GP5JI.ttf +0 -0
  304. package/testeranto/bundles/web/core/MPLUSRounded1c-Bold-R524Q5BH.ttf +0 -0
  305. package/testeranto/bundles/web/core/MPLUSRounded1c-ExtraBold-C6GRMYVT.ttf +0 -0
  306. package/testeranto/bundles/web/core/MPLUSRounded1c-Light-WKN65Y2C.ttf +0 -0
  307. package/testeranto/bundles/web/core/MPLUSRounded1c-Medium-ZC4DWL7C.ttf +0 -0
  308. package/testeranto/bundles/web/core/MPLUSRounded1c-Regular-DT6EKZ3S.ttf +0 -0
  309. package/testeranto/bundles/web/core/MPLUSRounded1c-Thin-YWDNVG6M.ttf +0 -0
  310. package/testeranto/bundles/web/core/chunk-DFRN4SYZ.mjs +2297 -0
  311. package/testeranto/bundles/web/core/chunk-JMDLMADH.mjs +27996 -0
  312. package/testeranto/bundles/web/core/chunk-LQMU5NCG.mjs +3082 -0
  313. package/testeranto/bundles/web/core/chunk-Q5TONB2Z.mjs +6874 -0
  314. package/testeranto/bundles/web/core/src/components/pure/FeaturesReporterView.test/index.mjs +164 -0
  315. package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.css +11697 -0
  316. package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.mjs +336 -0
  317. package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.css +11697 -0
  318. package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.mjs +517 -0
  319. package/testeranto/bundles/web/core/src/lib/BaseSuite.test/web.test.mjs +107 -1134
  320. package/testeranto/metafiles/golang/core.json +3 -3
  321. package/testeranto/metafiles/node/core.json +474 -31
  322. package/testeranto/metafiles/pure/core.json +144 -28
  323. package/testeranto/metafiles/python/core.json +11 -0
  324. package/testeranto/metafiles/web/core.json +15829 -45
  325. package/testeranto/reports/core/config.json +40 -0
  326. package/testeranto/reports/core/src/Pure.test/pure/exit.log +0 -0
  327. package/testeranto/reports/core/src/Pure.test/pure/lint_errors.txt +0 -0
  328. package/testeranto/reports/core/src/Pure.test/pure/prompt.txt +14 -0
  329. package/testeranto/reports/core/src/Pure.test/pure/type_errors.txt +73 -0
  330. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/debug.log +0 -0
  331. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/error.log +91 -0
  332. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/exit.log +1 -0
  333. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/info.log +2 -0
  334. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/tests.json +68 -0
  335. package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/warn.log +0 -0
  336. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/debug.log +0 -0
  337. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/error.log +30 -0
  338. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/exit.log +1 -0
  339. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/info.log +2 -0
  340. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/tests.json +88 -0
  341. package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/warn.log +0 -0
  342. package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/lint_errors.txt +0 -6
  343. package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/prompt.txt +0 -11
  344. package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/stdout.log +1 -0
  345. package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/tests.json +1 -1
  346. package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/type_errors.txt +35 -38
  347. package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/lint_errors.txt +0 -2
  348. package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/prompt.txt +0 -10
  349. package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/type_errors.txt +40 -38
  350. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/tests.json +1 -1
  351. package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/exit.log +1 -0
  352. package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/lint_errors.txt +0 -0
  353. package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/message.txt +17 -0
  354. package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/prompt.txt +17 -0
  355. package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/stderr.log +55 -0
  356. package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/stdout.log +191 -0
  357. package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/type_errors.txt +71 -0
  358. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/exit.log +1 -0
  359. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/lint_errors.txt +15 -0
  360. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/message.txt +17 -0
  361. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/prompt.txt +17 -0
  362. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/stderr.log +20 -0
  363. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/stdout.log +4 -0
  364. package/testeranto/reports/core/src/lib/pmProxy.test/index/node/type_errors.txt +49 -0
  365. package/testeranto/reports/core/summary.json +34 -6
  366. package/testeranto.config.ts +26 -20
  367. package/tsc.log +141 -91
  368. package/tsconfig.json +6 -2
  369. package/dist/prebuild/ReportServer.mjs +0 -227
  370. package/dist/prebuild/mothership/index.mjs +0 -22
  371. package/dist/types/design-editor/server.d.ts +0 -1
  372. package/testeranto/bundles/web/core/src/lib/BaseSuite.test/web.test.html +0 -15
  373. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/lint_errors.txt +0 -2
  374. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/prompt.txt +0 -25
  375. package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/type_errors.txt +0 -56
  376. /package/testeranto/reports/core/src/{lib/BaseSuite.test/web.test/web → Pure.test/pure}/message.txt +0 -0
@@ -0,0 +1,535 @@
1
+ "use strict";
2
+ /* eslint-disable @typescript-eslint/ban-ts-comment */
3
+ /* eslint-disable no-async-promise-executor */
4
+ /* eslint-disable @typescript-eslint/no-explicit-any */
5
+ /* eslint-disable @typescript-eslint/no-unused-vars */
6
+ var __importDefault = (this && this.__importDefault) || function (mod) {
7
+ return (mod && mod.__esModule) ? mod : { "default": mod };
8
+ };
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.PM_WithWebSocket = void 0;
11
+ const node_child_process_1 = require("node:child_process");
12
+ const fs_1 = __importDefault(require("fs"));
13
+ const http_1 = __importDefault(require("http"));
14
+ const url_1 = __importDefault(require("url"));
15
+ const mime_types_1 = __importDefault(require("mime-types"));
16
+ const ws_1 = require("ws");
17
+ const base_js_1 = require("./base.js");
18
+ class PM_WithWebSocket extends base_js_1.PM_Base {
19
+ constructor(configs) {
20
+ super(configs);
21
+ this.clients = new Set();
22
+ this.runningProcesses = new Map();
23
+ this.allProcesses = new Map();
24
+ this.processLogs = new Map();
25
+ // Create HTTP server
26
+ this.httpServer = http_1.default.createServer(this.requestHandler.bind(this));
27
+ // Start WebSocket server attached to the HTTP server
28
+ this.wss = new ws_1.WebSocketServer({ server: this.httpServer });
29
+ this.wss.on("connection", (ws) => {
30
+ this.clients.add(ws);
31
+ console.log("Client connected");
32
+ ws.on("message", (data) => {
33
+ var _a, _b;
34
+ try {
35
+ const message = JSON.parse(data.toString());
36
+ if (message.type === "executeCommand") {
37
+ const executeMessage = message;
38
+ // Validate the command starts with 'aider'
39
+ if (message.command && message.command.trim().startsWith("aider")) {
40
+ console.log(`Executing command: ${message.command}`);
41
+ // Execute the command
42
+ const processId = Date.now().toString();
43
+ const child = (0, node_child_process_1.spawn)(message.command, {
44
+ shell: true,
45
+ cwd: process.cwd(),
46
+ });
47
+ // Track the process in both maps
48
+ this.runningProcesses.set(processId, child);
49
+ this.allProcesses.set(processId, {
50
+ child,
51
+ status: "running",
52
+ command: message.command,
53
+ pid: child.pid,
54
+ timestamp: new Date().toISOString(),
55
+ type: "process",
56
+ category: "aider",
57
+ });
58
+ // Initialize logs for this process
59
+ this.processLogs.set(processId, []);
60
+ // Broadcast process started
61
+ this.broadcast({
62
+ type: "processStarted",
63
+ processId,
64
+ command: message.command,
65
+ timestamp: new Date().toISOString(),
66
+ logs: [],
67
+ });
68
+ // Capture stdout and stderr
69
+ (_a = child.stdout) === null || _a === void 0 ? void 0 : _a.on("data", (data) => {
70
+ const logData = data.toString();
71
+ // Add to stored logs
72
+ const logs = this.processLogs.get(processId) || [];
73
+ logs.push(logData);
74
+ this.processLogs.set(processId, logs);
75
+ this.broadcast({
76
+ type: "processStdout",
77
+ processId,
78
+ data: logData,
79
+ timestamp: new Date().toISOString(),
80
+ });
81
+ });
82
+ (_b = child.stderr) === null || _b === void 0 ? void 0 : _b.on("data", (data) => {
83
+ const logData = data.toString();
84
+ // Add to stored logs
85
+ const logs = this.processLogs.get(processId) || [];
86
+ logs.push(logData);
87
+ this.processLogs.set(processId, logs);
88
+ this.broadcast({
89
+ type: "processStderr",
90
+ processId,
91
+ data: logData,
92
+ timestamp: new Date().toISOString(),
93
+ });
94
+ });
95
+ child.on("error", (error) => {
96
+ console.error(`Failed to execute command: ${error}`);
97
+ this.runningProcesses.delete(processId);
98
+ // Update the process status to error
99
+ const processInfo = this.allProcesses.get(processId);
100
+ if (processInfo) {
101
+ this.allProcesses.set(processId, Object.assign(Object.assign({}, processInfo), { status: "error", error: error.message }));
102
+ }
103
+ this.broadcast({
104
+ type: "processError",
105
+ processId,
106
+ error: error.message,
107
+ timestamp: new Date().toISOString(),
108
+ });
109
+ });
110
+ child.on("exit", (code) => {
111
+ console.log(`Command exited with code ${code}`);
112
+ // Remove from running processes but keep in allProcesses
113
+ this.runningProcesses.delete(processId);
114
+ // Update the process status to exited
115
+ const processInfo = this.allProcesses.get(processId);
116
+ if (processInfo) {
117
+ this.allProcesses.set(processId, Object.assign(Object.assign({}, processInfo), { status: "exited", exitCode: code }));
118
+ }
119
+ this.broadcast({
120
+ type: "processExited",
121
+ processId,
122
+ exitCode: code,
123
+ timestamp: new Date().toISOString(),
124
+ });
125
+ });
126
+ }
127
+ else {
128
+ console.error('Invalid command: must start with "aider"');
129
+ }
130
+ }
131
+ else if (message.type === "getRunningProcesses") {
132
+ const getRunningMessage = message;
133
+ // Send list of all processes (both running and completed) with their full logs
134
+ const processes = Array.from(this.allProcesses.entries()).map(([id, procInfo]) => ({
135
+ processId: id,
136
+ command: procInfo.command,
137
+ pid: procInfo.pid,
138
+ status: procInfo.status,
139
+ exitCode: procInfo.exitCode,
140
+ error: procInfo.error,
141
+ timestamp: procInfo.timestamp,
142
+ category: procInfo.category,
143
+ testName: procInfo.testName,
144
+ platform: procInfo.platform,
145
+ logs: this.processLogs.get(id) || [],
146
+ }));
147
+ ws.send(JSON.stringify({
148
+ type: "runningProcesses",
149
+ processes,
150
+ }));
151
+ }
152
+ else if (message.type === "getProcess") {
153
+ const getProcessMessage = message;
154
+ // Send specific process with full logs
155
+ const processId = message.processId;
156
+ const procInfo = this.allProcesses.get(processId);
157
+ if (procInfo) {
158
+ ws.send(JSON.stringify({
159
+ type: "processData",
160
+ processId,
161
+ command: procInfo.command,
162
+ pid: procInfo.pid,
163
+ status: procInfo.status,
164
+ exitCode: procInfo.exitCode,
165
+ error: procInfo.error,
166
+ timestamp: procInfo.timestamp,
167
+ category: procInfo.category,
168
+ testName: procInfo.testName,
169
+ platform: procInfo.platform,
170
+ logs: this.processLogs.get(processId) || [],
171
+ }));
172
+ }
173
+ }
174
+ else if (message.type === "stdin") {
175
+ const stdinMessage = message;
176
+ // Handle stdin input for a process
177
+ const processId = message.processId;
178
+ const data = message.data;
179
+ console.log("Received stdin for process", processId, ":", data);
180
+ const childProcess = this.runningProcesses.get(processId);
181
+ if (childProcess && childProcess.stdin) {
182
+ console.log("Writing to process stdin");
183
+ childProcess.stdin.write(data);
184
+ }
185
+ else {
186
+ console.log("Cannot write to stdin - process not found or no stdin:", {
187
+ processExists: !!childProcess,
188
+ stdinExists: (childProcess === null || childProcess === void 0 ? void 0 : childProcess.stdin) ? true : false,
189
+ });
190
+ }
191
+ }
192
+ else if (message.type === "killProcess") {
193
+ const killProcessMessage = message;
194
+ // Handle killing a process
195
+ const processId = message.processId;
196
+ console.log("Received killProcess for process", processId);
197
+ const childProcess = this.runningProcesses.get(processId);
198
+ if (childProcess) {
199
+ console.log("Killing process");
200
+ childProcess.kill("SIGTERM");
201
+ // The process exit handler will update the status and broadcast the change
202
+ }
203
+ else {
204
+ console.log("Cannot kill process - process not found:", {
205
+ processExists: !!childProcess,
206
+ });
207
+ }
208
+ }
209
+ }
210
+ catch (error) {
211
+ console.error("Error handling WebSocket message:", error);
212
+ }
213
+ });
214
+ ws.on("close", () => {
215
+ this.clients.delete(ws);
216
+ console.log("Client disconnected");
217
+ });
218
+ ws.on("error", (error) => {
219
+ console.error("WebSocket error:", error);
220
+ this.clients.delete(ws);
221
+ });
222
+ });
223
+ // Start HTTP server
224
+ const httpPort = Number(process.env.HTTP_PORT) || 3000;
225
+ this.httpServer.listen(httpPort, () => {
226
+ console.log(`HTTP server running on http://localhost:${httpPort}`);
227
+ });
228
+ }
229
+ requestHandler(req, res) {
230
+ // Parse the URL
231
+ const parsedUrl = url_1.default.parse(req.url || "/");
232
+ const pathname = parsedUrl.pathname || "/";
233
+ // Handle health check endpoint
234
+ if (pathname === "/health") {
235
+ res.writeHead(200, { "Content-Type": "application/json" });
236
+ res.end(JSON.stringify({ status: "ok", timestamp: new Date().toISOString() }));
237
+ return;
238
+ }
239
+ // Handle root path
240
+ let processedPathname = pathname;
241
+ if (processedPathname === "/") {
242
+ processedPathname = "/index.html";
243
+ }
244
+ // Remove leading slash
245
+ let filePath = processedPathname.substring(1);
246
+ // Determine which directory to serve from
247
+ if (filePath.startsWith("reports/")) {
248
+ // Serve from reports directory
249
+ filePath = `testeranto/${filePath}`;
250
+ }
251
+ else if (filePath.startsWith("metafiles/")) {
252
+ // Serve from metafiles directory
253
+ filePath = `testeranto/${filePath}`;
254
+ }
255
+ else if (filePath === "projects.json") {
256
+ // Serve projects.json
257
+ filePath = `testeranto/${filePath}`;
258
+ }
259
+ else {
260
+ // For frontend assets, try multiple possible locations
261
+ // First, try the dist directory
262
+ const possiblePaths = [
263
+ `dist/${filePath}`,
264
+ `testeranto/dist/${filePath}`,
265
+ `../dist/${filePath}`,
266
+ `./${filePath}`,
267
+ ];
268
+ // Find the first existing file
269
+ let foundPath = null;
270
+ for (const possiblePath of possiblePaths) {
271
+ if (fs_1.default.existsSync(possiblePath)) {
272
+ foundPath = possiblePath;
273
+ break;
274
+ }
275
+ }
276
+ if (foundPath) {
277
+ filePath = foundPath;
278
+ }
279
+ else {
280
+ // If no file found, serve index.html for SPA routing
281
+ const indexPath = this.findIndexHtml();
282
+ if (indexPath) {
283
+ fs_1.default.readFile(indexPath, (err, data) => {
284
+ if (err) {
285
+ res.writeHead(404, { "Content-Type": "text/plain" });
286
+ res.end("404 Not Found");
287
+ return;
288
+ }
289
+ res.writeHead(200, { "Content-Type": "text/html" });
290
+ res.end(data);
291
+ });
292
+ return;
293
+ }
294
+ else {
295
+ res.writeHead(404, { "Content-Type": "text/plain" });
296
+ res.end("404 Not Found");
297
+ return;
298
+ }
299
+ }
300
+ }
301
+ // Check if file exists
302
+ fs_1.default.exists(filePath, (exists) => {
303
+ if (!exists) {
304
+ // For SPA routing, serve index.html if the path looks like a route
305
+ if (!processedPathname.includes(".") && processedPathname !== "/") {
306
+ const indexPath = this.findIndexHtml();
307
+ if (indexPath) {
308
+ fs_1.default.readFile(indexPath, (err, data) => {
309
+ if (err) {
310
+ res.writeHead(404, { "Content-Type": "text/plain" });
311
+ res.end("404 Not Found");
312
+ return;
313
+ }
314
+ res.writeHead(200, { "Content-Type": "text/html" });
315
+ res.end(data);
316
+ });
317
+ return;
318
+ }
319
+ else {
320
+ // Serve a simple message if index.html is not found
321
+ res.writeHead(200, { "Content-Type": "text/html" });
322
+ res.end(`
323
+ <html>
324
+ <body>
325
+ <h1>Testeranto is running</h1>
326
+ <p>Frontend files are not built yet. Run 'npm run build' to build the frontend.</p>
327
+ </body>
328
+ </html>
329
+ `);
330
+ return;
331
+ }
332
+ }
333
+ res.writeHead(404, { "Content-Type": "text/plain" });
334
+ res.end("404 Not Found");
335
+ return;
336
+ }
337
+ // Read and serve the file
338
+ fs_1.default.readFile(filePath, (err, data) => {
339
+ if (err) {
340
+ res.writeHead(500, { "Content-Type": "text/plain" });
341
+ res.end("500 Internal Server Error");
342
+ return;
343
+ }
344
+ // For HTML files, inject the configuration
345
+ if (filePath.endsWith(".html")) {
346
+ let content = data.toString();
347
+ // Inject the configuration script before the closing </body> tag
348
+ if (content.includes("</body>")) {
349
+ const configScript = `
350
+ <script>
351
+ window.testerantoConfig = ${JSON.stringify({
352
+ githubOAuth: {
353
+ clientId: process.env.GITHUB_CLIENT_ID || "",
354
+ },
355
+ serverOrigin: process.env.SERVER_ORIGIN || "http://localhost:3000",
356
+ })};
357
+ </script>
358
+ `;
359
+ content = content.replace("</body>", `${configScript}</body>`);
360
+ }
361
+ res.writeHead(200, { "Content-Type": "text/html" });
362
+ res.end(content);
363
+ }
364
+ else {
365
+ // Get MIME type for other files
366
+ const mimeType = mime_types_1.default.lookup(filePath) || "application/octet-stream";
367
+ res.writeHead(200, { "Content-Type": mimeType });
368
+ res.end(data);
369
+ }
370
+ });
371
+ });
372
+ }
373
+ findIndexHtml() {
374
+ const possiblePaths = [
375
+ "dist/index.html",
376
+ "testeranto/dist/index.html",
377
+ "../dist/index.html",
378
+ "./index.html",
379
+ ];
380
+ for (const path of possiblePaths) {
381
+ if (fs_1.default.existsSync(path)) {
382
+ return path;
383
+ }
384
+ }
385
+ return null;
386
+ }
387
+ // Add a method to track promise-based processes
388
+ addPromiseProcess(processId, promise, command, category = "other", testName, platform, onResolve, onReject) {
389
+ // Track the promise in both maps
390
+ this.runningProcesses.set(processId, promise);
391
+ this.allProcesses.set(processId, {
392
+ promise,
393
+ status: "running",
394
+ command,
395
+ timestamp: new Date().toISOString(),
396
+ type: "promise",
397
+ category,
398
+ testName,
399
+ platform,
400
+ });
401
+ // Initialize logs for this process
402
+ this.processLogs.set(processId, []);
403
+ // Add log entry for process start
404
+ const startMessage = `Starting: ${command}`;
405
+ const logs = this.processLogs.get(processId) || [];
406
+ logs.push(startMessage);
407
+ this.processLogs.set(processId, logs);
408
+ // Broadcast process started
409
+ this.broadcast({
410
+ type: "processStarted",
411
+ processId,
412
+ command,
413
+ timestamp: new Date().toISOString(),
414
+ logs: [startMessage],
415
+ });
416
+ // Handle promise resolution
417
+ promise
418
+ .then((result) => {
419
+ this.runningProcesses.delete(processId);
420
+ // Update the process status to completed
421
+ const processInfo = this.allProcesses.get(processId);
422
+ if (processInfo) {
423
+ this.allProcesses.set(processId, Object.assign(Object.assign({}, processInfo), { status: "completed", exitCode: 0 }));
424
+ }
425
+ // Add log entry for process completion
426
+ const successMessage = `Completed successfully with result: ${JSON.stringify(result)}`;
427
+ const currentLogs = this.processLogs.get(processId) || [];
428
+ currentLogs.push(successMessage);
429
+ this.processLogs.set(processId, currentLogs);
430
+ this.broadcast({
431
+ type: "processExited",
432
+ processId,
433
+ exitCode: 0,
434
+ timestamp: new Date().toISOString(),
435
+ logs: [successMessage],
436
+ });
437
+ if (onResolve)
438
+ onResolve(result);
439
+ })
440
+ .catch((error) => {
441
+ this.runningProcesses.delete(processId);
442
+ // Update the process status to error
443
+ const processInfo = this.allProcesses.get(processId);
444
+ if (processInfo) {
445
+ this.allProcesses.set(processId, Object.assign(Object.assign({}, processInfo), { status: "error", error: error.message }));
446
+ }
447
+ // Add log entry for process error
448
+ const errorMessage = `Failed with error: ${error.message}`;
449
+ const currentLogs = this.processLogs.get(processId) || [];
450
+ currentLogs.push(errorMessage);
451
+ this.processLogs.set(processId, currentLogs);
452
+ this.broadcast({
453
+ type: "processError",
454
+ processId,
455
+ error: error.message,
456
+ timestamp: new Date().toISOString(),
457
+ logs: [errorMessage],
458
+ });
459
+ if (onReject)
460
+ onReject(error);
461
+ });
462
+ return processId;
463
+ }
464
+ broadcast(message) {
465
+ const data = typeof message === "string" ? message : JSON.stringify(message);
466
+ this.clients.forEach((client) => {
467
+ if (client.readyState === 1) {
468
+ // WebSocket.OPEN
469
+ client.send(data);
470
+ }
471
+ });
472
+ }
473
+ // Helper methods to get processes by category
474
+ getProcessesByCategory(category) {
475
+ return Array.from(this.allProcesses.entries())
476
+ .filter(([id, procInfo]) => procInfo.category === category)
477
+ .map(([id, procInfo]) => ({
478
+ processId: id,
479
+ command: procInfo.command,
480
+ pid: procInfo.pid,
481
+ status: procInfo.status,
482
+ exitCode: procInfo.exitCode,
483
+ error: procInfo.error,
484
+ timestamp: procInfo.timestamp,
485
+ category: procInfo.category,
486
+ testName: procInfo.testName,
487
+ platform: procInfo.platform,
488
+ logs: this.processLogs.get(id) || [],
489
+ }));
490
+ }
491
+ getBDDTestProcesses() {
492
+ return this.getProcessesByCategory("bdd-test");
493
+ }
494
+ getBuildTimeProcesses() {
495
+ return this.getProcessesByCategory("build-time");
496
+ }
497
+ getAiderProcesses() {
498
+ return this.getProcessesByCategory("aider");
499
+ }
500
+ getProcessesByTestName(testName) {
501
+ return Array.from(this.allProcesses.entries())
502
+ .filter(([id, procInfo]) => procInfo.testName === testName)
503
+ .map(([id, procInfo]) => ({
504
+ processId: id,
505
+ command: procInfo.command,
506
+ pid: procInfo.pid,
507
+ status: procInfo.status,
508
+ exitCode: procInfo.exitCode,
509
+ error: procInfo.error,
510
+ timestamp: procInfo.timestamp,
511
+ category: procInfo.category,
512
+ testName: procInfo.testName,
513
+ platform: procInfo.platform,
514
+ logs: this.processLogs.get(id) || [],
515
+ }));
516
+ }
517
+ getProcessesByPlatform(platform) {
518
+ return Array.from(this.allProcesses.entries())
519
+ .filter(([id, procInfo]) => procInfo.platform === platform)
520
+ .map(([id, procInfo]) => ({
521
+ processId: id,
522
+ command: procInfo.command,
523
+ pid: procInfo.pid,
524
+ status: procInfo.status,
525
+ exitCode: procInfo.exitCode,
526
+ error: procInfo.error,
527
+ timestamp: procInfo.timestamp,
528
+ category: procInfo.category,
529
+ testName: procInfo.testName,
530
+ platform: procInfo.platform,
531
+ logs: this.processLogs.get(id) || [],
532
+ }));
533
+ }
534
+ }
535
+ exports.PM_WithWebSocket = PM_WithWebSocket;
@@ -18,6 +18,68 @@ class PM_Base {
18
18
  constructor(configs) {
19
19
  this.configs = configs;
20
20
  }
21
+ mapping() {
22
+ return [
23
+ ["$", this.$],
24
+ ["click", this.click],
25
+ ["closePage", this.closePage],
26
+ ["createWriteStream", this.createWriteStream],
27
+ ["customclose", this.customclose],
28
+ ["customScreenShot", this.customScreenShot.bind(this)],
29
+ ["end", this.end],
30
+ ["existsSync", this.existsSync],
31
+ ["focusOn", this.focusOn],
32
+ ["getAttribute", this.getAttribute],
33
+ ["getInnerHtml", this.getInnerHtml],
34
+ // ["setValue", this.setValue],
35
+ ["goto", this.goto.bind(this)],
36
+ ["isDisabled", this.isDisabled],
37
+ // ["launchSideCar", this.launchSideCar.bind(this)],
38
+ ["mkdirSync", this.mkdirSync],
39
+ ["newPage", this.newPage],
40
+ ["page", this.page],
41
+ ["pages", this.pages],
42
+ ["screencast", this.screencast],
43
+ ["screencastStop", this.screencastStop],
44
+ // ["stopSideCar", this.stopSideCar.bind(this)],
45
+ ["typeInto", this.typeInto],
46
+ ["waitForSelector", this.waitForSelector],
47
+ ["write", this.write],
48
+ ["writeFileSync", this.writeFileSync],
49
+ ];
50
+ }
51
+ // keep this forever. do not delete
52
+ // mapping(): [string, (...a) => any][] {
53
+ // return [
54
+ // ["$", (...args) => this.$(...args)],
55
+ // ["click", (...args) => this.click(...args)],
56
+ // ["closePage", (...args) => this.closePage(...args)],
57
+ // ["createWriteStream", (...args) => this.createWriteStream(...args)],
58
+ // ["customclose", (...args) => this.customclose(...args)],
59
+ // ["customScreenShot", (...args) => this.customScreenShot(...args)],
60
+ // ["end", (...args) => this.end(...args)],
61
+ // ["existsSync", (...args) => this.existsSync(...args)],
62
+ // ["focusOn", (...args) => this.focusOn(...args)],
63
+ // ["getAttribute", (...args) => this.getAttribute(...args)],
64
+ // ["getInnerHtml", (...args) => this.getInnerHtml(...args)],
65
+ // // ["setValue", (...args) => this.setValue(...args)],
66
+ // ["goto", (...args) => this.goto(...args)],
67
+ // ["isDisabled", (...args) => this.isDisabled(...args)],
68
+ // // ["launchSideCar", (...args) => this.launchSideCar(...args)],
69
+ // ["mkdirSync", (...args) => this.mkdirSync(...args)],
70
+ // ["newPage", (...args) => this.newPage(...args)],
71
+ // ["page", (...args) => this.page(...args)],
72
+ // ["pages", (...args) => this.pages(...args)],
73
+ // ["screencast", (...args) => this.screencast(...args)],
74
+ // ["screencastStop", (...args) => this.screencastStop(...args)],
75
+ // // ["stopSideCar", (...args) => this.stopSideCar(...args)],
76
+ // ["typeInto", (...args) => this.typeInto(...args)],
77
+ // ["waitForSelector", (...args) => this.waitForSelector(...args)],
78
+ // ["write", (...args) => this.write(...args)],
79
+ // ["writeFileSync", (...args) => this.writeFileSync(...args)],
80
+ // ];
81
+ // }
82
+ // abstract launchSideCar(n: number, testName: string, projectName: string);
21
83
  customclose() {
22
84
  throw new Error("customclose not implemented.");
23
85
  }