@ecopages/core 0.2.0-alpha.7 → 0.2.0-alpha.9
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/CHANGELOG.md +31 -0
- package/package.json +212 -92
- package/src/adapters/abstract/application-adapter.d.ts +168 -0
- package/src/adapters/abstract/application-adapter.js +109 -0
- package/src/adapters/abstract/router-adapter.d.ts +26 -0
- package/src/adapters/abstract/router-adapter.js +5 -0
- package/src/adapters/abstract/server-adapter.d.ts +69 -0
- package/src/adapters/abstract/server-adapter.js +15 -0
- package/src/adapters/bun/client-bridge.d.ts +34 -0
- package/src/adapters/bun/client-bridge.js +48 -0
- package/src/adapters/bun/create-app.d.ts +60 -0
- package/src/adapters/bun/create-app.js +117 -0
- package/src/adapters/bun/hmr-manager.d.ts +143 -0
- package/src/adapters/bun/hmr-manager.js +334 -0
- package/src/adapters/bun/index.d.ts +2 -0
- package/src/adapters/bun/index.js +8 -0
- package/src/adapters/bun/server-adapter.d.ts +155 -0
- package/src/adapters/bun/server-adapter.js +373 -0
- package/src/adapters/bun/server-lifecycle.d.ts +63 -0
- package/src/adapters/bun/server-lifecycle.js +92 -0
- package/src/adapters/index.d.ts +6 -0
- package/src/adapters/index.js +14 -0
- package/src/adapters/node/bootstrap-dependency-resolver.d.ts +44 -0
- package/src/adapters/node/bootstrap-dependency-resolver.js +172 -0
- package/src/adapters/node/create-app.d.ts +21 -0
- package/src/adapters/node/create-app.js +143 -0
- package/src/adapters/node/index.d.ts +6 -0
- package/src/adapters/node/index.js +11 -0
- package/src/adapters/node/node-client-bridge.d.ts +26 -0
- package/src/adapters/node/node-client-bridge.js +66 -0
- package/src/adapters/node/node-hmr-manager.d.ts +133 -0
- package/src/adapters/node/node-hmr-manager.js +312 -0
- package/src/adapters/node/runtime-adapter.d.ts +46 -0
- package/src/adapters/node/runtime-adapter.js +306 -0
- package/src/adapters/node/server-adapter.d.ts +161 -0
- package/src/adapters/node/server-adapter.js +358 -0
- package/src/adapters/node/static-content-server.d.ts +60 -0
- package/src/adapters/node/static-content-server.js +194 -0
- package/src/adapters/node/write-runtime-manifest.d.ts +26 -0
- package/src/adapters/node/write-runtime-manifest.js +12 -0
- package/src/adapters/shared/api-response.d.ts +52 -0
- package/src/adapters/shared/api-response.js +96 -0
- package/src/adapters/shared/application-adapter.d.ts +18 -0
- package/src/adapters/shared/application-adapter.js +90 -0
- package/src/adapters/shared/define-api-handler.d.ts +25 -0
- package/src/adapters/shared/define-api-handler.js +15 -0
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +38 -0
- package/src/adapters/shared/explicit-static-route-matcher.js +103 -0
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +65 -0
- package/src/adapters/shared/file-route-middleware-pipeline.js +99 -0
- package/src/adapters/shared/fs-server-response-factory.d.ts +19 -0
- package/src/adapters/shared/fs-server-response-factory.js +97 -0
- package/src/adapters/shared/fs-server-response-matcher.d.ts +75 -0
- package/src/adapters/shared/fs-server-response-matcher.js +160 -0
- package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
- package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
- package/src/adapters/shared/hmr-html-response.d.ts +22 -0
- package/src/adapters/shared/hmr-html-response.js +32 -0
- package/src/adapters/shared/render-context.d.ts +14 -0
- package/src/adapters/shared/render-context.js +70 -0
- package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
- package/src/adapters/shared/runtime-bootstrap.js +43 -0
- package/src/adapters/shared/server-adapter.d.ts +97 -0
- package/src/adapters/shared/server-adapter.js +386 -0
- package/src/adapters/shared/server-route-handler.d.ts +89 -0
- package/src/adapters/shared/server-route-handler.js +111 -0
- package/src/adapters/shared/server-static-builder.d.ts +70 -0
- package/src/adapters/shared/server-static-builder.js +99 -0
- package/src/build/build-adapter.d.ts +186 -0
- package/src/build/build-adapter.js +168 -0
- package/src/build/build-manifest.d.ts +27 -0
- package/src/build/build-manifest.js +30 -0
- package/src/build/build-types.d.ts +57 -0
- package/src/build/build-types.js +0 -0
- package/src/build/dev-build-coordinator.d.ts +74 -0
- package/src/build/dev-build-coordinator.js +161 -0
- package/src/build/esbuild-build-adapter.d.ts +72 -0
- package/src/build/esbuild-build-adapter.js +422 -0
- package/src/build/runtime-build-executor.d.ts +13 -0
- package/src/build/runtime-build-executor.js +20 -0
- package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
- package/src/build/runtime-specifier-alias-plugin.js +31 -0
- package/src/config/config-builder.d.ts +238 -0
- package/src/config/config-builder.js +565 -0
- package/src/constants.d.ts +45 -0
- package/src/constants.js +25 -0
- package/src/create-app.d.ts +17 -0
- package/src/create-app.js +66 -0
- package/src/dev/sc-server.d.ts +30 -0
- package/src/dev/sc-server.js +111 -0
- package/src/eco/component-render-context.d.ts +105 -0
- package/src/eco/component-render-context.js +87 -0
- package/src/eco/eco.d.ts +9 -0
- package/src/eco/eco.js +114 -0
- package/src/eco/eco.types.d.ts +178 -0
- package/src/eco/eco.types.js +0 -0
- package/src/eco/eco.utils.d.ts +40 -0
- package/src/eco/eco.utils.js +40 -0
- package/src/eco/global-injector-map.d.ts +16 -0
- package/src/eco/global-injector-map.js +80 -0
- package/src/eco/lazy-injector-map.d.ts +8 -0
- package/src/eco/lazy-injector-map.js +70 -0
- package/src/eco/module-dependencies.d.ts +18 -0
- package/src/eco/module-dependencies.js +49 -0
- package/src/errors/http-error.d.ts +31 -0
- package/src/errors/http-error.js +50 -0
- package/src/errors/index.d.ts +2 -0
- package/src/errors/index.js +4 -0
- package/src/errors/locals-access-error.d.ts +4 -0
- package/src/errors/locals-access-error.js +9 -0
- package/src/global/app-logger.d.ts +2 -0
- package/src/global/app-logger.js +6 -0
- package/src/hmr/client/hmr-runtime.d.ts +5 -0
- package/src/hmr/client/hmr-runtime.js +109 -0
- package/src/hmr/hmr-strategy.d.ts +159 -0
- package/src/hmr/hmr-strategy.js +29 -0
- package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
- package/src/hmr/hmr.postcss.test.e2e.js +31 -0
- package/src/hmr/hmr.test.e2e.d.ts +1 -0
- package/src/hmr/hmr.test.e2e.js +43 -0
- package/src/hmr/strategies/default-hmr-strategy.d.ts +43 -0
- package/src/hmr/strategies/default-hmr-strategy.js +34 -0
- package/src/hmr/strategies/js-hmr-strategy.d.ts +139 -0
- package/src/hmr/strategies/js-hmr-strategy.js +178 -0
- package/src/index.browser.d.ts +3 -0
- package/src/index.browser.js +4 -0
- package/src/index.d.ts +5 -0
- package/src/index.js +10 -0
- package/src/integrations/ghtml/ghtml-renderer.d.ts +15 -0
- package/src/integrations/ghtml/ghtml-renderer.js +62 -0
- package/src/integrations/ghtml/ghtml.plugin.d.ts +20 -0
- package/src/integrations/ghtml/ghtml.plugin.js +21 -0
- package/src/internal-types.d.ts +221 -0
- package/src/internal-types.js +0 -0
- package/src/plugins/alias-resolver-plugin.d.ts +2 -0
- package/src/plugins/alias-resolver-plugin.js +53 -0
- package/src/plugins/eco-component-meta-plugin.d.ts +97 -0
- package/src/plugins/eco-component-meta-plugin.js +157 -0
- package/src/plugins/integration-plugin.d.ts +136 -0
- package/src/plugins/integration-plugin.js +133 -0
- package/src/plugins/processor.d.ts +95 -0
- package/src/plugins/processor.js +136 -0
- package/src/plugins/runtime-capability.d.ts +9 -0
- package/src/plugins/runtime-capability.js +0 -0
- package/src/public-types.d.ts +1149 -0
- package/src/public-types.js +0 -0
- package/src/route-renderer/component-graph/component-graph-executor.d.ts +32 -0
- package/src/route-renderer/component-graph/component-graph-executor.js +31 -0
- package/src/route-renderer/component-graph/component-graph.d.ts +42 -0
- package/src/route-renderer/component-graph/component-graph.js +72 -0
- package/src/route-renderer/component-graph/component-marker.d.ts +52 -0
- package/src/route-renderer/component-graph/component-marker.js +46 -0
- package/src/route-renderer/component-graph/component-reference.d.ts +10 -0
- package/src/route-renderer/component-graph/component-reference.js +19 -0
- package/src/route-renderer/component-graph/marker-graph-resolver.d.ts +77 -0
- package/src/route-renderer/component-graph/marker-graph-resolver.js +95 -0
- package/src/route-renderer/orchestration/integration-renderer.d.ts +372 -0
- package/src/route-renderer/orchestration/integration-renderer.js +589 -0
- package/src/route-renderer/orchestration/render-execution.service.d.ts +103 -0
- package/src/route-renderer/orchestration/render-execution.service.js +121 -0
- package/src/route-renderer/orchestration/render-preparation.service.d.ts +121 -0
- package/src/route-renderer/orchestration/render-preparation.service.js +332 -0
- package/src/route-renderer/page-loading/dependency-resolver.d.ts +35 -0
- package/src/route-renderer/page-loading/dependency-resolver.js +442 -0
- package/src/route-renderer/page-loading/page-module-loader.d.ts +87 -0
- package/src/route-renderer/page-loading/page-module-loader.js +124 -0
- package/src/route-renderer/route-renderer.d.ts +61 -0
- package/src/route-renderer/route-renderer.js +87 -0
- package/src/router/client/link-intent.js +34 -0
- package/src/router/client/link-intent.test.browser.d.ts +1 -0
- package/src/router/client/link-intent.test.browser.js +43 -0
- package/src/router/client/navigation-coordinator.d.ts +149 -0
- package/src/router/client/navigation-coordinator.js +215 -0
- package/src/router/server/fs-router-scanner.d.ts +41 -0
- package/src/router/server/fs-router-scanner.js +156 -0
- package/src/router/server/fs-router.d.ts +26 -0
- package/src/router/server/fs-router.js +100 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +120 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.js +331 -0
- package/src/services/assets/asset-processing-service/asset.factory.d.ts +17 -0
- package/src/services/assets/asset-processing-service/asset.factory.js +82 -0
- package/src/services/assets/asset-processing-service/assets.types.d.ts +89 -0
- package/src/services/assets/asset-processing-service/assets.types.js +0 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +48 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
- package/src/services/assets/asset-processing-service/index.d.ts +5 -0
- package/src/services/assets/asset-processing-service/index.js +5 -0
- package/src/services/assets/asset-processing-service/processor.interface.d.ts +22 -0
- package/src/services/assets/asset-processing-service/processor.interface.js +6 -0
- package/src/services/assets/asset-processing-service/processor.registry.d.ts +8 -0
- package/src/services/assets/asset-processing-service/processor.registry.js +15 -0
- package/src/services/assets/asset-processing-service/processors/base/base-processor.d.ts +24 -0
- package/src/services/assets/asset-processing-service/processors/base/base-processor.js +64 -0
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +17 -0
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +72 -0
- package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
- package/src/services/assets/asset-processing-service/processors/index.js +5 -0
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.d.ts +5 -0
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +57 -0
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.d.ts +8 -0
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.js +76 -0
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +7 -0
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +75 -0
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +5 -0
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +25 -0
- package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +9 -0
- package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +66 -0
- package/src/services/assets/browser-bundle.service.d.ts +32 -0
- package/src/services/assets/browser-bundle.service.js +33 -0
- package/src/services/cache/cache.types.d.ts +107 -0
- package/src/services/cache/cache.types.js +0 -0
- package/src/services/cache/index.d.ts +7 -0
- package/src/services/cache/index.js +7 -0
- package/src/services/cache/memory-cache-store.d.ts +42 -0
- package/src/services/cache/memory-cache-store.js +98 -0
- package/src/services/cache/page-cache-service.d.ts +70 -0
- package/src/services/cache/page-cache-service.js +152 -0
- package/src/services/cache/page-request-cache-coordinator.service.d.ts +75 -0
- package/src/services/cache/page-request-cache-coordinator.service.js +109 -0
- package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
- package/src/services/html/html-rewriter-provider.service.js +65 -0
- package/src/services/html/html-transformer.service.d.ts +77 -0
- package/src/services/html/html-transformer.service.js +221 -0
- package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
- package/src/services/invalidation/development-invalidation.service.js +189 -0
- package/src/services/module-loading/app-server-module-transpiler.service.d.ts +16 -0
- package/src/services/module-loading/app-server-module-transpiler.service.js +34 -0
- package/src/services/module-loading/page-module-import.service.d.ts +71 -0
- package/src/services/module-loading/page-module-import.service.js +132 -0
- package/src/services/module-loading/server-loader.service.d.ts +96 -0
- package/src/services/module-loading/server-loader.service.js +32 -0
- package/src/services/module-loading/server-module-transpiler.service.d.ts +69 -0
- package/src/services/module-loading/server-module-transpiler.service.js +61 -0
- package/src/services/runtime-manifest/node-runtime-manifest.service.d.ts +35 -0
- package/src/services/runtime-manifest/node-runtime-manifest.service.js +60 -0
- package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
- package/src/services/runtime-state/dev-graph.service.js +162 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +69 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.js +37 -0
- package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
- package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
- package/src/services/validation/schema-validation-service.d.ts +122 -0
- package/src/services/validation/schema-validation-service.js +101 -0
- package/src/services/validation/standard-schema.types.d.ts +65 -0
- package/src/services/validation/standard-schema.types.js +0 -0
- package/src/static-site-generator/static-site-generator.d.ts +109 -0
- package/src/static-site-generator/static-site-generator.js +353 -0
- package/src/utils/css.d.ts +1 -0
- package/src/utils/css.js +7 -0
- package/src/utils/deep-merge.d.ts +14 -0
- package/src/utils/deep-merge.js +32 -0
- package/src/utils/hash.d.ts +1 -0
- package/src/utils/hash.js +7 -0
- package/src/utils/html.d.ts +1 -0
- package/src/utils/html.js +4 -0
- package/src/utils/invariant.d.ts +5 -0
- package/src/utils/invariant.js +11 -0
- package/src/utils/locals-utils.d.ts +15 -0
- package/src/utils/locals-utils.js +24 -0
- package/src/utils/parse-cli-args.d.ts +24 -0
- package/src/utils/parse-cli-args.js +47 -0
- package/src/utils/path-utils.module.d.ts +5 -0
- package/src/utils/path-utils.module.js +14 -0
- package/src/utils/resolve-work-dir.d.ts +11 -0
- package/src/utils/resolve-work-dir.js +31 -0
- package/src/utils/runtime.d.ts +11 -0
- package/src/utils/runtime.js +40 -0
- package/src/utils/server-utils.module.d.ts +19 -0
- package/src/utils/server-utils.module.js +56 -0
- package/src/watchers/project-watcher.d.ts +136 -0
- package/src/watchers/project-watcher.js +281 -0
- package/src/watchers/project-watcher.test-helpers.d.ts +4 -0
- package/src/watchers/project-watcher.test-helpers.js +52 -0
- package/src/adapters/bun/hmr-manager.test.ts +0 -267
- package/src/adapters/node/bootstrap-dependency-resolver.test.ts +0 -282
- package/src/adapters/node/node-client-bridge.test.ts +0 -198
- package/src/adapters/node/node-hmr-manager.test.ts +0 -322
- package/src/adapters/node/runtime-adapter.test.ts +0 -868
- package/src/adapters/node/static-content-server.test.ts +0 -60
- package/src/adapters/shared/api-response.test.ts +0 -97
- package/src/adapters/shared/explicit-static-route-matcher.test.ts +0 -381
- package/src/adapters/shared/file-route-middleware-pipeline.test.ts +0 -90
- package/src/adapters/shared/fs-server-response-factory.test.ts +0 -187
- package/src/adapters/shared/fs-server-response-matcher.test.ts +0 -286
- package/src/adapters/shared/hmr-manager.contract.test.ts +0 -196
- package/src/adapters/shared/hmr-manager.dispatch.test.ts +0 -220
- package/src/adapters/shared/render-context.test.ts +0 -146
- package/src/adapters/shared/server-adapter.test.ts +0 -77
- package/src/adapters/shared/server-route-handler.test.ts +0 -110
- package/src/adapters/shared/server-static-builder.test.ts +0 -316
- package/src/build/build-adapter-serialization.test.ts +0 -268
- package/src/build/build-adapter.test.ts +0 -815
- package/src/build/runtime-specifier-alias-plugin.test.ts +0 -43
- package/src/config/config-builder.test.ts +0 -410
- package/src/eco/eco.test.ts +0 -678
- package/src/eco/eco.utils.test.ts +0 -124
- package/src/eco/global-injector-map.test.ts +0 -42
- package/src/eco/lazy-injector-map.test.ts +0 -66
- package/src/eco/module-dependencies.test.ts +0 -30
- package/src/errors/http-error.test.ts +0 -134
- package/src/global/utils.test.ts +0 -12
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-have-HMR-script-injected-in-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
- package/src/hmr/hmr-strategy.test.ts +0 -124
- package/src/hmr/strategies/js-hmr-strategy.test.ts +0 -335
- package/src/integrations/ghtml/ghtml-renderer.test.ts +0 -63
- package/src/plugins/alias-resolver-plugin.test.ts +0 -41
- package/src/plugins/eco-component-meta-plugin.test.ts +0 -380
- package/src/plugins/integration-plugin.test.ts +0 -111
- package/src/plugins/processor.test.ts +0 -148
- package/src/route-renderer/component-graph/component-graph-executor.test.ts +0 -41
- package/src/route-renderer/component-graph/component-graph.test.ts +0 -63
- package/src/route-renderer/component-graph/component-marker.test.ts +0 -73
- package/src/route-renderer/component-graph/marker-graph-resolver.test.ts +0 -135
- package/src/route-renderer/orchestration/integration-renderer.test.ts +0 -936
- package/src/route-renderer/orchestration/render-execution.service.test.ts +0 -97
- package/src/route-renderer/orchestration/render-preparation.service.test.ts +0 -235
- package/src/route-renderer/page-loading/dependency-resolver.test.ts +0 -345
- package/src/route-renderer/page-loading/page-module-loader.test.ts +0 -96
- package/src/router/client/navigation-coordinator.test.ts +0 -237
- package/src/router/server/fs-router-scanner.test.ts +0 -83
- package/src/router/server/fs-router.test.ts +0 -214
- package/src/services/assets/asset-processing-service/asset-processing.service.test.ts +0 -385
- package/src/services/assets/asset-processing-service/asset.factory.test.ts +0 -63
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.test.ts +0 -72
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.test.ts +0 -67
- package/src/services/assets/asset-processing-service/processors/base/base-processor.test.ts +0 -59
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.test.ts +0 -286
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.test.ts +0 -227
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.test.ts +0 -199
- package/src/services/assets/browser-bundle.service.test.ts +0 -36
- package/src/services/cache/memory-cache-store.test.ts +0 -225
- package/src/services/cache/page-cache-service.test.ts +0 -175
- package/src/services/cache/page-request-cache-coordinator.service.test.ts +0 -79
- package/src/services/html/html-rewriter-provider.service.test.ts +0 -183
- package/src/services/html/html-transformer.service.test.ts +0 -378
- package/src/services/invalidation/development-invalidation.service.test.ts +0 -77
- package/src/services/module-loading/page-module-import.service.test.ts +0 -253
- package/src/services/module-loading/server-loader.service.test.ts +0 -161
- package/src/services/module-loading/server-module-transpiler.service.test.ts +0 -115
- package/src/services/runtime-manifest/node-runtime-manifest.service.test.ts +0 -95
- package/src/services/validation/schema-validation-service.test.ts +0 -223
- package/src/static-site-generator/static-site-generator.test.ts +0 -307
- package/src/utils/deep-merge.test.ts +0 -114
- package/src/utils/invariant.test.ts +0 -22
- package/src/utils/path-utils.test.ts +0 -15
- package/src/utils/server-utils.test.ts +0 -38
- package/src/watchers/project-watcher.integration.test.ts +0 -337
- package/src/watchers/project-watcher.test.ts +0 -678
|
@@ -1,220 +0,0 @@
|
|
|
1
|
-
import assert from 'node:assert/strict';
|
|
2
|
-
import fs from 'node:fs';
|
|
3
|
-
import os from 'node:os';
|
|
4
|
-
import path from 'node:path';
|
|
5
|
-
import { afterEach, describe, test } from 'vitest';
|
|
6
|
-
import { ConfigBuilder } from '../../config/config-builder.ts';
|
|
7
|
-
import { HmrStrategy, HmrStrategyType, type HmrAction } from '../../hmr/hmr-strategy.ts';
|
|
8
|
-
import type { ClientBridgeEvent } from '../../public-types.ts';
|
|
9
|
-
import { HmrManager as BunHmrManager } from '../bun/hmr-manager.ts';
|
|
10
|
-
import { NodeHmrManager } from '../node/node-hmr-manager.ts';
|
|
11
|
-
|
|
12
|
-
class FakeHmrStrategy extends HmrStrategy {
|
|
13
|
-
readonly type: HmrStrategyType;
|
|
14
|
-
private readonly _matches: (filePath: string) => boolean;
|
|
15
|
-
private readonly _action: HmrAction;
|
|
16
|
-
|
|
17
|
-
constructor(type: HmrStrategyType, matchFn: (f: string) => boolean, action: HmrAction) {
|
|
18
|
-
super();
|
|
19
|
-
this.type = type;
|
|
20
|
-
this._matches = matchFn;
|
|
21
|
-
this._action = action;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
matches(filePath: string): boolean {
|
|
25
|
-
return this._matches(filePath);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
async process(_filePath: string): Promise<HmrAction> {
|
|
29
|
-
return this._action;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
type BridgeSpy = {
|
|
34
|
-
broadcasts: ClientBridgeEvent[];
|
|
35
|
-
bridge: {
|
|
36
|
-
subscriberCount: number;
|
|
37
|
-
broadcast(event: ClientBridgeEvent): void;
|
|
38
|
-
subscribe(): void;
|
|
39
|
-
unsubscribe(): void;
|
|
40
|
-
};
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
function createBridgeSpy(): BridgeSpy {
|
|
44
|
-
const broadcasts: ClientBridgeEvent[] = [];
|
|
45
|
-
const bridge = {
|
|
46
|
-
subscriberCount: 0,
|
|
47
|
-
broadcast(event: ClientBridgeEvent) {
|
|
48
|
-
broadcasts.push(event);
|
|
49
|
-
},
|
|
50
|
-
subscribe() {},
|
|
51
|
-
unsubscribe() {},
|
|
52
|
-
};
|
|
53
|
-
return { broadcasts, bridge };
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
const tempRoots: string[] = [];
|
|
57
|
-
|
|
58
|
-
function createTempRoot(prefix: string): string {
|
|
59
|
-
const root = fs.mkdtempSync(path.join(os.tmpdir(), `${prefix}-`));
|
|
60
|
-
tempRoots.push(root);
|
|
61
|
-
return root;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
afterEach(() => {
|
|
65
|
-
for (const root of tempRoots.splice(0)) {
|
|
66
|
-
fs.rmSync(root, { recursive: true, force: true });
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
const runtimes = [
|
|
71
|
-
{
|
|
72
|
-
name: 'node',
|
|
73
|
-
async create(rootDir: string, bridgeSpy: BridgeSpy) {
|
|
74
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
75
|
-
return new NodeHmrManager({ appConfig: config, bridge: bridgeSpy.bridge as any });
|
|
76
|
-
},
|
|
77
|
-
},
|
|
78
|
-
{
|
|
79
|
-
name: 'bun',
|
|
80
|
-
async create(rootDir: string, bridgeSpy: BridgeSpy) {
|
|
81
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
82
|
-
return new BunHmrManager({ appConfig: config, bridge: bridgeSpy.bridge as any });
|
|
83
|
-
},
|
|
84
|
-
},
|
|
85
|
-
] as const;
|
|
86
|
-
|
|
87
|
-
describe.each(runtimes)('handleFileChange dispatch: $name', ({ create }) => {
|
|
88
|
-
test('CSS file change routes to DefaultHmrStrategy and broadcasts reload', async () => {
|
|
89
|
-
const rootDir = createTempRoot('ecopages-dispatch-css');
|
|
90
|
-
fs.mkdirSync(path.join(rootDir, 'src'), { recursive: true });
|
|
91
|
-
const spy = createBridgeSpy();
|
|
92
|
-
const manager = await create(rootDir, spy);
|
|
93
|
-
|
|
94
|
-
const cssFile = path.join(rootDir, 'src', 'styles', 'main.css');
|
|
95
|
-
await manager.handleFileChange(cssFile);
|
|
96
|
-
|
|
97
|
-
assert.equal(spy.broadcasts.length, 1);
|
|
98
|
-
assert.equal(spy.broadcasts[0].type, 'reload');
|
|
99
|
-
assert.equal(spy.broadcasts[0].path, cssFile);
|
|
100
|
-
|
|
101
|
-
manager.stop();
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
test('HTML file change routes to DefaultHmrStrategy and broadcasts reload', async () => {
|
|
105
|
-
const rootDir = createTempRoot('ecopages-dispatch-html');
|
|
106
|
-
fs.mkdirSync(path.join(rootDir, 'src'), { recursive: true });
|
|
107
|
-
const spy = createBridgeSpy();
|
|
108
|
-
const manager = await create(rootDir, spy);
|
|
109
|
-
|
|
110
|
-
const htmlFile = path.join(rootDir, 'src', 'pages', 'index.html');
|
|
111
|
-
await manager.handleFileChange(htmlFile);
|
|
112
|
-
|
|
113
|
-
assert.equal(spy.broadcasts.length, 1);
|
|
114
|
-
assert.equal(spy.broadcasts[0].type, 'reload');
|
|
115
|
-
assert.equal(spy.broadcasts[0].path, htmlFile);
|
|
116
|
-
|
|
117
|
-
manager.stop();
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
test('TS file with no registered entrypoints falls back to DefaultHmrStrategy reload', async () => {
|
|
121
|
-
const rootDir = createTempRoot('ecopages-dispatch-ts-fallback');
|
|
122
|
-
const srcDir = path.join(rootDir, 'src');
|
|
123
|
-
fs.mkdirSync(srcDir, { recursive: true });
|
|
124
|
-
const spy = createBridgeSpy();
|
|
125
|
-
const manager = await create(rootDir, spy);
|
|
126
|
-
|
|
127
|
-
const tsFile = path.join(srcDir, 'component.ts');
|
|
128
|
-
await manager.handleFileChange(tsFile);
|
|
129
|
-
|
|
130
|
-
assert.equal(spy.broadcasts.length, 1);
|
|
131
|
-
assert.equal(spy.broadcasts[0].type, 'reload');
|
|
132
|
-
|
|
133
|
-
manager.stop();
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
test('broadcast:false suppresses events even when the strategy returns a broadcast action', async () => {
|
|
137
|
-
const rootDir = createTempRoot('ecopages-dispatch-no-broadcast');
|
|
138
|
-
fs.mkdirSync(path.join(rootDir, 'src'), { recursive: true });
|
|
139
|
-
const spy = createBridgeSpy();
|
|
140
|
-
const manager = await create(rootDir, spy);
|
|
141
|
-
|
|
142
|
-
const cssFile = path.join(rootDir, 'src', 'main.css');
|
|
143
|
-
await manager.handleFileChange(cssFile, { broadcast: false });
|
|
144
|
-
|
|
145
|
-
assert.equal(spy.broadcasts.length, 0);
|
|
146
|
-
|
|
147
|
-
manager.stop();
|
|
148
|
-
});
|
|
149
|
-
|
|
150
|
-
test('INTEGRATION strategy wins over DefaultHmrStrategy for matched files', async () => {
|
|
151
|
-
const rootDir = createTempRoot('ecopages-dispatch-integration-priority');
|
|
152
|
-
fs.mkdirSync(path.join(rootDir, 'src'), { recursive: true });
|
|
153
|
-
const spy = createBridgeSpy();
|
|
154
|
-
const manager = await create(rootDir, spy);
|
|
155
|
-
|
|
156
|
-
const customFile = path.join(rootDir, 'src', 'component.jsx');
|
|
157
|
-
const integrationEvent: ClientBridgeEvent = {
|
|
158
|
-
type: 'update',
|
|
159
|
-
path: '/assets/_hmr/component.js',
|
|
160
|
-
timestamp: 1,
|
|
161
|
-
};
|
|
162
|
-
manager.registerStrategy(
|
|
163
|
-
new FakeHmrStrategy(HmrStrategyType.INTEGRATION, (f) => f === customFile, {
|
|
164
|
-
type: 'broadcast',
|
|
165
|
-
events: [integrationEvent],
|
|
166
|
-
}),
|
|
167
|
-
);
|
|
168
|
-
|
|
169
|
-
await manager.handleFileChange(customFile);
|
|
170
|
-
|
|
171
|
-
assert.equal(spy.broadcasts.length, 1);
|
|
172
|
-
assert.deepEqual(spy.broadcasts[0], integrationEvent);
|
|
173
|
-
|
|
174
|
-
manager.stop();
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
test('action.type none suppresses broadcast even when shouldBroadcast is true', async () => {
|
|
178
|
-
const rootDir = createTempRoot('ecopages-dispatch-none-action');
|
|
179
|
-
fs.mkdirSync(path.join(rootDir, 'src'), { recursive: true });
|
|
180
|
-
const spy = createBridgeSpy();
|
|
181
|
-
const manager = await create(rootDir, spy);
|
|
182
|
-
|
|
183
|
-
const customFile = path.join(rootDir, 'src', 'silent.ts');
|
|
184
|
-
manager.registerStrategy(
|
|
185
|
-
new FakeHmrStrategy(HmrStrategyType.INTEGRATION, (f) => f === customFile, { type: 'none' }),
|
|
186
|
-
);
|
|
187
|
-
|
|
188
|
-
await manager.handleFileChange(customFile);
|
|
189
|
-
|
|
190
|
-
assert.equal(spy.broadcasts.length, 0);
|
|
191
|
-
|
|
192
|
-
manager.stop();
|
|
193
|
-
});
|
|
194
|
-
|
|
195
|
-
test('all events returned by a strategy are each broadcast individually', async () => {
|
|
196
|
-
const rootDir = createTempRoot('ecopages-dispatch-multi-event');
|
|
197
|
-
fs.mkdirSync(path.join(rootDir, 'src'), { recursive: true });
|
|
198
|
-
const spy = createBridgeSpy();
|
|
199
|
-
const manager = await create(rootDir, spy);
|
|
200
|
-
|
|
201
|
-
const customFile = path.join(rootDir, 'src', 'multi.ts');
|
|
202
|
-
const events: ClientBridgeEvent[] = [
|
|
203
|
-
{ type: 'update', path: '/assets/_hmr/a.js', timestamp: 1 },
|
|
204
|
-
{ type: 'update', path: '/assets/_hmr/b.js', timestamp: 2 },
|
|
205
|
-
];
|
|
206
|
-
manager.registerStrategy(
|
|
207
|
-
new FakeHmrStrategy(HmrStrategyType.INTEGRATION, (f) => f === customFile, {
|
|
208
|
-
type: 'broadcast',
|
|
209
|
-
events,
|
|
210
|
-
}),
|
|
211
|
-
);
|
|
212
|
-
|
|
213
|
-
await manager.handleFileChange(customFile);
|
|
214
|
-
|
|
215
|
-
assert.equal(spy.broadcasts.length, 2);
|
|
216
|
-
assert.deepEqual(spy.broadcasts, events);
|
|
217
|
-
|
|
218
|
-
manager.stop();
|
|
219
|
-
});
|
|
220
|
-
});
|
|
@@ -1,146 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi } from 'vitest';
|
|
2
|
-
import { createRenderContext } from './render-context.ts';
|
|
3
|
-
import type { IntegrationPlugin } from '../../plugins/integration-plugin.ts';
|
|
4
|
-
import type { IntegrationRenderer } from '../../route-renderer/orchestration/integration-renderer.ts';
|
|
5
|
-
import type { EcoFunctionComponent } from '../../public-types.ts';
|
|
6
|
-
|
|
7
|
-
describe('createRenderContext', () => {
|
|
8
|
-
const RenderToResponse = vi.fn(() => Promise.resolve(new Response('rendered')));
|
|
9
|
-
|
|
10
|
-
const Renderer = {
|
|
11
|
-
name: '-renderer',
|
|
12
|
-
renderToResponse: RenderToResponse,
|
|
13
|
-
} as unknown as IntegrationRenderer;
|
|
14
|
-
|
|
15
|
-
const ExplicitRenderer = {
|
|
16
|
-
name: 'explicit-renderer',
|
|
17
|
-
renderToResponse: RenderToResponse,
|
|
18
|
-
} as unknown as IntegrationRenderer;
|
|
19
|
-
|
|
20
|
-
const InitializeRenderer = vi.fn(() => Renderer);
|
|
21
|
-
|
|
22
|
-
const Plugin = {
|
|
23
|
-
name: '-integration',
|
|
24
|
-
initializeRenderer: InitializeRenderer,
|
|
25
|
-
} as unknown as IntegrationPlugin;
|
|
26
|
-
|
|
27
|
-
const ExplicitInitializeRenderer = vi.fn(() => ExplicitRenderer);
|
|
28
|
-
|
|
29
|
-
const ExplicitPlugin = {
|
|
30
|
-
name: 'explicit-renderer',
|
|
31
|
-
initializeRenderer: ExplicitInitializeRenderer,
|
|
32
|
-
} as unknown as IntegrationPlugin;
|
|
33
|
-
|
|
34
|
-
const ViewFn = ((props: { foo: string }) => `<div>${props.foo}</div>`) as EcoFunctionComponent<
|
|
35
|
-
{ foo: string },
|
|
36
|
-
string
|
|
37
|
-
>;
|
|
38
|
-
ViewFn.config = {
|
|
39
|
-
__eco: {
|
|
40
|
-
id: 'test',
|
|
41
|
-
file: '/some/dir/-view.ts',
|
|
42
|
-
integration: '-integration',
|
|
43
|
-
},
|
|
44
|
-
};
|
|
45
|
-
|
|
46
|
-
const renderContext = createRenderContext({
|
|
47
|
-
integrations: [Plugin, ExplicitPlugin],
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
it('should create a render context with methods', () => {
|
|
51
|
-
expect(renderContext.render).toBeDefined();
|
|
52
|
-
expect(renderContext.renderPartial).toBeDefined();
|
|
53
|
-
expect(renderContext.json).toBeDefined();
|
|
54
|
-
expect(renderContext.html).toBeDefined();
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
describe('render', () => {
|
|
58
|
-
it('should call renderer.renderToResponse with partial: false', async () => {
|
|
59
|
-
RenderToResponse.mockClear();
|
|
60
|
-
InitializeRenderer.mockClear();
|
|
61
|
-
ExplicitInitializeRenderer.mockClear();
|
|
62
|
-
const props = { foo: 'bar' };
|
|
63
|
-
const options = { status: 201, headers: { 'X-Custom': '1' } };
|
|
64
|
-
|
|
65
|
-
const response = await renderContext.render(ViewFn, props, options);
|
|
66
|
-
|
|
67
|
-
expect(InitializeRenderer).toHaveBeenCalled();
|
|
68
|
-
expect(RenderToResponse).toHaveBeenCalledWith(ViewFn, props, {
|
|
69
|
-
partial: false,
|
|
70
|
-
status: 201,
|
|
71
|
-
headers: { 'X-Custom': '1' },
|
|
72
|
-
});
|
|
73
|
-
expect(response instanceof Response).toBe(true);
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
it('should throw if view integration is unknown', async () => {
|
|
77
|
-
const badViewFn = (() => '<div></div>') as EcoFunctionComponent<{}, string>;
|
|
78
|
-
badViewFn.config = { __eco: { id: 'test', file: '/bad-view.ts', integration: 'unknown' } };
|
|
79
|
-
await expect(renderContext.render(badViewFn, {})).rejects.toThrow('No integration found for: unknown');
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
it('should throw if view integration is missing', async () => {
|
|
83
|
-
const badViewFn = (() => '<div></div>') as EcoFunctionComponent<{}, string>;
|
|
84
|
-
badViewFn.config = { __eco: undefined };
|
|
85
|
-
await expect(renderContext.render(badViewFn, {})).rejects.toThrow('Cannot determine integration for view');
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
it('should prefer explicit config.integration over injected metadata', async () => {
|
|
89
|
-
RenderToResponse.mockClear();
|
|
90
|
-
InitializeRenderer.mockClear();
|
|
91
|
-
ExplicitInitializeRenderer.mockClear();
|
|
92
|
-
|
|
93
|
-
const explicitViewFn = (() => '<div></div>') as EcoFunctionComponent<{}, string>;
|
|
94
|
-
explicitViewFn.config = {
|
|
95
|
-
integration: 'explicit-renderer',
|
|
96
|
-
__eco: { id: 'test', file: '/some/file.tsx', integration: '-integration' },
|
|
97
|
-
};
|
|
98
|
-
|
|
99
|
-
await renderContext.render(explicitViewFn, {});
|
|
100
|
-
|
|
101
|
-
expect(ExplicitInitializeRenderer).toHaveBeenCalled();
|
|
102
|
-
expect(InitializeRenderer).not.toHaveBeenCalled();
|
|
103
|
-
});
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
describe('renderPartial', () => {
|
|
107
|
-
it('should call renderer.renderToResponse with partial: true', async () => {
|
|
108
|
-
RenderToResponse.mockClear();
|
|
109
|
-
const props = { foo: 'bar' };
|
|
110
|
-
const options = { status: 200 };
|
|
111
|
-
|
|
112
|
-
await renderContext.renderPartial(ViewFn, props, options);
|
|
113
|
-
|
|
114
|
-
expect(InitializeRenderer).toHaveBeenCalled();
|
|
115
|
-
expect(RenderToResponse).toHaveBeenCalledWith(ViewFn, props, {
|
|
116
|
-
partial: true,
|
|
117
|
-
status: 200,
|
|
118
|
-
headers: undefined,
|
|
119
|
-
});
|
|
120
|
-
});
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
describe('json', () => {
|
|
124
|
-
it('should return a JSON response', async () => {
|
|
125
|
-
const data = { hello: 'world' };
|
|
126
|
-
const response = renderContext.json(data);
|
|
127
|
-
expect(response.headers.get('Content-Type')).toContain('application/json');
|
|
128
|
-
expect(await response.json()).toEqual(data);
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
it('should support custom status and headers', async () => {
|
|
132
|
-
const response = renderContext.json({}, { status: 201, headers: { 'X-Test': 'true' } });
|
|
133
|
-
expect(response.status).toBe(201);
|
|
134
|
-
expect(response.headers.get('X-Test')).toBe('true');
|
|
135
|
-
});
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
describe('html', () => {
|
|
139
|
-
it('should return an HTML response', async () => {
|
|
140
|
-
const html = '<div>hello</div>';
|
|
141
|
-
const response = renderContext.html(html);
|
|
142
|
-
expect(response.headers.get('Content-Type')).toContain('text/html');
|
|
143
|
-
expect(await response.text()).toBe(html);
|
|
144
|
-
});
|
|
145
|
-
});
|
|
146
|
-
});
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
import assert from 'node:assert/strict';
|
|
2
|
-
import fs from 'node:fs';
|
|
3
|
-
import os from 'node:os';
|
|
4
|
-
import path from 'node:path';
|
|
5
|
-
import { afterEach, test } from 'vitest';
|
|
6
|
-
import { ConfigBuilder } from '../../config/config-builder.ts';
|
|
7
|
-
import type { ServerAdapterResult } from '../abstract/server-adapter.ts';
|
|
8
|
-
import { SharedServerAdapter } from './server-adapter.ts';
|
|
9
|
-
|
|
10
|
-
const tempRoots: string[] = [];
|
|
11
|
-
|
|
12
|
-
function createTempRoot(prefix: string): string {
|
|
13
|
-
const root = fs.mkdtempSync(path.join(os.tmpdir(), `${prefix}-`));
|
|
14
|
-
tempRoots.push(root);
|
|
15
|
-
return root;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
afterEach(() => {
|
|
19
|
-
for (const root of tempRoots.splice(0)) {
|
|
20
|
-
fs.rmSync(root, { recursive: true, force: true });
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
class TestSharedServerAdapter extends SharedServerAdapter<any, ServerAdapterResult> {
|
|
25
|
-
public async initialize(): Promise<void> {}
|
|
26
|
-
public getServerOptions(): Record<string, never> {
|
|
27
|
-
return {};
|
|
28
|
-
}
|
|
29
|
-
public async buildStatic(): Promise<void> {}
|
|
30
|
-
public async createAdapter(): Promise<ServerAdapterResult> {
|
|
31
|
-
return {
|
|
32
|
-
getServerOptions: () => ({}),
|
|
33
|
-
buildStatic: async () => {},
|
|
34
|
-
};
|
|
35
|
-
}
|
|
36
|
-
public async handleRequest(request: Request): Promise<Response> {
|
|
37
|
-
return await this.handleSharedRequest(request, {
|
|
38
|
-
apiHandlers: [],
|
|
39
|
-
hmrManager: {
|
|
40
|
-
getRuntimePath: () => '',
|
|
41
|
-
getDistDir: () => this.hmrDir,
|
|
42
|
-
},
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
constructor(
|
|
47
|
-
private readonly hmrDir: string,
|
|
48
|
-
rootDir: string,
|
|
49
|
-
) {
|
|
50
|
-
super({
|
|
51
|
-
appConfig: { rootDir } as any,
|
|
52
|
-
runtimeOrigin: 'http://localhost:3000',
|
|
53
|
-
serveOptions: {},
|
|
54
|
-
options: {},
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
test('SharedServerAdapter serves /assets/_hmr files from the HMR manager directory', async () => {
|
|
60
|
-
const rootDir = createTempRoot('ecopages-shared-server-hmr-assets');
|
|
61
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
62
|
-
const hmrDir = path.join(config.absolutePaths.workDir, 'assets', '_hmr');
|
|
63
|
-
const assetPath = path.join(hmrDir, 'pages', 'react-content.js');
|
|
64
|
-
fs.mkdirSync(path.dirname(assetPath), { recursive: true });
|
|
65
|
-
fs.writeFileSync(assetPath, 'export default 1;', 'utf8');
|
|
66
|
-
|
|
67
|
-
const adapter = new TestSharedServerAdapter(hmrDir, rootDir);
|
|
68
|
-
const response = await adapter.handleRequest(new Request('http://localhost/assets/_hmr/pages/react-content.js'));
|
|
69
|
-
|
|
70
|
-
assert.equal(response.status, 200);
|
|
71
|
-
assert.equal(response.headers.get('Content-Type'), 'application/javascript');
|
|
72
|
-
assert.equal(await response.text(), 'export default 1;');
|
|
73
|
-
assert.equal(
|
|
74
|
-
fs.existsSync(path.join(config.absolutePaths.distDir, 'assets', '_hmr', 'pages', 'react-content.js')),
|
|
75
|
-
false,
|
|
76
|
-
);
|
|
77
|
-
});
|
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
-
import { ServerRouteHandler } from './server-route-handler';
|
|
3
|
-
import type { FSRouter } from '../../router/server/fs-router';
|
|
4
|
-
import type { FileSystemResponseMatcher } from './fs-server-response-matcher';
|
|
5
|
-
import type { IHmrManager } from '../../public-types';
|
|
6
|
-
|
|
7
|
-
function createMockDependencies() {
|
|
8
|
-
const Router = {
|
|
9
|
-
match: vi.fn(() => null),
|
|
10
|
-
} as unknown as FSRouter;
|
|
11
|
-
|
|
12
|
-
const FileSystemResponseMatcher = {
|
|
13
|
-
handleMatch: vi.fn(() => Promise.resolve(new Response('Matched Content'))),
|
|
14
|
-
handleNoMatch: vi.fn(() => Promise.resolve(new Response('Not Found', { status: 404 }))),
|
|
15
|
-
} as unknown as FileSystemResponseMatcher;
|
|
16
|
-
|
|
17
|
-
const HmrManager = {
|
|
18
|
-
isEnabled: vi.fn(() => true),
|
|
19
|
-
broadcast: vi.fn(),
|
|
20
|
-
} as unknown as IHmrManager;
|
|
21
|
-
|
|
22
|
-
return {
|
|
23
|
-
Router,
|
|
24
|
-
FileSystemResponseMatcher,
|
|
25
|
-
HmrManager,
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
describe('ServerRouteHandler', () => {
|
|
30
|
-
describe('handleResponse', () => {
|
|
31
|
-
it('should delegate to fileSystemResponseMatcher when route matches', async () => {
|
|
32
|
-
const { Router, FileSystemResponseMatcher } = createMockDependencies();
|
|
33
|
-
const handler = new ServerRouteHandler({
|
|
34
|
-
router: Router,
|
|
35
|
-
fileSystemResponseMatcher: FileSystemResponseMatcher,
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
Router.match = vi.fn(
|
|
39
|
-
() =>
|
|
40
|
-
({
|
|
41
|
-
/* match */
|
|
42
|
-
}) as any,
|
|
43
|
-
);
|
|
44
|
-
const request = new Request('http://localhost/test');
|
|
45
|
-
const response = await handler.handleResponse(request);
|
|
46
|
-
|
|
47
|
-
expect(FileSystemResponseMatcher.handleMatch).toHaveBeenCalled();
|
|
48
|
-
expect(response.status).toBe(200);
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
it('should delegate to handleNoMatch when route does not match', async () => {
|
|
52
|
-
const { Router, FileSystemResponseMatcher } = createMockDependencies();
|
|
53
|
-
const handler = new ServerRouteHandler({
|
|
54
|
-
router: Router,
|
|
55
|
-
fileSystemResponseMatcher: FileSystemResponseMatcher,
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
const request = new Request('http://localhost/unknown');
|
|
59
|
-
const response = await handler.handleResponse(request);
|
|
60
|
-
|
|
61
|
-
expect(FileSystemResponseMatcher.handleNoMatch).toHaveBeenCalled();
|
|
62
|
-
expect(response.status).toBe(404);
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
it('should inject HMR script in watch mode for HTML responses', async () => {
|
|
66
|
-
const { Router, FileSystemResponseMatcher, HmrManager } = createMockDependencies();
|
|
67
|
-
const handler = new ServerRouteHandler({
|
|
68
|
-
router: Router,
|
|
69
|
-
fileSystemResponseMatcher: FileSystemResponseMatcher,
|
|
70
|
-
watch: true,
|
|
71
|
-
hmrManager: HmrManager,
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
Router.match = vi.fn(() => ({}) as any);
|
|
75
|
-
FileSystemResponseMatcher.handleMatch = vi.fn(() =>
|
|
76
|
-
Promise.resolve(
|
|
77
|
-
new Response('<html><body></body></html>', { headers: { 'Content-Type': 'text/html' } }),
|
|
78
|
-
),
|
|
79
|
-
);
|
|
80
|
-
|
|
81
|
-
const request = new Request('http://localhost/test');
|
|
82
|
-
const response = await handler.handleResponse(request);
|
|
83
|
-
const text = await response.text();
|
|
84
|
-
|
|
85
|
-
expect(text).toContain("import '/_hmr_runtime.js'");
|
|
86
|
-
});
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
describe('handleNoMatch', () => {
|
|
90
|
-
it('should broadcast error if handleNoMatch throws', async () => {
|
|
91
|
-
const { Router, FileSystemResponseMatcher, HmrManager } = createMockDependencies();
|
|
92
|
-
const handler = new ServerRouteHandler({
|
|
93
|
-
router: Router,
|
|
94
|
-
fileSystemResponseMatcher: FileSystemResponseMatcher,
|
|
95
|
-
watch: true,
|
|
96
|
-
hmrManager: HmrManager,
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
FileSystemResponseMatcher.handleNoMatch = vi.fn(() => {
|
|
100
|
-
throw new Error('Test Error');
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
const request = new Request('http://localhost/unknown');
|
|
104
|
-
const response = await handler.handleNoMatch(request);
|
|
105
|
-
|
|
106
|
-
expect(response.status).toBe(500);
|
|
107
|
-
expect(HmrManager.broadcast).toHaveBeenCalledWith({ type: 'error', message: 'Test Error' });
|
|
108
|
-
});
|
|
109
|
-
});
|
|
110
|
-
});
|