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