testeranto 0.202.0 → 0.203.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.
- package/README.md +23 -0
- package/UX/chache/index.md +11 -0
- package/dist/prebuild/App.css +78 -0
- package/dist/prebuild/App.js +4828 -2814
- package/dist/prebuild/testeranto.mjs +2650 -1037
- package/example/Calculator.go +63 -0
- package/example/Calculator.golingvu.adapter.go +81 -0
- package/example/Calculator.golingvu.go +67 -0
- package/example/Calculator.golingvu.implementation.go +95 -0
- package/example/Calculator.golingvu.specification.go +68 -0
- package/example/Calculator.pitono.adapter.py +68 -0
- package/example/Calculator.pitono.implementation.py +30 -0
- package/example/Calculator.pitono.specification.py +154 -0
- package/example/Calculator.pitono.test.py +47 -0
- package/example/Calculator.py +93 -0
- package/example/Calculator.test.adapter.ts +86 -0
- package/example/Calculator.test.implementation.ts +82 -0
- package/example/Calculator.test.specification.ts +213 -0
- package/example/Calculator.test.ts +13 -0
- package/example/Calculator.test.types.ts +50 -0
- package/example/Calculator.ts +130 -0
- package/example/README.md +1 -0
- package/example/base_suite_test.go +51 -0
- package/example/cmd/main.go +16 -0
- package/example/go.mod +9 -0
- package/example/main +0 -0
- package/example/test_example.py +143 -74
- package/{testeranto → example/testeranto}/bundles/golang/core/Calculator.golingvu.go +1 -1
- package/example/testeranto/metafiles/golang/core.json +198 -0
- package/go.mod +3 -1
- package/golingvu.tmp.txt +68 -0
- package/log.txt +85 -0
- package/package.json +50 -41
- package/scripts/build-example.ts +245 -0
- package/src/App.tsx +94 -44
- package/src/Helpo.tsx +89 -0
- package/src/PM/PM_WithBuild.ts +32 -20
- package/src/PM/PM_WithGit.ts +60 -13
- package/src/PM/PM_WithHelpo.ts +341 -0
- package/src/PM/PM_WithProcesses.ts +484 -223
- package/src/PM/PM_WithWebSocket.ts +210 -2
- package/src/PM/golingvuBuild.ts +56 -0
- package/src/PM/main.ts +570 -438
- package/src/PM/pitonoBuild.ts +56 -0
- package/src/PM/utils.ts +7 -1
- package/src/app.scss +102 -0
- package/src/components/pure/AppFrame.tsx +259 -149
- package/src/components/pure/GitIntegrationView.tsx +527 -238
- package/src/components/pure/HelpoChatDrawer.tsx +222 -0
- package/src/components/pure/MagicRobotModal.tsx +136 -0
- package/src/components/pure/ProcessDetails.tsx +99 -0
- package/src/components/pure/ProcessInput.tsx +67 -0
- package/src/components/pure/ProcessList.tsx +89 -0
- package/src/components/pure/ProcessLogs.tsx +54 -0
- package/src/components/pure/ProcessManager.tsx +37 -46
- package/src/components/pure/ProcessManagerView.tsx +42 -367
- package/src/components/pure/ProcessManagerViewTypes.ts +10 -0
- package/src/components/pure/ProcessSidebar.tsx +88 -0
- package/src/components/pure/ProcessTerminal.tsx +51 -0
- package/src/components/pure/SingleProcessView.tsx +140 -231
- package/src/components/pure/TerminalInput.tsx +73 -0
- package/src/components/pure/TerminalLogs.tsx +80 -0
- package/src/components/pure/TestPageView.tsx +21 -116
- package/src/components/pure/TestPageView_utils.tsx +2 -0
- package/src/components/stateful/DratoPage.tsx +457 -0
- package/src/components/stateful/GenericXMLEditor/AttributeEditor.tsx +87 -0
- package/src/components/stateful/GenericXMLEditor/Drawer.tsx +174 -0
- package/src/components/stateful/GenericXMLEditor/GenericPreview.tsx +160 -0
- package/src/components/stateful/GenericXMLEditor/GenericTextEditor.tsx +104 -0
- package/src/components/stateful/GenericXMLEditor/GenericTree.tsx +104 -0
- package/src/components/stateful/GenericXMLEditorPage.tsx +346 -0
- package/src/components/stateful/GitIntegrationPage.tsx +258 -3
- package/src/components/stateful/GrafeoPage.tsx +563 -0
- package/src/components/stateful/SVGEditor/SVGAttributesEditor.tsx +26 -8
- package/src/components/stateful/SVGEditor/SVGPreview.tsx +4 -2
- package/src/components/stateful/SVGEditorPage.tsx +195 -181
- package/src/components/stateful/SingleProcessPage.tsx +133 -131
- package/src/components/stateful/SkriboPage.tsx +765 -0
- package/src/components/stateful/TestPage.tsx +3 -2
- package/src/esbuildConfigs/node.ts +1 -1
- package/src/example/go.mod +9 -0
- package/src/example/main.go +61 -0
- package/src/golingvu/PM/golang_test.go +103 -0
- package/src/golingvu/README.md +186 -2
- package/src/golingvu/base_given.go +89 -2
- package/src/golingvu/base_suite.go +48 -2
- package/src/golingvu/go.mod +6 -0
- package/src/golingvu/golingvu.go +703 -29
- package/src/golingvu/types.go +0 -14
- package/src/helpo/directives.md +5 -0
- package/src/helpo/prompt.txt +38 -0
- package/src/hooks/useTerminalWebSocket.ts +49 -0
- package/src/lib/BaseGiven.ts +126 -28
- package/src/lib/BaseSuite.test/test.ts +97 -180
- package/src/lib/BaseSuite.ts +52 -10
- package/src/lib/BaseThen.ts +34 -38
- package/src/lib/BaseWhen.ts +9 -2
- package/src/lib/Tiposkripto.test/Tiposkripto.specification.ts +9 -8
- package/src/lib/Tiposkripto.ts +41 -11
- package/src/lib/pmProxy.ts +55 -18
- package/src/pitono/PM/python.py +165 -0
- package/src/pitono/Pitono.py +298 -0
- package/src/pitono/PitonoTest.py +25 -0
- package/src/pitono/README.md +21 -0
- package/src/pitono/__init__.py +6 -0
- package/{pitono → src/pitono}/base_given.py +42 -20
- package/{pitono → src/pitono}/base_suite.py +55 -2
- package/{pitono → src/pitono}/base_then.py +15 -1
- package/{pitono → src/pitono}/base_when.py +15 -1
- package/{pitono → src/pitono}/pitono.egg-info/PKG-INFO +25 -0
- package/{pitono → src/pitono}/pitono.egg-info/SOURCES.txt +1 -0
- package/src/pitono/types.py +87 -0
- package/src/services/FileService.ts +146 -11
- package/src/testeranto.ts +115 -149
- package/src/utils/golingvuMetafile.ts +822 -118
- package/src/utils/golingvuWatcher.ts +285 -0
- package/src/utils/logFiles.ts +10 -2
- package/src/utils/makePrompt.ts +12 -1
- package/src/utils/pitonoMetafile.ts +326 -54
- package/src/utils/pitonoWatcher.ts +157 -0
- package/testeranto/App.css +78 -0
- package/testeranto/App.js +4828 -2814
- package/testeranto/bundles/node/core/{chunk-RIM6RECA.mjs → chunk-MJTSYIAQ.mjs} +179 -250
- package/testeranto/bundles/node/core/src/lib/BaseSuite.test/node.test.mjs +110 -62
- package/testeranto/bundles/node/core/src/lib/TipoSkripto.test/TipoSkripto.mjs +135 -137
- package/testeranto/bundles/node/core/src/lib/pmProxy.test/index.mjs +4317 -4
- package/testeranto/bundles/pure/core/{chunk-XYOCRDEQ.mjs → chunk-6HR24P27.mjs} +96 -173
- package/testeranto/bundles/pure/core/src/Pure.test.mjs +1 -1
- package/testeranto/bundles/pure/core/src/lib/BaseSuite.test/pure.test.mjs +110 -62
- package/testeranto/bundles/web/core/{chunk-JMDLMADH.mjs → chunk-AZZHJNSU.mjs} +2473 -191
- package/testeranto/bundles/web/core/{chunk-LQMU5NCG.mjs → chunk-ME6I6FJZ.mjs} +96 -173
- package/testeranto/bundles/web/core/src/components/pure/FeaturesReporterView.test/index.html +15 -0
- package/testeranto/bundles/web/core/src/components/pure/FeaturesReporterView.test/index.mjs +3 -5
- package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.css +0 -78
- package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.html +15 -0
- package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.mjs +6476 -69
- package/testeranto/bundles/web/core/src/lib/BaseSuite.test/web.test.html +15 -0
- package/testeranto/bundles/web/core/src/lib/BaseSuite.test/web.test.mjs +110 -62
- package/testeranto/helpo_chat_history.json +1 -0
- package/testeranto/metafiles/golang/core.json +42 -47
- package/testeranto/metafiles/node/core.json +263 -247
- package/testeranto/metafiles/pure/core.json +23 -38
- package/testeranto/metafiles/python/core.json +85 -9
- package/testeranto/metafiles/web/core.json +966 -460
- package/testeranto/reports/core/config.json +30 -6
- package/testeranto/reports/core/example/Calculator.golingvu/golang/exit.log +1 -0
- package/testeranto/reports/core/example/Calculator.golingvu/golang/stderr.log +2 -0
- package/testeranto/reports/core/example/Calculator.golingvu/golang/stdout.log +1 -0
- package/testeranto/reports/core/example/Calculator.pitono.test/python/exit.log +1 -0
- package/testeranto/reports/core/example/Calculator.pitono.test/python/stderr.log +11 -0
- package/testeranto/reports/core/example/Calculator.pitono.test/python/stdout.log +1 -0
- package/testeranto/reports/core/example/Calculator.test/node/exit.log +1 -0
- package/testeranto/reports/core/example/Calculator.test/node/lint_errors.txt +2 -0
- package/testeranto/reports/core/example/Calculator.test/node/message.txt +16 -0
- package/testeranto/reports/core/example/Calculator.test/node/prompt.txt +13 -0
- package/testeranto/reports/core/example/Calculator.test/node/stderr.log +33 -0
- package/testeranto/reports/core/example/Calculator.test/node/stdout.log +1076 -0
- package/testeranto/reports/core/example/Calculator.test/node/tests.json +1109 -0
- package/testeranto/reports/core/example/Calculator.test/node/type_errors.txt +34 -0
- package/testeranto/reports/core/example/test_example/python/exit.log +1 -0
- package/testeranto/reports/core/example/test_example/python/stderr.log +24 -0
- package/testeranto/reports/core/src/Pure.test/pure/message.txt +1 -2
- package/testeranto/reports/core/src/Pure.test/pure/prompt.txt +4 -5
- package/testeranto/reports/core/src/Pure.test/pure/type_errors.txt +16 -3
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/error.log +0 -91
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/exit.log +0 -1
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/info.log +0 -2
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/message.txt +17 -0
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/prompt.txt +26 -0
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/type_errors.txt +69 -0
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/lint_errors.txt +16 -0
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/message.txt +17 -0
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/prompt.txt +27 -0
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/type_errors.txt +42 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/error.log +0 -30
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/exit.log +0 -1
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/info.log +0 -2
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/lint_errors.txt +30 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/message.txt +17 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/prompt.txt +30 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/type_errors.txt +58 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/exit.log +1 -1
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/prompt.txt +9 -1
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/stderr.log +1 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/stdout.log +4 -1
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/tests.json +98 -7
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/type_errors.txt +44 -28
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/message.txt +1 -2
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/prompt.txt +4 -6
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/type_errors.txt +44 -28
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/error.log +0 -1
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/exit.log +0 -1
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/message.txt +17 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/prompt.txt +25 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/type_errors.txt +69 -0
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/exit.log +1 -1
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/message.txt +1 -2
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/prompt.txt +4 -8
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/stderr.log +68 -35
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/stdout.log +336 -6
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/tests.json +166 -0
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/type_errors.txt +20 -13
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/exit.log +1 -1
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/prompt.txt +9 -1
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/stderr.log +0 -20
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/stdout.log +1 -3
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/tests.json +31 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/type_errors.txt +16 -3
- package/testeranto/reports/core/summary.json +46 -19
- package/testeranto.config.ts +18 -30
- package/dist/cjs-shim.js +0 -12
- package/dist/common/design-editor/DesignEditor.js +0 -77
- package/dist/common/design-editor/index.js +0 -18
- package/dist/common/design-editor/server.js +0 -98
- package/dist/common/design-editor/types.js +0 -2
- package/dist/common/package.json +0 -3
- package/dist/common/src/App.js +0 -219
- package/dist/common/src/CoreTypes.js +0 -2
- package/dist/common/src/Init.js +0 -48
- package/dist/common/src/Node.js +0 -40
- package/dist/common/src/NodeSidecar.js +0 -15
- package/dist/common/src/PM/PM_WithBuild.js +0 -135
- package/dist/common/src/PM/PM_WithEslintAndTsc.js +0 -204
- package/dist/common/src/PM/PM_WithGit.js +0 -517
- package/dist/common/src/PM/PM_WithProcesses.js +0 -519
- package/dist/common/src/PM/PM_WithWebSocket.js +0 -535
- package/dist/common/src/PM/__tests__/nodeSidecar.testeranto.js +0 -108
- package/dist/common/src/PM/__tests__/pureSidecar.testeranto.js +0 -93
- package/dist/common/src/PM/__tests__/webSidecar.testeranto.js +0 -93
- package/dist/common/src/PM/base.js +0 -319
- package/dist/common/src/PM/index.js +0 -6
- package/dist/common/src/PM/main.js +0 -672
- package/dist/common/src/PM/metafileOutputs.js +0 -78
- package/dist/common/src/PM/node.js +0 -179
- package/dist/common/src/PM/nodeSidecar.js +0 -65
- package/dist/common/src/PM/pitonoRunner.js +0 -54
- package/dist/common/src/PM/pure.js +0 -103
- package/dist/common/src/PM/pureSidecar.js +0 -48
- package/dist/common/src/PM/sidecar.js +0 -11
- package/dist/common/src/PM/types.js +0 -2
- package/dist/common/src/PM/utils.js +0 -210
- package/dist/common/src/PM/web.js +0 -106
- package/dist/common/src/PM/webSidecar.js +0 -47
- package/dist/common/src/Pure.js +0 -52
- package/dist/common/src/Pure.test.js +0 -180
- package/dist/common/src/PureSidecar.js +0 -13
- package/dist/common/src/ReportServer.js +0 -1
- package/dist/common/src/ReportServer.test.ts/index.js +0 -78
- package/dist/common/src/ReportServerLib.js +0 -1
- package/dist/common/src/Types.js +0 -2
- package/dist/common/src/Web.js +0 -61
- package/dist/common/src/WebSidecar.js +0 -14
- package/dist/common/src/components/DesignEditorPage.js +0 -205
- package/dist/common/src/components/SunriseAnimation.js +0 -291
- package/dist/common/src/components/SunriseAnimation.test/implementation.js +0 -1
- package/dist/common/src/components/SunriseAnimation.test/index.js +0 -1
- package/dist/common/src/components/SunriseAnimation.test/interface.js +0 -68
- package/dist/common/src/components/SunriseAnimation.test/specification.js +0 -1
- package/dist/common/src/components/SunriseAnimation.test/types.js +0 -2
- package/dist/common/src/components/TestStatusBadge.js +0 -35
- package/dist/common/src/components/pure/AppFrame.js +0 -81
- package/dist/common/src/components/pure/AppFrame.test/implementation.js +0 -63
- package/dist/common/src/components/pure/AppFrame.test/index.js +0 -14
- package/dist/common/src/components/pure/AppFrame.test/specification.js +0 -25
- package/dist/common/src/components/pure/AppFrame.test/types.js +0 -3
- package/dist/common/src/components/pure/ArtifactTree.js +0 -80
- package/dist/common/src/components/pure/BuildLogViewer.js +0 -106
- package/dist/common/src/components/pure/DebugEnv.js +0 -30
- package/dist/common/src/components/pure/FeaturesReporterView.js +0 -23
- package/dist/common/src/components/pure/FeaturesReporterView.test/implementation.js +0 -84
- package/dist/common/src/components/pure/FeaturesReporterView.test/index.js +0 -14
- package/dist/common/src/components/pure/FeaturesReporterView.test/specification.js +0 -27
- package/dist/common/src/components/pure/FeaturesReporterView.test/types.js +0 -2
- package/dist/common/src/components/pure/FileTree.js +0 -34
- package/dist/common/src/components/pure/FileTreeItem.js +0 -29
- package/dist/common/src/components/pure/GitHubLoginButton.js +0 -18
- package/dist/common/src/components/pure/GitIntegrationView.js +0 -342
- package/dist/common/src/components/pure/ModalContent.js +0 -86
- package/dist/common/src/components/pure/ModalContent.test/implementation.js +0 -35
- package/dist/common/src/components/pure/ModalContent.test/index.js +0 -58
- package/dist/common/src/components/pure/ModalContent.test/specification.js +0 -19
- package/dist/common/src/components/pure/ModalContent.test/types.js +0 -4
- package/dist/common/src/components/pure/NavBar.js +0 -44
- package/dist/common/src/components/pure/ProcessManager.js +0 -113
- package/dist/common/src/components/pure/ProcessManagerView.js +0 -236
- package/dist/common/src/components/pure/ProjectPageView.js +0 -68
- package/dist/common/src/components/pure/ProjectPageView.test/implementation.js +0 -184
- package/dist/common/src/components/pure/ProjectPageView.test/index.js +0 -14
- package/dist/common/src/components/pure/ProjectPageView.test/specification.js +0 -32
- package/dist/common/src/components/pure/ProjectPageView.test/types.js +0 -4
- package/dist/common/src/components/pure/ProjectsPageView.js +0 -72
- package/dist/common/src/components/pure/Settings.js +0 -121
- package/dist/common/src/components/pure/Settings.test.js +0 -34
- package/dist/common/src/components/pure/SettingsButton.js +0 -13
- package/dist/common/src/components/pure/SignIn.js +0 -22
- package/dist/common/src/components/pure/SingleProcessView.js +0 -167
- package/dist/common/src/components/pure/TestPageView.js +0 -373
- package/dist/common/src/components/pure/TestPageView.test/implementation.js +0 -157
- package/dist/common/src/components/pure/TestPageView.test/index.js +0 -15
- package/dist/common/src/components/pure/TestPageView.test/specification.js +0 -26
- package/dist/common/src/components/pure/TestPageView.test/types.js +0 -4
- package/dist/common/src/components/pure/TestPageView_utils.js +0 -117
- package/dist/common/src/components/pure/TestTable.js +0 -33
- package/dist/common/src/components/pure/ThemeCard.js +0 -15
- package/dist/common/src/components/pure/ToastNotification.js +0 -14
- package/dist/common/src/components/pure/UserProfile.js +0 -27
- package/dist/common/src/components/stateful/AuthCallbackPage.js +0 -51
- package/dist/common/src/components/stateful/FeaturesReporter.js +0 -60
- package/dist/common/src/components/stateful/FileTree.js +0 -59
- package/dist/common/src/components/stateful/GitIntegrationPage.js +0 -12
- package/dist/common/src/components/stateful/ProcessManagerPage.js +0 -110
- package/dist/common/src/components/stateful/ProjectPage.js +0 -102
- package/dist/common/src/components/stateful/ProjectsPage.js +0 -116
- package/dist/common/src/components/stateful/SettingsPage.js +0 -72
- package/dist/common/src/components/stateful/SingleProcessPage.js +0 -137
- package/dist/common/src/components/stateful/TestPage.js +0 -270
- package/dist/common/src/components/stateful/TextEditorPage.js +0 -154
- package/dist/common/src/defaultConfig.js +0 -19
- package/dist/common/src/esbuildConfigs/consoleDetectorPlugin.js +0 -38
- package/dist/common/src/esbuildConfigs/eslint-formatter-testeranto.js +0 -21
- package/dist/common/src/esbuildConfigs/featuresPlugin.js +0 -39
- package/dist/common/src/esbuildConfigs/index.js +0 -21
- package/dist/common/src/esbuildConfigs/inputFilesPlugin.js +0 -30
- package/dist/common/src/esbuildConfigs/nativeImportDetectorPlugin.js +0 -24
- package/dist/common/src/esbuildConfigs/node.js +0 -24
- package/dist/common/src/esbuildConfigs/pure.js +0 -42
- package/dist/common/src/esbuildConfigs/rebuildPlugin.js +0 -19
- package/dist/common/src/esbuildConfigs/web.js +0 -48
- package/dist/common/src/hooks/useGitMode.js +0 -21
- package/dist/common/src/init-docs.js +0 -9
- package/dist/common/src/lib/BaseGiven.js +0 -99
- package/dist/common/src/lib/BaseSuite.js +0 -91
- package/dist/common/src/lib/BaseSuite.test/mock.js +0 -68
- package/dist/common/src/lib/BaseSuite.test/node.test.js +0 -10
- package/dist/common/src/lib/BaseSuite.test/pure.test.js +0 -10
- package/dist/common/src/lib/BaseSuite.test/test.js +0 -229
- package/dist/common/src/lib/BaseSuite.test/web.test.js +0 -10
- package/dist/common/src/lib/BaseThen.js +0 -64
- package/dist/common/src/lib/BaseWhen.js +0 -45
- package/dist/common/src/lib/Sidecar.js +0 -7
- package/dist/common/src/lib/Tiposkripto.js +0 -173
- package/dist/common/src/lib/Tiposkripto.test/MockTiposkripto.js +0 -180
- package/dist/common/src/lib/Tiposkripto.test/Tiposkripto.adapter.js +0 -29
- package/dist/common/src/lib/Tiposkripto.test/Tiposkripto.implementation.js +0 -213
- package/dist/common/src/lib/Tiposkripto.test/Tiposkripto.js +0 -11
- package/dist/common/src/lib/Tiposkripto.test/Tiposkripto.specification.js +0 -50
- package/dist/common/src/lib/Tiposkripto.test/Tiposkripto.types.js +0 -2
- package/dist/common/src/lib/abstractBase.test/MockGiven.js +0 -24
- package/dist/common/src/lib/abstractBase.test/MockThen.js +0 -16
- package/dist/common/src/lib/abstractBase.test/MockWhen.js +0 -20
- package/dist/common/src/lib/abstractBase.test/adapter.js +0 -24
- package/dist/common/src/lib/abstractBase.test/implementation.js +0 -38
- package/dist/common/src/lib/abstractBase.test/index.js +0 -18
- package/dist/common/src/lib/abstractBase.test/specification.js +0 -19
- package/dist/common/src/lib/abstractBase.test/types.js +0 -2
- package/dist/common/src/lib/index.js +0 -31
- package/dist/common/src/lib/pmProxy.js +0 -293
- package/dist/common/src/lib/pmProxy.test/adapter.js +0 -54
- package/dist/common/src/lib/pmProxy.test/implementation.js +0 -137
- package/dist/common/src/lib/pmProxy.test/index.js +0 -15
- package/dist/common/src/lib/pmProxy.test/mockPM.js +0 -34
- package/dist/common/src/lib/pmProxy.test/mockPMBase.js +0 -131
- package/dist/common/src/lib/pmProxy.test/specification.js +0 -179
- package/dist/common/src/lib/pmProxy.test/types.js +0 -2
- package/dist/common/src/lib/types.js +0 -3
- package/dist/common/src/mothership/index.js +0 -21
- package/dist/common/src/mothership/test.js +0 -83
- package/dist/common/src/run.js +0 -49
- package/dist/common/src/services/FileService.js +0 -505
- package/dist/common/src/services/GitHubAuthService.js +0 -184
- package/dist/common/src/testeranto.js +0 -224
- package/dist/common/src/types/features.js +0 -34
- package/dist/common/src/utils/api.js +0 -93
- package/dist/common/src/utils/buildTemplates.js +0 -37
- package/dist/common/src/utils/featureUtils.js +0 -29
- package/dist/common/src/utils/gitTest.js +0 -27
- package/dist/common/src/utils/golingvuMetafile.js +0 -116
- package/dist/common/src/utils/logFiles.js +0 -52
- package/dist/common/src/utils/makePrompt.js +0 -116
- package/dist/common/src/utils/pitonoMetafile.js +0 -67
- package/dist/common/src/utils/queue.js +0 -36
- package/dist/common/src/utils.js +0 -143
- package/dist/common/src/web.html.js +0 -18
- package/dist/common/testeranto.config.js +0 -102
- package/dist/common/tsconfig.common.tsbuildinfo +0 -1
- package/dist/module/design-editor/DesignEditor.js +0 -40
- package/dist/module/design-editor/index.js +0 -2
- package/dist/module/design-editor/server.js +0 -92
- package/dist/module/design-editor/types.js +0 -1
- package/dist/module/package.json +0 -3
- package/dist/module/src/App.js +0 -176
- package/dist/module/src/CoreTypes.js +0 -1
- package/dist/module/src/Init.js +0 -43
- package/dist/module/src/Node.js +0 -33
- package/dist/module/src/NodeSidecar.js +0 -11
- package/dist/module/src/PM/PM_WithBuild.js +0 -128
- package/dist/module/src/PM/PM_WithEslintAndTsc.js +0 -197
- package/dist/module/src/PM/PM_WithGit.js +0 -477
- package/dist/module/src/PM/PM_WithProcesses.js +0 -479
- package/dist/module/src/PM/PM_WithWebSocket.js +0 -528
- package/dist/module/src/PM/__tests__/nodeSidecar.testeranto.js +0 -103
- package/dist/module/src/PM/__tests__/pureSidecar.testeranto.js +0 -88
- package/dist/module/src/PM/__tests__/webSidecar.testeranto.js +0 -88
- package/dist/module/src/PM/base.js +0 -312
- package/dist/module/src/PM/index.js +0 -2
- package/dist/module/src/PM/main.js +0 -632
- package/dist/module/src/PM/metafileOutputs.js +0 -78
- package/dist/module/src/PM/node.js +0 -172
- package/dist/module/src/PM/nodeSidecar.js +0 -58
- package/dist/module/src/PM/pitonoRunner.js +0 -47
- package/dist/module/src/PM/pure.js +0 -99
- package/dist/module/src/PM/pureSidecar.js +0 -41
- package/dist/module/src/PM/sidecar.js +0 -7
- package/dist/module/src/PM/types.js +0 -1
- package/dist/module/src/PM/utils.js +0 -196
- package/dist/module/src/PM/web.js +0 -102
- package/dist/module/src/PM/webSidecar.js +0 -40
- package/dist/module/src/Pure.js +0 -45
- package/dist/module/src/Pure.test.js +0 -175
- package/dist/module/src/PureSidecar.js +0 -9
- package/dist/module/src/ReportServer.js +0 -1
- package/dist/module/src/ReportServer.test.ts/index.js +0 -73
- package/dist/module/src/ReportServerLib.js +0 -1
- package/dist/module/src/Types.js +0 -1
- package/dist/module/src/Web.js +0 -54
- package/dist/module/src/WebSidecar.js +0 -10
- package/dist/module/src/components/DesignEditorPage.js +0 -168
- package/dist/module/src/components/SunriseAnimation.js +0 -256
- package/dist/module/src/components/SunriseAnimation.test/implementation.js +0 -1
- package/dist/module/src/components/SunriseAnimation.test/index.js +0 -1
- package/dist/module/src/components/SunriseAnimation.test/interface.js +0 -32
- package/dist/module/src/components/SunriseAnimation.test/specification.js +0 -1
- package/dist/module/src/components/SunriseAnimation.test/types.js +0 -1
- package/dist/module/src/components/TestStatusBadge.js +0 -28
- package/dist/module/src/components/pure/AppFrame.js +0 -74
- package/dist/module/src/components/pure/AppFrame.test/implementation.js +0 -57
- package/dist/module/src/components/pure/AppFrame.test/index.js +0 -9
- package/dist/module/src/components/pure/AppFrame.test/specification.js +0 -21
- package/dist/module/src/components/pure/AppFrame.test/types.js +0 -2
- package/dist/module/src/components/pure/ArtifactTree.js +0 -80
- package/dist/module/src/components/pure/BuildLogViewer.js +0 -99
- package/dist/module/src/components/pure/DebugEnv.js +0 -23
- package/dist/module/src/components/pure/FeaturesReporterView.js +0 -16
- package/dist/module/src/components/pure/FeaturesReporterView.test/implementation.js +0 -81
- package/dist/module/src/components/pure/FeaturesReporterView.test/index.js +0 -9
- package/dist/module/src/components/pure/FeaturesReporterView.test/specification.js +0 -23
- package/dist/module/src/components/pure/FeaturesReporterView.test/types.js +0 -1
- package/dist/module/src/components/pure/FileTree.js +0 -27
- package/dist/module/src/components/pure/FileTreeItem.js +0 -22
- package/dist/module/src/components/pure/GitHubLoginButton.js +0 -11
- package/dist/module/src/components/pure/GitIntegrationView.js +0 -305
- package/dist/module/src/components/pure/ModalContent.js +0 -79
- package/dist/module/src/components/pure/ModalContent.test/implementation.js +0 -32
- package/dist/module/src/components/pure/ModalContent.test/index.js +0 -53
- package/dist/module/src/components/pure/ModalContent.test/specification.js +0 -15
- package/dist/module/src/components/pure/ModalContent.test/types.js +0 -3
- package/dist/module/src/components/pure/NavBar.js +0 -37
- package/dist/module/src/components/pure/ProcessManager.js +0 -76
- package/dist/module/src/components/pure/ProcessManagerView.js +0 -199
- package/dist/module/src/components/pure/ProjectPageView.js +0 -61
- package/dist/module/src/components/pure/ProjectPageView.test/implementation.js +0 -181
- package/dist/module/src/components/pure/ProjectPageView.test/index.js +0 -9
- package/dist/module/src/components/pure/ProjectPageView.test/specification.js +0 -28
- package/dist/module/src/components/pure/ProjectPageView.test/types.js +0 -3
- package/dist/module/src/components/pure/ProjectsPageView.js +0 -65
- package/dist/module/src/components/pure/Settings.js +0 -84
- package/dist/module/src/components/pure/Settings.test.js +0 -29
- package/dist/module/src/components/pure/SettingsButton.js +0 -6
- package/dist/module/src/components/pure/SignIn.js +0 -15
- package/dist/module/src/components/pure/SingleProcessView.js +0 -130
- package/dist/module/src/components/pure/TestPageView.js +0 -336
- package/dist/module/src/components/pure/TestPageView.test/implementation.js +0 -121
- package/dist/module/src/components/pure/TestPageView.test/index.js +0 -10
- package/dist/module/src/components/pure/TestPageView.test/specification.js +0 -22
- package/dist/module/src/components/pure/TestPageView.test/types.js +0 -3
- package/dist/module/src/components/pure/TestPageView_utils.js +0 -109
- package/dist/module/src/components/pure/TestTable.js +0 -26
- package/dist/module/src/components/pure/ThemeCard.js +0 -8
- package/dist/module/src/components/pure/ToastNotification.js +0 -7
- package/dist/module/src/components/pure/UserProfile.js +0 -20
- package/dist/module/src/components/stateful/AuthCallbackPage.js +0 -14
- package/dist/module/src/components/stateful/FeaturesReporter.js +0 -23
- package/dist/module/src/components/stateful/FileTree.js +0 -59
- package/dist/module/src/components/stateful/GitIntegrationPage.js +0 -5
- package/dist/module/src/components/stateful/ProcessManagerPage.js +0 -73
- package/dist/module/src/components/stateful/ProjectPage.js +0 -65
- package/dist/module/src/components/stateful/ProjectsPage.js +0 -79
- package/dist/module/src/components/stateful/SettingsPage.js +0 -35
- package/dist/module/src/components/stateful/SingleProcessPage.js +0 -100
- package/dist/module/src/components/stateful/TestPage.js +0 -233
- package/dist/module/src/components/stateful/TextEditorPage.js +0 -117
- package/dist/module/src/defaultConfig.js +0 -17
- package/dist/module/src/esbuildConfigs/consoleDetectorPlugin.js +0 -32
- package/dist/module/src/esbuildConfigs/eslint-formatter-testeranto.js +0 -18
- package/dist/module/src/esbuildConfigs/featuresPlugin.js +0 -34
- package/dist/module/src/esbuildConfigs/index.js +0 -19
- package/dist/module/src/esbuildConfigs/inputFilesPlugin.js +0 -25
- package/dist/module/src/esbuildConfigs/nativeImportDetectorPlugin.js +0 -21
- package/dist/module/src/esbuildConfigs/node.js +0 -19
- package/dist/module/src/esbuildConfigs/pure.js +0 -37
- package/dist/module/src/esbuildConfigs/rebuildPlugin.js +0 -14
- package/dist/module/src/esbuildConfigs/web.js +0 -43
- package/dist/module/src/hooks/useGitMode.js +0 -17
- package/dist/module/src/init-docs.js +0 -4
- package/dist/module/src/lib/BaseGiven.js +0 -95
- package/dist/module/src/lib/BaseSuite.js +0 -87
- package/dist/module/src/lib/BaseSuite.test/mock.js +0 -61
- package/dist/module/src/lib/BaseSuite.test/node.test.js +0 -5
- package/dist/module/src/lib/BaseSuite.test/pure.test.js +0 -5
- package/dist/module/src/lib/BaseSuite.test/test.js +0 -225
- package/dist/module/src/lib/BaseSuite.test/web.test.js +0 -5
- package/dist/module/src/lib/BaseThen.js +0 -60
- package/dist/module/src/lib/BaseWhen.js +0 -41
- package/dist/module/src/lib/Sidecar.js +0 -3
- package/dist/module/src/lib/Tiposkripto.js +0 -170
- package/dist/module/src/lib/Tiposkripto.test/MockTiposkripto.js +0 -173
- package/dist/module/src/lib/Tiposkripto.test/Tiposkripto.adapter.js +0 -26
- package/dist/module/src/lib/Tiposkripto.test/Tiposkripto.implementation.js +0 -210
- package/dist/module/src/lib/Tiposkripto.test/Tiposkripto.js +0 -6
- package/dist/module/src/lib/Tiposkripto.test/Tiposkripto.specification.js +0 -46
- package/dist/module/src/lib/Tiposkripto.test/Tiposkripto.types.js +0 -1
- package/dist/module/src/lib/abstractBase.test/MockGiven.js +0 -20
- package/dist/module/src/lib/abstractBase.test/MockThen.js +0 -12
- package/dist/module/src/lib/abstractBase.test/MockWhen.js +0 -16
- package/dist/module/src/lib/abstractBase.test/adapter.js +0 -21
- package/dist/module/src/lib/abstractBase.test/implementation.js +0 -35
- package/dist/module/src/lib/abstractBase.test/index.js +0 -13
- package/dist/module/src/lib/abstractBase.test/specification.js +0 -15
- package/dist/module/src/lib/abstractBase.test/types.js +0 -1
- package/dist/module/src/lib/index.js +0 -26
- package/dist/module/src/lib/pmProxy.js +0 -284
- package/dist/module/src/lib/pmProxy.test/adapter.js +0 -51
- package/dist/module/src/lib/pmProxy.test/implementation.js +0 -134
- package/dist/module/src/lib/pmProxy.test/index.js +0 -10
- package/dist/module/src/lib/pmProxy.test/mockPM.js +0 -30
- package/dist/module/src/lib/pmProxy.test/mockPMBase.js +0 -127
- package/dist/module/src/lib/pmProxy.test/specification.js +0 -175
- package/dist/module/src/lib/pmProxy.test/types.js +0 -1
- package/dist/module/src/lib/types.js +0 -2
- package/dist/module/src/mothership/index.js +0 -16
- package/dist/module/src/mothership/test.js +0 -78
- package/dist/module/src/run.js +0 -49
- package/dist/module/src/services/FileService.js +0 -468
- package/dist/module/src/services/GitHubAuthService.js +0 -180
- package/dist/module/src/testeranto.js +0 -186
- package/dist/module/src/types/features.js +0 -31
- package/dist/module/src/utils/api.js +0 -87
- package/dist/module/src/utils/buildTemplates.js +0 -33
- package/dist/module/src/utils/featureUtils.js +0 -24
- package/dist/module/src/utils/gitTest.js +0 -23
- package/dist/module/src/utils/golingvuMetafile.js +0 -109
- package/dist/module/src/utils/logFiles.js +0 -47
- package/dist/module/src/utils/makePrompt.js +0 -109
- package/dist/module/src/utils/pitonoMetafile.js +0 -60
- package/dist/module/src/utils/queue.js +0 -32
- package/dist/module/src/utils.js +0 -130
- package/dist/module/src/web.html.js +0 -16
- package/dist/module/testeranto.config.js +0 -100
- package/dist/module/tsconfig.module.tsbuildinfo +0 -1
- package/dist/types/design-editor/DesignEditor.d.ts +0 -1
- package/dist/types/src/App.d.ts +0 -19
- package/dist/types/src/CoreTypes.d.ts +0 -52
- package/dist/types/src/Init.d.ts +0 -2
- package/dist/types/src/Node.d.ts +0 -9
- package/dist/types/src/NodeSidecar.d.ts +0 -6
- package/dist/types/src/PM/PM_WithBuild.d.ts +0 -13
- package/dist/types/src/PM/PM_WithEslintAndTsc.d.ts +0 -22
- package/dist/types/src/PM/PM_WithGit.d.ts +0 -27
- package/dist/types/src/PM/PM_WithProcesses.d.ts +0 -29
- package/dist/types/src/PM/PM_WithWebSocket.d.ts +0 -108
- package/dist/types/src/PM/__tests__/nodeSidecar.testeranto.d.ts +0 -2
- package/dist/types/src/PM/__tests__/pureSidecar.testeranto.d.ts +0 -2
- package/dist/types/src/PM/__tests__/webSidecar.testeranto.d.ts +0 -2
- package/dist/types/src/PM/base.d.ts +0 -35
- package/dist/types/src/PM/index.d.ts +0 -35
- package/dist/types/src/PM/main.d.ts +0 -8
- package/dist/types/src/PM/node.d.ts +0 -38
- package/dist/types/src/PM/nodeSidecar.d.ts +0 -13
- package/dist/types/src/PM/pitonoRunner.d.ts +0 -7
- package/dist/types/src/PM/pure.d.ts +0 -41
- package/dist/types/src/PM/pureSidecar.d.ts +0 -11
- package/dist/types/src/PM/sidecar.d.ts +0 -8
- package/dist/types/src/PM/types.d.ts +0 -118
- package/dist/types/src/PM/utils.d.ts +0 -35
- package/dist/types/src/PM/web.d.ts +0 -41
- package/dist/types/src/PM/webSidecar.d.ts +0 -11
- package/dist/types/src/Pure.d.ts +0 -14
- package/dist/types/src/Pure.test.d.ts +0 -2
- package/dist/types/src/PureSidecar.d.ts +0 -8
- package/dist/types/src/ReportServer.test.ts/index.d.ts +0 -2
- package/dist/types/src/Types.d.ts +0 -119
- package/dist/types/src/Web.d.ts +0 -9
- package/dist/types/src/WebSidecar.d.ts +0 -8
- package/dist/types/src/components/DesignEditorPage.d.ts +0 -1
- package/dist/types/src/components/SunriseAnimation.d.ts +0 -5
- package/dist/types/src/components/SunriseAnimation.test/interface.d.ts +0 -11
- package/dist/types/src/components/SunriseAnimation.test/types.d.ts +0 -39
- package/dist/types/src/components/TestStatusBadge.d.ts +0 -15
- package/dist/types/src/components/pure/AppFrame.d.ts +0 -11
- package/dist/types/src/components/pure/AppFrame.test/implementation.d.ts +0 -3
- package/dist/types/src/components/pure/AppFrame.test/index.d.ts +0 -3
- package/dist/types/src/components/pure/AppFrame.test/specification.d.ts +0 -3
- package/dist/types/src/components/pure/AppFrame.test/types.d.ts +0 -33
- package/dist/types/src/components/pure/BuildLogViewer.d.ts +0 -7
- package/dist/types/src/components/pure/DebugEnv.d.ts +0 -2
- package/dist/types/src/components/pure/FeaturesReporterView.d.ts +0 -7
- package/dist/types/src/components/pure/FeaturesReporterView.test/implementation.d.ts +0 -3
- package/dist/types/src/components/pure/FeaturesReporterView.test/index.d.ts +0 -2
- package/dist/types/src/components/pure/FeaturesReporterView.test/specification.d.ts +0 -3
- package/dist/types/src/components/pure/FeaturesReporterView.test/types.d.ts +0 -54
- package/dist/types/src/components/pure/FileTree.d.ts +0 -6
- package/dist/types/src/components/pure/FileTreeItem.d.ts +0 -8
- package/dist/types/src/components/pure/GitHubLoginButton.d.ts +0 -8
- package/dist/types/src/components/pure/GitIntegrationView.d.ts +0 -1
- package/dist/types/src/components/pure/ModalContent.d.ts +0 -7
- package/dist/types/src/components/pure/ModalContent.test/implementation.d.ts +0 -3
- package/dist/types/src/components/pure/ModalContent.test/index.d.ts +0 -2
- package/dist/types/src/components/pure/ModalContent.test/specification.d.ts +0 -3
- package/dist/types/src/components/pure/ModalContent.test/types.d.ts +0 -45
- package/dist/types/src/components/pure/NavBar.d.ts +0 -23
- package/dist/types/src/components/pure/ProcessManager.d.ts +0 -8
- package/dist/types/src/components/pure/ProcessManagerView.d.ts +0 -20
- package/dist/types/src/components/pure/ProjectPageView.d.ts +0 -14
- package/dist/types/src/components/pure/ProjectPageView.test/implementation.d.ts +0 -3
- package/dist/types/src/components/pure/ProjectPageView.test/index.d.ts +0 -2
- package/dist/types/src/components/pure/ProjectPageView.test/specification.d.ts +0 -3
- package/dist/types/src/components/pure/ProjectPageView.test/types.d.ts +0 -57
- package/dist/types/src/components/pure/ProjectsPageView.d.ts +0 -29
- package/dist/types/src/components/pure/Settings.d.ts +0 -1
- package/dist/types/src/components/pure/Settings.test.d.ts +0 -1
- package/dist/types/src/components/pure/SettingsButton.d.ts +0 -2
- package/dist/types/src/components/pure/SignIn.d.ts +0 -1
- package/dist/types/src/components/pure/SingleProcessView.d.ts +0 -10
- package/dist/types/src/components/pure/TestPageView.d.ts +0 -16
- package/dist/types/src/components/pure/TestPageView.test/implementation.d.ts +0 -12
- package/dist/types/src/components/pure/TestPageView.test/index.d.ts +0 -3
- package/dist/types/src/components/pure/TestPageView.test/specification.d.ts +0 -11
- package/dist/types/src/components/pure/TestPageView.test/types.d.ts +0 -65
- package/dist/types/src/components/pure/TestPageView_utils.d.ts +0 -23
- package/dist/types/src/components/pure/TestTable.d.ts +0 -16
- package/dist/types/src/components/pure/ThemeCard.d.ts +0 -9
- package/dist/types/src/components/pure/ToastNotification.d.ts +0 -6
- package/dist/types/src/components/pure/UserProfile.d.ts +0 -2
- package/dist/types/src/components/stateful/AuthCallbackPage.d.ts +0 -2
- package/dist/types/src/components/stateful/FeaturesReporter.d.ts +0 -2
- package/dist/types/src/components/stateful/GitIntegrationPage.d.ts +0 -1
- package/dist/types/src/components/stateful/ProcessManagerPage.d.ts +0 -2
- package/dist/types/src/components/stateful/ProjectPage.d.ts +0 -1
- package/dist/types/src/components/stateful/ProjectsPage.d.ts +0 -1
- package/dist/types/src/components/stateful/SettingsPage.d.ts +0 -2
- package/dist/types/src/components/stateful/SingleProcessPage.d.ts +0 -2
- package/dist/types/src/components/stateful/TestPage.d.ts +0 -1
- package/dist/types/src/components/stateful/TextEditorPage.d.ts +0 -1
- package/dist/types/src/defaultConfig.d.ts +0 -3
- package/dist/types/src/esbuildConfigs/consoleDetectorPlugin.d.ts +0 -2
- package/dist/types/src/esbuildConfigs/eslint-formatter-testeranto.d.ts +0 -2
- package/dist/types/src/esbuildConfigs/featuresPlugin.d.ts +0 -5
- package/dist/types/src/esbuildConfigs/index.d.ts +0 -4
- package/dist/types/src/esbuildConfigs/inputFilesPlugin.d.ts +0 -7
- package/dist/types/src/esbuildConfigs/nativeImportDetectorPlugin.d.ts +0 -2
- package/dist/types/src/esbuildConfigs/node.d.ts +0 -4
- package/dist/types/src/esbuildConfigs/pure.d.ts +0 -4
- package/dist/types/src/esbuildConfigs/rebuildPlugin.d.ts +0 -6
- package/dist/types/src/esbuildConfigs/web.d.ts +0 -4
- package/dist/types/src/hooks/useGitMode.d.ts +0 -7
- package/dist/types/src/init-docs.d.ts +0 -1
- package/dist/types/src/lib/BaseGiven.d.ts +0 -44
- package/dist/types/src/lib/BaseSuite.d.ts +0 -46
- package/dist/types/src/lib/BaseSuite.test/mock.d.ts +0 -21
- package/dist/types/src/lib/BaseSuite.test/node.test.d.ts +0 -2
- package/dist/types/src/lib/BaseSuite.test/pure.test.d.ts +0 -2
- package/dist/types/src/lib/BaseSuite.test/test.d.ts +0 -37
- package/dist/types/src/lib/BaseSuite.test/web.test.d.ts +0 -2
- package/dist/types/src/lib/BaseThen.d.ts +0 -27
- package/dist/types/src/lib/BaseWhen.d.ts +0 -27
- package/dist/types/src/lib/Sidecar.d.ts +0 -5
- package/dist/types/src/lib/Tiposkripto.d.ts +0 -37
- package/dist/types/src/lib/Tiposkripto.test/MockTiposkripto.d.ts +0 -18
- package/dist/types/src/lib/Tiposkripto.test/Tiposkripto.adapter.d.ts +0 -3
- package/dist/types/src/lib/Tiposkripto.test/Tiposkripto.d.ts +0 -2
- package/dist/types/src/lib/Tiposkripto.test/Tiposkripto.implementation.d.ts +0 -3
- package/dist/types/src/lib/Tiposkripto.test/Tiposkripto.specification.d.ts +0 -3
- package/dist/types/src/lib/Tiposkripto.test/Tiposkripto.types.d.ts +0 -58
- package/dist/types/src/lib/abstractBase.test/MockGiven.d.ts +0 -9
- package/dist/types/src/lib/abstractBase.test/MockThen.d.ts +0 -6
- package/dist/types/src/lib/abstractBase.test/MockWhen.d.ts +0 -6
- package/dist/types/src/lib/abstractBase.test/adapter.d.ts +0 -3
- package/dist/types/src/lib/abstractBase.test/implementation.d.ts +0 -3
- package/dist/types/src/lib/abstractBase.test/index.d.ts +0 -2
- package/dist/types/src/lib/abstractBase.test/specification.d.ts +0 -3
- package/dist/types/src/lib/abstractBase.test/types.d.ts +0 -39
- package/dist/types/src/lib/index.d.ts +0 -73
- package/dist/types/src/lib/pmProxy.d.ts +0 -12
- package/dist/types/src/lib/pmProxy.test/adapter.d.ts +0 -3
- package/dist/types/src/lib/pmProxy.test/implementation.d.ts +0 -3
- package/dist/types/src/lib/pmProxy.test/index.d.ts +0 -6
- package/dist/types/src/lib/pmProxy.test/mockPM.d.ts +0 -10
- package/dist/types/src/lib/pmProxy.test/mockPMBase.d.ts +0 -40
- package/dist/types/src/lib/pmProxy.test/specification.d.ts +0 -3
- package/dist/types/src/lib/pmProxy.test/types.d.ts +0 -42
- package/dist/types/src/lib/types.d.ts +0 -24
- package/dist/types/src/mothership/index.d.ts +0 -2
- package/dist/types/src/mothership/test.d.ts +0 -2
- package/dist/types/src/services/FileService.d.ts +0 -34
- package/dist/types/src/services/GitHubAuthService.d.ts +0 -32
- package/dist/types/src/testeranto.d.ts +0 -1
- package/dist/types/src/types/features.d.ts +0 -7
- package/dist/types/src/utils/api.d.ts +0 -10
- package/dist/types/src/utils/buildTemplates.d.ts +0 -1
- package/dist/types/src/utils/featureUtils.d.ts +0 -6
- package/dist/types/src/utils/gitTest.d.ts +0 -11
- package/dist/types/src/utils/golingvuMetafile.d.ts +0 -19
- package/dist/types/src/utils/logFiles.d.ts +0 -75
- package/dist/types/src/utils/makePrompt.d.ts +0 -2
- package/dist/types/src/utils/pitonoMetafile.d.ts +0 -7
- package/dist/types/src/utils/queue.d.ts +0 -11
- package/dist/types/src/utils.d.ts +0 -20
- package/dist/types/src/web.html.d.ts +0 -2
- package/dist/types/tsconfig.types.tsbuildinfo +0 -1
- package/example/__pycache__/Calculator.cpython-313.pyc +0 -0
- package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/README.md +0 -187
- package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/base_given.go +0 -163
- package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/base_suite.go +0 -85
- package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/base_then.go +0 -21
- package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/base_when.go +0 -21
- package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/golingvu.go +0 -554
- package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/test_adapter.go +0 -33
- package/example/vendor/github.com/adamwong246/testeranto/src/golingvu/types.go +0 -72
- package/example/vendor/modules.txt +0 -5
- package/pitono/__init__.py +0 -54
- package/pitono/types.py +0 -78
- package/src/PM/metafileOutputs.ts +0 -90
- package/src/golingvu/base_suite_test.go +0 -197
- package/src/pitono/PM/__pycache__/python.cpython-313.pyc +0 -0
- package/src/pitono/__pycache__/Pitono.cpython-313.pyc +0 -0
- package/src/pitono/__pycache__/__init__.cpython-313.pyc +0 -0
- package/src/pitono/__pycache__/base_given.cpython-313.pyc +0 -0
- package/src/pitono/__pycache__/base_suite.cpython-313.pyc +0 -0
- package/src/pitono/__pycache__/base_then.cpython-313.pyc +0 -0
- package/src/pitono/__pycache__/base_when.cpython-313.pyc +0 -0
- package/src/pitono/__pycache__/core_generator.cpython-313.pyc +0 -0
- package/src/pitono/__pycache__/simple_adapter.cpython-313.pyc +0 -0
- package/src/pitono/__pycache__/types.cpython-313.pyc +0 -0
- package/src/templates/frontpage.html +0 -340
- package/src/templates/frontpage.md +0 -79
- package/testeranto/bundles/golang/core/Calculator.golingvu.golingvu.go +0 -53
- package/testeranto/bundles/node/core/chunk-VXVF7WFO.mjs +0 -4321
- package/testeranto/bundles/node/core/example/Calculator.test.mjs +0 -503
- package/testeranto/bundles/python/core/Calculator.pitono.test.py +0 -24
- package/testeranto/bundles/python/core/test_example.py +0 -24
- package/testeranto/bundles/web/core/chunk-DFRN4SYZ.mjs +0 -2297
- package/testeranto/bundles/web/core/chunk-Q5TONB2Z.mjs +0 -6874
- package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.css +0 -11697
- package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.mjs +0 -336
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/tests.json +0 -68
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/tests.json +0 -88
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/tests.json +0 -29
- /package/{pitono → src/pitono}/core_generator.py +0 -0
- /package/{pitono → src/pitono}/pitono.egg-info/dependency_links.txt +0 -0
- /package/{pitono → src/pitono}/pitono.egg-info/entry_points.txt +0 -0
- /package/{pitono → src/pitono}/pitono.egg-info/top_level.txt +0 -0
- /package/{pitono → src/pitono}/pyproject.toml +0 -0
- /package/{pitono → src/pitono}/setup.py +0 -0
- /package/{pitono → src/pitono}/simple_adapter.py +0 -0
- /package/{dist/types/src/PM/metafileOutputs.d.ts → testeranto/helpo_chat_message.txt} +0 -0
- /package/{dist/types/src/ReportServer.d.ts → testeranto/reports/core/example/test_example/python/stdout.log} +0 -0
- /package/{dist/types/src/ReportServerLib.d.ts → testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/lint_errors.txt} +0 -0
- /package/{dist/types/src/components/SunriseAnimation.test/implementation.d.ts → testeranto/reports/core/src/components/pure/ModalContent.test/index/web/debug.log} +0 -0
- /package/{dist/types/src/components/SunriseAnimation.test/index.d.ts → testeranto/reports/core/src/components/pure/ModalContent.test/index/web/error.log} +0 -0
- /package/{dist/types/src/components/SunriseAnimation.test/specification.d.ts → testeranto/reports/core/src/components/pure/ModalContent.test/index/web/exit.log} +0 -0
- /package/{dist/types/src/components/pure/ArtifactTree.d.ts → testeranto/reports/core/src/components/pure/ModalContent.test/index/web/info.log} +0 -0
- /package/{dist/types/src/components/stateful/FileTree.d.ts → testeranto/reports/core/src/components/pure/ModalContent.test/index/web/warn.log} +0 -0
- /package/{dist/types/src/run.d.ts → testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/lint_errors.txt} +0 -0
package/src/lib/Tiposkripto.ts
CHANGED
|
@@ -111,13 +111,25 @@ export default abstract class Tiposkripto<
|
|
|
111
111
|
const classyGivens = Object.entries(testImplementation.givens).reduce(
|
|
112
112
|
(a, [key, g]) => {
|
|
113
113
|
a[key] = (
|
|
114
|
-
name: string,
|
|
114
|
+
// name: string,
|
|
115
115
|
features: string[],
|
|
116
116
|
whens: BaseWhen<I>[],
|
|
117
117
|
thens: BaseThen<I>[],
|
|
118
118
|
gcb: I["given"],
|
|
119
119
|
initialValues: any
|
|
120
120
|
) => {
|
|
121
|
+
// Debug the parameters being passed - check if features contains when-like objects
|
|
122
|
+
// console.log(`[Tiposkripto] Creating Given ${key} with:`);
|
|
123
|
+
// console.log(` name: ${name}`);
|
|
124
|
+
// console.log(` features:`, features);
|
|
125
|
+
// console.log(` whens:`, whens);
|
|
126
|
+
// console.log(` thens:`, thens);
|
|
127
|
+
|
|
128
|
+
// Ensure parameters are arrays and create copies to avoid reference issues
|
|
129
|
+
const safeFeatures = Array.isArray(features) ? [...features] : [];
|
|
130
|
+
const safeWhens = Array.isArray(whens) ? [...whens] : [];
|
|
131
|
+
const safeThens = Array.isArray(thens) ? [...thens] : [];
|
|
132
|
+
|
|
121
133
|
return new (class extends BaseGiven<I> {
|
|
122
134
|
uberCatcher = uberCatcher;
|
|
123
135
|
|
|
@@ -147,10 +159,10 @@ export default abstract class Tiposkripto<
|
|
|
147
159
|
return Promise.resolve(fullAdapter.afterEach(store, key, pm));
|
|
148
160
|
}
|
|
149
161
|
})(
|
|
150
|
-
name,
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
162
|
+
// name,
|
|
163
|
+
safeFeatures,
|
|
164
|
+
safeWhens,
|
|
165
|
+
safeThens,
|
|
154
166
|
testImplementation.givens[key],
|
|
155
167
|
initialValues
|
|
156
168
|
);
|
|
@@ -163,11 +175,13 @@ export default abstract class Tiposkripto<
|
|
|
163
175
|
const classyWhens = Object.entries(testImplementation.whens).reduce(
|
|
164
176
|
(a, [key, whEn]: [string, (...x: any[]) => any]) => {
|
|
165
177
|
a[key] = (...payload: any[]) => {
|
|
166
|
-
|
|
178
|
+
const whenInstance = new (class extends BaseWhen<I> {
|
|
167
179
|
async andWhen(store, whenCB, testResource, pm) {
|
|
168
180
|
return await fullAdapter.andWhen(store, whenCB, testResource, pm);
|
|
169
181
|
}
|
|
170
182
|
})(`${key}: ${payload && payload.toString()}`, whEn(...payload));
|
|
183
|
+
// console.log(`[Tiposkripto] Created When ${key}:`, whenInstance.name);
|
|
184
|
+
return whenInstance;
|
|
171
185
|
};
|
|
172
186
|
return a;
|
|
173
187
|
},
|
|
@@ -177,7 +191,7 @@ export default abstract class Tiposkripto<
|
|
|
177
191
|
const classyThens = Object.entries(testImplementation.thens).reduce(
|
|
178
192
|
(a, [key, thEn]: [string, (...x: any[]) => any]) => {
|
|
179
193
|
a[key] = (...args: any[]) => {
|
|
180
|
-
|
|
194
|
+
const thenInstance = new (class extends BaseThen<I> {
|
|
181
195
|
async butThen(
|
|
182
196
|
store: any,
|
|
183
197
|
thenCB,
|
|
@@ -187,6 +201,8 @@ export default abstract class Tiposkripto<
|
|
|
187
201
|
return await fullAdapter.butThen(store, thenCB, testResource, pm);
|
|
188
202
|
}
|
|
189
203
|
})(`${key}: ${args && args.toString()}`, thEn(...args));
|
|
204
|
+
// console.log(`[Tiposkripto] Created Then ${key}:`, thenInstance.name);
|
|
205
|
+
return thenInstance;
|
|
190
206
|
};
|
|
191
207
|
return a;
|
|
192
208
|
},
|
|
@@ -209,10 +225,24 @@ export default abstract class Tiposkripto<
|
|
|
209
225
|
this.Then()
|
|
210
226
|
);
|
|
211
227
|
|
|
228
|
+
// Debug: log the structure of the first suite to see if whens are properly set up
|
|
229
|
+
// if (this.specs.length > 0 && this.specs[0]) {
|
|
230
|
+
// const firstSuite = this.specs[0] as any;
|
|
231
|
+
// if (firstSuite.givens) {
|
|
232
|
+
// Object.entries(firstSuite.givens).forEach(([givenKey, given]) => {
|
|
233
|
+
// console.log(`[DEBUG] Given "${givenKey}":`, {
|
|
234
|
+
// name: given.name,
|
|
235
|
+
// whens: given.whens ? given.whens.map((w) => w?.name) : [],
|
|
236
|
+
// thens: given.thens ? given.thens.map((t) => t?.name) : [],
|
|
237
|
+
// });
|
|
238
|
+
// });
|
|
239
|
+
// }
|
|
240
|
+
// }
|
|
241
|
+
|
|
212
242
|
// Calculate total number of tests (sum of all Givens across all Suites)
|
|
213
243
|
// Each suite should have a 'givens' property that's a record of test names to BaseGiven instances
|
|
214
244
|
this.totalTests = this.calculateTotalTests();
|
|
215
|
-
console.log(`Total tests calculated: ${this.totalTests}`);
|
|
245
|
+
// console.log(`Total tests calculated: ${this.totalTests}`);
|
|
216
246
|
|
|
217
247
|
// Create test jobs
|
|
218
248
|
this.testJobs = this.specs.map((suite: BaseSuite<I, O>) => {
|
|
@@ -336,12 +366,12 @@ export default abstract class Tiposkripto<
|
|
|
336
366
|
private calculateTotalTests(): number {
|
|
337
367
|
let total = 0;
|
|
338
368
|
for (const suite of this.specs) {
|
|
339
|
-
if (suite && typeof suite ===
|
|
369
|
+
if (suite && typeof suite === "object") {
|
|
340
370
|
// Access the givens property which should be a record of test names to BaseGiven instances
|
|
341
371
|
// The givens property is typically on the suite instance
|
|
342
|
-
if (
|
|
372
|
+
if ("givens" in suite) {
|
|
343
373
|
const givens = (suite as any).givens;
|
|
344
|
-
if (givens && typeof givens ===
|
|
374
|
+
if (givens && typeof givens === "object") {
|
|
345
375
|
total += Object.keys(givens).length;
|
|
346
376
|
}
|
|
347
377
|
}
|
package/src/lib/pmProxy.ts
CHANGED
|
@@ -90,6 +90,25 @@ export const butThenProxy: IProxy = (
|
|
|
90
90
|
[
|
|
91
91
|
"createWriteStream",
|
|
92
92
|
(fp) => {
|
|
93
|
+
// Add debug logging to see what fp is
|
|
94
|
+
// console.log(
|
|
95
|
+
// `[DEBUG] createWriteStream fp type: ${typeof fp}, value:`,
|
|
96
|
+
// fp
|
|
97
|
+
// );
|
|
98
|
+
|
|
99
|
+
// // Ensure fp is always a string
|
|
100
|
+
// if (typeof fp !== "string") {
|
|
101
|
+
// console.error(
|
|
102
|
+
// `[PROXY ERROR] createWriteStream fp is not a string:`,
|
|
103
|
+
// fp
|
|
104
|
+
// );
|
|
105
|
+
// // Don't convert, just throw to find the source
|
|
106
|
+
// throw new Error(
|
|
107
|
+
// `createWriteStream expected string for fp, got ${typeof fp}: ${JSON.stringify(
|
|
108
|
+
// fp
|
|
109
|
+
// )}`
|
|
110
|
+
// );
|
|
111
|
+
// }
|
|
93
112
|
const path = `${filepath}/butThen/${fp}`;
|
|
94
113
|
addArtifact(path);
|
|
95
114
|
return [path];
|
|
@@ -98,25 +117,17 @@ export const butThenProxy: IProxy = (
|
|
|
98
117
|
[
|
|
99
118
|
"writeFileSync",
|
|
100
119
|
(fp, contents, testName) => {
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
//
|
|
105
|
-
if (typeof fp !== "string") {
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
fp = fp.join("");
|
|
111
|
-
console.log(`[DEBUG] Converted array to string: "${fp}"`);
|
|
112
|
-
} else {
|
|
113
|
-
// For other cases, convert to string
|
|
114
|
-
fp = String(fp);
|
|
115
|
-
console.log(`[DEBUG] Converted to string: "${fp}"`);
|
|
116
|
-
}
|
|
117
|
-
}
|
|
120
|
+
// Add debug logging to see what fp is
|
|
121
|
+
// console.log(`[DEBUG] writeFileSync fp type: ${typeof fp}, value:`, fp);
|
|
122
|
+
|
|
123
|
+
// Ensure fp is always a string
|
|
124
|
+
// if (typeof fp !== "string") {
|
|
125
|
+
// console.error(`[PROXY ERROR] writeFileSync fp is not a string:`, fp);
|
|
126
|
+
// // Don't convert, just throw to find the source
|
|
127
|
+
// throw new Error(`writeFileSync expected string for fp, got ${typeof fp}: ${JSON.stringify(fp)}`);
|
|
128
|
+
// }
|
|
118
129
|
const path = `${filepath}/butThen/${fp}`;
|
|
119
|
-
console.log(`[DEBUG]
|
|
130
|
+
// console.log(`[DEBUG] Adding artifact: "${path}"`);
|
|
120
131
|
addArtifact(path);
|
|
121
132
|
return [path, contents, testName];
|
|
122
133
|
},
|
|
@@ -162,6 +173,19 @@ export const andWhenProxy: IProxy = (
|
|
|
162
173
|
[
|
|
163
174
|
"createWriteStream",
|
|
164
175
|
(fp) => {
|
|
176
|
+
// // Add debug logging to see what fp is
|
|
177
|
+
// console.log(
|
|
178
|
+
// `[DEBUG] andWhen createWriteStream fp type: ${typeof fp}, value:`,
|
|
179
|
+
// fp
|
|
180
|
+
// );
|
|
181
|
+
|
|
182
|
+
// if (typeof fp !== "string") {
|
|
183
|
+
// throw new Error(
|
|
184
|
+
// `andWhen createWriteStream expected string for fp, got ${typeof fp}: ${JSON.stringify(
|
|
185
|
+
// fp
|
|
186
|
+
// )}`
|
|
187
|
+
// );
|
|
188
|
+
// }
|
|
165
189
|
const path = `${filepath}/andWhen/${fp}`;
|
|
166
190
|
addArtifact(path);
|
|
167
191
|
return [path];
|
|
@@ -171,6 +195,19 @@ export const andWhenProxy: IProxy = (
|
|
|
171
195
|
[
|
|
172
196
|
"writeFileSync",
|
|
173
197
|
(fp, contents, testName) => {
|
|
198
|
+
// Add debug logging to see what fp is
|
|
199
|
+
// console.log(
|
|
200
|
+
// `[DEBUG] andWhen writeFileSync fp type: ${typeof fp}, value:`,
|
|
201
|
+
// fp
|
|
202
|
+
// );
|
|
203
|
+
|
|
204
|
+
// if (typeof fp !== "string") {
|
|
205
|
+
// throw new Error(
|
|
206
|
+
// `andWhen writeFileSync expected string for fp, got ${typeof fp}: ${JSON.stringify(
|
|
207
|
+
// fp
|
|
208
|
+
// )}`
|
|
209
|
+
// );
|
|
210
|
+
// }
|
|
174
211
|
const path = `${filepath}/andWhen/${fp}`;
|
|
175
212
|
addArtifact(path);
|
|
176
213
|
return [path, contents, testName];
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import socket
|
|
2
|
+
import json
|
|
3
|
+
import random
|
|
4
|
+
import struct
|
|
5
|
+
from typing import Any, List, Dict, Optional
|
|
6
|
+
from ..types import ITTestResourceConfiguration
|
|
7
|
+
|
|
8
|
+
class PM_Python:
|
|
9
|
+
def __init__(self, t: ITTestResourceConfiguration, ipc_file: str):
|
|
10
|
+
self.test_resource_configuration = t
|
|
11
|
+
self.client = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
|
|
12
|
+
try:
|
|
13
|
+
self.client.connect(ipc_file)
|
|
14
|
+
# Set a timeout to prevent blocking forever
|
|
15
|
+
self.client.settimeout(30.0)
|
|
16
|
+
except Exception as e:
|
|
17
|
+
raise e
|
|
18
|
+
|
|
19
|
+
def start(self) -> None:
|
|
20
|
+
raise Exception("DEPRECATED")
|
|
21
|
+
|
|
22
|
+
def stop(self) -> None:
|
|
23
|
+
try:
|
|
24
|
+
self.client.close()
|
|
25
|
+
except:
|
|
26
|
+
pass
|
|
27
|
+
|
|
28
|
+
def send(self, command: str, *args) -> Any:
|
|
29
|
+
# Generate a unique key for this request
|
|
30
|
+
key = str(random.random())
|
|
31
|
+
# Create the message array with command, arguments, and key
|
|
32
|
+
message = [command]
|
|
33
|
+
message.extend(args)
|
|
34
|
+
message.append(key)
|
|
35
|
+
|
|
36
|
+
# Convert to JSON and encode
|
|
37
|
+
data = json.dumps(message).encode('utf-8')
|
|
38
|
+
|
|
39
|
+
# Send the length of the data first (as 4-byte big-endian)
|
|
40
|
+
length = struct.pack('>I', len(data))
|
|
41
|
+
self.client.sendall(length)
|
|
42
|
+
# Send the actual data
|
|
43
|
+
self.client.sendall(data)
|
|
44
|
+
|
|
45
|
+
# Wait for response
|
|
46
|
+
# First read the length
|
|
47
|
+
length_data = self._recv_all(4)
|
|
48
|
+
if not length_data:
|
|
49
|
+
raise Exception("No response length received")
|
|
50
|
+
response_length = struct.unpack('>I', length_data)[0]
|
|
51
|
+
|
|
52
|
+
# Read the response data
|
|
53
|
+
response_data = self._recv_all(response_length)
|
|
54
|
+
if not response_data:
|
|
55
|
+
raise Exception("No response data received")
|
|
56
|
+
|
|
57
|
+
# Parse the response
|
|
58
|
+
try:
|
|
59
|
+
response = json.loads(response_data.decode('utf-8'))
|
|
60
|
+
# Check if the response key matches our request key
|
|
61
|
+
if response.get('key') == key:
|
|
62
|
+
return response.get('payload')
|
|
63
|
+
else:
|
|
64
|
+
raise Exception(f"Key mismatch in response. Expected: {key}, Got: {response.get('key')}")
|
|
65
|
+
except json.JSONDecodeError:
|
|
66
|
+
raise Exception("Invalid JSON response")
|
|
67
|
+
|
|
68
|
+
def _recv_all(self, length: int) -> bytes:
|
|
69
|
+
data = b''
|
|
70
|
+
while len(data) < length:
|
|
71
|
+
chunk = self.client.recv(length - len(data))
|
|
72
|
+
if not chunk:
|
|
73
|
+
break
|
|
74
|
+
data += chunk
|
|
75
|
+
return data
|
|
76
|
+
|
|
77
|
+
async def pages(self) -> List[str]:
|
|
78
|
+
return self.send("pages")
|
|
79
|
+
|
|
80
|
+
def wait_for_selector(self, p: str, s: str) -> Any:
|
|
81
|
+
return self.send("waitForSelector", p, s)
|
|
82
|
+
|
|
83
|
+
def close_page(self, p: Any) -> Any:
|
|
84
|
+
return self.send("closePage", p)
|
|
85
|
+
|
|
86
|
+
def goto(self, page: str, url: str) -> Any:
|
|
87
|
+
return self.send("goto", page, url)
|
|
88
|
+
|
|
89
|
+
async def new_page(self) -> str:
|
|
90
|
+
return self.send("newPage")
|
|
91
|
+
|
|
92
|
+
def __call__(self, selector: str, page: str) -> Any:
|
|
93
|
+
return self.send("$", selector, page)
|
|
94
|
+
|
|
95
|
+
def is_disabled(self, selector: str) -> bool:
|
|
96
|
+
return self.send("isDisabled", selector)
|
|
97
|
+
|
|
98
|
+
def get_attribute(self, selector: str, attribute: str, p: str) -> Any:
|
|
99
|
+
return self.send("getAttribute", selector, attribute, p)
|
|
100
|
+
|
|
101
|
+
def get_inner_html(self, selector: str, p: str) -> Any:
|
|
102
|
+
return self.send("getInnerHtml", selector, p)
|
|
103
|
+
|
|
104
|
+
def focus_on(self, selector: str) -> Any:
|
|
105
|
+
return self.send("focusOn", selector)
|
|
106
|
+
|
|
107
|
+
def type_into(self, selector: str) -> Any:
|
|
108
|
+
return self.send("typeInto", selector)
|
|
109
|
+
|
|
110
|
+
def page(self) -> Optional[str]:
|
|
111
|
+
return self.send("page")
|
|
112
|
+
|
|
113
|
+
def click(self, selector: str) -> Any:
|
|
114
|
+
return self.send("click", selector)
|
|
115
|
+
|
|
116
|
+
def screencast(self, opts: Dict, page: str) -> Any:
|
|
117
|
+
adjusted_opts = dict(opts)
|
|
118
|
+
if 'path' in adjusted_opts:
|
|
119
|
+
adjusted_opts['path'] = f"{self.test_resource_configuration.fs}/{opts['path']}"
|
|
120
|
+
return self.send("screencast", adjusted_opts, page, self.test_resource_configuration.name)
|
|
121
|
+
|
|
122
|
+
def screencast_stop(self, p: str) -> Any:
|
|
123
|
+
return self.send("screencastStop", p)
|
|
124
|
+
|
|
125
|
+
def custom_screenshot(self, x: List) -> Any:
|
|
126
|
+
opts = x[0]
|
|
127
|
+
page = x[1] if len(x) > 1 else None
|
|
128
|
+
|
|
129
|
+
adjusted_opts = dict(opts)
|
|
130
|
+
if 'path' in adjusted_opts:
|
|
131
|
+
adjusted_opts['path'] = f"{self.test_resource_configuration.fs}/{opts['path']}"
|
|
132
|
+
|
|
133
|
+
if page:
|
|
134
|
+
return self.send("customScreenShot", adjusted_opts, self.test_resource_configuration.name, page)
|
|
135
|
+
else:
|
|
136
|
+
return self.send("customScreenShot", adjusted_opts, self.test_resource_configuration.name)
|
|
137
|
+
|
|
138
|
+
async def exists_sync(self, dest_folder: str) -> bool:
|
|
139
|
+
path = f"{self.test_resource_configuration.fs}/{dest_folder}"
|
|
140
|
+
return self.send("existsSync", path)
|
|
141
|
+
|
|
142
|
+
def mkdir_sync(self) -> Any:
|
|
143
|
+
path = f"{self.test_resource_configuration.fs}/"
|
|
144
|
+
return self.send("mkdirSync", path)
|
|
145
|
+
|
|
146
|
+
async def write(self, uid: int, contents: str) -> bool:
|
|
147
|
+
return self.send("write", uid, contents)
|
|
148
|
+
|
|
149
|
+
def write_file_sync(self, filepath: str, contents: str) -> bool:
|
|
150
|
+
full_path = f"{self.test_resource_configuration.fs}/{filepath}"
|
|
151
|
+
try:
|
|
152
|
+
result = self.send("writeFileSync", full_path, contents, self.test_resource_configuration.name)
|
|
153
|
+
return result
|
|
154
|
+
except Exception as e:
|
|
155
|
+
raise e
|
|
156
|
+
|
|
157
|
+
async def create_write_stream(self, filepath: str) -> str:
|
|
158
|
+
full_path = f"{self.test_resource_configuration.fs}/{filepath}"
|
|
159
|
+
return self.send("createWriteStream", full_path, self.test_resource_configuration.name)
|
|
160
|
+
|
|
161
|
+
async def end(self, uid: Any) -> bool:
|
|
162
|
+
return self.send("end", uid)
|
|
163
|
+
|
|
164
|
+
async def custom_close(self) -> Any:
|
|
165
|
+
return self.send("customclose", self.test_resource_configuration.fs, self.test_resource_configuration.name)
|
|
@@ -0,0 +1,298 @@
|
|
|
1
|
+
from typing import Any, Callable, Dict, List, Optional
|
|
2
|
+
import json
|
|
3
|
+
import asyncio
|
|
4
|
+
from .types import ITestSpecification, ITestImplementation, ITestAdapter, ITTestResourceRequest
|
|
5
|
+
from .simple_adapter import SimpleTestAdapter
|
|
6
|
+
from .base_suite import BaseSuite
|
|
7
|
+
from .base_given import BaseGiven
|
|
8
|
+
from .base_when import BaseWhen
|
|
9
|
+
from .base_then import BaseThen
|
|
10
|
+
from .PM.python import PM_Python
|
|
11
|
+
|
|
12
|
+
# Export these for easier imports
|
|
13
|
+
__all__ = [
|
|
14
|
+
'Pitono', 'set_default_instance', 'main'
|
|
15
|
+
]
|
|
16
|
+
|
|
17
|
+
import sys
|
|
18
|
+
|
|
19
|
+
def Pitono(
|
|
20
|
+
input_val: Any = None,
|
|
21
|
+
test_specification: ITestSpecification = None,
|
|
22
|
+
test_implementation: ITestImplementation = None,
|
|
23
|
+
test_adapter: ITestAdapter = None,
|
|
24
|
+
test_resource_requirement: ITTestResourceRequest = None,
|
|
25
|
+
uber_catcher: Callable[[Callable], None] = None,
|
|
26
|
+
**kwargs
|
|
27
|
+
):
|
|
28
|
+
# Create a Pitono instance and return it
|
|
29
|
+
instance = PitonoClass(
|
|
30
|
+
input_val,
|
|
31
|
+
test_specification,
|
|
32
|
+
test_implementation,
|
|
33
|
+
test_resource_requirement or {},
|
|
34
|
+
test_adapter,
|
|
35
|
+
uber_catcher or (lambda x: None)
|
|
36
|
+
)
|
|
37
|
+
return instance
|
|
38
|
+
|
|
39
|
+
# Store the default instance
|
|
40
|
+
_default_instance = None
|
|
41
|
+
|
|
42
|
+
def set_default_instance(instance):
|
|
43
|
+
global _default_instance
|
|
44
|
+
_default_instance = instance
|
|
45
|
+
|
|
46
|
+
async def main():
|
|
47
|
+
if len(sys.argv) < 3:
|
|
48
|
+
print("Usage: python <test_file.py> <partialTestResource> <ipcfile>")
|
|
49
|
+
sys.exit(-1)
|
|
50
|
+
|
|
51
|
+
partialTestResource = sys.argv[1]
|
|
52
|
+
ipcfile = sys.argv[2]
|
|
53
|
+
|
|
54
|
+
if _default_instance is None:
|
|
55
|
+
print("ERROR: No default Pitono instance has been configured")
|
|
56
|
+
sys.exit(-1)
|
|
57
|
+
|
|
58
|
+
result = await _default_instance.receiveTestResourceConfig(partialTestResource, ipcfile)
|
|
59
|
+
sys.exit(result.fails)
|
|
60
|
+
|
|
61
|
+
class PitonoClass:
|
|
62
|
+
def __init__(
|
|
63
|
+
self,
|
|
64
|
+
input_val: Any,
|
|
65
|
+
test_specification: ITestSpecification,
|
|
66
|
+
test_implementation: ITestImplementation,
|
|
67
|
+
test_resource_requirement: ITTestResourceRequest,
|
|
68
|
+
test_adapter: ITestAdapter,
|
|
69
|
+
uber_catcher: Callable[[Callable], None]
|
|
70
|
+
):
|
|
71
|
+
self.test_resource_requirement = test_resource_requirement
|
|
72
|
+
self.artifacts: List[Any] = []
|
|
73
|
+
self.test_jobs: List[Any] = []
|
|
74
|
+
self.test_specification = test_specification
|
|
75
|
+
self.suites_overrides: Dict[str, Any] = {}
|
|
76
|
+
self.given_overrides: Dict[str, Any] = {}
|
|
77
|
+
self.when_overrides: Dict[str, Any] = {}
|
|
78
|
+
self.then_overrides: Dict[str, Any] = {}
|
|
79
|
+
self.puppet_master: Any = None
|
|
80
|
+
self.specs: Any = None
|
|
81
|
+
self.test_implementation = test_implementation
|
|
82
|
+
self.test_subject = input_val
|
|
83
|
+
self.test_adapter = test_adapter
|
|
84
|
+
|
|
85
|
+
# Generate specs
|
|
86
|
+
self.specs = test_specification(
|
|
87
|
+
self.Suites(),
|
|
88
|
+
self.Given(),
|
|
89
|
+
self.When(),
|
|
90
|
+
self.Then()
|
|
91
|
+
)
|
|
92
|
+
|
|
93
|
+
def Suites(self):
|
|
94
|
+
return self.suites_overrides
|
|
95
|
+
|
|
96
|
+
def Given(self):
|
|
97
|
+
# Return a function that creates the appropriate Given instance
|
|
98
|
+
def create_given(given_type, features, whens, thens, initial_values=None):
|
|
99
|
+
if given_type in self.given_overrides:
|
|
100
|
+
return self.given_overrides[given_type](features, whens, thens, initial_values)
|
|
101
|
+
else:
|
|
102
|
+
raise ValueError(f"Given type '{given_type}' not found")
|
|
103
|
+
|
|
104
|
+
# Create a wrapper that provides access to all given types
|
|
105
|
+
class GivenWrapper:
|
|
106
|
+
def __getattr__(self, name):
|
|
107
|
+
def given_func(features, whens, thens, initial_values=None):
|
|
108
|
+
return create_given(name, features, whens, thens, initial_values)
|
|
109
|
+
return given_func
|
|
110
|
+
|
|
111
|
+
return GivenWrapper()
|
|
112
|
+
|
|
113
|
+
def When(self):
|
|
114
|
+
# Similar approach for When
|
|
115
|
+
def create_when(when_type, *args):
|
|
116
|
+
if when_type in self.when_overrides:
|
|
117
|
+
return self.when_overrides[when_type](*args)
|
|
118
|
+
else:
|
|
119
|
+
raise ValueError(f"When type '{when_type}' not found")
|
|
120
|
+
|
|
121
|
+
class WhenWrapper:
|
|
122
|
+
def __getattr__(self, name):
|
|
123
|
+
def when_func(*args):
|
|
124
|
+
return create_when(name, *args)
|
|
125
|
+
return when_func
|
|
126
|
+
|
|
127
|
+
return WhenWrapper()
|
|
128
|
+
|
|
129
|
+
def Then(self):
|
|
130
|
+
# Similar approach for Then
|
|
131
|
+
def create_then(then_type, *args):
|
|
132
|
+
if then_type in self.then_overrides:
|
|
133
|
+
return self.then_overrides[then_type](*args)
|
|
134
|
+
else:
|
|
135
|
+
raise ValueError(f"Then type '{then_type}' not found")
|
|
136
|
+
|
|
137
|
+
class ThenWrapper:
|
|
138
|
+
def __getattr__(self, name):
|
|
139
|
+
def then_func(*args):
|
|
140
|
+
return create_then(name, *args)
|
|
141
|
+
return then_func
|
|
142
|
+
|
|
143
|
+
return ThenWrapper()
|
|
144
|
+
|
|
145
|
+
def _initialize_classy_implementations(self, test_implementation):
|
|
146
|
+
# Create classy implementations similar to TypeScript
|
|
147
|
+
classyGivens = {}
|
|
148
|
+
for key in test_implementation.givens.keys():
|
|
149
|
+
def create_given_closure(given_key):
|
|
150
|
+
def given_func(features, whens, thens, initial_values=None):
|
|
151
|
+
return BaseGiven(
|
|
152
|
+
given_key,
|
|
153
|
+
features,
|
|
154
|
+
whens,
|
|
155
|
+
thens,
|
|
156
|
+
test_implementation.givens[given_key],
|
|
157
|
+
initial_values
|
|
158
|
+
)
|
|
159
|
+
return given_func
|
|
160
|
+
classyGivens[key] = create_given_closure(key)
|
|
161
|
+
|
|
162
|
+
classyWhens = {}
|
|
163
|
+
for key in test_implementation.whens.keys():
|
|
164
|
+
def create_when_closure(when_key):
|
|
165
|
+
def when_func(*args):
|
|
166
|
+
# Create a BaseWhen instance
|
|
167
|
+
name = f"{when_key}: {args}"
|
|
168
|
+
when_cb = test_implementation.whens[when_key](*args)
|
|
169
|
+
return BaseWhen(name, when_cb)
|
|
170
|
+
return when_func
|
|
171
|
+
classyWhens[key] = create_when_closure(key)
|
|
172
|
+
|
|
173
|
+
classyThens = {}
|
|
174
|
+
for key in test_implementation.thens.keys():
|
|
175
|
+
def create_then_closure(then_key):
|
|
176
|
+
def then_func(*args):
|
|
177
|
+
# Create a BaseThen instance
|
|
178
|
+
name = f"{then_key}: {args}"
|
|
179
|
+
then_cb = test_implementation.thens[then_key](*args)
|
|
180
|
+
return BaseThen(name, then_cb)
|
|
181
|
+
return then_func
|
|
182
|
+
classyThens[key] = create_then_closure(key)
|
|
183
|
+
|
|
184
|
+
self.given_overrides = classyGivens
|
|
185
|
+
self.when_overrides = classyWhens
|
|
186
|
+
self.then_overrides = classyThens
|
|
187
|
+
|
|
188
|
+
# Initialize the classy implementations
|
|
189
|
+
self._initialize_classy_implementations(test_implementation)
|
|
190
|
+
|
|
191
|
+
async def _run_test_job(self, runner, suite, puppet_master):
|
|
192
|
+
try:
|
|
193
|
+
# Create a simple t_log function
|
|
194
|
+
def t_log(*args):
|
|
195
|
+
print(" ".join(map(str, args)))
|
|
196
|
+
|
|
197
|
+
# Run the suite
|
|
198
|
+
suite_done = await runner(puppet_master, t_log)
|
|
199
|
+
fails = suite_done.fails
|
|
200
|
+
|
|
201
|
+
# Get features and artifacts
|
|
202
|
+
features = []
|
|
203
|
+
if hasattr(suite_done, 'features') and callable(suite_done.features):
|
|
204
|
+
features = suite_done.features()
|
|
205
|
+
elif hasattr(suite_done, 'features'):
|
|
206
|
+
features = suite_done.features
|
|
207
|
+
|
|
208
|
+
artifacts = []
|
|
209
|
+
if hasattr(suite_done, 'artifacts'):
|
|
210
|
+
artifacts = suite_done.artifacts
|
|
211
|
+
|
|
212
|
+
# Create a simple result object
|
|
213
|
+
class Result:
|
|
214
|
+
def __init__(self, failed, fails, artifacts, features):
|
|
215
|
+
self.failed = failed
|
|
216
|
+
self.fails = fails
|
|
217
|
+
self.artifacts = artifacts
|
|
218
|
+
self.features = features
|
|
219
|
+
|
|
220
|
+
return Result(
|
|
221
|
+
fails > 0,
|
|
222
|
+
fails,
|
|
223
|
+
artifacts,
|
|
224
|
+
features
|
|
225
|
+
)
|
|
226
|
+
except Exception as e:
|
|
227
|
+
print(f"Error in test job: {e}")
|
|
228
|
+
|
|
229
|
+
class Result:
|
|
230
|
+
def __init__(self, failed, fails, artifacts, features):
|
|
231
|
+
self.failed = failed
|
|
232
|
+
self.fails = fails
|
|
233
|
+
self.artifacts = artifacts
|
|
234
|
+
self.features = features
|
|
235
|
+
|
|
236
|
+
return Result(True, 1, [], [])
|
|
237
|
+
|
|
238
|
+
async def receiveTestResourceConfig(self, partialTestResource: str, ipcfile: str) -> Any:
|
|
239
|
+
# Parse the test resource configuration
|
|
240
|
+
test_resource_config = json.loads(partialTestResource)
|
|
241
|
+
|
|
242
|
+
# Create a PM_Python instance
|
|
243
|
+
pm = PM_Python(test_resource_config, ipcfile)
|
|
244
|
+
|
|
245
|
+
# Run all test jobs
|
|
246
|
+
total_fails = 0
|
|
247
|
+
all_features = set()
|
|
248
|
+
all_artifacts = []
|
|
249
|
+
|
|
250
|
+
# Collect all suite results
|
|
251
|
+
suite_results = []
|
|
252
|
+
for job in self.test_jobs:
|
|
253
|
+
try:
|
|
254
|
+
result = await job['receiveTestResourceConfig'](pm)
|
|
255
|
+
total_fails += result.fails
|
|
256
|
+
# Add features to the set
|
|
257
|
+
if hasattr(result, 'features'):
|
|
258
|
+
for feature in result.features:
|
|
259
|
+
all_features.add(feature)
|
|
260
|
+
if hasattr(result, 'artifacts'):
|
|
261
|
+
all_artifacts.extend(result.artifacts)
|
|
262
|
+
# Get the suite object
|
|
263
|
+
suite_obj = job['to_obj']()
|
|
264
|
+
suite_results.append(suite_obj)
|
|
265
|
+
except Exception as e:
|
|
266
|
+
print(f"Error running test job: {e}")
|
|
267
|
+
total_fails += 1
|
|
268
|
+
|
|
269
|
+
# Write the final tests.json
|
|
270
|
+
try:
|
|
271
|
+
# Flatten all givens from all suites
|
|
272
|
+
all_givens = []
|
|
273
|
+
for suite in suite_results:
|
|
274
|
+
if 'givens' in suite:
|
|
275
|
+
all_givens.extend(suite['givens'])
|
|
276
|
+
|
|
277
|
+
# Prepare tests data matching the TypeScript structure
|
|
278
|
+
tests_data = {
|
|
279
|
+
"name": self.specs[0].name if self.specs else "Unnamed Test",
|
|
280
|
+
"givens": all_givens,
|
|
281
|
+
"fails": total_fails,
|
|
282
|
+
"features": list(all_features),
|
|
283
|
+
"artifacts": all_artifacts
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
# Write to file
|
|
287
|
+
tests_json_path = f"{test_resource_config['fs']}/tests.json"
|
|
288
|
+
with open(tests_json_path, 'w') as f:
|
|
289
|
+
json.dump(tests_data, f, indent=2)
|
|
290
|
+
|
|
291
|
+
except Exception as e:
|
|
292
|
+
print(f"Error writing tests.json: {e}")
|
|
293
|
+
|
|
294
|
+
# Return result
|
|
295
|
+
class Result:
|
|
296
|
+
def __init__(self, fails):
|
|
297
|
+
self.fails = fails
|
|
298
|
+
return Result(total_fails)
|