testeranto 0.177.0 → 0.197.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ALL_LICENSES.txt +11246 -0
- package/LICENSE +21 -0
- package/README.md +24 -4
- package/default-project.json +44 -0
- package/design-editor/DesignEditor.tsx +247 -0
- package/design-editor/index.ts +2 -0
- package/design-editor/server.ts +121 -0
- package/design-editor/types.ts +16 -0
- package/designs/default-project.json +210 -0
- package/dist/common/design-editor/DesignEditor.js +239 -0
- package/dist/common/design-editor/index.js +18 -0
- package/dist/common/design-editor/server.js +98 -0
- package/dist/common/design-editor/types.js +2 -0
- package/dist/common/src/App.js +53 -0
- package/dist/common/src/Node.js +4 -8
- package/dist/common/src/PM/PM_WithEslintAndTsc.js +10 -34
- package/dist/common/src/PM/base.js +1 -1
- package/dist/common/src/PM/main.js +581 -113
- package/dist/common/src/PM/node.js +4 -2
- package/dist/common/src/PM/nodeSidecar.js +1 -0
- package/dist/common/src/PM/pure.js +20 -57
- package/dist/common/src/PM/pureSidecar.js +1 -1
- package/dist/common/src/PM/types.js +1 -0
- package/dist/common/src/PM/web.js +7 -4
- package/dist/common/src/Pure.js +1 -1
- package/dist/common/src/Pure.test.js +49 -79
- package/dist/common/src/ReportServer.js +8 -2
- package/dist/common/src/build.js +31 -40
- package/dist/common/src/components/DesignEditorPage.js +169 -0
- package/dist/common/src/components/SunriseAnimation.js +291 -0
- package/dist/common/src/components/SunriseAnimation.test/interface.js +67 -0
- package/dist/common/src/components/SunriseAnimation.test/types.js +2 -0
- package/dist/common/src/components/TestStatusBadge.js +1 -21
- package/dist/common/src/components/pure/AppFrame.js +69 -0
- package/dist/common/src/components/pure/AppFrame.test/implementation.js +63 -0
- package/dist/common/src/components/pure/AppFrame.test/index.js +14 -0
- package/dist/common/src/components/pure/AppFrame.test/specification.js +25 -0
- package/dist/common/src/components/pure/AppFrame.test/types.js +3 -0
- package/dist/common/src/components/pure/FeaturesReporterView.js +23 -0
- package/dist/common/src/components/pure/FeaturesReporterView.test/implementation.js +84 -0
- package/dist/common/src/components/pure/FeaturesReporterView.test/index.js +14 -0
- package/dist/common/src/components/pure/FeaturesReporterView.test/specification.js +27 -0
- package/dist/common/src/components/pure/FeaturesReporterView.test/types.js +2 -0
- package/dist/common/src/components/pure/ModalContent.js +86 -0
- package/dist/common/src/components/pure/ModalContent.test/implementation.js +35 -0
- package/dist/common/src/components/pure/ModalContent.test/index.js +58 -0
- package/dist/common/src/components/pure/ModalContent.test/specification.js +19 -0
- package/dist/common/src/components/pure/ModalContent.test/types.js +4 -0
- package/dist/common/src/{NavBar.js → components/pure/NavBar.js} +9 -10
- package/dist/common/src/components/pure/ProcessManager.js +112 -0
- package/dist/common/src/components/pure/ProcessManagerView.js +237 -0
- package/dist/common/src/components/pure/ProjectPageView.js +53 -76
- package/dist/common/src/components/pure/ProjectPageView.test/implementation.js +167 -54
- package/dist/common/src/components/pure/ProjectPageView.test/index.js +5 -1
- package/dist/common/src/components/pure/ProjectPageView.test/specification.js +15 -2
- package/dist/common/src/components/pure/ProjectPageView.test/types.js +2 -0
- package/dist/common/src/components/pure/ProjectsPageView.js +72 -0
- package/dist/common/src/components/pure/SettingsButton.js +13 -0
- package/dist/common/src/components/pure/SingleProcessView.js +214 -0
- package/dist/common/src/components/pure/TestPageView.js +513 -0
- package/dist/common/src/components/pure/TestPageView.test/implementation.js +157 -0
- package/dist/common/src/components/pure/TestPageView.test/index.js +15 -0
- package/dist/common/src/components/pure/TestPageView.test/specification.js +26 -0
- package/dist/common/src/components/pure/TestPageView.test/types.js +4 -0
- package/dist/common/src/components/pure/ThemeCard.js +15 -0
- package/dist/common/src/components/stateful/FeaturesReporter.js +59 -0
- package/dist/common/src/components/stateful/FileTree.js +40 -0
- package/dist/common/src/components/stateful/ProcessManagerPage.js +112 -0
- package/dist/common/src/components/stateful/ProjectPage.js +101 -0
- package/dist/common/src/components/stateful/ProjectsPage.js +118 -0
- package/dist/common/src/components/stateful/SettingsPage.js +72 -0
- package/dist/common/src/components/stateful/SingleProcessPage.js +147 -0
- package/dist/common/src/components/stateful/TestPage.js +229 -0
- package/dist/common/src/components/stateful/TextEditorPage.js +154 -0
- package/dist/common/src/defaultConfig.js +1 -0
- package/dist/common/src/esbuildConfigs/inputFilesPlugin.js +3 -4
- package/dist/common/src/esbuildConfigs/web.js +1 -1
- package/dist/common/src/lib/BaseSuite.js +7 -3
- package/dist/common/src/lib/BaseSuite.test/mock.js +17 -41
- package/dist/common/src/lib/BaseSuite.test/test.js +33 -42
- package/dist/common/src/lib/Sidecar.js +1 -0
- package/dist/common/src/lib/abstractBase.js +40 -13
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.adapter.js +12 -12
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.implementation.js +15 -13
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.mock.js +28 -17
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.pure.js +2 -2
- package/dist/common/src/lib/basebuilder.js +29 -35
- package/dist/common/src/lib/classBuilder.js +5 -3
- package/dist/common/src/lib/core.js +3 -6
- package/dist/common/src/lib/core.test/MockCore.js +0 -14
- package/dist/common/src/lib/core.test/core.test.adapter.js +2 -9
- package/dist/common/src/lib/core.test/core.test.implementation.js +3 -7
- package/dist/common/src/lib/index.js +13 -14
- package/dist/common/src/lib/pmProxy.js +37 -16
- package/dist/common/src/lib/pmProxy.test/adapter.js +20 -4
- package/dist/common/src/lib/pmProxy.test/implementation.js +93 -34
- package/dist/common/src/lib/pmProxy.test/mockPMBase.js +9 -0
- package/dist/common/src/lib/pmProxy.test/specification.js +3 -0
- package/dist/common/src/mothership/index.js +5 -0
- package/dist/common/src/mothership/test.js +44 -25
- package/dist/common/src/types/features.js +34 -0
- package/dist/common/src/utils/api.js +57 -27
- package/dist/common/src/utils/featureUtils.js +29 -0
- package/dist/common/src/utils/logFiles.js +51 -0
- package/dist/common/src/utils/makePrompt.js +116 -0
- package/dist/common/src/web.html.js +2 -6
- package/dist/common/testeranto.config.js +54 -24
- package/dist/common/tsconfig.common.tsbuildinfo +1 -1
- package/dist/module/design-editor/DesignEditor.js +203 -0
- package/dist/module/design-editor/index.js +2 -0
- package/dist/module/design-editor/server.js +92 -0
- package/dist/module/design-editor/types.js +1 -0
- package/dist/module/src/App.js +19 -17
- package/dist/module/src/Node.js +4 -8
- package/dist/module/src/PM/PM_WithEslintAndTsc.js +11 -35
- package/dist/module/src/PM/base.js +1 -1
- package/dist/module/src/PM/main.js +577 -109
- package/dist/module/src/PM/node.js +4 -2
- package/dist/module/src/PM/nodeSidecar.js +1 -0
- package/dist/module/src/PM/pure.js +20 -57
- package/dist/module/src/PM/pureSidecar.js +1 -1
- package/dist/module/src/PM/types.js +1 -0
- package/dist/module/src/PM/web.js +7 -4
- package/dist/module/src/Pure.js +1 -1
- package/dist/module/src/Pure.test.js +49 -79
- package/dist/module/src/ReportServer.js +8 -2
- package/dist/module/src/build.js +26 -38
- package/dist/module/src/components/DesignEditorPage.js +132 -0
- package/dist/module/src/components/SunriseAnimation.test/interface.js +32 -1
- package/dist/module/src/components/SunriseAnimation.test/types.js +1 -0
- package/dist/module/src/components/TestStatusBadge.js +1 -21
- package/dist/module/src/components/pure/AppFrame.js +32 -0
- package/dist/module/src/components/pure/AppFrame.test/implementation.js +57 -0
- package/dist/module/src/components/pure/AppFrame.test/index.js +9 -0
- package/dist/module/src/components/pure/AppFrame.test/specification.js +21 -0
- package/dist/module/src/components/pure/AppFrame.test/types.js +2 -0
- package/dist/module/src/components/pure/FeaturesReporterView.js +16 -0
- package/dist/module/src/components/pure/FeaturesReporterView.test/implementation.js +81 -0
- package/dist/module/src/components/pure/FeaturesReporterView.test/index.js +9 -0
- package/dist/module/src/components/pure/FeaturesReporterView.test/specification.js +23 -0
- package/dist/module/src/components/pure/FeaturesReporterView.test/types.js +1 -0
- package/dist/module/src/components/pure/ModalContent.js +79 -0
- package/dist/module/src/components/pure/ModalContent.test/implementation.js +32 -0
- package/dist/module/src/components/pure/ModalContent.test/index.js +53 -0
- package/dist/module/src/components/pure/ModalContent.test/specification.js +15 -0
- package/dist/module/src/components/pure/ModalContent.test/types.js +3 -0
- package/dist/module/src/{NavBar.js → components/pure/NavBar.js} +10 -11
- package/dist/module/src/components/pure/ProcessManager.js +75 -0
- package/dist/module/src/components/pure/ProcessManagerView.js +200 -0
- package/dist/module/src/components/pure/ProjectPageView.js +54 -77
- package/dist/module/src/components/pure/ProjectPageView.test/implementation.js +167 -54
- package/dist/module/src/components/pure/ProjectPageView.test/index.js +5 -1
- package/dist/module/src/components/pure/ProjectPageView.test/specification.js +15 -2
- package/dist/module/src/components/pure/ProjectPageView.test/types.js +2 -0
- package/dist/module/src/components/pure/ProjectsPageView.js +21 -14
- package/dist/module/src/components/pure/SettingsButton.js +6 -0
- package/dist/module/src/components/pure/SingleProcessView.js +214 -0
- package/dist/module/src/components/pure/TestPageView.js +470 -142
- package/dist/module/src/components/pure/TestPageView.test/implementation.js +121 -0
- package/dist/module/src/components/pure/TestPageView.test/index.js +10 -0
- package/dist/module/src/components/pure/TestPageView.test/specification.js +22 -0
- package/dist/module/src/components/pure/TestPageView.test/types.js +3 -0
- package/dist/module/src/components/pure/ThemeCard.js +8 -0
- package/dist/module/src/components/stateful/FeaturesReporter.js +22 -0
- package/dist/module/src/components/stateful/FileTree.js +33 -0
- package/dist/module/src/components/stateful/ProcessManagerPage.js +75 -0
- package/dist/module/src/components/stateful/ProjectPage.js +7 -6
- package/dist/module/src/components/stateful/ProjectsPage.js +32 -6
- package/dist/module/src/components/stateful/SettingsPage.js +35 -0
- package/dist/module/src/components/stateful/SingleProcessPage.js +110 -0
- package/dist/module/src/components/stateful/TestPage.js +123 -13
- package/dist/module/src/components/stateful/TextEditorPage.js +117 -0
- package/dist/module/src/defaultConfig.js +1 -0
- package/dist/module/src/esbuildConfigs/inputFilesPlugin.js +3 -4
- package/dist/module/src/esbuildConfigs/web.js +1 -1
- package/dist/module/src/lib/BaseSuite.js +7 -3
- package/dist/module/src/lib/BaseSuite.test/mock.js +17 -41
- package/dist/module/src/lib/BaseSuite.test/test.js +33 -42
- package/dist/module/src/lib/Sidecar.js +1 -0
- package/dist/module/src/lib/abstractBase.js +40 -13
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.adapter.js +12 -12
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.implementation.js +15 -13
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.mock.js +28 -17
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.pure.js +1 -1
- package/dist/module/src/lib/basebuilder.js +29 -35
- package/dist/module/src/lib/classBuilder.js +5 -3
- package/dist/module/src/lib/core.js +3 -6
- package/dist/module/src/lib/core.test/MockCore.js +0 -14
- package/dist/module/src/lib/core.test/core.test.adapter.js +2 -9
- package/dist/module/src/lib/core.test/core.test.implementation.js +3 -7
- package/dist/module/src/lib/index.js +13 -14
- package/dist/module/src/lib/pmProxy.js +37 -16
- package/dist/module/src/lib/pmProxy.test/adapter.js +20 -4
- package/dist/module/src/lib/pmProxy.test/implementation.js +93 -34
- package/dist/module/src/lib/pmProxy.test/mockPMBase.js +9 -0
- package/dist/module/src/lib/pmProxy.test/specification.js +3 -0
- package/dist/module/src/mothership/index.js +5 -0
- package/dist/module/src/mothership/test.js +44 -25
- package/dist/module/src/types/features.js +31 -0
- package/dist/module/src/utils/api.js +56 -25
- package/dist/module/src/utils/featureUtils.js +24 -0
- package/dist/module/src/utils/logFiles.js +46 -0
- package/dist/module/src/utils/makePrompt.js +109 -0
- package/dist/module/src/web.html.js +2 -6
- package/dist/module/testeranto.config.js +54 -24
- package/dist/module/tsconfig.module.tsbuildinfo +1 -1
- package/dist/prebuild/App.css +53 -80
- package/dist/prebuild/App.js +15520 -4397
- package/dist/prebuild/ReportServer.mjs +104 -6
- package/dist/prebuild/build.mjs +95 -108
- package/dist/prebuild/mothership/index.mjs +5 -0
- package/dist/prebuild/run.mjs +704 -221
- package/dist/types/design-editor/DesignEditor.d.ts +18 -0
- package/dist/types/design-editor/server.d.ts +1 -0
- package/dist/types/src/App.d.ts +1 -0
- package/dist/types/src/PM/index.d.ts +1 -1
- package/dist/types/src/PM/main.d.ts +37 -3
- package/dist/types/src/PM/pure.d.ts +10 -7
- package/dist/types/src/PM/web.d.ts +1 -1
- package/dist/types/src/Pure.test.d.ts +13 -1
- package/dist/types/src/Types.d.ts +1 -0
- package/dist/types/src/components/DesignEditorPage.d.ts +1 -0
- package/dist/types/src/components/SunriseAnimation.d.ts +5 -0
- package/dist/types/src/components/SunriseAnimation.test/interface.d.ts +11 -0
- package/dist/types/src/components/SunriseAnimation.test/types.d.ts +39 -0
- package/dist/types/src/components/pure/AppFrame.d.ts +11 -0
- package/dist/types/src/components/pure/AppFrame.test/implementation.d.ts +3 -0
- package/dist/types/src/components/pure/AppFrame.test/index.d.ts +5 -0
- package/dist/types/src/components/pure/AppFrame.test/specification.d.ts +3 -0
- package/dist/types/src/components/pure/AppFrame.test/types.d.ts +33 -0
- package/dist/types/src/components/pure/FeaturesReporterView.d.ts +7 -0
- package/dist/types/src/components/pure/FeaturesReporterView.test/implementation.d.ts +3 -0
- package/dist/types/src/components/pure/FeaturesReporterView.test/index.d.ts +2 -0
- package/dist/types/src/components/pure/FeaturesReporterView.test/specification.d.ts +3 -0
- package/dist/types/src/components/pure/FeaturesReporterView.test/types.d.ts +54 -0
- package/dist/types/src/components/pure/ModalContent.d.ts +7 -0
- package/dist/types/src/components/pure/ModalContent.test/implementation.d.ts +3 -0
- package/dist/types/src/components/pure/ModalContent.test/index.d.ts +3 -0
- package/dist/types/src/components/pure/ModalContent.test/specification.d.ts +3 -0
- package/dist/types/src/components/pure/ModalContent.test/types.d.ts +45 -0
- package/dist/types/src/{NavBar.d.ts → components/pure/NavBar.d.ts} +4 -0
- package/dist/types/src/components/pure/ProcessManager.d.ts +8 -0
- package/dist/types/src/components/pure/ProcessManagerView.d.ts +20 -0
- package/dist/types/src/components/pure/ProjectPageView.d.ts +7 -7
- package/dist/types/src/components/pure/ProjectPageView.test/index.d.ts +1 -2
- package/dist/types/src/components/pure/ProjectPageView.test/types.d.ts +29 -11
- package/dist/types/src/components/pure/ProjectsPageView.d.ts +29 -0
- package/dist/types/src/components/pure/SettingsButton.d.ts +2 -0
- package/dist/types/src/components/pure/SingleProcessView.d.ts +0 -0
- package/dist/types/src/components/pure/TestPageView.d.ts +15 -0
- package/dist/types/src/components/pure/TestPageView.test/implementation.d.ts +12 -0
- package/dist/types/src/components/pure/TestPageView.test/index.d.ts +3 -0
- package/dist/types/src/components/pure/TestPageView.test/specification.d.ts +11 -0
- package/dist/types/src/components/pure/TestPageView.test/types.d.ts +65 -0
- package/dist/types/src/components/pure/ThemeCard.d.ts +9 -0
- package/dist/types/src/components/stateful/FeaturesReporter.d.ts +2 -0
- package/dist/types/src/components/stateful/FileTree.d.ts +8 -0
- package/dist/types/src/components/stateful/ProcessManagerPage.d.ts +2 -0
- package/dist/types/src/components/stateful/ProjectPage.d.ts +1 -0
- package/dist/types/src/components/stateful/ProjectsPage.d.ts +1 -0
- package/dist/types/src/components/stateful/SettingsPage.d.ts +2 -0
- package/dist/types/src/components/stateful/SingleProcessPage.d.ts +2 -0
- package/dist/types/src/components/stateful/TestPage.d.ts +1 -0
- package/dist/types/src/components/stateful/TextEditorPage.d.ts +1 -0
- package/dist/types/src/lib/BaseSuite.test/mock.d.ts +3 -3
- package/dist/types/src/lib/abstractBase.d.ts +1 -1
- package/dist/types/src/lib/abstractBase.test/MockGiven.d.ts +1 -1
- package/dist/types/src/lib/baseBuilder.test/baseBuilder.test.pure.d.ts +1 -1
- package/dist/types/src/lib/basebuilder.d.ts +1 -1
- package/dist/types/src/lib/index.d.ts +8 -8
- package/dist/types/src/lib/pmProxy.test/mockPMBase.d.ts +1 -1
- package/dist/types/src/types/features.d.ts +7 -0
- package/dist/types/src/utils/api.d.ts +1 -5
- package/dist/types/src/utils/featureUtils.d.ts +6 -0
- package/dist/types/src/utils/logFiles.d.ts +71 -0
- package/dist/types/src/utils/makePrompt.d.ts +2 -0
- package/dist/types/src/web.html.d.ts +1 -1
- package/dist/types/tsconfig.types.tsbuildinfo +1 -1
- package/docs/index.md +17 -0
- package/docs/test-page-components.md +91 -0
- package/docs/testing.prompt.txt +1 -3
- package/index.d.ts +38 -13
- package/marketing.md +166 -0
- package/package.json +38 -11
- package/src/App.tsx +22 -25
- package/src/Node.ts +6 -9
- package/src/PM/PM_WithEslintAndTsc.ts +16 -97
- package/src/PM/__tests__/nodeSidecar.testeranto.ts +2 -0
- package/src/PM/base.ts +1 -3
- package/src/PM/index.ts +1 -1
- package/src/PM/main.ts +673 -128
- package/src/PM/node.ts +5 -2
- package/src/PM/nodeSidecar.ts +1 -0
- package/src/PM/pure.ts +28 -72
- package/src/PM/pureSidecar.ts +1 -1
- package/src/PM/types.ts +0 -0
- package/src/PM/web.ts +9 -4
- package/src/Pure.test.ts +66 -101
- package/src/Pure.ts +1 -1
- package/src/README.md +85 -0
- package/src/ReportServer.ts +10 -3
- package/src/Types.ts +1 -0
- package/src/app.scss +169 -0
- package/src/build.ts +33 -55
- package/src/components/DesignEditorPage.tsx +169 -0
- package/src/components/{pure/ProjectPageView.test/index.ts → SunriseAnimation.test/index.tsx} +7 -4
- package/src/components/SunriseAnimation.test/interface.ts +49 -0
- package/src/components/SunriseAnimation.test/types.ts +53 -0
- package/src/components/TestStatusBadge.tsx +2 -23
- package/src/components/pure/AppFrame.test/implementation.tsx +72 -0
- package/src/components/pure/AppFrame.test/index.tsx +22 -0
- package/src/components/pure/AppFrame.test/specification.ts +35 -0
- package/src/components/pure/AppFrame.test/types.ts +65 -0
- package/src/components/pure/AppFrame.tsx +134 -0
- package/src/components/pure/FeaturesReporterView.test/implementation.tsx +106 -0
- package/src/components/pure/FeaturesReporterView.test/index.tsx +18 -0
- package/src/components/pure/FeaturesReporterView.test/specification.ts +39 -0
- package/src/components/pure/FeaturesReporterView.test/types.ts +77 -0
- package/src/components/pure/FeaturesReporterView.tsx +37 -0
- package/src/components/pure/ModalContent.test/implementation.tsx +45 -0
- package/src/components/pure/ModalContent.test/index.tsx +67 -0
- package/src/components/pure/ModalContent.test/specification.ts +27 -0
- package/src/components/pure/ModalContent.test/types.ts +72 -0
- package/src/components/pure/ModalContent.tsx +182 -0
- package/src/{NavBar.tsx → components/pure/NavBar.tsx} +31 -15
- package/src/components/pure/ProcessManager.tsx +117 -0
- package/src/components/pure/ProcessManagerView.tsx +414 -0
- package/src/components/pure/ProjectPageView.test/implementation.tsx +186 -57
- package/src/components/pure/ProjectPageView.test/index.tsx +18 -0
- package/src/components/pure/ProjectPageView.test/specification.ts +15 -2
- package/src/components/pure/ProjectPageView.test/types.ts +57 -13
- package/src/components/pure/ProjectPageView.tsx +155 -121
- package/src/components/pure/ProjectsPageView.tsx +73 -32
- package/src/components/pure/SettingsButton.md +1 -0
- package/src/components/pure/SettingsButton.tsx +11 -0
- package/src/components/pure/SingleProcessView.tsx +235 -0
- package/src/components/pure/TestPageView.test/implementation.ts +162 -0
- package/src/components/pure/TestPageView.test/index.tsx +20 -0
- package/src/components/pure/TestPageView.test/specification.ts +58 -0
- package/src/components/pure/TestPageView.test/types.ts +92 -0
- package/src/components/pure/TestPageView.tsx +1009 -299
- package/src/components/pure/ThemeCard.tsx +34 -0
- package/src/components/stateful/FeaturesReporter.tsx +24 -0
- package/src/components/stateful/FileTree.tsx +66 -0
- package/src/components/stateful/ProcessManagerPage.tsx +108 -0
- package/src/components/stateful/ProjectPage.tsx +10 -8
- package/src/components/stateful/ProjectsPage.tsx +36 -7
- package/src/components/stateful/SettingsPage.tsx +82 -0
- package/src/components/stateful/SingleProcessPage.tsx +155 -0
- package/src/components/stateful/TestPage.tsx +147 -30
- package/src/components/stateful/TextEditorPage.tsx +170 -0
- package/src/defaultConfig.ts +1 -0
- package/src/esbuildConfigs/inputFilesPlugin.ts +3 -4
- package/src/esbuildConfigs/web.ts +2 -1
- package/src/lib/BaseSuite.test/mock.ts +21 -68
- package/src/lib/BaseSuite.test/test.ts +39 -65
- package/src/lib/BaseSuite.ts +9 -3
- package/src/lib/Sidecar.ts +2 -0
- package/src/lib/abstractBase.test/MockGiven.ts +1 -1
- package/src/lib/abstractBase.ts +47 -20
- package/src/lib/baseBuilder.test/baseBuilder.test.adapter.ts +14 -13
- package/src/lib/baseBuilder.test/baseBuilder.test.implementation.ts +17 -14
- package/src/lib/baseBuilder.test/baseBuilder.test.mock.ts +27 -17
- package/src/lib/baseBuilder.test/baseBuilder.test.pure.ts +1 -1
- package/src/lib/basebuilder.ts +48 -54
- package/src/lib/classBuilder.ts +11 -10
- package/src/lib/core.test/MockCore.ts +0 -23
- package/src/lib/core.test/core.test.adapter.ts +6 -12
- package/src/lib/core.test/core.test.implementation.ts +7 -10
- package/src/lib/core.ts +5 -20
- package/src/lib/index.ts +28 -27
- package/src/lib/pmProxy.test/adapter.ts +18 -4
- package/src/lib/pmProxy.test/implementation.ts +130 -46
- package/src/lib/pmProxy.test/mockPMBase.ts +12 -1
- package/src/lib/pmProxy.test/specification.ts +11 -0
- package/src/lib/pmProxy.ts +42 -17
- package/src/lib/types.ts +2 -0
- package/src/mothership/index.ts +6 -0
- package/src/mothership/test.ts +53 -26
- package/src/style.md +2 -0
- package/src/style.scss +3 -486
- package/src/templates/frontpage.html +331 -0
- package/src/templates/frontpage.md +79 -0
- package/src/themes.scss +48 -16
- package/src/types/features.ts +38 -0
- package/src/utils/api.ts +66 -33
- package/src/utils/featureUtils.tsx +42 -0
- package/src/utils/logFiles.ts +60 -0
- package/src/utils/makePrompt.ts +149 -0
- package/src/web.html.ts +6 -6
- package/stargazers.txt +15 -0
- package/stargzers.js +68 -0
- package/testeranto/App.css +53 -80
- package/testeranto/App.js +15520 -4397
- package/testeranto/bundles/node/core/chunk-4CSH4UJE.mjs +872 -0
- package/testeranto/bundles/node/core/chunk-4JTDLQVA.mjs +253 -0
- package/testeranto/bundles/node/core/chunk-C3APFDUV.mjs +70 -0
- package/testeranto/bundles/node/core/src/lib/BaseSuite.test/node.test.mjs +295 -0
- package/testeranto/bundles/node/core/src/lib/baseBuilder.test/baseBuilder.test.node.mjs +243 -0
- package/testeranto/bundles/node/core/src/lib/classBuilder.test/classBuilder.test.mjs +411 -0
- package/testeranto/bundles/node/core/src/lib/core.test/core.test.mjs +494 -0
- package/testeranto/bundles/node/core/src/lib/pmProxy.test/index.mjs +4755 -0
- package/testeranto/bundles/pure/core/chunk-62UVCSQC.mjs +1022 -0
- package/testeranto/bundles/pure/core/src/Pure.test.mjs +410 -0
- package/testeranto/bundles/pure/core/src/lib/BaseSuite.test/pure.test.mjs +352 -0
- package/testeranto/bundles/pure/core/src/lib/baseBuilder.test/baseBuilder.test.pure.mjs +241 -0
- package/testeranto/bundles/web/core/src/components/pure/FeaturesReporterView.test/index.html +15 -0
- package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.html +1 -5
- package/testeranto/bundles/web/core/src/components/pure/TestPageView.test/index.html +15 -0
- package/testeranto/bundles/web/core/src/lib/BaseSuite.test/web.test.html +15 -0
- package/testeranto/bundles/web/core/src/lib/baseBuilder.test/baseBuilder.test.web.html +15 -0
- package/testeranto/metafiles/node/core.json +2906 -0
- package/testeranto/metafiles/pure/core.json +860 -0
- package/testeranto/metafiles/web/core.json +546 -0
- package/testeranto/reports/core/config.json +103 -2
- package/testeranto/reports/core/src/Pure.test/pure/exit.log +0 -0
- package/testeranto/reports/core/src/Pure.test/pure/lint_errors.txt +0 -0
- package/testeranto/reports/core/src/Pure.test/pure/message.txt +17 -0
- package/testeranto/reports/core/src/Pure.test/pure/prompt.txt +14 -0
- package/testeranto/reports/core/src/Pure.test/pure/type_errors.txt +71 -0
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/debug.log +0 -0
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/error.log +3 -0
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/exit.log +1 -0
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/info.log +0 -0
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/warn.log +0 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/debug.log +0 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/error.log +3 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/exit.log +1 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/info.log +0 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/warn.log +0 -0
- package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/debug.log +0 -0
- package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/error.log +3 -0
- package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/exit.log +1 -0
- package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/info.log +0 -0
- package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/warn.log +0 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/exit.log +1 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/lint_errors.txt +0 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/message.txt +17 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/prompt.txt +14 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/stderr.log +0 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/stdout.log +0 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/tests.json +31 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/type_errors.txt +61 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/exit.log +0 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/lint_errors.txt +0 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/message.txt +17 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/prompt.txt +15 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/type_errors.txt +61 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/debug.log +0 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/error.log +3 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/exit.log +1 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/info.log +0 -0
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/warn.log +0 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/exit.log +1 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/lint_errors.txt +10 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/message.txt +17 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/prompt.txt +17 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/stderr.log +0 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/stdout.log +6 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/suite-0/given-testInitialization/then-0/butThen/hello.txt +1 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/suite-0/given-testInitialization/then-1/butThen/artifact_test.txt +1 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/tests.json +71 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/type_errors.txt +42 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/exit.log +0 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/lint_errors.txt +10 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/message.txt +17 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/prompt.txt +17 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/type_errors.txt +42 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/debug.log +0 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/error.log +3 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/exit.log +1 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/info.log +0 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/warn.log +0 -0
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/exit.log +1 -0
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/lint_errors.txt +0 -0
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/message.txt +17 -0
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/prompt.txt +17 -0
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/stderr.log +0 -0
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/stdout.log +619 -0
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/tests.json +165 -0
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/type_errors.txt +88 -0
- package/testeranto/reports/core/src/lib/core.test/core.test/node/exit.log +1 -0
- package/testeranto/reports/core/src/lib/core.test/core.test/node/lint_errors.txt +21 -0
- package/testeranto/reports/core/src/lib/core.test/core.test/node/message.txt +17 -0
- package/testeranto/reports/core/src/lib/core.test/core.test/node/prompt.txt +19 -0
- package/testeranto/reports/core/src/lib/core.test/core.test/node/stderr.log +0 -0
- package/testeranto/reports/core/src/lib/core.test/core.test/node/stdout.log +0 -0
- package/testeranto/reports/core/src/lib/core.test/core.test/node/type_errors.txt +45 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/exit.log +1 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/lint_errors.txt +15 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/message.txt +17 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/prompt.txt +17 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/stderr.log +88 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/stdout.log +10 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/tests.json +152 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/type_errors.txt +52 -0
- package/testeranto/reports/core/summary.json +74 -5
- package/testeranto/reportsweb_build_errors +546 -0
- package/testeranto.config.ts +58 -25
- package/tsc.log +378 -211
- package/tsconfig.common.json +4 -2
- package/tsconfig.json +9 -6
- package/tsconfig.module.json +3 -2
- package/tsconfig.types.json +3 -1
- package/dist/common/src/components/pure/ProjectPageView.test/adapter.js +0 -20
- package/dist/common/src/lib/dailyAnimation.js +0 -130
- package/dist/module/src/Footer.js +0 -5
- package/dist/module/src/ProjectPage.js +0 -319
- package/dist/module/src/ProjectsPage.js +0 -1
- package/dist/module/src/SettingsButton.js +0 -157
- package/dist/module/src/TestPage.js +0 -271
- package/dist/module/src/TestReport.js +0 -368
- package/dist/module/src/components/pure/ProjectPageView.test/adapter.js +0 -17
- package/dist/module/src/lib/dailyAnimation.js +0 -130
- package/dist/types/src/components/pure/ProjectPageView.test/adapter.d.ts +0 -3
- package/dist/types/testeranto.config.d.ts +0 -3
- package/docs/testing.ai.txt +0 -106
- package/docs.html +0 -572
- package/example.css +0 -351
- package/index.html +0 -284
- package/scripts/compile-docs.js +0 -140
- package/src/App.scss +0 -132
- package/src/Footer.tsx +0 -8
- package/src/Project.scss +0 -1
- package/src/ProjectPage.tsx +0 -459
- package/src/ProjectsPage.tsx +0 -1
- package/src/ReportApp.scss +0 -1
- package/src/SettingsButton.tsx +0 -268
- package/src/TestPage.tsx +0 -476
- package/src/TestReport.scss +0 -24
- package/src/TestReport.tsx +0 -411
- package/src/components/pure/ProjectPageView.test/adapter.ts +0 -21
- package/src/fonts.scss +0 -55
- package/src/lib/dailyAnimation.ts +0 -147
- package/style.css +0 -12156
- package/testeranto/bundles/node/core/metafile.json +0 -8
- package/testeranto/bundles/pure/core/metafile.json +0 -8
- package/testeranto/bundles/web/core/metafile.json +0 -15086
- package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.mjs +0 -39991
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/lint_errors.txt +0 -18
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/logs.txt +0 -59
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/message.txt +0 -2
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/prompt.txt +0 -27
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/suite-0/given-basicRender/then-0/butThen/happyPath.png +0 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/type_errors.txt +0 -50
- /package/dist/types/src/{lib/dailyAnimation.d.ts → PM/types.d.ts} +0 -0
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
|
+
import React, { useState, useEffect, useRef } from 'react';
|
|
3
|
+
import { Canvas, Rect, Circle, Text } from 'fabric';
|
|
4
|
+
import { toPng } from 'html-to-image';
|
|
5
|
+
export const DesignEditor = React.forwardRef(({ projectId }, ref) => {
|
|
6
|
+
const canvasRef = useRef(null);
|
|
7
|
+
const [design, setDesign] = useState({
|
|
8
|
+
objects: [],
|
|
9
|
+
background: '#ffffff',
|
|
10
|
+
version: '1.0'
|
|
11
|
+
});
|
|
12
|
+
const [collaborators, setCollaborators] = useState([]);
|
|
13
|
+
const wsRef = useRef(null);
|
|
14
|
+
// Initialize canvas and WebSocket connection
|
|
15
|
+
useEffect(() => {
|
|
16
|
+
const canvas = new Canvas('design-canvas', {
|
|
17
|
+
width: 800,
|
|
18
|
+
height: 600
|
|
19
|
+
});
|
|
20
|
+
canvas.backgroundColor = design.background;
|
|
21
|
+
canvasRef.current = canvas;
|
|
22
|
+
const wsPort = window.location.port ? Number(window.location.port) + 1 : 3001;
|
|
23
|
+
const protocol = window.location.protocol === 'https:' ? 'wss:' : 'ws:';
|
|
24
|
+
const host = window.location.hostname;
|
|
25
|
+
wsRef.current = new WebSocket(`${protocol}//${host}:${wsPort}/design?project=${projectId}`);
|
|
26
|
+
wsRef.current.onmessage = (event) => {
|
|
27
|
+
const message = JSON.parse(event.data);
|
|
28
|
+
if (message.type === 'design_update' && canvasRef.current) {
|
|
29
|
+
canvasRef.current.loadFromJSON(message.data, () => {
|
|
30
|
+
var _a;
|
|
31
|
+
(_a = canvasRef.current) === null || _a === void 0 ? void 0 : _a.renderAll();
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
else if (message.type === 'collaborators_update') {
|
|
35
|
+
setCollaborators(message.data);
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
return () => {
|
|
39
|
+
var _a;
|
|
40
|
+
(_a = wsRef.current) === null || _a === void 0 ? void 0 : _a.close();
|
|
41
|
+
canvas.dispose();
|
|
42
|
+
};
|
|
43
|
+
}, [projectId]);
|
|
44
|
+
const addShape = (shape) => {
|
|
45
|
+
if (!canvasRef.current)
|
|
46
|
+
return;
|
|
47
|
+
let object;
|
|
48
|
+
switch (shape) {
|
|
49
|
+
case 'rectangle':
|
|
50
|
+
object = new Rect({
|
|
51
|
+
width: 100,
|
|
52
|
+
height: 100,
|
|
53
|
+
fill: 'red',
|
|
54
|
+
left: 100,
|
|
55
|
+
top: 100
|
|
56
|
+
});
|
|
57
|
+
break;
|
|
58
|
+
case 'circle':
|
|
59
|
+
object = new Circle({
|
|
60
|
+
radius: 50,
|
|
61
|
+
fill: 'blue',
|
|
62
|
+
left: 200,
|
|
63
|
+
top: 200
|
|
64
|
+
});
|
|
65
|
+
break;
|
|
66
|
+
case 'text':
|
|
67
|
+
object = new Text('Double click to edit', {
|
|
68
|
+
fontFamily: 'Arial',
|
|
69
|
+
fontSize: 20,
|
|
70
|
+
left: 100,
|
|
71
|
+
top: 300
|
|
72
|
+
});
|
|
73
|
+
break;
|
|
74
|
+
default:
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
canvasRef.current.add(object);
|
|
78
|
+
canvasRef.current.renderAll();
|
|
79
|
+
};
|
|
80
|
+
const saveDesign = () => {
|
|
81
|
+
if (!canvasRef.current) {
|
|
82
|
+
console.warn('Canvas ref is null, cannot save design');
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
try {
|
|
86
|
+
// Get current canvas state
|
|
87
|
+
const json = canvasRef.current.toJSON();
|
|
88
|
+
setDesign(json);
|
|
89
|
+
// Send update to collaborators
|
|
90
|
+
if (wsRef.current) {
|
|
91
|
+
wsRef.current.send(JSON.stringify({
|
|
92
|
+
type: 'design_update',
|
|
93
|
+
data: json
|
|
94
|
+
}));
|
|
95
|
+
}
|
|
96
|
+
// Force re-render of all objects
|
|
97
|
+
canvasRef.current.getObjects().forEach(obj => {
|
|
98
|
+
obj.set('dirty', true);
|
|
99
|
+
});
|
|
100
|
+
canvasRef.current.renderAll();
|
|
101
|
+
console.log('Design saved:', json);
|
|
102
|
+
return json;
|
|
103
|
+
}
|
|
104
|
+
catch (err) {
|
|
105
|
+
console.error('Error saving design:', err);
|
|
106
|
+
return null;
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
const loadDesign = (design) => {
|
|
110
|
+
console.log('loadDesign called with:', design);
|
|
111
|
+
if (!canvasRef.current) {
|
|
112
|
+
console.warn('Canvas ref is null, cannot load design');
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
try {
|
|
116
|
+
console.log('Loading design into canvas...');
|
|
117
|
+
// Clear existing canvas
|
|
118
|
+
canvasRef.current.clear();
|
|
119
|
+
// Set background color
|
|
120
|
+
if (design.background) {
|
|
121
|
+
canvasRef.current.backgroundColor = design.background;
|
|
122
|
+
}
|
|
123
|
+
// Load objects if they exist
|
|
124
|
+
if (design.objects && design.objects.length > 0) {
|
|
125
|
+
console.log('Loading objects:', design.objects.length);
|
|
126
|
+
canvasRef.current.loadFromJSON(design, () => {
|
|
127
|
+
var _a, _b;
|
|
128
|
+
console.log('Design loaded, rendering canvas...');
|
|
129
|
+
// Force re-render of all objects
|
|
130
|
+
(_a = canvasRef.current) === null || _a === void 0 ? void 0 : _a.getObjects().forEach(obj => {
|
|
131
|
+
obj.set('dirty', true);
|
|
132
|
+
});
|
|
133
|
+
(_b = canvasRef.current) === null || _b === void 0 ? void 0 : _b.renderAll();
|
|
134
|
+
console.log('Canvas rendered with new design');
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
console.log('No objects to load, rendering empty canvas');
|
|
139
|
+
canvasRef.current.renderAll();
|
|
140
|
+
}
|
|
141
|
+
// Force immediate render
|
|
142
|
+
canvasRef.current.renderAll();
|
|
143
|
+
}
|
|
144
|
+
catch (err) {
|
|
145
|
+
console.error('Error loading design:', err);
|
|
146
|
+
if (err instanceof Error) {
|
|
147
|
+
console.error('Error details:', {
|
|
148
|
+
name: err.name,
|
|
149
|
+
message: err.message,
|
|
150
|
+
stack: err.stack
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
};
|
|
155
|
+
// Expose methods via ref
|
|
156
|
+
React.useImperativeHandle(ref, () => ({
|
|
157
|
+
loadDesign,
|
|
158
|
+
saveDesign
|
|
159
|
+
}));
|
|
160
|
+
const exportAsPNG = async () => {
|
|
161
|
+
if (!canvasRef.current)
|
|
162
|
+
return;
|
|
163
|
+
try {
|
|
164
|
+
// Store current active object and hide controls
|
|
165
|
+
const activeObject = canvasRef.current.getActiveObject();
|
|
166
|
+
if (activeObject) {
|
|
167
|
+
canvasRef.current.discardActiveObject();
|
|
168
|
+
}
|
|
169
|
+
// Render once to clear controls
|
|
170
|
+
canvasRef.current.renderAll();
|
|
171
|
+
// Get canvas element and export
|
|
172
|
+
const canvasElement = document.getElementById('design-canvas');
|
|
173
|
+
if (!canvasElement)
|
|
174
|
+
return;
|
|
175
|
+
const dataUrl = await toPng(canvasElement);
|
|
176
|
+
const link = document.createElement('a');
|
|
177
|
+
link.download = `design-${projectId}.png`;
|
|
178
|
+
link.href = dataUrl;
|
|
179
|
+
link.click();
|
|
180
|
+
// Restore active object if there was one
|
|
181
|
+
if (activeObject) {
|
|
182
|
+
canvasRef.current.setActiveObject(activeObject);
|
|
183
|
+
canvasRef.current.renderAll();
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
catch (error) {
|
|
187
|
+
console.error('Error exporting PNG:', error);
|
|
188
|
+
}
|
|
189
|
+
};
|
|
190
|
+
return (React.createElement("div", { className: "design-editor" },
|
|
191
|
+
React.createElement("div", { className: "toolbar" },
|
|
192
|
+
React.createElement("button", { onClick: () => addShape('rectangle') }, "Add Rectangle"),
|
|
193
|
+
React.createElement("button", { onClick: () => addShape('circle') }, "Add Circle"),
|
|
194
|
+
React.createElement("button", { onClick: () => addShape('text') }, "Add Text"),
|
|
195
|
+
React.createElement("button", { onClick: exportAsPNG }, "Export PNG")),
|
|
196
|
+
React.createElement("canvas", { id: "design-canvas" }),
|
|
197
|
+
React.createElement("div", { className: "collaborators" },
|
|
198
|
+
React.createElement("h3", null,
|
|
199
|
+
"Collaborators (",
|
|
200
|
+
collaborators.length,
|
|
201
|
+
")"),
|
|
202
|
+
React.createElement("ul", null, collaborators.map(user => (React.createElement("li", { key: user.id }, user.name)))))));
|
|
203
|
+
});
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
2
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
3
|
+
import { WebSocketServer } from "ws";
|
|
4
|
+
import fs from "fs";
|
|
5
|
+
import path from "path";
|
|
6
|
+
const projects = new Map();
|
|
7
|
+
export function startDesignEditorServer(wssPort, httpPort) {
|
|
8
|
+
const wss = new WebSocketServer({ port: wssPort });
|
|
9
|
+
wss.on("connection", (ws, req) => {
|
|
10
|
+
// Create URL from request URL and host header
|
|
11
|
+
const url = new URL(req.url || "", `http://${req.headers.host}`);
|
|
12
|
+
const projectId = url.searchParams.get("project") || "default";
|
|
13
|
+
if (!projects.has(projectId)) {
|
|
14
|
+
projects.set(projectId, {
|
|
15
|
+
connections: new Set(),
|
|
16
|
+
design: loadDesign(projectId),
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
const project = projects.get(projectId);
|
|
20
|
+
project.connections.add(ws);
|
|
21
|
+
// Send current design to new collaborator
|
|
22
|
+
ws.send(JSON.stringify({
|
|
23
|
+
type: "design_update",
|
|
24
|
+
data: project.design,
|
|
25
|
+
}));
|
|
26
|
+
broadcastCollaborators(projectId);
|
|
27
|
+
ws.on("message", (message) => {
|
|
28
|
+
const data = JSON.parse(message);
|
|
29
|
+
if (data.type === "design_update") {
|
|
30
|
+
project.design = data.data;
|
|
31
|
+
saveDesign(projectId, data.data);
|
|
32
|
+
broadcastToProject(projectId, message.toString());
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
ws.on("close", (code, reason) => {
|
|
36
|
+
project.connections.delete(ws);
|
|
37
|
+
if (project.connections.size === 0) {
|
|
38
|
+
projects.delete(projectId);
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
broadcastCollaborators(projectId);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
console.log(`Design editor WebSocket server running on port ${wssPort}`);
|
|
46
|
+
}
|
|
47
|
+
function broadcastToProject(projectId, message) {
|
|
48
|
+
const project = projects.get(projectId);
|
|
49
|
+
if (project) {
|
|
50
|
+
project.connections.forEach((client) => {
|
|
51
|
+
if (client.readyState === client.OPEN) {
|
|
52
|
+
client.send(message);
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
function broadcastCollaborators(projectId) {
|
|
58
|
+
const project = projects.get(projectId);
|
|
59
|
+
if (project) {
|
|
60
|
+
const collaborators = Array.from(project.connections).map((_, i) => ({
|
|
61
|
+
id: `user-${i}`,
|
|
62
|
+
name: `Collaborator ${i + 1}`,
|
|
63
|
+
}));
|
|
64
|
+
broadcastToProject(projectId, JSON.stringify({
|
|
65
|
+
type: "collaborators_update",
|
|
66
|
+
data: collaborators,
|
|
67
|
+
}));
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
function loadDesign(projectId) {
|
|
71
|
+
const designsDir = path.join(process.cwd(), "designs");
|
|
72
|
+
const filePath = path.join(designsDir, `${projectId}.json`);
|
|
73
|
+
try {
|
|
74
|
+
const data = fs.readFileSync(filePath, "utf-8");
|
|
75
|
+
return JSON.parse(data);
|
|
76
|
+
}
|
|
77
|
+
catch (_a) {
|
|
78
|
+
return {
|
|
79
|
+
version: "1.0",
|
|
80
|
+
background: "#ffffff",
|
|
81
|
+
objects: [],
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
function saveDesign(projectId, design) {
|
|
86
|
+
const designsDir = path.join(process.cwd(), "designs");
|
|
87
|
+
if (!fs.existsSync(designsDir)) {
|
|
88
|
+
fs.mkdirSync(designsDir, { recursive: true });
|
|
89
|
+
}
|
|
90
|
+
const filePath = path.join(designsDir, `${projectId}.json`);
|
|
91
|
+
fs.writeFileSync(filePath, JSON.stringify(design, null, 2));
|
|
92
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/dist/module/src/App.js
CHANGED
|
@@ -1,28 +1,30 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
2
1
|
import React from 'react';
|
|
3
2
|
import ReactDom from "react-dom/client";
|
|
4
3
|
import { HashRouter as Router, Routes, Route } from 'react-router-dom';
|
|
5
4
|
import { TestPage } from './components/stateful/TestPage';
|
|
6
|
-
import { Container } from 'react-bootstrap';
|
|
7
|
-
import { SettingsButton } from './SettingsButton';
|
|
8
5
|
import { ProjectPage } from './components/stateful/ProjectPage';
|
|
9
6
|
import { ProjectsPage } from './components/stateful/ProjectsPage';
|
|
7
|
+
import { AppFrame } from './components/pure/AppFrame';
|
|
8
|
+
import { FeaturesReporter } from './components/stateful/FeaturesReporter';
|
|
9
|
+
import { DesignEditorPage } from './components/DesignEditorPage';
|
|
10
|
+
import { TextEditorPage } from './components/stateful/TextEditorPage';
|
|
11
|
+
import { ProcessManagerPage } from './components/stateful/ProcessManagerPage';
|
|
12
|
+
import { SingleProcessPage } from './components/stateful/SingleProcessPage';
|
|
13
|
+
import { SettingsPage } from './components/stateful/SettingsPage';
|
|
10
14
|
export const App = () => {
|
|
11
15
|
return (React.createElement(Router, null,
|
|
12
|
-
React.createElement(
|
|
13
|
-
React.createElement(
|
|
14
|
-
React.createElement(
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
React.createElement(
|
|
22
|
-
|
|
23
|
-
React.createElement(
|
|
24
|
-
"made with \u2764\uFE0F and ",
|
|
25
|
-
React.createElement("a", { href: "https://www.npmjs.com/package/testeranto" }, "testeranto"))))));
|
|
16
|
+
React.createElement(AppFrame, null,
|
|
17
|
+
React.createElement(Routes, null,
|
|
18
|
+
React.createElement(Route, { path: "/", element: React.createElement(ProjectsPage, null) }),
|
|
19
|
+
React.createElement(Route, { path: "/projects/:projectName", element: React.createElement(ProjectPage, null) }),
|
|
20
|
+
React.createElement(Route, { path: "/projects/:projectName/tests/*", element: React.createElement(TestPage, null) }),
|
|
21
|
+
React.createElement(Route, { path: "/projects/:projectName#:tab", element: React.createElement(ProjectPage, null) }),
|
|
22
|
+
React.createElement(Route, { path: "/features-reporter", element: React.createElement(FeaturesReporter, null) }),
|
|
23
|
+
React.createElement(Route, { path: "/design-editor", element: React.createElement(DesignEditorPage, null) }),
|
|
24
|
+
React.createElement(Route, { path: "/text-editor", element: React.createElement(TextEditorPage, null) }),
|
|
25
|
+
React.createElement(Route, { path: "/processes", element: React.createElement(ProcessManagerPage, null) }),
|
|
26
|
+
React.createElement(Route, { path: "/processes/:processId", element: React.createElement(SingleProcessPage, null) }),
|
|
27
|
+
React.createElement(Route, { path: "/settings", element: React.createElement(SettingsPage, null) })))));
|
|
26
28
|
};
|
|
27
29
|
// Export App to global scope
|
|
28
30
|
function initApp() {
|
package/dist/module/src/Node.js
CHANGED
|
@@ -9,10 +9,7 @@ export class NodeTesteranto extends Testeranto {
|
|
|
9
9
|
});
|
|
10
10
|
}
|
|
11
11
|
async receiveTestResourceConfig(partialTestResource) {
|
|
12
|
-
|
|
13
|
-
const t = JSON.parse(partialTestResource);
|
|
14
|
-
const pm = new PM_Node(t, ipcfile);
|
|
15
|
-
return await this.testJobs[0].receiveTestResourceConfig(pm);
|
|
12
|
+
return await this.testJobs[0].receiveTestResourceConfig(new PM_Node(JSON.parse(partialTestResource), ipcfile));
|
|
16
13
|
}
|
|
17
14
|
}
|
|
18
15
|
const testeranto = async (input, testSpecification, testImplementation, testAdapter, testResourceRequirement = defaultTestResourceRequirement) => {
|
|
@@ -24,12 +21,11 @@ const testeranto = async (input, testSpecification, testImplementation, testAdap
|
|
|
24
21
|
// t.registerUncaughtPromise(reason, promise);
|
|
25
22
|
});
|
|
26
23
|
ipcfile = process.argv[3];
|
|
27
|
-
|
|
28
|
-
console.error("goodbye node with failures", f.fails);
|
|
29
|
-
process.exit(f.fails);
|
|
24
|
+
process.exit((await t.receiveTestResourceConfig(process.argv[2])).fails);
|
|
30
25
|
}
|
|
31
26
|
catch (e) {
|
|
32
|
-
console.error(
|
|
27
|
+
console.error(e);
|
|
28
|
+
console.error(e.stack);
|
|
33
29
|
process.exit(-1);
|
|
34
30
|
}
|
|
35
31
|
};
|
|
@@ -4,12 +4,12 @@
|
|
|
4
4
|
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
5
5
|
import ts from "typescript";
|
|
6
6
|
import fs from "fs";
|
|
7
|
-
import path from "path";
|
|
8
7
|
import ansiC from "ansi-colors";
|
|
9
8
|
import { ESLint } from "eslint";
|
|
10
9
|
import tsc from "tsc-prog";
|
|
11
|
-
import { lintPather,
|
|
10
|
+
import { lintPather, tscPather } from "../utils";
|
|
12
11
|
import { PM_Base } from "./base.js";
|
|
12
|
+
import { makePromptInternal } from "../utils/makePrompt";
|
|
13
13
|
const eslint = new ESLint();
|
|
14
14
|
const formatter = await eslint.loadFormatter("./node_modules/testeranto/dist/prebuild/esbuildConfigs/eslint-formatter-testeranto.mjs");
|
|
15
15
|
export class PM_WithEslintAndTsc extends PM_Base {
|
|
@@ -85,38 +85,7 @@ export class PM_WithEslintAndTsc extends PM_Base {
|
|
|
85
85
|
this.lintIsNowDone(entrypoint, results.length);
|
|
86
86
|
};
|
|
87
87
|
this.makePrompt = async (entryPoint, addableFiles, platform) => {
|
|
88
|
-
this.summary
|
|
89
|
-
const promptPath = promptPather(entryPoint, platform, this.name);
|
|
90
|
-
const testPaths = path.join("testeranto", "reports", this.name, entryPoint.split(".").slice(0, -1).join("."), platform, `tests.json`);
|
|
91
|
-
const featuresPath = path.join("testeranto", "reports", this.name, platform, entryPoint.split(".").slice(0, -1).join("."), `featurePrompt.txt`);
|
|
92
|
-
const logPath = path.join("testeranto", "reports", this.name, entryPoint.split(".").slice(0, -1).join("."), platform, `logs.txt`);
|
|
93
|
-
const lintPath = path.join("testeranto", "reports", this.name, entryPoint.split(".").slice(0, -1).join("."), platform, `lint_errors.txt`);
|
|
94
|
-
const typePath = path.join("testeranto", "reports", this.name, entryPoint.split(".").slice(0, -1).join("."), platform, `type_errors.txt`);
|
|
95
|
-
const messagePath = path.join("testeranto", "reports", this.name, entryPoint.split(".").slice(0, -1).join("."), platform, `message.txt`);
|
|
96
|
-
fs.writeFileSync(promptPath, `
|
|
97
|
-
${addableFiles
|
|
98
|
-
.map((x) => {
|
|
99
|
-
return `/add ${x}`;
|
|
100
|
-
})
|
|
101
|
-
.join("\n")}
|
|
102
|
-
|
|
103
|
-
/read node_modules/testeranto/docs/index.md
|
|
104
|
-
/read node_modules/testeranto/docs/style.md
|
|
105
|
-
/read node_modules/testeranto/docs/testing.ai.txt
|
|
106
|
-
/read node_modules/testeranto/src/CoreTypes.ts
|
|
107
|
-
|
|
108
|
-
/read ${testPaths}
|
|
109
|
-
/read ${logPath}
|
|
110
|
-
/read ${typePath}
|
|
111
|
-
/read ${lintPath}
|
|
112
|
-
`);
|
|
113
|
-
fs.writeFileSync(messagePath, `
|
|
114
|
-
Fix the failing tests described in ${testPaths} and ${logPath}. Focus on the bdd tests before all other concerns. You may add any debugging you think is necessary.
|
|
115
|
-
`);
|
|
116
|
-
this.summary[entryPoint].prompt = `aider --model deepseek/deepseek-chat --load testeranto/${this.name}/reports/${platform}/${entryPoint
|
|
117
|
-
.split(".")
|
|
118
|
-
.slice(0, -1)
|
|
119
|
-
.join(".")}/prompt.txt`;
|
|
88
|
+
await makePromptInternal(this.summary, this.name, entryPoint, addableFiles, platform);
|
|
120
89
|
this.checkForShutdown();
|
|
121
90
|
};
|
|
122
91
|
this.typeCheckIsRunning = (src) => {
|
|
@@ -176,7 +145,14 @@ Fix the failing tests described in ${testPaths} and ${logPath}. Focus on the bdd
|
|
|
176
145
|
this.checkForShutdown();
|
|
177
146
|
};
|
|
178
147
|
this.writeBigBoard = () => {
|
|
179
|
-
|
|
148
|
+
const summaryPath = `./testeranto/reports/${this.name}/summary.json`;
|
|
149
|
+
const summaryData = JSON.stringify(this.summary, null, 2);
|
|
150
|
+
fs.writeFileSync(summaryPath, summaryData);
|
|
151
|
+
// Broadcast the update
|
|
152
|
+
this.broadcast({
|
|
153
|
+
type: 'summaryUpdate',
|
|
154
|
+
data: this.summary
|
|
155
|
+
});
|
|
180
156
|
};
|
|
181
157
|
this.name = name;
|
|
182
158
|
this.mode = mode;
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
/* eslint-disable no-async-promise-executor */
|
|
1
2
|
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
2
3
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
3
4
|
import fs from "fs";
|
|
@@ -116,7 +117,6 @@ export class PM_Base {
|
|
|
116
117
|
const filepath = x[0];
|
|
117
118
|
const contents = x[1];
|
|
118
119
|
const testName = x[2];
|
|
119
|
-
console.log("writing file", filepath);
|
|
120
120
|
return new Promise(async (res) => {
|
|
121
121
|
fs.mkdirSync(path.dirname(filepath), {
|
|
122
122
|
recursive: true,
|