testeranto 0.189.0 → 0.198.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/.vscode/settings.json +7 -2
- package/ALL_LICENSES.txt +11246 -0
- package/LICENSE +21 -0
- package/default-project.json +44 -0
- package/design-editor/DesignEditor.tsx +251 -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 +242 -0
- package/dist/common/design-editor/index.js +18 -0
- package/dist/common/design-editor/server.js +98 -0
- package/dist/common/src/App.js +40 -6
- package/dist/common/src/Node.js +3 -2
- package/dist/common/src/PM/PM_WithEslintAndTsc.js +8 -1
- package/dist/common/src/PM/base.js +1 -0
- package/dist/common/src/PM/main.js +371 -5
- package/dist/common/src/PM/node.js +4 -2
- package/dist/common/src/PM/pure.js +15 -57
- package/dist/common/src/PM/web.js +5 -3
- package/dist/common/src/Pure.js +2 -2
- package/dist/common/src/Pure.test.js +46 -78
- package/dist/common/src/ReportServer.js +8 -2
- package/dist/common/src/Web.js +2 -2
- package/dist/common/src/build.js +1 -1
- package/dist/common/src/components/DesignEditorPage.js +205 -0
- package/dist/common/src/components/pure/AppFrame.js +62 -13
- package/dist/common/src/components/pure/ModalContent.test/implementation.js +13 -11
- package/dist/common/src/components/pure/ModalContent.test/index.js +48 -2
- package/dist/common/src/components/pure/ModalContent.test/specification.js +2 -2
- package/dist/common/src/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.test/implementation.js +134 -106
- package/dist/common/src/components/pure/ProjectsPageView.js +18 -12
- package/dist/common/src/components/pure/SettingsButton.js +4 -74
- package/dist/common/src/components/pure/SingleProcessView.js +214 -0
- package/dist/common/src/components/pure/TestPageView.js +457 -78
- package/dist/common/src/components/pure/TestPageView.test/implementation.js +90 -135
- package/dist/common/src/components/stateful/FeaturesReporter.js +1 -1
- 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 +6 -5
- package/dist/common/src/components/stateful/ProjectsPage.js +32 -6
- 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 +104 -8
- package/dist/common/src/components/stateful/TextEditorPage.js +154 -0
- package/dist/common/src/esbuildConfigs/inputFilesPlugin.js +3 -4
- package/dist/common/src/lib/{abstractBase.js → BaseGiven.js} +14 -91
- package/dist/common/src/lib/BaseSuite.js +6 -3
- package/dist/common/src/lib/BaseSuite.test/mock.js +25 -34
- package/dist/common/src/lib/BaseSuite.test/test.js +33 -31
- package/dist/common/src/lib/BaseThen.js +64 -0
- package/dist/common/src/lib/BaseWhen.js +45 -0
- package/dist/common/src/lib/Tiposkripto.js +149 -0
- package/dist/common/src/lib/{core.test/MockCore.js → Tiposkripto.test/MockTiposkripto.js} +5 -8
- package/dist/common/src/lib/{core.test/core.test.adapter.js → Tiposkripto.test/Tiposkripto.adapter.js} +10 -8
- package/dist/common/src/lib/{classBuilder.test/classBuilder.test.implementation.js → Tiposkripto.test/Tiposkripto.implementation.js} +44 -61
- package/dist/common/src/lib/Tiposkripto.test/Tiposkripto.js +11 -0
- package/dist/common/src/lib/{classBuilder.test/classBuilder.test.specification.js → Tiposkripto.test/Tiposkripto.specification.js} +13 -9
- package/dist/common/src/lib/abstractBase.test/MockGiven.js +10 -3
- package/dist/common/src/lib/abstractBase.test/MockThen.js +6 -3
- package/dist/common/src/lib/abstractBase.test/MockWhen.js +10 -3
- package/dist/common/src/lib/abstractBase.test/adapter.js +18 -6
- package/dist/common/src/lib/abstractBase.test/implementation.js +3 -3
- package/dist/common/src/lib/index.js +11 -14
- package/dist/common/src/lib/mocks.test.js +10 -8
- package/dist/common/src/lib/pmProxy.js +37 -14
- package/dist/common/src/lib/pmProxy.test/adapter.js +12 -2
- package/dist/common/src/lib/pmProxy.test/implementation.js +73 -43
- package/dist/common/src/lib/pmProxy.test/specification.js +3 -0
- package/dist/common/src/run.js +15 -4
- package/dist/common/src/utils/api.js +44 -33
- package/dist/common/src/utils/logFiles.js +48 -22
- package/dist/common/src/utils/makePrompt.js +5 -4
- package/dist/common/testeranto.config.js +19 -41
- package/dist/common/tsconfig.common.tsbuildinfo +1 -1
- package/dist/module/design-editor/DesignEditor.js +206 -0
- package/dist/module/design-editor/index.js +2 -0
- package/dist/module/design-editor/server.js +92 -0
- package/dist/module/src/App.js +40 -6
- package/dist/module/src/Node.js +3 -2
- package/dist/module/src/PM/PM_WithEslintAndTsc.js +8 -1
- package/dist/module/src/PM/base.js +1 -0
- package/dist/module/src/PM/main.js +371 -5
- package/dist/module/src/PM/node.js +4 -2
- package/dist/module/src/PM/pure.js +15 -57
- package/dist/module/src/PM/web.js +5 -3
- package/dist/module/src/Pure.js +2 -2
- package/dist/module/src/Pure.test.js +46 -78
- package/dist/module/src/ReportServer.js +8 -2
- package/dist/module/src/Web.js +2 -2
- package/dist/module/src/build.js +1 -1
- package/dist/module/src/components/DesignEditorPage.js +168 -0
- package/dist/module/src/components/pure/AppFrame.js +30 -11
- package/dist/module/src/components/pure/ModalContent.test/implementation.js +13 -11
- package/dist/module/src/components/pure/ModalContent.test/index.js +48 -2
- package/dist/module/src/components/pure/ModalContent.test/specification.js +2 -2
- package/dist/module/src/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.test/implementation.js +134 -106
- package/dist/module/src/components/pure/ProjectsPageView.js +20 -14
- package/dist/module/src/components/pure/SettingsButton.js +5 -42
- package/dist/module/src/components/pure/SingleProcessView.js +214 -0
- package/dist/module/src/components/pure/TestPageView.js +425 -76
- package/dist/module/src/components/pure/TestPageView.test/implementation.js +90 -135
- package/dist/module/src/components/stateful/FeaturesReporter.js +1 -1
- 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 +6 -5
- 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 +104 -8
- package/dist/module/src/components/stateful/TextEditorPage.js +117 -0
- package/dist/module/src/esbuildConfigs/inputFilesPlugin.js +3 -4
- package/dist/module/src/lib/{abstractBase.js → BaseGiven.js} +14 -89
- package/dist/module/src/lib/BaseSuite.js +6 -3
- package/dist/module/src/lib/BaseSuite.test/mock.js +22 -31
- package/dist/module/src/lib/BaseSuite.test/test.js +33 -31
- package/dist/module/src/lib/BaseThen.js +60 -0
- package/dist/module/src/lib/BaseWhen.js +41 -0
- package/dist/module/src/lib/Tiposkripto.js +146 -0
- package/dist/module/src/lib/{core.test/MockCore.js → Tiposkripto.test/MockTiposkripto.js} +3 -6
- package/dist/module/src/lib/{core.test/core.test.adapter.js → Tiposkripto.test/Tiposkripto.adapter.js} +10 -8
- package/dist/module/src/lib/{classBuilder.test/classBuilder.test.implementation.js → Tiposkripto.test/Tiposkripto.implementation.js} +44 -58
- package/dist/module/src/lib/Tiposkripto.test/Tiposkripto.js +6 -0
- package/dist/module/src/lib/{classBuilder.test/classBuilder.test.specification.js → Tiposkripto.test/Tiposkripto.specification.js} +12 -8
- package/dist/module/src/lib/abstractBase.test/MockGiven.js +9 -2
- package/dist/module/src/lib/abstractBase.test/MockThen.js +5 -2
- package/dist/module/src/lib/abstractBase.test/MockWhen.js +9 -2
- package/dist/module/src/lib/abstractBase.test/adapter.js +18 -6
- package/dist/module/src/lib/abstractBase.test/implementation.js +3 -3
- package/dist/module/src/lib/index.js +11 -14
- package/dist/module/src/lib/mocks.test.js +11 -5
- package/dist/module/src/lib/pmProxy.js +37 -14
- package/dist/module/src/lib/pmProxy.test/adapter.js +12 -2
- package/dist/module/src/lib/pmProxy.test/implementation.js +73 -43
- package/dist/module/src/lib/pmProxy.test/specification.js +3 -0
- package/dist/module/src/run.js +15 -4
- package/dist/module/src/utils/api.js +45 -34
- package/dist/module/src/utils/logFiles.js +45 -20
- package/dist/module/src/utils/makePrompt.js +5 -4
- package/dist/module/testeranto.config.js +19 -41
- package/dist/module/tsconfig.module.tsbuildinfo +1 -1
- package/dist/prebuild/App.css +54 -513
- package/dist/prebuild/App.js +5291 -1921
- package/dist/prebuild/ReportServer.mjs +104 -6
- package/dist/prebuild/build.mjs +8 -5
- package/dist/prebuild/run.mjs +414 -51
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/types/design-editor/DesignEditor.d.ts +18 -0
- package/dist/types/design-editor/server.d.ts +1 -0
- package/dist/types/{Node.d.ts → src/Node.d.ts} +2 -2
- package/dist/types/src/PM/__tests__/nodeSidecar.testeranto.d.ts +2 -0
- package/dist/types/src/PM/__tests__/pureSidecar.testeranto.d.ts +2 -0
- package/dist/types/src/PM/__tests__/webSidecar.testeranto.d.ts +2 -0
- package/dist/types/{PM → src/PM}/index.d.ts +1 -1
- package/dist/types/{PM → src/PM}/main.d.ts +19 -0
- package/dist/types/{PM → src/PM}/pure.d.ts +7 -7
- package/dist/types/{Pure.d.ts → src/Pure.d.ts} +2 -2
- package/dist/types/src/Pure.test.d.ts +2 -0
- package/dist/types/src/ReportServer.test.ts/index.d.ts +2 -0
- package/dist/types/{Types.d.ts → src/Types.d.ts} +3 -1
- package/dist/types/{Web.d.ts → src/Web.d.ts} +2 -2
- package/dist/types/src/components/DesignEditorPage.d.ts +1 -0
- package/dist/types/{components → src/components}/pure/AppFrame.d.ts +3 -1
- package/dist/types/src/components/pure/AppFrame.test/index.d.ts +3 -0
- package/dist/types/src/components/pure/FeaturesReporterView.test/index.d.ts +2 -0
- package/dist/types/src/components/pure/ModalContent.test/index.d.ts +2 -0
- package/dist/types/{components → src/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.test/index.d.ts +2 -0
- package/dist/types/{components → src/components}/pure/ProjectsPageView.d.ts +1 -1
- package/dist/types/src/components/pure/SettingsButton.d.ts +2 -0
- package/dist/types/{components → src/components}/pure/TestPageView.test/implementation.d.ts +3 -2
- package/dist/types/src/components/pure/TestPageView.test/index.d.ts +3 -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/SettingsPage.d.ts +2 -0
- package/dist/types/src/components/stateful/SingleProcessPage.d.ts +2 -0
- package/dist/types/src/components/stateful/TextEditorPage.d.ts +1 -0
- package/dist/types/src/lib/BaseGiven.d.ts +44 -0
- package/dist/types/{lib → src/lib}/BaseSuite.d.ts +12 -7
- package/dist/types/{lib → src/lib}/BaseSuite.test/mock.d.ts +6 -4
- package/dist/types/src/lib/BaseSuite.test/node.test.d.ts +2 -0
- package/dist/types/src/lib/BaseSuite.test/pure.test.d.ts +2 -0
- package/dist/types/src/lib/BaseSuite.test/web.test.d.ts +2 -0
- package/dist/types/src/lib/BaseThen.d.ts +27 -0
- package/dist/types/src/lib/BaseWhen.d.ts +27 -0
- package/dist/types/src/lib/Tiposkripto.d.ts +35 -0
- package/dist/types/{lib/core.test/MockCore.d.ts → src/lib/Tiposkripto.test/MockTiposkripto.d.ts} +3 -3
- package/dist/types/{lib/core.test/core.test.adapter.d.ts → src/lib/Tiposkripto.test/Tiposkripto.adapter.d.ts} +1 -1
- package/dist/types/src/lib/Tiposkripto.test/Tiposkripto.d.ts +2 -0
- package/dist/types/{lib/core.test/core.test.implementation.d.ts → src/lib/Tiposkripto.test/Tiposkripto.implementation.d.ts} +1 -1
- package/dist/types/{lib/core.test/core.test.specification.d.ts → src/lib/Tiposkripto.test/Tiposkripto.specification.d.ts} +1 -1
- package/dist/types/{lib/classBuilder.test/classBuilder.test.types.d.ts → src/lib/Tiposkripto.test/Tiposkripto.types.d.ts} +11 -9
- package/dist/types/{lib → src/lib}/abstractBase.test/MockGiven.d.ts +3 -1
- package/dist/types/{lib → src/lib}/abstractBase.test/MockThen.d.ts +1 -1
- package/dist/types/{lib → src/lib}/abstractBase.test/MockWhen.d.ts +1 -1
- package/dist/types/src/lib/abstractBase.test/index.d.ts +2 -0
- package/dist/types/{lib → src/lib}/abstractBase.test/types.d.ts +3 -3
- package/dist/types/{lib → src/lib}/index.d.ts +2 -2
- package/dist/types/{lib → src/lib}/pmProxy.test/index.d.ts +1 -2
- package/dist/types/{lib → src/lib}/pmProxy.test/mockPMBase.d.ts +1 -1
- package/dist/types/{lib → src/lib}/types.d.ts +3 -1
- package/dist/types/src/mothership/test.d.ts +2 -0
- package/dist/types/src/utils/logFiles.d.ts +71 -0
- package/dist/types/tsconfig.types.tsbuildinfo +1 -1
- package/docs/test-page-components.md +91 -0
- package/package.json +29 -10
- package/src/App.tsx +38 -5
- package/src/Node.ts +3 -2
- package/src/PM/PM_WithEslintAndTsc.ts +9 -4
- package/src/PM/base.ts +1 -0
- package/src/PM/index.ts +1 -1
- package/src/PM/main.ts +425 -9
- package/src/PM/node.ts +5 -2
- package/src/PM/pure.ts +23 -61
- package/src/PM/web.ts +7 -3
- package/src/Pure.test.ts +63 -99
- package/src/Pure.ts +3 -2
- package/src/README.md +20 -1
- package/src/ReportServer.ts +10 -3
- package/src/Types.ts +5 -3
- package/src/Web.ts +2 -2
- package/src/app.scss +169 -0
- package/src/build.ts +5 -1
- package/src/components/DesignEditorPage.tsx +202 -0
- package/src/components/pure/AppFrame.tsx +121 -16
- package/src/components/pure/ModalContent.test/implementation.tsx +14 -12
- package/src/components/pure/ModalContent.test/index.tsx +58 -6
- package/src/components/pure/ModalContent.test/specification.ts +2 -2
- package/src/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 +136 -106
- package/src/components/pure/ProjectPageView.test/index.tsx +0 -2
- package/src/components/pure/ProjectsPageView.tsx +41 -31
- package/src/components/pure/SettingsButton.tsx +7 -62
- package/src/components/pure/SingleProcessView.tsx +235 -0
- package/src/components/pure/TestPageView.test/implementation.ts +115 -147
- package/src/components/pure/TestPageView.test/specification.ts +0 -1
- package/src/components/pure/TestPageView.tsx +821 -100
- package/src/components/stateful/FeaturesReporter.tsx +1 -1
- package/src/components/stateful/FileTree.tsx +66 -0
- package/src/components/stateful/ProcessManagerPage.tsx +108 -0
- package/src/components/stateful/ProjectPage.tsx +6 -5
- 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 +128 -20
- package/src/components/stateful/TextEditorPage.tsx +170 -0
- package/src/esbuildConfigs/inputFilesPlugin.ts +3 -4
- package/src/lib/BaseGiven.ts +193 -0
- package/src/lib/BaseSuite.test/mock.ts +28 -42
- package/src/lib/BaseSuite.test/test.ts +38 -42
- package/src/lib/BaseSuite.ts +20 -4
- package/src/lib/BaseThen.ts +108 -0
- package/src/lib/BaseWhen.ts +91 -0
- package/src/lib/{core.test/MockCore.ts → Tiposkripto.test/MockTiposkripto.ts} +4 -7
- package/src/lib/{core.test/core.test.adapter.ts → Tiposkripto.test/Tiposkripto.adapter.ts} +12 -11
- package/src/lib/{classBuilder.test/classBuilder.test.implementation.ts → Tiposkripto.test/Tiposkripto.implementation.ts} +75 -78
- package/src/lib/Tiposkripto.test/Tiposkripto.specification.ts +109 -0
- package/src/lib/Tiposkripto.test/Tiposkripto.ts +15 -0
- package/src/lib/{classBuilder.test/classBuilder.test.types.ts → Tiposkripto.test/Tiposkripto.types.ts} +12 -9
- package/src/lib/Tiposkripto.ts +325 -0
- package/src/lib/abstractBase.test/MockGiven.ts +12 -2
- package/src/lib/abstractBase.test/MockThen.ts +7 -2
- package/src/lib/abstractBase.test/MockWhen.ts +10 -2
- package/src/lib/abstractBase.test/adapter.ts +20 -6
- package/src/lib/abstractBase.test/implementation.ts +6 -6
- package/src/lib/abstractBase.test/types.ts +3 -3
- package/src/lib/index.ts +26 -20
- package/src/lib/mocks.test.ts +10 -9
- package/src/lib/pmProxy.test/adapter.ts +10 -2
- package/src/lib/pmProxy.test/implementation.ts +108 -57
- package/src/lib/pmProxy.test/mockPMBase.ts +1 -1
- package/src/lib/pmProxy.test/specification.ts +11 -0
- package/src/lib/pmProxy.ts +40 -15
- package/src/lib/types.ts +3 -1
- package/src/run.ts +19 -4
- package/src/style.scss +3 -502
- package/src/templates/frontpage.html +317 -40
- package/src/templates/frontpage.md +79 -0
- package/src/themes.scss +40 -8
- package/src/utils/api.ts +47 -44
- package/src/utils/logFiles.ts +57 -23
- package/src/utils/makePrompt.ts +5 -4
- package/stargazers.txt +15 -0
- package/stargzers.js +68 -0
- package/testeranto/App.css +54 -513
- package/testeranto/App.js +5291 -1921
- package/testeranto/bundles/node/core/src/lib/BaseSuite.test/node.test.mjs +1146 -46
- package/testeranto/bundles/pure/core/src/lib/BaseSuite.test/pure.test.mjs +1016 -72
- package/testeranto/bundles/web/core/src/lib/BaseSuite.test/web.test.mjs +1004 -86
- package/testeranto/metafiles/node/core.json +990 -0
- package/testeranto/{bundles/pure/core/metafile.json → metafiles/pure/core.json} +153 -309
- package/testeranto/{bundles/web/core/metafile.json → metafiles/web/core.json} +1075 -1825
- package/testeranto/reports/core/config.json +8 -64
- package/testeranto/reports/core/src/Pure.test/pure/prompt.txt +1 -1
- package/testeranto/reports/core/src/Pure.test/pure/type_errors.txt +63 -103
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/error.log +61 -50
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/prompt.txt +1 -1
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/tests.json +24 -32
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/type_errors.txt +17 -41
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/error.log +22 -33
- 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 +13 -2
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/prompt.txt +1 -1
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/tests.json +30 -41
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/type_errors.txt +31 -77
- package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/lint_errors.txt +47 -0
- package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/prompt.txt +2 -3
- package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/tests.json +17 -29
- package/testeranto/reports/core/src/components/pure/TestPageView.test/index/web/type_errors.txt +84 -96
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/prompt.txt +3 -2
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/tests.json +7 -9
- package/testeranto/reports/core/src/lib/BaseSuite.test/node.test/node/type_errors.txt +42 -99
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/prompt.txt +1 -1
- package/testeranto/reports/core/src/lib/BaseSuite.test/pure.test/pure/type_errors.txt +42 -99
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/prompt.txt +1 -1
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/tests.json +7 -9
- package/testeranto/reports/core/src/lib/BaseSuite.test/web.test/web/type_errors.txt +41 -98
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/exit.log +1 -0
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/prompt.txt +17 -0
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/stderr.log +18 -0
- package/testeranto/reports/core/src/lib/TipoSkripto.test/TipoSkripto/node/type_errors.txt +32 -0
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/exit.log +1 -1
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/lint_errors.txt +6 -14
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/prompt.txt +3 -3
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/stderr.log +66 -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/type_errors.txt +21 -52
- package/testeranto/reports/core/summary.json +22 -71
- package/testeranto.config.ts +21 -45
- package/tsc.log +289 -449
- package/tsconfig.json +3 -2
- package/CNAME +0 -1
- package/README.html +0 -302
- package/dist/common/src/PM/layers/base/PM_Base.js +0 -1
- package/dist/common/src/PM/layers/base/components/PageOperations.js +0 -1
- package/dist/common/src/PM/layers/base/components/PageOperations.testeranto.js +0 -1
- package/dist/common/src/PM/layers/linting/components/Linter.js +0 -1
- package/dist/common/src/PM/layers/linting/components/TypeChecker.js +0 -1
- package/dist/common/src/PM/layers/main/components/SidecarManager.js +0 -1
- package/dist/common/src/PM/layers/main/components/TestRunner.js +0 -1
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.adapter.js +0 -19
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.implementation.js +0 -113
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.mock.js +0 -46
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.node.js +0 -12
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.pure.js +0 -12
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.specification.js +0 -18
- package/dist/common/src/lib/baseBuilder.test/baseBuilder.test.web.js +0 -12
- package/dist/common/src/lib/basebuilder.js +0 -96
- package/dist/common/src/lib/classBuilder.js +0 -36
- package/dist/common/src/lib/classBuilder.test/classBuilder.test.adapter.js +0 -23
- package/dist/common/src/lib/classBuilder.test/classBuilder.test.js +0 -12
- package/dist/common/src/lib/classBuilder.test/mock.js +0 -17
- package/dist/common/src/lib/core.js +0 -47
- package/dist/common/src/lib/core.test/core.test.implementation.js +0 -121
- package/dist/common/src/lib/core.test/core.test.js +0 -63
- package/dist/common/src/lib/core.test/core.test.specification.js +0 -53
- package/dist/common/src/lib/core.test/core.test.types.js +0 -2
- package/dist/module/src/PM/layers/base/PM_Base.js +0 -1
- package/dist/module/src/PM/layers/base/components/PageOperations.js +0 -1
- package/dist/module/src/PM/layers/base/components/PageOperations.testeranto.js +0 -1
- package/dist/module/src/PM/layers/linting/components/Linter.js +0 -1
- package/dist/module/src/PM/layers/linting/components/TypeChecker.js +0 -1
- package/dist/module/src/PM/layers/main/components/SidecarManager.js +0 -1
- package/dist/module/src/PM/layers/main/components/TestRunner.js +0 -1
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.adapter.js +0 -16
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.implementation.js +0 -110
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.mock.js +0 -42
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.node.js +0 -7
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.pure.js +0 -7
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.specification.js +0 -14
- package/dist/module/src/lib/baseBuilder.test/baseBuilder.test.web.js +0 -7
- package/dist/module/src/lib/basebuilder.js +0 -92
- package/dist/module/src/lib/classBuilder.js +0 -32
- package/dist/module/src/lib/classBuilder.test/classBuilder.test.adapter.js +0 -20
- package/dist/module/src/lib/classBuilder.test/classBuilder.test.js +0 -7
- package/dist/module/src/lib/classBuilder.test/mock.js +0 -14
- package/dist/module/src/lib/core.js +0 -44
- package/dist/module/src/lib/core.test/core.test.implementation.js +0 -118
- package/dist/module/src/lib/core.test/core.test.js +0 -58
- package/dist/module/src/lib/core.test/core.test.specification.js +0 -49
- package/dist/module/src/lib/core.test/core.test.types.js +0 -1
- package/dist/types/PM/__tests__/nodeSidecar.testeranto.d.ts +0 -16
- package/dist/types/PM/__tests__/pureSidecar.testeranto.d.ts +0 -16
- package/dist/types/PM/__tests__/webSidecar.testeranto.d.ts +0 -16
- package/dist/types/PM/layers/base/components/PageOperations.testeranto.d.ts +0 -0
- package/dist/types/PM/layers/linting/components/Linter.d.ts +0 -0
- package/dist/types/PM/layers/linting/components/TypeChecker.d.ts +0 -0
- package/dist/types/PM/layers/main/components/SidecarManager.d.ts +0 -0
- package/dist/types/PM/layers/main/components/TestRunner.d.ts +0 -0
- package/dist/types/Pure.test.d.ts +0 -47
- package/dist/types/ReportServer.test.ts/index.d.ts +0 -29
- package/dist/types/components/pure/AppFrame.test/index.d.ts +0 -5
- package/dist/types/components/pure/FeaturesReporterView.test/index.d.ts +0 -2
- package/dist/types/components/pure/ModalContent.test/index.d.ts +0 -2
- package/dist/types/components/pure/ProjectPageView.test/index.d.ts +0 -2
- package/dist/types/components/pure/SettingsButton.d.ts +0 -3
- package/dist/types/components/pure/TestPageView.test/index.d.ts +0 -32
- package/dist/types/lib/BaseSuite.test/node.test.d.ts +0 -3
- package/dist/types/lib/BaseSuite.test/pure.test.d.ts +0 -3
- package/dist/types/lib/BaseSuite.test/web.test.d.ts +0 -3
- package/dist/types/lib/abstractBase.d.ts +0 -70
- package/dist/types/lib/abstractBase.test/index.d.ts +0 -3
- package/dist/types/lib/baseBuilder.test/baseBuilder.test.adapter.d.ts +0 -3
- package/dist/types/lib/baseBuilder.test/baseBuilder.test.implementation.d.ts +0 -3
- package/dist/types/lib/baseBuilder.test/baseBuilder.test.mock.d.ts +0 -15
- package/dist/types/lib/baseBuilder.test/baseBuilder.test.node.d.ts +0 -3
- package/dist/types/lib/baseBuilder.test/baseBuilder.test.pure.d.ts +0 -3
- package/dist/types/lib/baseBuilder.test/baseBuilder.test.specification.d.ts +0 -3
- package/dist/types/lib/baseBuilder.test/baseBuilder.test.types.d.ts +0 -22
- package/dist/types/lib/baseBuilder.test/baseBuilder.test.web.d.ts +0 -3
- package/dist/types/lib/basebuilder.d.ts +0 -23
- package/dist/types/lib/classBuilder.d.ts +0 -15
- package/dist/types/lib/classBuilder.test/classBuilder.test.adapter.d.ts +0 -3
- package/dist/types/lib/classBuilder.test/classBuilder.test.d.ts +0 -3
- package/dist/types/lib/classBuilder.test/classBuilder.test.implementation.d.ts +0 -3
- package/dist/types/lib/classBuilder.test/classBuilder.test.specification.d.ts +0 -3
- package/dist/types/lib/classBuilder.test/mock.d.ts +0 -14
- package/dist/types/lib/core.d.ts +0 -12
- package/dist/types/lib/core.test/core.test.d.ts +0 -3
- package/dist/types/lib/core.test/core.test.types.d.ts +0 -46
- package/dist/types/lib/mocks.test.d.ts +0 -2
- package/dist/types/mothership/test.d.ts +0 -19
- package/dist/types/utils/logFiles.d.ts +0 -7
- package/docs.html +0 -590
- package/example.css +0 -351
- package/index.html +0 -138
- package/scripts/compile-docs.js +0 -150
- package/smil30/SMIL-anim.mod.xsd +0 -163
- package/smil30/SMIL-control.mod.xsd +0 -73
- package/smil30/SMIL-layout.mod.xsd +0 -149
- package/smil30/SMIL-link.mod.xsd +0 -145
- package/smil30/SMIL-media.mod.xsd +0 -1646
- package/smil30/SMIL-metainformation.mod.xsd +0 -45
- package/smil30/SMIL-smiltext.mod.xsd +0 -353
- package/smil30/SMIL-state.mod.xsd +0 -133
- package/smil30/SMIL-struct.mod.xsd +0 -70
- package/smil30/SMIL-timing.mod.xsd +0 -105
- package/smil30/SMIL-transition.mod.xsd +0 -229
- package/smil30/SMIL.xsd +0 -63
- package/smil30/its.xsd +0 -42
- package/smil30/smil-attribs-1.mod.xsd +0 -610
- package/smil30/smil-datatypes-1.mod.xsd +0 -72
- package/smil30/smil-framework-1.mod.xsd +0 -45
- package/smil30/xml.xsd +0 -16
- package/src/App.scss +0 -123
- package/src/PM/layers/base/PM_Base.ts +0 -0
- package/src/PM/layers/base/components/PageOperations.testeranto.ts +0 -0
- package/src/PM/layers/base/components/PageOperations.ts +0 -0
- package/src/PM/layers/linting/components/Linter.ts +0 -0
- package/src/PM/layers/linting/components/TypeChecker.ts +0 -0
- package/src/PM/layers/main/components/SidecarManager.ts +0 -0
- package/src/PM/layers/main/components/TestRunner.ts +0 -0
- package/src/fonts.scss +0 -55
- package/src/lib/abstractBase.ts +0 -332
- package/src/lib/baseBuilder.test/baseBuilder.test.adapter.ts +0 -22
- package/src/lib/baseBuilder.test/baseBuilder.test.implementation.ts +0 -138
- package/src/lib/baseBuilder.test/baseBuilder.test.mock.ts +0 -90
- package/src/lib/baseBuilder.test/baseBuilder.test.node.ts +0 -16
- package/src/lib/baseBuilder.test/baseBuilder.test.pure.ts +0 -16
- package/src/lib/baseBuilder.test/baseBuilder.test.specification.ts +0 -35
- package/src/lib/baseBuilder.test/baseBuilder.test.types.ts +0 -36
- package/src/lib/baseBuilder.test/baseBuilder.test.web.ts +0 -16
- package/src/lib/basebuilder.ts +0 -192
- package/src/lib/classBuilder.test/classBuilder.test.adapter.ts +0 -25
- package/src/lib/classBuilder.test/classBuilder.test.specification.ts +0 -104
- package/src/lib/classBuilder.test/classBuilder.test.ts +0 -14
- package/src/lib/classBuilder.test/mock.ts +0 -83
- package/src/lib/classBuilder.ts +0 -122
- package/src/lib/core.test/core.test.implementation.ts +0 -155
- package/src/lib/core.test/core.test.specification.ts +0 -113
- package/src/lib/core.test/core.test.ts +0 -72
- package/src/lib/core.test/core.test.types.ts +0 -68
- package/src/lib/core.ts +0 -141
- package/style.css +0 -12175
- package/testeranto/bundles/node/core/chunk-JBB5E3XJ.mjs +0 -258
- package/testeranto/bundles/node/core/chunk-L67RWZ4W.mjs +0 -899
- package/testeranto/bundles/node/core/chunk-ZQRRQYS4.mjs +0 -92
- package/testeranto/bundles/node/core/metafile.json +0 -5735
- package/testeranto/bundles/node/core/src/lib/baseBuilder.test/baseBuilder.test.node.mjs +0 -247
- package/testeranto/bundles/node/core/src/lib/classBuilder.test/classBuilder.test.mjs +0 -423
- package/testeranto/bundles/node/core/src/lib/core.test/core.test.mjs +0 -505
- package/testeranto/bundles/node/core/src/lib/pmProxy.test/index.mjs +0 -4804
- package/testeranto/bundles/node/core/src/mothership/test.mjs +0 -24588
- package/testeranto/bundles/pure/core/chunk-KHJ35R7C.mjs +0 -997
- package/testeranto/bundles/pure/core/src/Pure.test.mjs +0 -428
- package/testeranto/bundles/pure/core/src/lib/baseBuilder.test/baseBuilder.test.pure.mjs +0 -235
- package/testeranto/bundles/web/core/MPLUSRounded1c-Black-O75GP5JI.ttf +0 -0
- package/testeranto/bundles/web/core/MPLUSRounded1c-Bold-R524Q5BH.ttf +0 -0
- package/testeranto/bundles/web/core/MPLUSRounded1c-ExtraBold-C6GRMYVT.ttf +0 -0
- package/testeranto/bundles/web/core/MPLUSRounded1c-Light-WKN65Y2C.ttf +0 -0
- package/testeranto/bundles/web/core/MPLUSRounded1c-Medium-ZC4DWL7C.ttf +0 -0
- package/testeranto/bundles/web/core/MPLUSRounded1c-Regular-DT6EKZ3S.ttf +0 -0
- package/testeranto/bundles/web/core/MPLUSRounded1c-Thin-YWDNVG6M.ttf +0 -0
- package/testeranto/bundles/web/core/chunk-BADF3AZF.mjs +0 -108
- package/testeranto/bundles/web/core/chunk-BXV27S2S.mjs +0 -6252
- package/testeranto/bundles/web/core/chunk-EIYZKF2C.mjs +0 -223
- package/testeranto/bundles/web/core/chunk-FNXFUNA7.mjs +0 -28528
- package/testeranto/bundles/web/core/chunk-LU364HVS.mjs +0 -3311
- package/testeranto/bundles/web/core/chunk-QWII7WIM.mjs +0 -2281
- package/testeranto/bundles/web/core/chunk-VAYOSMXI.mjs +0 -21775
- package/testeranto/bundles/web/core/src/components/pure/AppFrame.test/index.css +0 -12105
- package/testeranto/bundles/web/core/src/components/pure/AppFrame.test/index.html +0 -15
- package/testeranto/bundles/web/core/src/components/pure/AppFrame.test/index.mjs +0 -517
- package/testeranto/bundles/web/core/src/components/pure/FeaturesReporterView.test/index.html +0 -15
- package/testeranto/bundles/web/core/src/components/pure/FeaturesReporterView.test/index.mjs +0 -166
- package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.css +0 -12105
- package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.html +0 -15
- package/testeranto/bundles/web/core/src/components/pure/ModalContent.test/index.mjs +0 -93
- package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.css +0 -12105
- package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.html +0 -15
- package/testeranto/bundles/web/core/src/components/pure/ProjectPageView.test/index.mjs +0 -343
- package/testeranto/bundles/web/core/src/components/pure/TestPageView.test/index.css +0 -12105
- package/testeranto/bundles/web/core/src/components/pure/TestPageView.test/index.html +0 -15
- package/testeranto/bundles/web/core/src/components/pure/TestPageView.test/index.mjs +0 -483
- package/testeranto/bundles/web/core/src/lib/baseBuilder.test/baseBuilder.test.web.html +0 -15
- package/testeranto/bundles/web/core/src/lib/baseBuilder.test/baseBuilder.test.web.mjs +0 -256
- package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/debug.log +0 -0
- package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/error.log +0 -22
- package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/exit.log +0 -1
- package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/info.log +0 -4
- package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/lint_errors.txt +0 -2
- package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/prompt.txt +0 -18
- package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/tests.json +0 -57
- package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/type_errors.txt +0 -55
- package/testeranto/reports/core/src/components/pure/AppFrame.test/index/web/warn.log +0 -0
- package/testeranto/reports/core/src/components/pure/FeaturesReporterView.test/index/web/suite-0/given-basicRender/then-4/butThen/features-reporter.png +0 -0
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/debug.log +0 -0
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/error.log +0 -0
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/exit.log +0 -0
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/info.log +0 -4
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/message.txt +0 -17
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/prompt.txt +0 -15
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/suite-0/given-basicRender/then-2/butThen/modal-content.png +0 -0
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/tests.json +0 -42
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/type_errors.txt +0 -65
- package/testeranto/reports/core/src/components/pure/ModalContent.test/index/web/warn.log +0 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/suite-0/given-basicRender/then-6/butThen/happy-state.png +0 -0
- package/testeranto/reports/core/src/components/pure/ProjectPageView.test/index/web/suite-0/given-errorHandling/then-1/butThen/error-state.png +0 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/exit.log +0 -1
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/lint_errors.txt +0 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/message.txt +0 -17
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/prompt.txt +0 -17
- 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 +0 -2
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/suite-0/given-testInitialization/then-0/butThen/hello.txt +0 -1
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/suite-0/given-testInitialization/then-1/butThen/artifact_test.txt +0 -1
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/tests.json +0 -71
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.node/node/type_errors.txt +0 -65
- 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 +0 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/message.txt +0 -17
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/prompt.txt +0 -17
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.pure/pure/type_errors.txt +0 -65
- 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 +0 -1
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/exit.log +0 -1
- 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/lint_errors.txt +0 -0
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/message.txt +0 -17
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/prompt.txt +0 -17
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/suite-0/given-testInitialization/then-0/butThen/hello.txt +0 -1
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/suite-0/given-testInitialization/then-1/butThen/artifact_test.txt +0 -1
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/tests.json +0 -71
- package/testeranto/reports/core/src/lib/baseBuilder.test/baseBuilder.test.web/web/type_errors.txt +0 -65
- 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 +0 -1
- 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 +0 -17
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/prompt.txt +0 -17
- 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 +0 -619
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/tests.json +0 -165
- package/testeranto/reports/core/src/lib/classBuilder.test/classBuilder.test/node/type_errors.txt +0 -140
- package/testeranto/reports/core/src/lib/core.test/core.test/node/exit.log +0 -1
- package/testeranto/reports/core/src/lib/core.test/core.test/node/lint_errors.txt +0 -21
- package/testeranto/reports/core/src/lib/core.test/core.test/node/message.txt +0 -17
- package/testeranto/reports/core/src/lib/core.test/core.test/node/prompt.txt +0 -19
- 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/type_errors.txt +0 -64
- package/testeranto/reports/core/src/lib/pmProxy.test/index/node/tests.json +0 -162
- package/testeranto/reports/core/src/mothership/test/node/exit.log +0 -1
- package/testeranto/reports/core/src/mothership/test/node/lint_errors.txt +0 -0
- package/testeranto/reports/core/src/mothership/test/node/message.txt +0 -17
- package/testeranto/reports/core/src/mothership/test/node/prompt.txt +0 -14
- package/testeranto/reports/core/src/mothership/test/node/stderr.log +0 -27
- package/testeranto/reports/core/src/mothership/test/node/stdout.log +0 -8
- package/testeranto/reports/core/src/mothership/test/node/tests.json +0 -36
- package/testeranto/reports/core/src/mothership/test/node/type_errors.txt +0 -38
- package/videos/download-smil-xsd.sh +0 -29
- package/videos/project0/index.md +0 -72
- package/videos/project0/narration.json +0 -7
- package/videos/project0/narration.ssml +0 -58
- package/videos/project0/package.json +0 -21
- package/videos/project0/presentation.smil +0 -25
- package/videos/project0/smil30/SMIL-anim.mod.xsd +0 -163
- package/videos/project0/smil30/SMIL-anim.mod.xsd.1 +0 -163
- package/videos/project0/smil30/SMIL-anim.mod.xsd.2 +0 -163
- package/videos/project0/smil30/SMIL-control.mod.xsd +0 -73
- package/videos/project0/smil30/SMIL-control.mod.xsd.1 +0 -73
- package/videos/project0/smil30/SMIL-control.mod.xsd.2 +0 -73
- package/videos/project0/smil30/SMIL-layout.mod.xsd +0 -149
- package/videos/project0/smil30/SMIL-layout.mod.xsd.1 +0 -149
- package/videos/project0/smil30/SMIL-layout.mod.xsd.2 +0 -149
- package/videos/project0/smil30/SMIL-link.mod.xsd +0 -145
- package/videos/project0/smil30/SMIL-link.mod.xsd.1 +0 -145
- package/videos/project0/smil30/SMIL-link.mod.xsd.2 +0 -145
- package/videos/project0/smil30/SMIL-media.mod.xsd +0 -1646
- package/videos/project0/smil30/SMIL-media.mod.xsd.1 +0 -1646
- package/videos/project0/smil30/SMIL-media.mod.xsd.2 +0 -1646
- package/videos/project0/smil30/SMIL-metainformation.mod.xsd +0 -45
- package/videos/project0/smil30/SMIL-metainformation.mod.xsd.1 +0 -45
- package/videos/project0/smil30/SMIL-metainformation.mod.xsd.2 +0 -45
- package/videos/project0/smil30/SMIL-smiltext.mod.xsd +0 -353
- package/videos/project0/smil30/SMIL-smiltext.mod.xsd.1 +0 -353
- package/videos/project0/smil30/SMIL-smiltext.mod.xsd.2 +0 -353
- package/videos/project0/smil30/SMIL-state.mod.xsd +0 -133
- package/videos/project0/smil30/SMIL-state.mod.xsd.1 +0 -133
- package/videos/project0/smil30/SMIL-state.mod.xsd.2 +0 -133
- package/videos/project0/smil30/SMIL-struct.mod.xsd +0 -70
- package/videos/project0/smil30/SMIL-struct.mod.xsd.1 +0 -70
- package/videos/project0/smil30/SMIL-struct.mod.xsd.2 +0 -70
- package/videos/project0/smil30/SMIL-timing.mod.xsd +0 -105
- package/videos/project0/smil30/SMIL-timing.mod.xsd.1 +0 -105
- package/videos/project0/smil30/SMIL-timing.mod.xsd.2 +0 -105
- package/videos/project0/smil30/SMIL-transition.mod.xsd +0 -229
- package/videos/project0/smil30/SMIL-transition.mod.xsd.1 +0 -229
- package/videos/project0/smil30/SMIL-transition.mod.xsd.2 +0 -229
- package/videos/project0/smil30/SMIL.xsd +0 -63
- package/videos/project0/smil30/SMIL.xsd.1 +0 -63
- package/videos/project0/smil30/SMIL.xsd.2 +0 -63
- package/videos/project0/smil30/its.xsd +0 -42
- package/videos/project0/smil30/its.xsd.1 +0 -42
- package/videos/project0/smil30/its.xsd.2 +0 -42
- package/videos/project0/smil30/smil-attribs-1.mod.xsd +0 -610
- package/videos/project0/smil30/smil-attribs-1.mod.xsd.1 +0 -610
- package/videos/project0/smil30/smil-attribs-1.mod.xsd.2 +0 -610
- package/videos/project0/smil30/smil-datatypes-1.mod.xsd +0 -72
- package/videos/project0/smil30/smil-datatypes-1.mod.xsd.1 +0 -72
- package/videos/project0/smil30/smil-datatypes-1.mod.xsd.2 +0 -72
- package/videos/project0/smil30/smil-framework-1.mod.xsd +0 -45
- package/videos/project0/smil30/smil-framework-1.mod.xsd.1 +0 -45
- package/videos/project0/smil30/smil-framework-1.mod.xsd.2 +0 -45
- package/videos/project0/smil30/smil-profile-model-1.mod.xsd +0 -1331
- package/videos/project0/smil30/smil-profile-model-1.mod.xsd.1 +0 -1331
- package/videos/project0/smil30/smil-qname-1.mod.xsd +0 -121
- package/videos/project0/smil30/smil-qname-1.mod.xsd.1 +0 -121
- package/videos/project0/smil30/xml.xsd +0 -16
- package/videos/project0/smil30/xml.xsd.1 +0 -16
- package/videos/project0/smil30/xml.xsd.2 +0 -16
- package/videos/project0/smil30.xsd +0 -137
- package/videos/project0/src/audio/metadata.json +0 -5
- package/videos/project0/src/audio/narration.mp3 +0 -0
- package/videos/project0/src/motion-canvas.d.ts +0 -1
- package/videos/project0/src/project.meta +0 -31
- package/videos/project0/src/project.ts +0 -13
- package/videos/project0/src/scenes/example.meta +0 -5
- package/videos/project0/src/scenes/scene1.meta +0 -3
- package/videos/project0/src/scenes/scene1.tsx +0 -129
- package/videos/project0/src/scenes/scene2.tsx +0 -132
- package/videos/project0/src/scenes/scene3.meta +0 -26
- package/videos/project0/src/scenes/scene3.tsx +0 -188
- package/videos/project0/tsconfig.json +0 -4
- package/videos/project0/vite.config.ts +0 -10
- package/videos/trash/output/project.mp4 +0 -0
- package/videos/trash/text.mp4 +0 -0
- package/videos/trash/video/project.tsx +0 -549
- package/videos/trash/video/render.ts +0 -15
- package/videos/trash/vite.config.ts +0 -10
- package/videos/tts.js +0 -109
- /package/dist/common/{src/lib/baseBuilder.test/baseBuilder.test.types.js → design-editor/types.js} +0 -0
- /package/dist/common/src/lib/{classBuilder.test/classBuilder.test.types.js → Tiposkripto.test/Tiposkripto.types.js} +0 -0
- /package/dist/module/{src/lib/baseBuilder.test/baseBuilder.test.types.js → design-editor/types.js} +0 -0
- /package/dist/module/src/lib/{classBuilder.test/classBuilder.test.types.js → Tiposkripto.test/Tiposkripto.types.js} +0 -0
- /package/dist/types/{App.d.ts → src/App.d.ts} +0 -0
- /package/dist/types/{CoreTypes.d.ts → src/CoreTypes.d.ts} +0 -0
- /package/dist/types/{Init.d.ts → src/Init.d.ts} +0 -0
- /package/dist/types/{NodeSidecar.d.ts → src/NodeSidecar.d.ts} +0 -0
- /package/dist/types/{PM → src/PM}/PM_WithEslintAndTsc.d.ts +0 -0
- /package/dist/types/{PM → src/PM}/base.d.ts +0 -0
- /package/dist/types/{PM → src/PM}/node.d.ts +0 -0
- /package/dist/types/{PM → src/PM}/nodeSidecar.d.ts +0 -0
- /package/dist/types/{PM → src/PM}/pureSidecar.d.ts +0 -0
- /package/dist/types/{PM → src/PM}/sidecar.d.ts +0 -0
- /package/dist/types/{PM → src/PM}/types.d.ts +0 -0
- /package/dist/types/{PM → src/PM}/web.d.ts +0 -0
- /package/dist/types/{PM → src/PM}/webSidecar.d.ts +0 -0
- /package/dist/types/{PureSidecar.d.ts → src/PureSidecar.d.ts} +0 -0
- /package/dist/types/{ReportServer.d.ts → src/ReportServer.d.ts} +0 -0
- /package/dist/types/{ReportServerLib.d.ts → src/ReportServerLib.d.ts} +0 -0
- /package/dist/types/{WebSidecar.d.ts → src/WebSidecar.d.ts} +0 -0
- /package/dist/types/{build.d.ts → src/build.d.ts} +0 -0
- /package/dist/types/{components → src/components}/SunriseAnimation.d.ts +0 -0
- /package/dist/types/{components → src/components}/SunriseAnimation.test/implementation.d.ts +0 -0
- /package/dist/types/{components → src/components}/SunriseAnimation.test/index.d.ts +0 -0
- /package/dist/types/{components → src/components}/SunriseAnimation.test/interface.d.ts +0 -0
- /package/dist/types/{components → src/components}/SunriseAnimation.test/specification.d.ts +0 -0
- /package/dist/types/{components → src/components}/SunriseAnimation.test/types.d.ts +0 -0
- /package/dist/types/{components → src/components}/TestStatusBadge.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/AppFrame.test/implementation.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/AppFrame.test/specification.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/AppFrame.test/types.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/FeaturesReporterView.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/FeaturesReporterView.test/implementation.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/FeaturesReporterView.test/specification.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/FeaturesReporterView.test/types.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/ModalContent.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/ModalContent.test/implementation.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/ModalContent.test/specification.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/ModalContent.test/types.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/ProjectPageView.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/ProjectPageView.test/implementation.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/ProjectPageView.test/specification.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/ProjectPageView.test/types.d.ts +0 -0
- /package/dist/types/{PM/layers/base/PM_Base.d.ts → src/components/pure/SingleProcessView.d.ts} +0 -0
- /package/dist/types/{components → src/components}/pure/TestPageView.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/TestPageView.test/specification.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/TestPageView.test/types.d.ts +0 -0
- /package/dist/types/{components → src/components}/pure/ThemeCard.d.ts +0 -0
- /package/dist/types/{components → src/components}/stateful/FeaturesReporter.d.ts +0 -0
- /package/dist/types/{components → src/components}/stateful/ProjectPage.d.ts +0 -0
- /package/dist/types/{components → src/components}/stateful/ProjectsPage.d.ts +0 -0
- /package/dist/types/{components → src/components}/stateful/TestPage.d.ts +0 -0
- /package/dist/types/{defaultConfig.d.ts → src/defaultConfig.d.ts} +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/consoleDetectorPlugin.d.ts +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/eslint-formatter-testeranto.d.ts +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/featuresPlugin.d.ts +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/index.d.ts +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/inputFilesPlugin.d.ts +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/nativeImportDetectorPlugin.d.ts +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/node.d.ts +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/pure.d.ts +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/rebuildPlugin.d.ts +0 -0
- /package/dist/types/{esbuildConfigs → src/esbuildConfigs}/web.d.ts +0 -0
- /package/dist/types/{init-docs.d.ts → src/init-docs.d.ts} +0 -0
- /package/dist/types/{lib → src/lib}/BaseSuite.test/test.d.ts +0 -0
- /package/dist/types/{lib → src/lib}/Sidecar.d.ts +0 -0
- /package/dist/types/{lib → src/lib}/abstractBase.test/adapter.d.ts +0 -0
- /package/dist/types/{lib → src/lib}/abstractBase.test/implementation.d.ts +0 -0
- /package/dist/types/{lib → src/lib}/abstractBase.test/specification.d.ts +0 -0
- /package/dist/types/{PM/layers/base/components/PageOperations.d.ts → src/lib/mocks.test.d.ts} +0 -0
- /package/dist/types/{lib → src/lib}/pmProxy.d.ts +0 -0
- /package/dist/types/{lib → src/lib}/pmProxy.test/adapter.d.ts +0 -0
- /package/dist/types/{lib → src/lib}/pmProxy.test/implementation.d.ts +0 -0
- /package/dist/types/{lib → src/lib}/pmProxy.test/mockPM.d.ts +0 -0
- /package/dist/types/{lib → src/lib}/pmProxy.test/specification.d.ts +0 -0
- /package/dist/types/{lib → src/lib}/pmProxy.test/types.d.ts +0 -0
- /package/dist/types/{mothership → src/mothership}/index.d.ts +0 -0
- /package/dist/types/{run.d.ts → src/run.d.ts} +0 -0
- /package/dist/types/{types → src/types}/features.d.ts +0 -0
- /package/dist/types/{utils → src/utils}/api.d.ts +0 -0
- /package/dist/types/{utils → src/utils}/buildTemplates.d.ts +0 -0
- /package/dist/types/{utils → src/utils}/featureUtils.d.ts +0 -0
- /package/dist/types/{utils → src/utils}/makePrompt.d.ts +0 -0
- /package/dist/types/{utils → src/utils}/queue.d.ts +0 -0
- /package/dist/types/{utils.d.ts → src/utils.d.ts} +0 -0
- /package/dist/types/{web.html.d.ts → src/web.html.d.ts} +0 -0
- /package/testeranto/reports/core/src/{components/pure/ModalContent.test/index/web → lib/TipoSkripto.test/TipoSkripto/node}/lint_errors.txt +0 -0
- /package/testeranto/reports/core/src/{components/pure/AppFrame.test/index/web → lib/TipoSkripto.test/TipoSkripto/node}/message.txt +0 -0
- /package/testeranto/reports/core/src/lib/{core.test/core.test → TipoSkripto.test/TipoSkripto}/node/stdout.log +0 -0
|
@@ -1,8 +1,17 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
1
2
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
|
-
import React, { ReactElement } from
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
3
|
+
import React, { ReactElement, useState, useMemo, useEffect } from "react";
|
|
4
|
+
import { Toast, ToastContainer } from "react-bootstrap";
|
|
5
|
+
import { useNavigate } from "react-router-dom";
|
|
6
|
+
import {
|
|
7
|
+
RuntimeName,
|
|
8
|
+
STANDARD_LOGS,
|
|
9
|
+
RUNTIME_SPECIFIC_LOGS
|
|
10
|
+
} from "../../utils/logFiles";
|
|
11
|
+
import { Container, Row, Col, Nav, Button, Modal } from "react-bootstrap";
|
|
12
|
+
import { Editor } from "@monaco-editor/react";
|
|
13
|
+
import { NavBar } from "./NavBar";
|
|
14
|
+
import { TestStatusBadge } from "../TestStatusBadge";
|
|
6
15
|
|
|
7
16
|
type TestData = {
|
|
8
17
|
name: string;
|
|
@@ -39,6 +48,61 @@ type TestPageViewProps = {
|
|
|
39
48
|
};
|
|
40
49
|
};
|
|
41
50
|
|
|
51
|
+
const FileTree = ({ data, onSelect, level = 0, selectedSourcePath }) => {
|
|
52
|
+
const [expanded, setExpanded] = useState({});
|
|
53
|
+
|
|
54
|
+
const toggleExpand = (path) => {
|
|
55
|
+
setExpanded((prev) => ({ ...prev, [path]: !prev[path] }));
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
return (
|
|
59
|
+
<div>
|
|
60
|
+
{Object.entries(data).map(([name, node]) => {
|
|
61
|
+
const path = Object.keys(expanded).find((k) => k.endsWith(name)) || name;
|
|
62
|
+
const isExpanded = expanded[path];
|
|
63
|
+
|
|
64
|
+
if (node.__isFile) {
|
|
65
|
+
return (
|
|
66
|
+
<FileTreeItem
|
|
67
|
+
key={name}
|
|
68
|
+
name={name}
|
|
69
|
+
isFile={true}
|
|
70
|
+
level={level}
|
|
71
|
+
isSelected={selectedSourcePath === path}
|
|
72
|
+
onClick={() => onSelect(path, node.content)}
|
|
73
|
+
/>
|
|
74
|
+
);
|
|
75
|
+
} else {
|
|
76
|
+
return (
|
|
77
|
+
<div key={name}>
|
|
78
|
+
<div
|
|
79
|
+
className="d-flex align-items-center py-1 text-dark"
|
|
80
|
+
style={{
|
|
81
|
+
paddingLeft: `${level * 16}px`,
|
|
82
|
+
cursor: 'pointer',
|
|
83
|
+
fontSize: '0.875rem'
|
|
84
|
+
}}
|
|
85
|
+
onClick={() => toggleExpand(path)}
|
|
86
|
+
>
|
|
87
|
+
<i className={`bi ${isExpanded ? 'bi-folder2-open' : 'bi-folder'} me-1`}></i>
|
|
88
|
+
<span>{name}</span>
|
|
89
|
+
</div>
|
|
90
|
+
{isExpanded && (
|
|
91
|
+
<FileTree
|
|
92
|
+
data={node}
|
|
93
|
+
onSelect={onSelect}
|
|
94
|
+
level={level + 1}
|
|
95
|
+
selectedSourcePath={selectedSourcePath}
|
|
96
|
+
/>
|
|
97
|
+
)}
|
|
98
|
+
</div>
|
|
99
|
+
);
|
|
100
|
+
}
|
|
101
|
+
})}
|
|
102
|
+
</div>
|
|
103
|
+
);
|
|
104
|
+
};
|
|
105
|
+
|
|
42
106
|
export const TestPageView = ({
|
|
43
107
|
projectName,
|
|
44
108
|
testName,
|
|
@@ -48,7 +112,72 @@ export const TestPageView = ({
|
|
|
48
112
|
errorCounts,
|
|
49
113
|
logs,
|
|
50
114
|
}: TestPageViewProps) => {
|
|
51
|
-
const
|
|
115
|
+
const navigate = useNavigate();
|
|
116
|
+
const [showAiderModal, setShowAiderModal] = useState(false);
|
|
117
|
+
const [messageOption, setMessageOption] = useState<'default' | 'custom'>('default');
|
|
118
|
+
const [customMessage, setCustomMessage] = useState(
|
|
119
|
+
typeof logs['message.txt'] === 'string' ? logs['message.txt'] : 'make a script that prints hello'
|
|
120
|
+
);
|
|
121
|
+
const [showToast, setShowToast] = useState(false);
|
|
122
|
+
const [toastMessage, setToastMessage] = useState('');
|
|
123
|
+
const [toastVariant, setToastVariant] = useState<'success' | 'danger'>('success');
|
|
124
|
+
const [ws, setWs] = useState<WebSocket | null>(null);
|
|
125
|
+
const [expandedSections, setExpandedSections] = useState({
|
|
126
|
+
standardLogs: true,
|
|
127
|
+
runtimeLogs: true,
|
|
128
|
+
sourceFiles: true
|
|
129
|
+
});
|
|
130
|
+
const [isNavbarCollapsed, setIsNavbarCollapsed] = useState(false);
|
|
131
|
+
|
|
132
|
+
// Update customMessage when logs change
|
|
133
|
+
useEffect(() => {
|
|
134
|
+
if (typeof logs['message.txt'] === 'string' && logs['message.txt'].trim()) {
|
|
135
|
+
setCustomMessage(logs['message.txt']);
|
|
136
|
+
}
|
|
137
|
+
}, [logs]);
|
|
138
|
+
|
|
139
|
+
// Set up WebSocket connection
|
|
140
|
+
useEffect(() => {
|
|
141
|
+
const wsProtocol = window.location.protocol === 'https:' ? 'wss:' : 'ws:';
|
|
142
|
+
const wsUrl = `${wsProtocol}//${window.location.host}`;
|
|
143
|
+
const websocket = new WebSocket(wsUrl);
|
|
144
|
+
setWs(websocket);
|
|
145
|
+
|
|
146
|
+
return () => {
|
|
147
|
+
websocket.close();
|
|
148
|
+
};
|
|
149
|
+
}, []);
|
|
150
|
+
const [activeTab, setActiveTab] = React.useState("tests.json");
|
|
151
|
+
const [selectedFile, setSelectedFile] = useState<{
|
|
152
|
+
path: string;
|
|
153
|
+
content: string;
|
|
154
|
+
language?: string;
|
|
155
|
+
} | null>(null);
|
|
156
|
+
const [selectedSourcePath, setSelectedSourcePath] = useState<string | null>(
|
|
157
|
+
null
|
|
158
|
+
);
|
|
159
|
+
const [editorTheme, setEditorTheme] = useState<"light" | "vs-dark">(
|
|
160
|
+
"vs-dark"
|
|
161
|
+
);
|
|
162
|
+
|
|
163
|
+
// Determine language from file extension
|
|
164
|
+
const getLanguage = (path: string) => {
|
|
165
|
+
const ext = path.split(".").pop()?.toLowerCase();
|
|
166
|
+
switch (ext) {
|
|
167
|
+
case "ts":
|
|
168
|
+
return "typescript";
|
|
169
|
+
case "tsx":
|
|
170
|
+
return "typescript";
|
|
171
|
+
case "js":
|
|
172
|
+
return "javascript";
|
|
173
|
+
case "json":
|
|
174
|
+
return "json";
|
|
175
|
+
case "md":
|
|
176
|
+
return "markdown";
|
|
177
|
+
default:
|
|
178
|
+
return "plaintext";
|
|
179
|
+
}
|
|
180
|
+
};
|
|
52
181
|
|
|
53
182
|
const renderTestResults = (testData: TestData) => {
|
|
54
183
|
return (
|
|
@@ -65,8 +194,13 @@ export const TestPageView = ({
|
|
|
65
194
|
<ul className="list-unstyled">
|
|
66
195
|
{given.features.map((feature, fi) => (
|
|
67
196
|
<li key={fi}>
|
|
68
|
-
{feature.startsWith(
|
|
69
|
-
<a
|
|
197
|
+
{feature.startsWith("http") ? (
|
|
198
|
+
<a
|
|
199
|
+
href={feature}
|
|
200
|
+
target="_blank"
|
|
201
|
+
rel="noopener noreferrer"
|
|
202
|
+
className="text-white"
|
|
203
|
+
>
|
|
70
204
|
{new URL(feature).hostname}
|
|
71
205
|
</a>
|
|
72
206
|
) : (
|
|
@@ -92,11 +226,14 @@ export const TestPageView = ({
|
|
|
92
226
|
<li key={ai}>
|
|
93
227
|
<a
|
|
94
228
|
className="dropdown-item"
|
|
95
|
-
href={`reports/${projectName}/${testName
|
|
229
|
+
href={`reports/${projectName}/${testName
|
|
230
|
+
.split(".")
|
|
231
|
+
.slice(0, -1)
|
|
232
|
+
.join(".")}/${runtime}/${artifact}`}
|
|
96
233
|
target="_blank"
|
|
97
234
|
rel="noopener noreferrer"
|
|
98
235
|
>
|
|
99
|
-
{artifact.split(
|
|
236
|
+
{artifact.split("/").pop()}
|
|
100
237
|
</a>
|
|
101
238
|
</li>
|
|
102
239
|
))}
|
|
@@ -107,7 +244,13 @@ export const TestPageView = ({
|
|
|
107
244
|
</div>
|
|
108
245
|
<div className="card-body">
|
|
109
246
|
{given.whens.map((when, j) => (
|
|
110
|
-
<div
|
|
247
|
+
<div
|
|
248
|
+
key={`w-${j}`}
|
|
249
|
+
className={`p-3 mb-2 ${when.error
|
|
250
|
+
? "bg-danger text-white"
|
|
251
|
+
: "bg-success text-white"
|
|
252
|
+
}`}
|
|
253
|
+
>
|
|
111
254
|
<div className="d-flex justify-content-between align-items-start">
|
|
112
255
|
<div>
|
|
113
256
|
<div>
|
|
@@ -118,8 +261,12 @@ export const TestPageView = ({
|
|
|
118
261
|
<ul className="list-unstyled">
|
|
119
262
|
{when.features.map((feature, fi) => (
|
|
120
263
|
<li key={fi}>
|
|
121
|
-
{feature.startsWith(
|
|
122
|
-
<a
|
|
264
|
+
{feature.startsWith("http") ? (
|
|
265
|
+
<a
|
|
266
|
+
href={feature}
|
|
267
|
+
target="_blank"
|
|
268
|
+
rel="noopener noreferrer"
|
|
269
|
+
>
|
|
123
270
|
{new URL(feature).hostname}
|
|
124
271
|
</a>
|
|
125
272
|
) : (
|
|
@@ -140,12 +287,15 @@ export const TestPageView = ({
|
|
|
140
287
|
{when.artifacts.map((artifact, ai) => (
|
|
141
288
|
<li key={ai}>
|
|
142
289
|
<a
|
|
143
|
-
href={`reports/${projectName}/${testName
|
|
290
|
+
href={`reports/${projectName}/${testName
|
|
291
|
+
.split(".")
|
|
292
|
+
.slice(0, -1)
|
|
293
|
+
.join(".")}/${runtime}/${artifact}`}
|
|
144
294
|
target="_blank"
|
|
145
295
|
className="text-white"
|
|
146
296
|
rel="noopener noreferrer"
|
|
147
297
|
>
|
|
148
|
-
{artifact.split(
|
|
298
|
+
{artifact.split("/").pop()}
|
|
149
299
|
</a>
|
|
150
300
|
</li>
|
|
151
301
|
))}
|
|
@@ -156,7 +306,13 @@ export const TestPageView = ({
|
|
|
156
306
|
</div>
|
|
157
307
|
))}
|
|
158
308
|
{given.thens.map((then, k) => (
|
|
159
|
-
<div
|
|
309
|
+
<div
|
|
310
|
+
key={`t-${k}`}
|
|
311
|
+
className={`p-3 mb-2 ${then.error
|
|
312
|
+
? "bg-danger text-white"
|
|
313
|
+
: "bg-success text-white"
|
|
314
|
+
}`}
|
|
315
|
+
>
|
|
160
316
|
<div className="d-flex justify-content-between align-items-start">
|
|
161
317
|
<div>
|
|
162
318
|
<div>
|
|
@@ -167,8 +323,12 @@ export const TestPageView = ({
|
|
|
167
323
|
<ul className="list-unstyled">
|
|
168
324
|
{then.features.map((feature, fi) => (
|
|
169
325
|
<li key={fi}>
|
|
170
|
-
{feature.startsWith(
|
|
171
|
-
<a
|
|
326
|
+
{feature.startsWith("http") ? (
|
|
327
|
+
<a
|
|
328
|
+
href={feature}
|
|
329
|
+
target="_blank"
|
|
330
|
+
rel="noopener noreferrer"
|
|
331
|
+
>
|
|
172
332
|
{new URL(feature).hostname}
|
|
173
333
|
</a>
|
|
174
334
|
) : (
|
|
@@ -189,12 +349,15 @@ export const TestPageView = ({
|
|
|
189
349
|
{then.artifacts.map((artifact, ai) => (
|
|
190
350
|
<li key={ai}>
|
|
191
351
|
<a
|
|
192
|
-
href={`reports/${projectName}/${testName
|
|
352
|
+
href={`reports/${projectName}/${testName
|
|
353
|
+
.split(".")
|
|
354
|
+
.slice(0, -1)
|
|
355
|
+
.join(".")}/${runtime}/${artifact}`}
|
|
193
356
|
target="_blank"
|
|
194
357
|
className="text-white"
|
|
195
358
|
rel="noopener noreferrer"
|
|
196
359
|
>
|
|
197
|
-
{artifact.split(
|
|
360
|
+
{artifact.split("/").pop()}
|
|
198
361
|
</a>
|
|
199
362
|
</li>
|
|
200
363
|
))}
|
|
@@ -211,6 +374,13 @@ export const TestPageView = ({
|
|
|
211
374
|
);
|
|
212
375
|
};
|
|
213
376
|
|
|
377
|
+
console.log("Rendering TestPageView with logs:", {
|
|
378
|
+
logKeys: Object.keys(logs),
|
|
379
|
+
sourceFiles: logs.source_files ? Object.keys(logs.source_files) : null,
|
|
380
|
+
selectedFile,
|
|
381
|
+
activeTab,
|
|
382
|
+
});
|
|
383
|
+
|
|
214
384
|
return (
|
|
215
385
|
<Container fluid className="px-0">
|
|
216
386
|
<NavBar
|
|
@@ -218,110 +388,661 @@ export const TestPageView = ({
|
|
|
218
388
|
backLink={`/projects/${projectName}`}
|
|
219
389
|
navItems={[
|
|
220
390
|
{
|
|
221
|
-
label:
|
|
391
|
+
label: "",
|
|
222
392
|
badge: {
|
|
223
|
-
variant:
|
|
224
|
-
runtime ===
|
|
225
|
-
|
|
226
|
-
|
|
393
|
+
variant:
|
|
394
|
+
runtime === "node"
|
|
395
|
+
? "primary"
|
|
396
|
+
: runtime === "web"
|
|
397
|
+
? "success"
|
|
398
|
+
: "info",
|
|
399
|
+
text: runtime,
|
|
227
400
|
},
|
|
228
|
-
className:
|
|
229
|
-
}
|
|
401
|
+
className: "pe-none d-flex align-items-center gap-2",
|
|
402
|
+
},
|
|
230
403
|
]}
|
|
231
404
|
rightContent={
|
|
232
405
|
<Button
|
|
233
406
|
variant="info"
|
|
407
|
+
onClick={() => setShowAiderModal(true)}
|
|
408
|
+
className="ms-2"
|
|
409
|
+
title="AI Assistant"
|
|
410
|
+
>
|
|
411
|
+
🤖
|
|
412
|
+
</Button>
|
|
413
|
+
}
|
|
414
|
+
/>
|
|
415
|
+
|
|
416
|
+
<Modal show={showAiderModal} onHide={() => setShowAiderModal(false)} size="lg" onShow={() => setMessageOption('default')}>
|
|
417
|
+
<Modal.Header closeButton>
|
|
418
|
+
<Modal.Title>Aider</Modal.Title>
|
|
419
|
+
</Modal.Header>
|
|
420
|
+
<Modal.Body>
|
|
421
|
+
|
|
422
|
+
<div className="mb-3">
|
|
423
|
+
|
|
424
|
+
<div className="form-check">
|
|
425
|
+
<input
|
|
426
|
+
className="form-check-input"
|
|
427
|
+
type="radio"
|
|
428
|
+
name="messageOption"
|
|
429
|
+
id="defaultMessage"
|
|
430
|
+
value="default"
|
|
431
|
+
checked={messageOption === 'default'}
|
|
432
|
+
onChange={() => setMessageOption('default')}
|
|
433
|
+
/>
|
|
434
|
+
<label className="form-check-label" htmlFor="defaultMessage">
|
|
435
|
+
Use default message.txt
|
|
436
|
+
</label>
|
|
437
|
+
</div>
|
|
438
|
+
<div className="form-check">
|
|
439
|
+
<input
|
|
440
|
+
className="form-check-input"
|
|
441
|
+
type="radio"
|
|
442
|
+
name="messageOption"
|
|
443
|
+
id="customMessage"
|
|
444
|
+
value="custom"
|
|
445
|
+
checked={messageOption === 'custom'}
|
|
446
|
+
onChange={() => setMessageOption('custom')}
|
|
447
|
+
/>
|
|
448
|
+
<label className="form-check-label" htmlFor="customMessage">
|
|
449
|
+
Use custom message
|
|
450
|
+
</label>
|
|
451
|
+
</div>
|
|
452
|
+
{messageOption === 'custom' && (
|
|
453
|
+
<div className="mt-2">
|
|
454
|
+
<textarea
|
|
455
|
+
className="form-control"
|
|
456
|
+
rows={8}
|
|
457
|
+
placeholder="Enter your custom message"
|
|
458
|
+
value={customMessage}
|
|
459
|
+
onChange={(e) => setCustomMessage(e.target.value)}
|
|
460
|
+
style={{ minHeight: '500px' }}
|
|
461
|
+
/>
|
|
462
|
+
</div>
|
|
463
|
+
)}
|
|
464
|
+
</div>
|
|
465
|
+
</Modal.Body>
|
|
466
|
+
<Modal.Footer>
|
|
467
|
+
{/* <Button
|
|
468
|
+
variant="secondary"
|
|
469
|
+
onClick={() => setShowAiderModal(false)}
|
|
470
|
+
>
|
|
471
|
+
Close
|
|
472
|
+
</Button> */}
|
|
473
|
+
<Button
|
|
474
|
+
variant="primary"
|
|
234
475
|
onClick={async () => {
|
|
235
476
|
try {
|
|
236
|
-
const promptPath = `testeranto/reports/${projectName}/${testName
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
477
|
+
const promptPath = `testeranto/reports/${projectName}/${testName
|
|
478
|
+
.split(".")
|
|
479
|
+
.slice(0, -1)
|
|
480
|
+
.join(".")}/${runtime}/prompt.txt`;
|
|
481
|
+
|
|
482
|
+
let command = `aider --load ${promptPath}`;
|
|
483
|
+
|
|
484
|
+
if (messageOption === 'default') {
|
|
485
|
+
const messagePath = `testeranto/reports/${projectName}/${testName
|
|
486
|
+
.split(".")
|
|
487
|
+
.slice(0, -1)
|
|
488
|
+
.join(".")}/${runtime}/message.txt`;
|
|
489
|
+
command += ` --message-file ${messagePath}`;
|
|
490
|
+
} else {
|
|
491
|
+
command += ` --message "${customMessage}"`;
|
|
492
|
+
}
|
|
493
|
+
|
|
494
|
+
// Send command to server via WebSocket
|
|
495
|
+
const ws = new WebSocket(`ws://${window.location.host}`);
|
|
496
|
+
ws.onopen = () => {
|
|
497
|
+
ws.send(JSON.stringify({
|
|
498
|
+
type: 'executeCommand',
|
|
499
|
+
command: command
|
|
500
|
+
}));
|
|
501
|
+
setToastMessage('Command sent to server');
|
|
502
|
+
setToastVariant('success');
|
|
503
|
+
setShowToast(true);
|
|
504
|
+
setShowAiderModal(false);
|
|
505
|
+
ws.close();
|
|
506
|
+
|
|
507
|
+
// Navigate to process manager page
|
|
508
|
+
setTimeout(() => {
|
|
509
|
+
navigate('/processes');
|
|
510
|
+
}, 1000);
|
|
511
|
+
};
|
|
512
|
+
|
|
513
|
+
ws.onerror = (error) => {
|
|
514
|
+
setToastMessage('Failed to connect to server');
|
|
515
|
+
setToastVariant('danger');
|
|
516
|
+
setShowToast(true);
|
|
517
|
+
};
|
|
241
518
|
} catch (err) {
|
|
242
|
-
|
|
243
|
-
|
|
519
|
+
console.error("WebSocket error:", err);
|
|
520
|
+
setToastMessage('Error preparing command');
|
|
521
|
+
setToastVariant('danger');
|
|
522
|
+
setShowToast(true);
|
|
244
523
|
}
|
|
245
524
|
}}
|
|
246
|
-
className="ms-2"
|
|
247
525
|
>
|
|
248
|
-
|
|
526
|
+
Run Aider Command
|
|
249
527
|
</Button>
|
|
250
|
-
|
|
251
|
-
|
|
528
|
+
</Modal.Footer>
|
|
529
|
+
</Modal>
|
|
252
530
|
|
|
253
531
|
<Row className="g-0">
|
|
254
|
-
<Col sm={3} className="border-end"
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
} else if (logName === 'lint_errors.txt' && errorCounts.staticErrors > 0) {
|
|
264
|
-
statusIndicator = <span className="ms-1">❌ {errorCounts.staticErrors}</span>;
|
|
265
|
-
} else if (logName === 'stderr.log' && errorCounts.runTimeErrors > 0) {
|
|
266
|
-
statusIndicator = <span className="ms-1">❌ {errorCounts.runTimeErrors}</span>;
|
|
267
|
-
} else if (logName === 'exit.log' && logs['exit.log']?.trim() !== '0') {
|
|
268
|
-
statusIndicator = <span className="ms-1">⚠️</span>;
|
|
269
|
-
} else if (logName === 'tests.json' && logs['tests.json']) {
|
|
270
|
-
statusIndicator = <div className="ms-1">
|
|
271
|
-
<TestStatusBadge
|
|
272
|
-
testName={decodedTestPath}
|
|
273
|
-
testsExist={testsExist}
|
|
274
|
-
runTimeErrors={errorCounts.runTimeErrors}
|
|
275
|
-
typeErrors={errorCounts.typeErrors}
|
|
276
|
-
staticErrors={errorCounts.staticErrors}
|
|
277
|
-
variant="compact"
|
|
278
|
-
className="mt-1"
|
|
279
|
-
/>
|
|
280
|
-
</div>;
|
|
281
|
-
}
|
|
532
|
+
<Col sm={3} className="border-end" style={{
|
|
533
|
+
height: "calc(100vh - 56px)",
|
|
534
|
+
overflow: "auto",
|
|
535
|
+
backgroundColor: '#f8f9fa'
|
|
536
|
+
}}>
|
|
537
|
+
{/* File Tree Header */}
|
|
538
|
+
<div className="p-2 border-bottom">
|
|
539
|
+
<small className="fw-bold text-muted">EXPLORER</small>
|
|
540
|
+
</div>
|
|
282
541
|
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
542
|
+
{/* Standard Logs Section */}
|
|
543
|
+
<div className="p-2">
|
|
544
|
+
<div
|
|
545
|
+
className="d-flex align-items-center text-muted mb-1"
|
|
546
|
+
style={{ cursor: 'pointer', fontSize: '0.875rem' }}
|
|
547
|
+
onClick={() => setExpandedSections(prev => ({ ...prev, standardLogs: !prev.standardLogs }))}
|
|
548
|
+
>
|
|
549
|
+
<i className={`bi bi-chevron-${expandedSections.standardLogs ? 'down' : 'right'} me-1`}></i>
|
|
550
|
+
<span>Standard Logs</span>
|
|
551
|
+
</div>
|
|
552
|
+
{expandedSections.standardLogs && (
|
|
553
|
+
<div>
|
|
554
|
+
{Object.values(STANDARD_LOGS).map((logName) => {
|
|
555
|
+
const logContent = logs[logName];
|
|
556
|
+
const exists = logContent !== undefined &&
|
|
557
|
+
((typeof logContent === "string" && logContent.trim() !== "") ||
|
|
558
|
+
(typeof logContent === "object" && Object.keys(logContent).length > 0));
|
|
559
|
+
|
|
560
|
+
return (
|
|
561
|
+
<FileTreeItem
|
|
562
|
+
key={logName}
|
|
563
|
+
name={logName}
|
|
564
|
+
isFile={true}
|
|
565
|
+
level={1}
|
|
566
|
+
isSelected={activeTab === logName}
|
|
567
|
+
exists={exists}
|
|
568
|
+
onClick={() => {
|
|
569
|
+
if (exists) {
|
|
570
|
+
setActiveTab(logName);
|
|
571
|
+
setSelectedFile({
|
|
572
|
+
path: logName,
|
|
573
|
+
content: typeof logContent === "string" ? logContent : JSON.stringify(logContent, null, 2),
|
|
574
|
+
language: logName.endsWith(".json") ? "json" : "plaintext",
|
|
575
|
+
});
|
|
576
|
+
} else {
|
|
577
|
+
setActiveTab(logName);
|
|
578
|
+
setSelectedFile({
|
|
579
|
+
path: logName,
|
|
580
|
+
content: `// ${logName} not found or empty\nThis file was not generated during the test run.`,
|
|
581
|
+
language: "plaintext",
|
|
582
|
+
});
|
|
583
|
+
}
|
|
584
|
+
}}
|
|
585
|
+
/>
|
|
586
|
+
);
|
|
587
|
+
})}
|
|
588
|
+
</div>
|
|
589
|
+
)}
|
|
590
|
+
</div>
|
|
591
|
+
|
|
592
|
+
{/* Runtime Logs Section */}
|
|
593
|
+
{Object.values(RUNTIME_SPECIFIC_LOGS[runtime as RuntimeName]).length > 0 && (
|
|
594
|
+
<div className="p-2">
|
|
595
|
+
<div
|
|
596
|
+
className="d-flex align-items-center text-muted mb-1"
|
|
597
|
+
style={{ cursor: 'pointer', fontSize: '0.875rem' }}
|
|
598
|
+
onClick={() => setExpandedSections(prev => ({ ...prev, runtimeLogs: !prev.runtimeLogs }))}
|
|
599
|
+
>
|
|
600
|
+
<i className={`bi bi-chevron-${expandedSections.runtimeLogs ? 'down' : 'right'} me-1`}></i>
|
|
601
|
+
<span>Runtime Logs</span>
|
|
602
|
+
</div>
|
|
603
|
+
{expandedSections.runtimeLogs && (
|
|
604
|
+
<div>
|
|
605
|
+
{Object.values(RUNTIME_SPECIFIC_LOGS[runtime as RuntimeName]).map((logName) => {
|
|
606
|
+
const logContent = logs[logName];
|
|
607
|
+
const exists = logContent !== undefined &&
|
|
608
|
+
((typeof logContent === "string" && logContent.trim() !== "") ||
|
|
609
|
+
(typeof logContent === "object" && Object.keys(logContent).length > 0));
|
|
610
|
+
|
|
611
|
+
return (
|
|
612
|
+
<FileTreeItem
|
|
613
|
+
key={logName}
|
|
614
|
+
name={logName}
|
|
615
|
+
isFile={true}
|
|
616
|
+
level={1}
|
|
617
|
+
isSelected={activeTab === logName}
|
|
618
|
+
exists={exists}
|
|
619
|
+
onClick={() => {
|
|
620
|
+
if (exists) {
|
|
621
|
+
setActiveTab(logName);
|
|
622
|
+
setSelectedFile({
|
|
623
|
+
path: logName,
|
|
624
|
+
content: typeof logContent === "string" ? logContent : JSON.stringify(logContent, null, 2),
|
|
625
|
+
language: logName.endsWith(".json") ? "json" : "plaintext",
|
|
626
|
+
});
|
|
627
|
+
} else {
|
|
628
|
+
setActiveTab(logName);
|
|
629
|
+
setSelectedFile({
|
|
630
|
+
path: logName,
|
|
631
|
+
content: `// ${logName} not found or empty\nThis file was not generated during the test run.`,
|
|
632
|
+
language: "plaintext",
|
|
633
|
+
});
|
|
634
|
+
}
|
|
635
|
+
}}
|
|
636
|
+
/>
|
|
637
|
+
);
|
|
638
|
+
})}
|
|
639
|
+
</div>
|
|
640
|
+
)}
|
|
641
|
+
</div>
|
|
642
|
+
)}
|
|
643
|
+
|
|
644
|
+
{/* Source Files Section */}
|
|
645
|
+
{logs.source_files && (
|
|
646
|
+
<div className="p-2">
|
|
647
|
+
<div
|
|
648
|
+
className="d-flex align-items-center text-muted mb-1"
|
|
649
|
+
style={{ cursor: 'pointer', fontSize: '0.875rem' }}
|
|
650
|
+
onClick={() => setExpandedSections(prev => ({ ...prev, sourceFiles: !prev.sourceFiles }))}
|
|
651
|
+
>
|
|
652
|
+
<i className={`bi bi-chevron-${expandedSections.sourceFiles ? 'down' : 'right'} me-1`}></i>
|
|
653
|
+
<span>Source Files</span>
|
|
654
|
+
</div>
|
|
655
|
+
{expandedSections.sourceFiles && (
|
|
656
|
+
<div>
|
|
657
|
+
<FileTree
|
|
658
|
+
data={logs.source_files}
|
|
659
|
+
onSelect={(path, content) => {
|
|
660
|
+
setActiveTab("source_file");
|
|
661
|
+
setSelectedSourcePath(path);
|
|
662
|
+
setSelectedFile({
|
|
663
|
+
path,
|
|
664
|
+
content,
|
|
665
|
+
language: getLanguage(path),
|
|
666
|
+
});
|
|
667
|
+
}}
|
|
668
|
+
level={1}
|
|
669
|
+
selectedSourcePath={selectedSourcePath}
|
|
670
|
+
/>
|
|
671
|
+
</div>
|
|
672
|
+
)}
|
|
673
|
+
</div>
|
|
674
|
+
)}
|
|
300
675
|
</Col>
|
|
301
|
-
<Col
|
|
676
|
+
<Col
|
|
677
|
+
sm={6}
|
|
678
|
+
className="border-end p-0"
|
|
679
|
+
style={{ height: "calc(100vh - 56px)", overflow: "hidden" }}
|
|
680
|
+
>
|
|
681
|
+
<Editor
|
|
682
|
+
height="100%"
|
|
683
|
+
path={selectedFile?.path || "empty"}
|
|
684
|
+
defaultLanguage={selectedFile?.language || "plaintext"}
|
|
685
|
+
value={
|
|
686
|
+
selectedFile?.content || "// Select a file to view its contents"
|
|
687
|
+
}
|
|
688
|
+
theme={editorTheme}
|
|
689
|
+
options={{
|
|
690
|
+
minimap: { enabled: false },
|
|
691
|
+
fontSize: 14,
|
|
692
|
+
wordWrap: "on",
|
|
693
|
+
automaticLayout: true,
|
|
694
|
+
readOnly: !selectedFile?.path.includes("source_files"),
|
|
695
|
+
}}
|
|
696
|
+
/>
|
|
697
|
+
</Col>
|
|
698
|
+
<Col sm={3} className="p-0 border-start" style={{ height: "calc(100vh - 56px)", overflow: "auto" }}>
|
|
302
699
|
<div className="p-3">
|
|
303
|
-
{
|
|
304
|
-
<
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
700
|
+
{selectedFile?.path.endsWith("tests.json") && (
|
|
701
|
+
<div className="test-results-preview">
|
|
702
|
+
{typeof selectedFile.content === "string"
|
|
703
|
+
? renderTestResults(JSON.parse(selectedFile.content))
|
|
704
|
+
: renderTestResults(selectedFile.content)
|
|
705
|
+
}
|
|
706
|
+
</div>
|
|
707
|
+
)}
|
|
708
|
+
{selectedFile?.path.match(/\.(png|jpg|jpeg|gif|svg)$/i) && (
|
|
709
|
+
<div className="text-center">
|
|
710
|
+
<img
|
|
711
|
+
src={selectedFile.content}
|
|
712
|
+
alt={selectedFile.path}
|
|
713
|
+
className="img-fluid"
|
|
714
|
+
style={{ maxHeight: '300px' }}
|
|
715
|
+
/>
|
|
716
|
+
<div className="mt-2">
|
|
717
|
+
<a
|
|
718
|
+
href={selectedFile.content}
|
|
719
|
+
target="_blank"
|
|
720
|
+
rel="noopener noreferrer"
|
|
721
|
+
className="btn btn-sm btn-outline-primary"
|
|
722
|
+
>
|
|
723
|
+
Open Full Size
|
|
724
|
+
</a>
|
|
725
|
+
</div>
|
|
726
|
+
</div>
|
|
727
|
+
)}
|
|
728
|
+
{selectedFile?.path.endsWith(".json") && !selectedFile.path.endsWith("tests.json") && (
|
|
729
|
+
<pre className="bg-light p-2 small">
|
|
730
|
+
<code>{selectedFile.content}</code>
|
|
318
731
|
</pre>
|
|
319
|
-
)
|
|
320
|
-
|
|
732
|
+
)}
|
|
733
|
+
{selectedFile?.path.includes("source_files") && (
|
|
734
|
+
<div>
|
|
735
|
+
<div className="mb-2 small text-muted">
|
|
736
|
+
<i className="bi bi-file-earmark-text me-1"></i>
|
|
737
|
+
{selectedFile.path.split('/').pop()}
|
|
738
|
+
</div>
|
|
739
|
+
<Button
|
|
740
|
+
variant="outline-primary"
|
|
741
|
+
size="sm"
|
|
742
|
+
className="mb-2"
|
|
743
|
+
onClick={() => {
|
|
744
|
+
// TODO: Add save functionality
|
|
745
|
+
alert("Save functionality will be implemented here");
|
|
746
|
+
}}
|
|
747
|
+
>
|
|
748
|
+
Save Changes
|
|
749
|
+
</Button>
|
|
750
|
+
</div>
|
|
321
751
|
)}
|
|
322
752
|
</div>
|
|
323
753
|
</Col>
|
|
324
754
|
</Row>
|
|
755
|
+
|
|
756
|
+
<ToastContainer position="top-end" className="p-3">
|
|
757
|
+
<Toast
|
|
758
|
+
show={showToast}
|
|
759
|
+
onClose={() => setShowToast(false)}
|
|
760
|
+
delay={3000}
|
|
761
|
+
autohide
|
|
762
|
+
bg={toastVariant}
|
|
763
|
+
>
|
|
764
|
+
<Toast.Header>
|
|
765
|
+
<strong className="me-auto">Command Status</strong>
|
|
766
|
+
</Toast.Header>
|
|
767
|
+
<Toast.Body className="text-white">
|
|
768
|
+
{toastMessage}
|
|
769
|
+
</Toast.Body>
|
|
770
|
+
</Toast>
|
|
771
|
+
</ToastContainer>
|
|
772
|
+
|
|
325
773
|
</Container>
|
|
326
774
|
);
|
|
327
775
|
};
|
|
776
|
+
// Simple file tree item component
|
|
777
|
+
const FileTreeItem = ({
|
|
778
|
+
name,
|
|
779
|
+
isFile,
|
|
780
|
+
level,
|
|
781
|
+
isSelected,
|
|
782
|
+
exists = true,
|
|
783
|
+
onClick
|
|
784
|
+
}: {
|
|
785
|
+
name: string;
|
|
786
|
+
isFile: boolean;
|
|
787
|
+
level: number;
|
|
788
|
+
isSelected: boolean;
|
|
789
|
+
exists?: boolean;
|
|
790
|
+
onClick: () => void;
|
|
791
|
+
}) => {
|
|
792
|
+
const displayName = name
|
|
793
|
+
.replace(".json", "")
|
|
794
|
+
.replace(".txt", "")
|
|
795
|
+
.replace(".log", "")
|
|
796
|
+
.replace(/_/g, " ")
|
|
797
|
+
.replace(/^std/, "Standard ")
|
|
798
|
+
.replace(/^exit/, "Exit Code")
|
|
799
|
+
.split('/').pop();
|
|
800
|
+
|
|
801
|
+
return (
|
|
802
|
+
<div
|
|
803
|
+
className={`d-flex align-items-center py-1 ${isSelected ? 'text-primary fw-bold' : exists ? 'text-dark' : 'text-muted'}`}
|
|
804
|
+
style={{
|
|
805
|
+
paddingLeft: `${level * 16}px`,
|
|
806
|
+
cursor: exists ? 'pointer' : 'not-allowed',
|
|
807
|
+
fontSize: '0.875rem',
|
|
808
|
+
opacity: exists ? 1 : 0.6
|
|
809
|
+
}}
|
|
810
|
+
onClick={exists ? onClick : undefined}
|
|
811
|
+
title={exists ? undefined : "File not found or empty"}
|
|
812
|
+
>
|
|
813
|
+
<i className={`bi ${isFile ? (exists ? 'bi-file-earmark-text' : 'bi-file-earmark') : 'bi-folder'} me-1`}></i>
|
|
814
|
+
<span>{displayName}</span>
|
|
815
|
+
{!exists && (
|
|
816
|
+
<i className="bi bi-question-circle ms-1" title="File not found or empty"></i>
|
|
817
|
+
)}
|
|
818
|
+
</div>
|
|
819
|
+
);
|
|
820
|
+
};
|
|
821
|
+
|
|
822
|
+
const ArtifactTree = ({
|
|
823
|
+
treeData,
|
|
824
|
+
projectName,
|
|
825
|
+
testName,
|
|
826
|
+
runtime,
|
|
827
|
+
onSelect,
|
|
828
|
+
level = 0,
|
|
829
|
+
basePath = ''
|
|
830
|
+
}: {
|
|
831
|
+
treeData: Record<string, any>;
|
|
832
|
+
projectName: string;
|
|
833
|
+
testName: string;
|
|
834
|
+
runtime: string;
|
|
835
|
+
onSelect: (path: string) => void;
|
|
836
|
+
level?: number;
|
|
837
|
+
basePath?: string;
|
|
838
|
+
}) => {
|
|
839
|
+
const [expanded, setExpanded] = useState<Record<string, boolean>>({});
|
|
840
|
+
|
|
841
|
+
const toggleExpand = (path: string) => {
|
|
842
|
+
setExpanded(prev => ({ ...prev, [path]: !prev[path] }));
|
|
843
|
+
};
|
|
844
|
+
|
|
845
|
+
return (
|
|
846
|
+
<ul className="list-unstyled" style={{ paddingLeft: `${level * 16}px` }}>
|
|
847
|
+
{Object.entries(treeData).map(([name, node]) => {
|
|
848
|
+
const fullPath = basePath ? `${basePath}/${name}` : name;
|
|
849
|
+
const isExpanded = expanded[fullPath];
|
|
850
|
+
|
|
851
|
+
if (node.__isFile) {
|
|
852
|
+
return (
|
|
853
|
+
<li key={fullPath} className="py-1">
|
|
854
|
+
<a
|
|
855
|
+
href={`reports/${projectName}/${testName
|
|
856
|
+
.split('.')
|
|
857
|
+
.slice(0, -1)
|
|
858
|
+
.join('.')}/${runtime}/${node.path}`}
|
|
859
|
+
target="_blank"
|
|
860
|
+
rel="noopener noreferrer"
|
|
861
|
+
className="text-decoration-none"
|
|
862
|
+
onClick={(e) => {
|
|
863
|
+
e.preventDefault();
|
|
864
|
+
onSelect(node.path);
|
|
865
|
+
}}
|
|
866
|
+
>
|
|
867
|
+
<i className="bi bi-file-earmark-text me-2"></i>
|
|
868
|
+
{name}
|
|
869
|
+
</a>
|
|
870
|
+
</li>
|
|
871
|
+
);
|
|
872
|
+
} else {
|
|
873
|
+
return (
|
|
874
|
+
<li key={fullPath} className="py-1">
|
|
875
|
+
<div className="d-flex align-items-center">
|
|
876
|
+
<button
|
|
877
|
+
className="btn btn-link text-start p-0 text-decoration-none me-1"
|
|
878
|
+
onClick={() => toggleExpand(fullPath)}
|
|
879
|
+
>
|
|
880
|
+
<i
|
|
881
|
+
className={`bi ${isExpanded ? 'bi-folder2-open' : 'bi-folder'} me-2`}
|
|
882
|
+
></i>
|
|
883
|
+
{name}
|
|
884
|
+
</button>
|
|
885
|
+
</div>
|
|
886
|
+
{isExpanded && (
|
|
887
|
+
<ArtifactTree
|
|
888
|
+
treeData={node}
|
|
889
|
+
projectName={projectName}
|
|
890
|
+
testName={testName}
|
|
891
|
+
runtime={runtime}
|
|
892
|
+
onSelect={onSelect}
|
|
893
|
+
level={level + 1}
|
|
894
|
+
basePath={fullPath}
|
|
895
|
+
/>
|
|
896
|
+
)}
|
|
897
|
+
</li>
|
|
898
|
+
);
|
|
899
|
+
}
|
|
900
|
+
})}
|
|
901
|
+
</ul>
|
|
902
|
+
);
|
|
903
|
+
};
|
|
904
|
+
|
|
905
|
+
const buildArtifactTree = (testData: any) => {
|
|
906
|
+
const artifactPaths = new Set<string>();
|
|
907
|
+
testData.givens?.forEach((given: any) => {
|
|
908
|
+
given.artifacts?.forEach((artifact: string) => artifactPaths.add(artifact));
|
|
909
|
+
given.whens?.forEach((when: any) =>
|
|
910
|
+
when.artifacts?.forEach((artifact: string) => artifactPaths.add(artifact)));
|
|
911
|
+
given.thens?.forEach((then: any) =>
|
|
912
|
+
then.artifacts?.forEach((artifact: string) => artifactPaths.add(artifact)));
|
|
913
|
+
});
|
|
914
|
+
|
|
915
|
+
const sortedArtifacts = Array.from(artifactPaths).sort();
|
|
916
|
+
|
|
917
|
+
return sortedArtifacts.reduce((tree, artifactPath) => {
|
|
918
|
+
const parts = artifactPath.split('/');
|
|
919
|
+
let currentLevel = tree;
|
|
920
|
+
|
|
921
|
+
parts.forEach((part, i) => {
|
|
922
|
+
if (!currentLevel[part]) {
|
|
923
|
+
currentLevel[part] = i === parts.length - 1
|
|
924
|
+
? { __isFile: true, path: artifactPath }
|
|
925
|
+
: {};
|
|
926
|
+
}
|
|
927
|
+
currentLevel = currentLevel[part];
|
|
928
|
+
});
|
|
929
|
+
|
|
930
|
+
return tree;
|
|
931
|
+
}, {} as Record<string, any>);
|
|
932
|
+
};
|
|
933
|
+
|
|
934
|
+
const LogNavItem = ({
|
|
935
|
+
logName,
|
|
936
|
+
logContent,
|
|
937
|
+
activeTab,
|
|
938
|
+
setActiveTab,
|
|
939
|
+
setSelectedFile,
|
|
940
|
+
errorCounts,
|
|
941
|
+
decodedTestPath,
|
|
942
|
+
testsExist,
|
|
943
|
+
}: {
|
|
944
|
+
logName: string;
|
|
945
|
+
logContent: any;
|
|
946
|
+
activeTab: string;
|
|
947
|
+
setActiveTab: (tab: string) => void;
|
|
948
|
+
setSelectedFile: (file: {
|
|
949
|
+
path: string;
|
|
950
|
+
content: string;
|
|
951
|
+
language?: string;
|
|
952
|
+
}) => void;
|
|
953
|
+
errorCounts: {
|
|
954
|
+
runTimeErrors: number;
|
|
955
|
+
typeErrors: number;
|
|
956
|
+
staticErrors: number;
|
|
957
|
+
};
|
|
958
|
+
decodedTestPath: string;
|
|
959
|
+
testsExist: boolean;
|
|
960
|
+
}) => {
|
|
961
|
+
const displayName = logName
|
|
962
|
+
.replace(".json", "")
|
|
963
|
+
.replace(".txt", "")
|
|
964
|
+
.replace(".log", "")
|
|
965
|
+
.replace(/_/g, " ")
|
|
966
|
+
.replace(/^std/, "Standard ")
|
|
967
|
+
.replace(/^exit/, "Exit Code");
|
|
968
|
+
|
|
969
|
+
const logValue = typeof logContent === "string" ? logContent.trim() : "";
|
|
970
|
+
let statusIndicator: ReactElement<any, any> | null = null;
|
|
971
|
+
|
|
972
|
+
if (
|
|
973
|
+
logName === STANDARD_LOGS.TYPE_ERRORS &&
|
|
974
|
+
(errorCounts.typeErrors > 0 || (logValue && logValue !== "0"))
|
|
975
|
+
) {
|
|
976
|
+
statusIndicator = (
|
|
977
|
+
<span className="ms-1">
|
|
978
|
+
❌ {errorCounts.typeErrors || (logValue ? 1 : 0)}
|
|
979
|
+
</span>
|
|
980
|
+
);
|
|
981
|
+
} else if (
|
|
982
|
+
logName === STANDARD_LOGS.LINT_ERRORS &&
|
|
983
|
+
(errorCounts.staticErrors > 0 || (logValue && logValue !== "0"))
|
|
984
|
+
) {
|
|
985
|
+
statusIndicator = (
|
|
986
|
+
<span className="ms-1">
|
|
987
|
+
❌ {errorCounts.staticErrors || (logValue ? 1 : 0)}
|
|
988
|
+
</span>
|
|
989
|
+
);
|
|
990
|
+
} else if (
|
|
991
|
+
logName === RUNTIME_SPECIFIC_LOGS.node.STDERR &&
|
|
992
|
+
(errorCounts.runTimeErrors > 0 || (logValue && logValue !== "0"))
|
|
993
|
+
) {
|
|
994
|
+
statusIndicator = (
|
|
995
|
+
<span className="ms-1">
|
|
996
|
+
❌ {errorCounts.runTimeErrors || (logValue ? 1 : 0)}
|
|
997
|
+
</span>
|
|
998
|
+
);
|
|
999
|
+
} else if (logName === STANDARD_LOGS.EXIT && logValue !== "0") {
|
|
1000
|
+
statusIndicator = <span className="ms-1">⚠️ {logValue}</span>;
|
|
1001
|
+
} else if (logName === STANDARD_LOGS.TESTS && logValue) {
|
|
1002
|
+
statusIndicator = (
|
|
1003
|
+
<div className="ms-1">
|
|
1004
|
+
<TestStatusBadge
|
|
1005
|
+
testName={decodedTestPath}
|
|
1006
|
+
testsExist={testsExist}
|
|
1007
|
+
runTimeErrors={errorCounts.runTimeErrors}
|
|
1008
|
+
typeErrors={errorCounts.typeErrors}
|
|
1009
|
+
staticErrors={errorCounts.staticErrors}
|
|
1010
|
+
variant="compact"
|
|
1011
|
+
className="mt-1"
|
|
1012
|
+
/>
|
|
1013
|
+
</div>
|
|
1014
|
+
);
|
|
1015
|
+
}
|
|
1016
|
+
|
|
1017
|
+
return (
|
|
1018
|
+
<Nav.Item key={logName}>
|
|
1019
|
+
<Nav.Link
|
|
1020
|
+
eventKey={logName}
|
|
1021
|
+
active={activeTab === logName}
|
|
1022
|
+
onClick={() => {
|
|
1023
|
+
setActiveTab(logName);
|
|
1024
|
+
setSelectedFile({
|
|
1025
|
+
path: logName,
|
|
1026
|
+
content:
|
|
1027
|
+
typeof logContent === "string"
|
|
1028
|
+
? logContent
|
|
1029
|
+
: JSON.stringify(logContent, null, 2),
|
|
1030
|
+
language: logName.endsWith(".json")
|
|
1031
|
+
? "json"
|
|
1032
|
+
: logName.endsWith(".txt")
|
|
1033
|
+
? "plaintext"
|
|
1034
|
+
: logName.endsWith(".log")
|
|
1035
|
+
? "log"
|
|
1036
|
+
: "plaintext",
|
|
1037
|
+
});
|
|
1038
|
+
}}
|
|
1039
|
+
className="d-flex flex-column align-items-start"
|
|
1040
|
+
>
|
|
1041
|
+
<div className="d-flex justify-content-between w-100">
|
|
1042
|
+
<span className="text-capitalize">{displayName}</span>
|
|
1043
|
+
{statusIndicator}
|
|
1044
|
+
</div>
|
|
1045
|
+
</Nav.Link>
|
|
1046
|
+
</Nav.Item>
|
|
1047
|
+
);
|
|
1048
|
+
};
|