@ecopages/core 0.2.0-alpha.27 → 0.2.0-alpha.28
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 +91 -0
- package/package.json +162 -72
- package/src/adapters/abstract/application-adapter.d.ts +194 -0
- package/src/adapters/abstract/application-adapter.js +121 -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 +53 -0
- package/src/adapters/bun/create-app.js +153 -0
- package/src/adapters/bun/hmr-manager.d.ts +131 -0
- package/src/adapters/bun/hmr-manager.js +312 -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 +393 -0
- package/src/adapters/bun/server-lifecycle.d.ts +63 -0
- package/src/adapters/bun/server-lifecycle.js +92 -0
- package/src/adapters/create-app.d.ts +20 -0
- package/src/adapters/create-app.js +66 -0
- package/src/adapters/index.d.ts +2 -0
- package/src/adapters/index.js +8 -0
- package/src/adapters/node/create-app.d.ts +18 -0
- package/src/adapters/node/create-app.js +149 -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 +121 -0
- package/src/adapters/node/node-hmr-manager.js +290 -0
- package/src/adapters/node/server-adapter.d.ts +162 -0
- package/src/adapters/node/server-adapter.js +368 -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/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-render-preparation.d.ts +25 -0
- package/src/adapters/shared/explicit-static-render-preparation.js +26 -0
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +41 -0
- package/src/adapters/shared/explicit-static-route-matcher.js +101 -0
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +62 -0
- package/src/adapters/shared/file-route-middleware-pipeline.js +90 -0
- package/src/adapters/shared/fs-server-response-factory.d.ts +23 -0
- package/src/adapters/shared/fs-server-response-factory.js +81 -0
- package/src/adapters/shared/fs-server-response-matcher.d.ts +75 -0
- package/src/adapters/shared/fs-server-response-matcher.js +186 -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 +15 -0
- package/src/adapters/shared/render-context.js +72 -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 +108 -0
- package/src/adapters/shared/server-adapter.js +429 -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 +71 -0
- package/src/adapters/shared/server-static-builder.js +100 -0
- package/src/build/build-adapter.d.ts +239 -0
- package/src/build/build-adapter.js +642 -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 +72 -0
- package/src/build/dev-build-coordinator.js +154 -0
- package/src/build/esbuild-build-adapter.d.ts +78 -0
- package/src/build/esbuild-build-adapter.js +505 -0
- package/src/build/runtime-build-executor.d.ts +14 -0
- package/src/build/runtime-build-executor.js +22 -0
- package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
- package/src/build/runtime-specifier-alias-plugin.js +35 -0
- package/src/build/runtime-specifier-aliases.d.ts +5 -0
- package/src/build/runtime-specifier-aliases.js +95 -0
- package/src/config/config-builder.d.ts +252 -0
- package/src/config/config-builder.js +598 -0
- package/src/config/{constants.ts → constants.d.ts} +13 -22
- package/src/config/constants.js +25 -0
- package/src/dev/host-runtime.d.ts +10 -0
- package/src/dev/host-runtime.js +24 -0
- package/src/dev/sc-server.d.ts +30 -0
- package/src/dev/sc-server.js +111 -0
- package/src/eco/eco.browser.d.ts +2 -0
- package/src/eco/eco.browser.js +83 -0
- package/src/eco/eco.d.ts +9 -0
- package/src/eco/eco.js +85 -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 +1 -0
- package/src/eco/eco.utils.js +10 -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 +3 -0
- package/src/errors/index.js +6 -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 +117 -0
- package/src/hmr/hmr-strategy.d.ts +162 -0
- package/src/hmr/hmr-strategy.js +44 -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 +134 -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 +6 -0
- package/src/index.js +21 -0
- package/src/integrations/ghtml/ghtml-renderer.d.ts +16 -0
- package/src/integrations/ghtml/ghtml-renderer.js +57 -0
- package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
- package/src/integrations/ghtml/ghtml.constants.js +4 -0
- package/src/integrations/ghtml/ghtml.plugin.d.ts +16 -0
- package/src/integrations/ghtml/ghtml.plugin.js +20 -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 +108 -0
- package/src/plugins/eco-component-meta-plugin.js +162 -0
- package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
- package/src/plugins/foreign-jsx-override-plugin.js +35 -0
- package/src/plugins/integration-plugin.d.ts +215 -0
- package/src/plugins/integration-plugin.js +189 -0
- package/src/plugins/processor.d.ts +97 -0
- package/src/plugins/processor.js +141 -0
- package/src/plugins/{runtime-capability.ts → runtime-capability.d.ts} +3 -8
- package/src/plugins/runtime-capability.js +0 -0
- package/src/plugins/source-transform.d.ts +46 -0
- package/src/plugins/source-transform.js +71 -0
- package/src/route-renderer/orchestration/component-render-context.d.ts +89 -0
- package/src/route-renderer/orchestration/component-render-context.js +147 -0
- package/src/route-renderer/orchestration/declared-ownership-graph.d.ts +18 -0
- package/src/route-renderer/orchestration/declared-ownership-graph.js +34 -0
- package/src/route-renderer/orchestration/foreign-subtree-execution.service.d.ts +108 -0
- package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +206 -0
- package/src/route-renderer/orchestration/integration-renderer.d.ts +516 -0
- package/src/route-renderer/orchestration/integration-renderer.js +909 -0
- package/src/route-renderer/orchestration/ownership-planning.service.d.ts +24 -0
- package/src/route-renderer/orchestration/ownership-planning.service.js +63 -0
- package/src/route-renderer/orchestration/ownership-validation.service.d.ts +29 -0
- package/src/route-renderer/orchestration/ownership-validation.service.js +53 -0
- package/src/route-renderer/orchestration/processed-asset-dedupe.d.ts +2 -0
- package/src/route-renderer/orchestration/processed-asset-dedupe.js +23 -0
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +90 -0
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +158 -0
- package/src/route-renderer/orchestration/render-output.utils.d.ts +66 -0
- package/src/route-renderer/orchestration/render-output.utils.js +171 -0
- package/src/route-renderer/orchestration/route-render-orchestrator.d.ts +120 -0
- package/src/route-renderer/orchestration/route-render-orchestrator.js +388 -0
- package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
- package/src/route-renderer/orchestration/template-serialization.js +45 -0
- package/src/route-renderer/page-loading/component-dependency-collection.d.ts +37 -0
- package/src/route-renderer/page-loading/component-dependency-collection.js +132 -0
- package/src/route-renderer/page-loading/declared-asset-collection.d.ts +24 -0
- package/src/route-renderer/page-loading/declared-asset-collection.js +106 -0
- package/src/route-renderer/page-loading/dependency-resolver.d.ts +35 -0
- package/src/route-renderer/page-loading/dependency-resolver.js +115 -0
- package/src/route-renderer/page-loading/ecopages-virtual-imports.d.ts +11 -0
- package/src/route-renderer/page-loading/ecopages-virtual-imports.js +57 -0
- package/src/route-renderer/page-loading/lazy-entry-collection.d.ts +45 -0
- package/src/route-renderer/page-loading/lazy-entry-collection.js +105 -0
- package/src/route-renderer/page-loading/lazy-trigger-planning.d.ts +19 -0
- package/src/route-renderer/page-loading/lazy-trigger-planning.js +40 -0
- package/src/route-renderer/page-loading/module-declaration-aggregation.d.ts +5 -0
- package/src/route-renderer/page-loading/module-declaration-aggregation.js +33 -0
- package/src/route-renderer/page-loading/module-declaration-scripts.d.ts +3 -0
- package/src/route-renderer/page-loading/module-declaration-scripts.js +18 -0
- package/src/route-renderer/page-loading/page-dependency-bundling.d.ts +13 -0
- package/src/route-renderer/page-loading/page-dependency-bundling.js +137 -0
- package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
- package/src/route-renderer/page-loading/page-module-loader.js +127 -0
- package/src/route-renderer/route-renderer.d.ts +69 -0
- package/src/route-renderer/route-renderer.js +80 -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 +169 -0
- package/src/router/client/navigation-coordinator.js +215 -0
- package/src/router/server/route-registry.d.ts +78 -0
- package/src/router/server/route-registry.js +262 -0
- package/src/services/assets/asset-processing-service/asset-dependency-keys.d.ts +3 -0
- package/src/services/assets/asset-processing-service/asset-dependency-keys.js +56 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +103 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.js +285 -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 +103 -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 +49 -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/grouped-content-bundles.d.ts +30 -0
- package/src/services/assets/asset-processing-service/grouped-content-bundles.js +65 -0
- package/src/services/assets/asset-processing-service/index.d.ts +6 -0
- package/src/services/assets/asset-processing-service/index.js +6 -0
- package/src/services/assets/asset-processing-service/page-package.d.ts +3 -0
- package/src/services/assets/asset-processing-service/page-package.js +74 -0
- package/src/services/assets/asset-processing-service/{processor.interface.ts → processor.interface.d.ts} +5 -10
- 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 +65 -0
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +22 -0
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +136 -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 +6 -0
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +119 -0
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.d.ts +9 -0
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.js +97 -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 +79 -0
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +8 -0
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +59 -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 +69 -0
- package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.d.ts +18 -0
- package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.js +45 -0
- package/src/services/assets/browser-bundle.service.d.ts +73 -0
- package/src/services/assets/browser-bundle.service.js +41 -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 +68 -0
- package/src/services/html/html-transformer.service.d.ts +87 -0
- package/src/services/html/html-transformer.service.js +216 -0
- package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
- package/src/services/invalidation/development-invalidation.service.js +190 -0
- package/src/services/module-loading/app-module-loader.service.d.ts +7 -0
- package/src/services/module-loading/app-module-loader.service.js +0 -0
- package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
- package/src/services/module-loading/app-server-module-transpiler.service.js +115 -0
- package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
- package/src/services/module-loading/host-module-loader-registry.js +15 -0
- package/src/services/module-loading/{module-loading-types.ts → module-loading-types.d.ts} +0 -1
- package/src/services/module-loading/module-loading-types.js +0 -0
- package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
- package/src/services/module-loading/node-bootstrap-plugin.js +216 -0
- package/src/services/module-loading/page-module-import.service.d.ts +76 -0
- package/src/services/module-loading/page-module-import.service.js +170 -0
- package/src/services/module-loading/server-module-transpiler.service.d.ts +63 -0
- package/src/services/module-loading/server-module-transpiler.service.js +64 -0
- package/src/services/module-loading/source-module-support.d.ts +5 -0
- package/src/services/module-loading/source-module-support.js +8 -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/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.ts → standard-schema.types.d.ts} +17 -20
- package/src/services/validation/standard-schema.types.js +0 -0
- package/src/static-site-generator/static-site-generator.d.ts +104 -0
- package/src/static-site-generator/static-site-generator.js +316 -0
- package/src/types/internal-types.d.ts +232 -0
- package/src/types/internal-types.js +0 -0
- package/src/types/public-types.d.ts +1267 -0
- package/src/types/public-types.js +0 -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-escaping.d.ts +7 -0
- package/src/utils/html-escaping.js +6 -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 +27 -0
- package/src/utils/parse-cli-args.js +62 -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 +275 -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/abstract/application-adapter.test.ts +0 -172
- package/src/adapters/abstract/application-adapter.ts +0 -379
- package/src/adapters/abstract/router-adapter.ts +0 -30
- package/src/adapters/abstract/server-adapter.ts +0 -79
- package/src/adapters/bun/client-bridge.ts +0 -62
- package/src/adapters/bun/create-app.ts +0 -232
- package/src/adapters/bun/hmr-manager.test.ts +0 -265
- package/src/adapters/bun/hmr-manager.ts +0 -383
- package/src/adapters/bun/index.ts +0 -2
- package/src/adapters/bun/server-adapter.ts +0 -526
- package/src/adapters/bun/server-lifecycle.ts +0 -124
- package/src/adapters/create-app.test.ts +0 -10
- package/src/adapters/create-app.ts +0 -91
- package/src/adapters/index.ts +0 -2
- package/src/adapters/node/create-app.test.ts +0 -53
- package/src/adapters/node/create-app.ts +0 -183
- package/src/adapters/node/node-client-bridge.test.ts +0 -198
- package/src/adapters/node/node-client-bridge.ts +0 -79
- package/src/adapters/node/node-hmr-manager.test.ts +0 -320
- package/src/adapters/node/node-hmr-manager.ts +0 -355
- package/src/adapters/node/server-adapter.ts +0 -502
- package/src/adapters/node/static-content-server.test.ts +0 -60
- package/src/adapters/node/static-content-server.ts +0 -239
- package/src/adapters/shared/api-response.test.ts +0 -97
- package/src/adapters/shared/api-response.ts +0 -104
- package/src/adapters/shared/application-adapter.ts +0 -199
- package/src/adapters/shared/define-api-handler.ts +0 -66
- package/src/adapters/shared/explicit-static-render-preparation.ts +0 -58
- package/src/adapters/shared/explicit-static-route-matcher.test.ts +0 -381
- package/src/adapters/shared/explicit-static-route-matcher.ts +0 -131
- package/src/adapters/shared/file-route-middleware-pipeline.test.ts +0 -85
- package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -118
- package/src/adapters/shared/fs-server-response-factory.test.ts +0 -176
- package/src/adapters/shared/fs-server-response-factory.ts +0 -96
- package/src/adapters/shared/fs-server-response-matcher.test.ts +0 -311
- package/src/adapters/shared/fs-server-response-matcher.ts +0 -240
- package/src/adapters/shared/hmr-entrypoint-registrar.ts +0 -149
- package/src/adapters/shared/hmr-html-response.ts +0 -52
- package/src/adapters/shared/hmr-manager.contract.test.ts +0 -228
- package/src/adapters/shared/hmr-manager.dispatch.test.ts +0 -220
- package/src/adapters/shared/render-context.test.ts +0 -150
- package/src/adapters/shared/render-context.ts +0 -123
- package/src/adapters/shared/runtime-bootstrap.ts +0 -79
- package/src/adapters/shared/server-adapter.test.ts +0 -130
- package/src/adapters/shared/server-adapter.ts +0 -562
- package/src/adapters/shared/server-route-handler.test.ts +0 -111
- package/src/adapters/shared/server-route-handler.ts +0 -153
- package/src/adapters/shared/server-static-builder.test.ts +0 -338
- package/src/adapters/shared/server-static-builder.ts +0 -170
- package/src/build/build-adapter-serialization.test.ts +0 -281
- package/src/build/build-adapter.test.ts +0 -1240
- package/src/build/build-adapter.ts +0 -1012
- package/src/build/build-manifest.ts +0 -54
- package/src/build/build-types.ts +0 -83
- package/src/build/dev-build-coordinator.ts +0 -220
- package/src/build/esbuild-build-adapter.ts +0 -660
- package/src/build/runtime-build-executor.test.ts +0 -81
- package/src/build/runtime-build-executor.ts +0 -40
- package/src/build/runtime-specifier-alias-plugin.test.ts +0 -67
- package/src/build/runtime-specifier-alias-plugin.ts +0 -62
- package/src/build/runtime-specifier-aliases.ts +0 -135
- package/src/config/config-builder.test.ts +0 -442
- package/src/config/config-builder.ts +0 -737
- package/src/config/config-builder.typecheck.test.ts +0 -96
- package/src/dev/host-runtime.ts +0 -34
- package/src/dev/sc-server.ts +0 -143
- package/src/eco/eco.browser.test.ts +0 -43
- package/src/eco/eco.browser.ts +0 -118
- package/src/eco/eco.test.ts +0 -654
- package/src/eco/eco.ts +0 -205
- package/src/eco/eco.types.ts +0 -221
- package/src/eco/eco.utils.test.ts +0 -219
- package/src/eco/eco.utils.ts +0 -5
- package/src/eco/global-injector-map.test.ts +0 -42
- package/src/eco/global-injector-map.ts +0 -112
- package/src/eco/lazy-injector-map.test.ts +0 -66
- package/src/eco/lazy-injector-map.ts +0 -120
- package/src/eco/module-dependencies.test.ts +0 -30
- package/src/eco/module-dependencies.ts +0 -75
- package/src/errors/http-error.test.ts +0 -134
- package/src/errors/http-error.ts +0 -72
- package/src/errors/index.ts +0 -3
- package/src/errors/locals-access-error.ts +0 -7
- package/src/global/app-logger.ts +0 -4
- 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/client/hmr-runtime.ts +0 -162
- package/src/hmr/hmr-strategy.test.ts +0 -124
- package/src/hmr/hmr-strategy.ts +0 -177
- package/src/hmr/hmr.postcss.test.e2e.ts +0 -41
- package/src/hmr/hmr.test.e2e.ts +0 -66
- package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
- package/src/hmr/strategies/js-hmr-strategy.test.ts +0 -334
- package/src/hmr/strategies/js-hmr-strategy.ts +0 -314
- package/src/index.browser.ts +0 -3
- package/src/index.ts +0 -15
- package/src/integrations/ghtml/ghtml-renderer.test.ts +0 -253
- package/src/integrations/ghtml/ghtml-renderer.ts +0 -87
- package/src/integrations/ghtml/ghtml.constants.ts +0 -1
- package/src/integrations/ghtml/ghtml.plugin.ts +0 -28
- package/src/plugins/alias-resolver-plugin.test.ts +0 -41
- package/src/plugins/alias-resolver-plugin.ts +0 -63
- package/src/plugins/eco-component-meta-plugin.test.ts +0 -406
- package/src/plugins/eco-component-meta-plugin.ts +0 -494
- package/src/plugins/foreign-jsx-override-plugin.test.ts +0 -65
- package/src/plugins/foreign-jsx-override-plugin.ts +0 -67
- package/src/plugins/integration-plugin.test.ts +0 -151
- package/src/plugins/integration-plugin.ts +0 -323
- package/src/plugins/processor.test.ts +0 -148
- package/src/plugins/processor.ts +0 -257
- package/src/plugins/source-transform.test.ts +0 -82
- package/src/plugins/source-transform.ts +0 -123
- package/src/route-renderer/orchestration/component-render-context.ts +0 -325
- package/src/route-renderer/orchestration/declared-ownership-graph.ts +0 -62
- package/src/route-renderer/orchestration/foreign-subtree-execution.service.ts +0 -383
- package/src/route-renderer/orchestration/integration-renderer.test.ts +0 -2085
- package/src/route-renderer/orchestration/integration-renderer.ts +0 -1244
- package/src/route-renderer/orchestration/ownership-planning.service.ts +0 -97
- package/src/route-renderer/orchestration/ownership-validation.service.ts +0 -76
- package/src/route-renderer/orchestration/processed-asset-dedupe.ts +0 -25
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.test.ts +0 -324
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.ts +0 -294
- package/src/route-renderer/orchestration/render-output.utils.ts +0 -310
- package/src/route-renderer/orchestration/route-render-orchestrator.prepare-render-options.test.ts +0 -644
- package/src/route-renderer/orchestration/route-render-orchestrator.test.ts +0 -265
- package/src/route-renderer/orchestration/route-render-orchestrator.ts +0 -592
- package/src/route-renderer/orchestration/template-serialization.test.ts +0 -110
- package/src/route-renderer/orchestration/template-serialization.ts +0 -117
- package/src/route-renderer/page-loading/component-dependency-collection.ts +0 -202
- package/src/route-renderer/page-loading/declared-asset-collection.ts +0 -153
- package/src/route-renderer/page-loading/dependency-resolver.test.ts +0 -761
- package/src/route-renderer/page-loading/dependency-resolver.ts +0 -144
- package/src/route-renderer/page-loading/ecopages-virtual-imports.ts +0 -75
- package/src/route-renderer/page-loading/lazy-entry-collection.ts +0 -167
- package/src/route-renderer/page-loading/lazy-trigger-planning.ts +0 -74
- package/src/route-renderer/page-loading/module-declaration-aggregation.ts +0 -60
- package/src/route-renderer/page-loading/module-declaration-scripts.ts +0 -16
- package/src/route-renderer/page-loading/page-dependency-bundling.ts +0 -244
- package/src/route-renderer/page-loading/page-module-loader.test.ts +0 -183
- package/src/route-renderer/page-loading/page-module-loader.ts +0 -184
- package/src/route-renderer/route-renderer.ts +0 -133
- package/src/router/client/link-intent.test.browser.ts +0 -51
- package/src/router/client/link-intent.ts +0 -92
- package/src/router/client/navigation-coordinator.test.ts +0 -237
- package/src/router/client/navigation-coordinator.ts +0 -453
- package/src/router/server/route-registry.test.ts +0 -176
- package/src/router/server/route-registry.ts +0 -382
- package/src/services/assets/asset-processing-service/asset-dependency-keys.ts +0 -66
- package/src/services/assets/asset-processing-service/asset-processing.service.test.ts +0 -473
- package/src/services/assets/asset-processing-service/asset-processing.service.ts +0 -344
- package/src/services/assets/asset-processing-service/asset.factory.test.ts +0 -63
- package/src/services/assets/asset-processing-service/asset.factory.ts +0 -105
- package/src/services/assets/asset-processing-service/assets.types.ts +0 -128
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.test.ts +0 -74
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.ts +0 -96
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.test.ts +0 -67
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.ts +0 -78
- package/src/services/assets/asset-processing-service/grouped-content-bundles.ts +0 -104
- package/src/services/assets/asset-processing-service/index.ts +0 -6
- package/src/services/assets/asset-processing-service/page-package.test.ts +0 -100
- package/src/services/assets/asset-processing-service/page-package.ts +0 -93
- package/src/services/assets/asset-processing-service/processor.registry.ts +0 -18
- package/src/services/assets/asset-processing-service/processors/base/base-processor.test.ts +0 -59
- package/src/services/assets/asset-processing-service/processors/base/base-processor.ts +0 -83
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.ts +0 -173
- package/src/services/assets/asset-processing-service/processors/index.ts +0 -5
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.test.ts +0 -195
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.ts +0 -137
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.test.ts +0 -326
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.ts +0 -116
- 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/script/node-module-script.processor.ts +0 -89
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.test.ts +0 -261
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -72
- package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -83
- package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.ts +0 -65
- package/src/services/assets/browser-bundle.service.test.ts +0 -66
- package/src/services/assets/browser-bundle.service.ts +0 -109
- package/src/services/cache/cache.types.ts +0 -126
- package/src/services/cache/index.ts +0 -18
- package/src/services/cache/memory-cache-store.test.ts +0 -225
- package/src/services/cache/memory-cache-store.ts +0 -130
- package/src/services/cache/page-cache-service.test.ts +0 -175
- package/src/services/cache/page-cache-service.ts +0 -202
- package/src/services/cache/page-request-cache-coordinator.service.test.ts +0 -79
- package/src/services/cache/page-request-cache-coordinator.service.ts +0 -131
- package/src/services/html/html-rewriter-provider.service.test.ts +0 -183
- package/src/services/html/html-rewriter-provider.service.ts +0 -104
- package/src/services/html/html-transformer.service.test.ts +0 -476
- package/src/services/html/html-transformer.service.ts +0 -275
- package/src/services/invalidation/development-invalidation.service.test.ts +0 -87
- package/src/services/invalidation/development-invalidation.service.ts +0 -262
- package/src/services/module-loading/app-module-loader.service.ts +0 -9
- package/src/services/module-loading/app-server-module-transpiler.service.test.ts +0 -130
- package/src/services/module-loading/app-server-module-transpiler.service.ts +0 -141
- package/src/services/module-loading/host-module-loader-registry.ts +0 -15
- package/src/services/module-loading/node-bootstrap-plugin.test.ts +0 -335
- package/src/services/module-loading/node-bootstrap-plugin.ts +0 -311
- package/src/services/module-loading/page-module-import.service.test.ts +0 -504
- package/src/services/module-loading/page-module-import.service.ts +0 -251
- package/src/services/module-loading/server-module-transpiler.service.test.ts +0 -243
- package/src/services/module-loading/server-module-transpiler.service.ts +0 -104
- package/src/services/module-loading/source-module-support.ts +0 -19
- package/src/services/runtime-state/dev-graph.service.ts +0 -217
- package/src/services/runtime-state/entrypoint-dependency-graph.service.ts +0 -136
- package/src/services/runtime-state/server-invalidation-state.service.ts +0 -68
- package/src/services/validation/schema-validation-service.test.ts +0 -223
- package/src/services/validation/schema-validation-service.ts +0 -204
- package/src/static-site-generator/static-site-generator.test.ts +0 -408
- package/src/static-site-generator/static-site-generator.ts +0 -445
- package/src/types/internal-types.ts +0 -243
- package/src/types/public-types.ts +0 -1459
- package/src/utils/deep-merge.test.ts +0 -114
- package/src/utils/deep-merge.ts +0 -47
- package/src/utils/hash.ts +0 -5
- package/src/utils/html-escaping.ts +0 -9
- package/src/utils/invariant.test.ts +0 -22
- package/src/utils/invariant.ts +0 -15
- package/src/utils/locals-utils.ts +0 -37
- package/src/utils/parse-cli-args.test.ts +0 -69
- package/src/utils/parse-cli-args.ts +0 -105
- package/src/utils/path-utils.module.ts +0 -14
- package/src/utils/path-utils.test.ts +0 -15
- package/src/utils/resolve-work-dir.ts +0 -45
- package/src/utils/runtime.ts +0 -44
- package/src/utils/server-utils.module.ts +0 -67
- 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-helpers.ts +0 -42
- package/src/watchers/project-watcher.test.ts +0 -768
- package/src/watchers/project-watcher.ts +0 -357
- /package/src/utils/{html.ts → html.d.ts} +0 -0
|
@@ -1,320 +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, vi } from 'vitest';
|
|
6
|
-
import { ConfigBuilder } from '../../config/config-builder.ts';
|
|
7
|
-
import { resolveInternalExecutionDir, resolveInternalWorkDir } from '../../utils/resolve-work-dir.ts';
|
|
8
|
-
import { NodeHmrManager } from './node-hmr-manager.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
|
-
vi.restoreAllMocks();
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
test('NodeHmrManager shares one in-flight entrypoint registration across concurrent callers', async () => {
|
|
26
|
-
const rootDir = createTempRoot('ecopages-node-hmr-register');
|
|
27
|
-
const srcDir = path.join(rootDir, 'src');
|
|
28
|
-
const pagesDir = path.join(srcDir, 'pages');
|
|
29
|
-
fs.mkdirSync(pagesDir, { recursive: true });
|
|
30
|
-
|
|
31
|
-
const entrypointPath = path.join(pagesDir, 'react-lab.tsx');
|
|
32
|
-
fs.writeFileSync(entrypointPath, 'export default function Page() { return null; }', 'utf8');
|
|
33
|
-
|
|
34
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
35
|
-
const manager = new NodeHmrManager({
|
|
36
|
-
appConfig: config,
|
|
37
|
-
bridge: {
|
|
38
|
-
subscriberCount: 0,
|
|
39
|
-
broadcast: () => {},
|
|
40
|
-
} as any,
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
const relativePathJs = path
|
|
44
|
-
.relative(config.absolutePaths.srcDir, entrypointPath)
|
|
45
|
-
.replace(/\.(tsx?|jsx?|mdx?)$/, '.js');
|
|
46
|
-
const encodedPathJs = relativePathJs.replace(/\[([^\]]+)\]/g, '_$1_');
|
|
47
|
-
const outputPath = path.join(resolveInternalWorkDir(config), 'assets', '_hmr', encodedPathJs);
|
|
48
|
-
|
|
49
|
-
const handleFileChange = vi.spyOn(manager, 'handleFileChange').mockImplementation(async () => {
|
|
50
|
-
await new Promise((resolve) => setTimeout(resolve, 25));
|
|
51
|
-
fs.mkdirSync(path.dirname(outputPath), { recursive: true });
|
|
52
|
-
fs.writeFileSync(outputPath, 'export default 1;', 'utf8');
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
const [firstUrl, secondUrl] = await Promise.all([
|
|
56
|
-
manager.registerEntrypoint(entrypointPath),
|
|
57
|
-
manager.registerEntrypoint(entrypointPath),
|
|
58
|
-
]);
|
|
59
|
-
|
|
60
|
-
assert.equal(firstUrl, '/assets/_hmr/pages/react-lab.js');
|
|
61
|
-
assert.equal(secondUrl, '/assets/_hmr/pages/react-lab.js');
|
|
62
|
-
assert.equal(handleFileChange.mock.calls.length, 1);
|
|
63
|
-
assert.equal(fs.existsSync(outputPath), true);
|
|
64
|
-
|
|
65
|
-
manager.stop();
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
test('NodeHmrManager does not broadcast HMR events for initial entrypoint registration builds', async () => {
|
|
69
|
-
const rootDir = createTempRoot('ecopages-node-hmr-silent-register');
|
|
70
|
-
const srcDir = path.join(rootDir, 'src');
|
|
71
|
-
const pagesDir = path.join(srcDir, 'pages');
|
|
72
|
-
fs.mkdirSync(pagesDir, { recursive: true });
|
|
73
|
-
|
|
74
|
-
const entrypointPath = path.join(pagesDir, 'react-content.tsx');
|
|
75
|
-
fs.writeFileSync(entrypointPath, 'export default function Page() { return null; }', 'utf8');
|
|
76
|
-
|
|
77
|
-
const broadcast = vi.fn();
|
|
78
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
79
|
-
const manager = new NodeHmrManager({
|
|
80
|
-
appConfig: config,
|
|
81
|
-
bridge: {
|
|
82
|
-
subscriberCount: 1,
|
|
83
|
-
broadcast,
|
|
84
|
-
} as any,
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
const relativePathJs = path
|
|
88
|
-
.relative(config.absolutePaths.srcDir, entrypointPath)
|
|
89
|
-
.replace(/\.(tsx?|jsx?|mdx?)$/, '.js');
|
|
90
|
-
const encodedPathJs = relativePathJs.replace(/\[([^\]]+)\]/g, '_$1_');
|
|
91
|
-
const outputPath = path.join(resolveInternalWorkDir(config), 'assets', '_hmr', encodedPathJs);
|
|
92
|
-
|
|
93
|
-
vi.spyOn(manager, 'handleFileChange').mockImplementation(async (_filePath, _options) => {
|
|
94
|
-
fs.mkdirSync(path.dirname(outputPath), { recursive: true });
|
|
95
|
-
fs.writeFileSync(outputPath, 'export default 1;', 'utf8');
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
const outputUrl = await manager.registerEntrypoint(entrypointPath);
|
|
99
|
-
|
|
100
|
-
assert.equal(outputUrl, '/assets/_hmr/pages/react-content.js');
|
|
101
|
-
assert.equal(broadcast.mock.calls.length, 0);
|
|
102
|
-
|
|
103
|
-
manager.stop();
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
test('NodeHmrManager clears timed-out entrypoint registrations so later requests can retry', async () => {
|
|
107
|
-
const rootDir = createTempRoot('ecopages-node-hmr-timeout-register');
|
|
108
|
-
const srcDir = path.join(rootDir, 'src');
|
|
109
|
-
const pagesDir = path.join(srcDir, 'pages');
|
|
110
|
-
fs.mkdirSync(pagesDir, { recursive: true });
|
|
111
|
-
|
|
112
|
-
const entrypointPath = path.join(pagesDir, 'stuck-page.tsx');
|
|
113
|
-
fs.writeFileSync(entrypointPath, 'export default function Page() { return null; }', 'utf8');
|
|
114
|
-
|
|
115
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
116
|
-
const manager = new NodeHmrManager({
|
|
117
|
-
appConfig: config,
|
|
118
|
-
bridge: {
|
|
119
|
-
subscriberCount: 0,
|
|
120
|
-
broadcast: () => {},
|
|
121
|
-
} as any,
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
const previousNodeEnv = process.env.NODE_ENV;
|
|
125
|
-
process.env.NODE_ENV = 'development';
|
|
126
|
-
|
|
127
|
-
const handleFileChange = vi.spyOn(manager, 'handleFileChange').mockImplementation(async () => {
|
|
128
|
-
await new Promise(() => undefined);
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
try {
|
|
132
|
-
await assert.rejects(() => manager.registerEntrypoint(entrypointPath), /Timed out registering entrypoint/);
|
|
133
|
-
|
|
134
|
-
const registrations = (manager as unknown as { entrypointRegistrations: Map<string, Promise<string>> })
|
|
135
|
-
.entrypointRegistrations;
|
|
136
|
-
const watchedFiles = manager.getWatchedFiles();
|
|
137
|
-
assert.equal(registrations.size, 0);
|
|
138
|
-
assert.equal(watchedFiles.has(entrypointPath), false);
|
|
139
|
-
|
|
140
|
-
handleFileChange.mockImplementationOnce(async () => {
|
|
141
|
-
const relativePathJs = path
|
|
142
|
-
.relative(config.absolutePaths.srcDir, entrypointPath)
|
|
143
|
-
.replace(/\.(tsx?|jsx?|mdx?)$/, '.js');
|
|
144
|
-
const encodedPathJs = relativePathJs.replace(/\[([^\]]+)\]/g, '_$1_');
|
|
145
|
-
const outputPath = path.join(resolveInternalWorkDir(config), 'assets', '_hmr', encodedPathJs);
|
|
146
|
-
fs.mkdirSync(path.dirname(outputPath), { recursive: true });
|
|
147
|
-
fs.writeFileSync(outputPath, 'export default 2;', 'utf8');
|
|
148
|
-
});
|
|
149
|
-
|
|
150
|
-
const retriedUrl = await manager.registerEntrypoint(entrypointPath);
|
|
151
|
-
assert.equal(retriedUrl, '/assets/_hmr/pages/stuck-page.js');
|
|
152
|
-
assert.equal(watchedFiles.get(entrypointPath), retriedUrl);
|
|
153
|
-
} finally {
|
|
154
|
-
process.env.NODE_ENV = previousNodeEnv;
|
|
155
|
-
manager.stop();
|
|
156
|
-
}
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
test('NodeHmrManager fails strict entrypoint registration when the owning integration emits no output', async () => {
|
|
160
|
-
const rootDir = createTempRoot('ecopages-node-hmr-strict-fail');
|
|
161
|
-
const srcDir = path.join(rootDir, 'src');
|
|
162
|
-
const pagesDir = path.join(srcDir, 'pages');
|
|
163
|
-
fs.mkdirSync(pagesDir, { recursive: true });
|
|
164
|
-
|
|
165
|
-
const entrypointPath = path.join(pagesDir, 'react-content.mdx');
|
|
166
|
-
fs.writeFileSync(entrypointPath, '# Hello', 'utf8');
|
|
167
|
-
|
|
168
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
169
|
-
const manager = new NodeHmrManager({
|
|
170
|
-
appConfig: config,
|
|
171
|
-
bridge: {
|
|
172
|
-
subscriberCount: 0,
|
|
173
|
-
broadcast: () => {},
|
|
174
|
-
} as any,
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
vi.spyOn(manager, 'handleFileChange').mockImplementation(async () => {});
|
|
178
|
-
|
|
179
|
-
await assert.rejects(() => manager.registerEntrypoint(entrypointPath), /Integration failed to emit entrypoint/);
|
|
180
|
-
assert.equal(manager.getWatchedFiles().has(path.resolve(entrypointPath)), false);
|
|
181
|
-
|
|
182
|
-
manager.stop();
|
|
183
|
-
});
|
|
184
|
-
|
|
185
|
-
test('NodeHmrManager uses the generic build path for script entrypoints when no strategy emits output', async () => {
|
|
186
|
-
const rootDir = createTempRoot('ecopages-node-hmr-script-fallback');
|
|
187
|
-
const srcDir = path.join(rootDir, 'src');
|
|
188
|
-
fs.mkdirSync(srcDir, { recursive: true });
|
|
189
|
-
|
|
190
|
-
const entrypointPath = path.join(srcDir, 'script.ts');
|
|
191
|
-
fs.writeFileSync(entrypointPath, 'console.log("hello");', 'utf8');
|
|
192
|
-
|
|
193
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
194
|
-
const manager = new NodeHmrManager({
|
|
195
|
-
appConfig: config,
|
|
196
|
-
bridge: {
|
|
197
|
-
subscriberCount: 0,
|
|
198
|
-
broadcast: () => {},
|
|
199
|
-
} as any,
|
|
200
|
-
});
|
|
201
|
-
|
|
202
|
-
const relativePathJs = path
|
|
203
|
-
.relative(config.absolutePaths.srcDir, entrypointPath)
|
|
204
|
-
.replace(/\.(tsx?|jsx?|mdx?)$/, '.js');
|
|
205
|
-
const outputPath = path.join(resolveInternalWorkDir(config), 'assets', '_hmr', relativePathJs);
|
|
206
|
-
|
|
207
|
-
const buildCalls: string[] = [];
|
|
208
|
-
config.runtime!.buildExecutor = {
|
|
209
|
-
build: vi.fn(async (options) => {
|
|
210
|
-
buildCalls.push(options.entrypoints[0] as string);
|
|
211
|
-
fs.mkdirSync(path.dirname(outputPath), { recursive: true });
|
|
212
|
-
fs.writeFileSync(outputPath, 'fresh-output', 'utf8');
|
|
213
|
-
|
|
214
|
-
return {
|
|
215
|
-
success: true,
|
|
216
|
-
logs: [],
|
|
217
|
-
outputs: [{ path: outputPath }],
|
|
218
|
-
};
|
|
219
|
-
}),
|
|
220
|
-
};
|
|
221
|
-
|
|
222
|
-
vi.spyOn(manager, 'handleFileChange').mockImplementation(async () => {});
|
|
223
|
-
|
|
224
|
-
const outputUrl = await manager.registerScriptEntrypoint(entrypointPath);
|
|
225
|
-
|
|
226
|
-
assert.equal(outputUrl, '/assets/_hmr/script.js');
|
|
227
|
-
assert.deepEqual(buildCalls, [entrypointPath]);
|
|
228
|
-
assert.equal(fs.readFileSync(outputPath, 'utf8'), 'fresh-output');
|
|
229
|
-
|
|
230
|
-
manager.stop();
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
test('NodeHmrManager disables HMR instead of throwing when runtime bundle generation crashes', async () => {
|
|
234
|
-
const rootDir = createTempRoot('ecopages-node-hmr-runtime-failure');
|
|
235
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
236
|
-
const manager = new NodeHmrManager({
|
|
237
|
-
appConfig: config,
|
|
238
|
-
bridge: {
|
|
239
|
-
subscriberCount: 0,
|
|
240
|
-
broadcast: () => {},
|
|
241
|
-
} as any,
|
|
242
|
-
});
|
|
243
|
-
const errorSpy = vi.spyOn(console, 'error').mockImplementation(() => {});
|
|
244
|
-
|
|
245
|
-
vi.spyOn(
|
|
246
|
-
(manager as unknown as { browserBundleService: { bundle: () => Promise<unknown> } }).browserBundleService,
|
|
247
|
-
'bundle',
|
|
248
|
-
).mockRejectedValueOnce(new Error('Unexpected end of JSON input'));
|
|
249
|
-
|
|
250
|
-
await assert.doesNotReject(() => manager.buildRuntime());
|
|
251
|
-
assert.equal(manager.isEnabled(), false);
|
|
252
|
-
|
|
253
|
-
manager.stop();
|
|
254
|
-
errorSpy.mockRestore();
|
|
255
|
-
});
|
|
256
|
-
|
|
257
|
-
test('NodeHmrManager stop clears retained registration state', async () => {
|
|
258
|
-
const rootDir = createTempRoot('ecopages-node-hmr-stop-cleanup');
|
|
259
|
-
const srcDir = path.join(rootDir, 'src');
|
|
260
|
-
const pagesDir = path.join(srcDir, 'pages');
|
|
261
|
-
fs.mkdirSync(pagesDir, { recursive: true });
|
|
262
|
-
|
|
263
|
-
const entrypointPath = path.join(pagesDir, 'react-content.tsx');
|
|
264
|
-
fs.writeFileSync(entrypointPath, 'export default function Page() { return null; }', 'utf8');
|
|
265
|
-
|
|
266
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
267
|
-
const manager = new NodeHmrManager({
|
|
268
|
-
appConfig: config,
|
|
269
|
-
bridge: {
|
|
270
|
-
subscriberCount: 0,
|
|
271
|
-
broadcast: () => {},
|
|
272
|
-
} as any,
|
|
273
|
-
});
|
|
274
|
-
|
|
275
|
-
const relativePathJs = path
|
|
276
|
-
.relative(config.absolutePaths.srcDir, entrypointPath)
|
|
277
|
-
.replace(/\.(tsx?|jsx?|mdx?)$/, '.js');
|
|
278
|
-
const encodedPathJs = relativePathJs.replace(/\[([^\]]+)\]/g, '_$1_');
|
|
279
|
-
const outputPath = path.join(resolveInternalWorkDir(config), 'assets', '_hmr', encodedPathJs);
|
|
280
|
-
|
|
281
|
-
vi.spyOn(manager, 'handleFileChange').mockImplementation(async () => {
|
|
282
|
-
fs.mkdirSync(path.dirname(outputPath), { recursive: true });
|
|
283
|
-
fs.writeFileSync(outputPath, 'export default 1;', 'utf8');
|
|
284
|
-
});
|
|
285
|
-
|
|
286
|
-
await manager.registerEntrypoint(entrypointPath);
|
|
287
|
-
|
|
288
|
-
manager.stop();
|
|
289
|
-
|
|
290
|
-
assert.equal(manager.getWatchedFiles().size, 0);
|
|
291
|
-
assert.equal(config.runtime?.entrypointDependencyGraph?.getDependencyEntrypoints(entrypointPath).size, 0);
|
|
292
|
-
});
|
|
293
|
-
|
|
294
|
-
test('NodeHmrManager keeps internal browser and server-module outputs out of distDir', async () => {
|
|
295
|
-
const rootDir = createTempRoot('ecopages-node-hmr-internal-paths');
|
|
296
|
-
const config = await new ConfigBuilder().setRootDir(rootDir).build();
|
|
297
|
-
const manager = new NodeHmrManager({
|
|
298
|
-
appConfig: config,
|
|
299
|
-
bridge: {
|
|
300
|
-
subscriberCount: 0,
|
|
301
|
-
broadcast: () => {},
|
|
302
|
-
} as any,
|
|
303
|
-
});
|
|
304
|
-
|
|
305
|
-
assert.equal(manager.getDistDir(), path.join(resolveInternalWorkDir(config), 'assets', '_hmr'));
|
|
306
|
-
|
|
307
|
-
const importModule = vi.fn(async (_options: { outdir: string }) => ({}));
|
|
308
|
-
(manager as unknown as { serverModuleTranspiler: { importModule: typeof importModule } }).serverModuleTranspiler = {
|
|
309
|
-
importModule,
|
|
310
|
-
};
|
|
311
|
-
|
|
312
|
-
await manager.getDefaultContext().importServerModule(path.join(config.absolutePaths.srcDir, 'pages', 'index.tsx'));
|
|
313
|
-
|
|
314
|
-
assert.equal(
|
|
315
|
-
importModule.mock.calls[0]?.[0]?.outdir,
|
|
316
|
-
path.join(resolveInternalExecutionDir(config), '.server-modules'),
|
|
317
|
-
);
|
|
318
|
-
|
|
319
|
-
manager.stop();
|
|
320
|
-
});
|
|
@@ -1,355 +0,0 @@
|
|
|
1
|
-
import fs from 'node:fs';
|
|
2
|
-
import path from 'node:path';
|
|
3
|
-
import { RESOLVED_ASSETS_DIR } from '../../config/constants.ts';
|
|
4
|
-
import { getAppBuildExecutor } from '../../build/build-adapter.ts';
|
|
5
|
-
import type { DefaultHmrContext, EcoPagesAppConfig, IHmrManager, IClientBridge } from '../../types/internal-types.ts';
|
|
6
|
-
import type { EcoBuildPlugin } from '../../build/build-types.ts';
|
|
7
|
-
import { fileSystem } from '@ecopages/file-system';
|
|
8
|
-
import { HmrStrategyType, type HmrStrategy } from '../../hmr/hmr-strategy.ts';
|
|
9
|
-
import { DefaultHmrStrategy } from '../../hmr/strategies/default-hmr-strategy.ts';
|
|
10
|
-
import { JsHmrStrategy } from '../../hmr/strategies/js-hmr-strategy.ts';
|
|
11
|
-
import { appLogger } from '../../global/app-logger.ts';
|
|
12
|
-
import type { ClientBridgeEvent } from '../../types/public-types.ts';
|
|
13
|
-
import { HmrEntrypointRegistrar } from '../shared/hmr-entrypoint-registrar.ts';
|
|
14
|
-
import { BrowserBundleService } from '../../services/assets/browser-bundle.service.ts';
|
|
15
|
-
import { getAppServerModuleTranspiler } from '../../services/module-loading/app-server-module-transpiler.service.ts';
|
|
16
|
-
import {
|
|
17
|
-
getAppEntrypointDependencyGraph,
|
|
18
|
-
InMemoryEntrypointDependencyGraph,
|
|
19
|
-
setAppEntrypointDependencyGraph,
|
|
20
|
-
type EntrypointDependencyGraph,
|
|
21
|
-
} from '../../services/runtime-state/entrypoint-dependency-graph.service.ts';
|
|
22
|
-
import type { ServerModuleTranspiler } from '../../services/module-loading/server-module-transpiler.service.ts';
|
|
23
|
-
import { resolveInternalExecutionDir, resolveInternalWorkDir } from '../../utils/resolve-work-dir.ts';
|
|
24
|
-
|
|
25
|
-
export interface NodeHmrManagerParams {
|
|
26
|
-
appConfig: EcoPagesAppConfig;
|
|
27
|
-
bridge: IClientBridge;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
type HandleFileChangeOptions = {
|
|
31
|
-
broadcast?: boolean;
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* Node development HMR manager.
|
|
36
|
-
*
|
|
37
|
-
* @remarks
|
|
38
|
-
* This manager owns three separate concerns:
|
|
39
|
-
* - runtime websocket event fanout
|
|
40
|
-
* - entrypoint registration and dedupe
|
|
41
|
-
* - strategy coordination for rebuilds and invalidation
|
|
42
|
-
*
|
|
43
|
-
* The strict page-entrypoint contract lives here: `registerEntrypoint()` is
|
|
44
|
-
* reserved for integration-owned page bundles, while generic script assets must
|
|
45
|
-
* go through `registerScriptEntrypoint()`.
|
|
46
|
-
*/
|
|
47
|
-
export class NodeHmrManager implements IHmrManager {
|
|
48
|
-
private static readonly entrypointRegistrationTimeoutMs = 4000;
|
|
49
|
-
public readonly appConfig: EcoPagesAppConfig;
|
|
50
|
-
private readonly bridge: IClientBridge;
|
|
51
|
-
private watchers = new Map<string, fs.FSWatcher>();
|
|
52
|
-
private watchedFiles = new Map<string, string>();
|
|
53
|
-
private entrypointRegistrations = new Map<string, Promise<string>>();
|
|
54
|
-
private distDir: string;
|
|
55
|
-
private plugins: EcoBuildPlugin[] = [];
|
|
56
|
-
private enabled = true;
|
|
57
|
-
private strategies: HmrStrategy[] = [];
|
|
58
|
-
private readonly entrypointRegistrar: HmrEntrypointRegistrar;
|
|
59
|
-
private readonly browserBundleService: BrowserBundleService;
|
|
60
|
-
private readonly entrypointDependencyGraph: EntrypointDependencyGraph;
|
|
61
|
-
private readonly serverModuleTranspiler: ServerModuleTranspiler;
|
|
62
|
-
|
|
63
|
-
constructor({ appConfig, bridge }: NodeHmrManagerParams) {
|
|
64
|
-
this.appConfig = appConfig;
|
|
65
|
-
this.bridge = bridge;
|
|
66
|
-
this.distDir = path.join(resolveInternalWorkDir(this.appConfig), RESOLVED_ASSETS_DIR, '_hmr');
|
|
67
|
-
this.entrypointRegistrar = new HmrEntrypointRegistrar({
|
|
68
|
-
srcDir: this.appConfig.absolutePaths.srcDir,
|
|
69
|
-
distDir: this.distDir,
|
|
70
|
-
entrypointRegistrations: this.entrypointRegistrations,
|
|
71
|
-
watchedFiles: this.watchedFiles,
|
|
72
|
-
clearFailedRegistration: (entrypointPath) => this.clearFailedEntrypointRegistration(entrypointPath),
|
|
73
|
-
registrationTimeoutMs: NodeHmrManager.entrypointRegistrationTimeoutMs,
|
|
74
|
-
});
|
|
75
|
-
this.browserBundleService = new BrowserBundleService(appConfig);
|
|
76
|
-
const existingEntrypointDependencyGraph = getAppEntrypointDependencyGraph(appConfig);
|
|
77
|
-
this.entrypointDependencyGraph =
|
|
78
|
-
existingEntrypointDependencyGraph instanceof InMemoryEntrypointDependencyGraph
|
|
79
|
-
? existingEntrypointDependencyGraph
|
|
80
|
-
: new InMemoryEntrypointDependencyGraph();
|
|
81
|
-
setAppEntrypointDependencyGraph(this.appConfig, this.entrypointDependencyGraph);
|
|
82
|
-
this.serverModuleTranspiler = getAppServerModuleTranspiler(this.appConfig);
|
|
83
|
-
this.cleanDistDir();
|
|
84
|
-
this.initializeStrategies();
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
/**
|
|
88
|
-
* Ensures the HMR output directory exists.
|
|
89
|
-
*
|
|
90
|
-
* This must not remove the directory because multiple app processes
|
|
91
|
-
* can share the same dist path during e2e runs.
|
|
92
|
-
*/
|
|
93
|
-
private cleanDistDir(): void {
|
|
94
|
-
fileSystem.ensureDir(this.distDir);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
/**
|
|
98
|
-
* Returns whether the generic JS strategy is allowed to rebuild an entrypoint.
|
|
99
|
-
*
|
|
100
|
-
* @remarks
|
|
101
|
-
* Higher-priority integration strategies own framework page entrypoints. When
|
|
102
|
-
* one of them matches, the generic JS strategy must stay out of the way so a
|
|
103
|
-
* shared dependency invalidation does not overwrite framework-specific output.
|
|
104
|
-
*/
|
|
105
|
-
private shouldJsStrategyProcessEntrypoint(entrypointPath: string): boolean {
|
|
106
|
-
return !this.strategies.some((strategy) => {
|
|
107
|
-
if (strategy.type !== HmrStrategyType.INTEGRATION || strategy.priority <= HmrStrategyType.SCRIPT) {
|
|
108
|
-
return false;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
try {
|
|
112
|
-
return strategy.matches(entrypointPath);
|
|
113
|
-
} catch (error) {
|
|
114
|
-
appLogger.error(error);
|
|
115
|
-
return false;
|
|
116
|
-
}
|
|
117
|
-
});
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
private initializeStrategies(): void {
|
|
121
|
-
const jsContext = {
|
|
122
|
-
getWatchedFiles: () => this.watchedFiles,
|
|
123
|
-
getDistDir: () => this.distDir,
|
|
124
|
-
getPlugins: () => this.plugins,
|
|
125
|
-
getSrcDir: () => this.appConfig.absolutePaths.srcDir,
|
|
126
|
-
getPagesDir: () => this.appConfig.absolutePaths.pagesDir,
|
|
127
|
-
getLayoutsDir: () => this.appConfig.absolutePaths.layoutsDir,
|
|
128
|
-
getTemplateExtensions: () => this.appConfig.templatesExt,
|
|
129
|
-
getBrowserBundleService: () => this.browserBundleService,
|
|
130
|
-
getEntrypointDependencyGraph: () => this.entrypointDependencyGraph,
|
|
131
|
-
shouldProcessEntrypoint: (entrypointPath: string) => this.shouldJsStrategyProcessEntrypoint(entrypointPath),
|
|
132
|
-
};
|
|
133
|
-
|
|
134
|
-
this.strategies = [new JsHmrStrategy(jsContext), new DefaultHmrStrategy()];
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
public registerStrategy(strategy: HmrStrategy): void {
|
|
138
|
-
this.strategies.push(strategy);
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
public setPlugins(plugins: EcoBuildPlugin[]): void {
|
|
142
|
-
this.plugins = [...plugins];
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
public setEnabled(enabled: boolean): void {
|
|
146
|
-
this.enabled = enabled;
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
public isEnabled(): boolean {
|
|
150
|
-
return this.enabled;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
public async buildRuntime(): Promise<void> {
|
|
154
|
-
const runtimeSource = path.resolve(import.meta.dirname, '../../hmr/client/hmr-runtime.ts');
|
|
155
|
-
|
|
156
|
-
try {
|
|
157
|
-
const result = await this.browserBundleService.bundle({
|
|
158
|
-
profile: 'hmr-runtime',
|
|
159
|
-
entrypoints: [runtimeSource],
|
|
160
|
-
outdir: this.distDir,
|
|
161
|
-
naming: '_hmr_runtime.js',
|
|
162
|
-
minify: false,
|
|
163
|
-
plugins: this.plugins,
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
if (!result.success) {
|
|
167
|
-
this.enabled = false;
|
|
168
|
-
appLogger.error('[HMR] Failed to build runtime script; continuing with HMR disabled.', result.logs);
|
|
169
|
-
}
|
|
170
|
-
} catch (error) {
|
|
171
|
-
this.enabled = false;
|
|
172
|
-
appLogger.error('[HMR] Failed to build runtime script; continuing with HMR disabled.', error);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
public getRuntimePath(): string {
|
|
177
|
-
return path.join(this.distDir, '_hmr_runtime.js');
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
public broadcast(event: ClientBridgeEvent) {
|
|
181
|
-
appLogger.debug(
|
|
182
|
-
`[HMR] Broadcasting ${event.type} event, path=${event.path || 'all'}, subscribers=${this.bridge.subscriberCount}`,
|
|
183
|
-
);
|
|
184
|
-
this.bridge.broadcast(event);
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
public async handleFileChange(filePath: string, options: HandleFileChangeOptions = {}): Promise<void> {
|
|
188
|
-
const sorted = [...this.strategies].sort((a, b) => b.priority - a.priority);
|
|
189
|
-
const strategy = sorted.find((s) => {
|
|
190
|
-
try {
|
|
191
|
-
return s.matches(filePath);
|
|
192
|
-
} catch (err) {
|
|
193
|
-
appLogger.error(err);
|
|
194
|
-
return false;
|
|
195
|
-
}
|
|
196
|
-
});
|
|
197
|
-
|
|
198
|
-
if (!strategy) {
|
|
199
|
-
appLogger.warn(`[HMR] No strategy found for ${filePath}`);
|
|
200
|
-
return;
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
appLogger.debug(`[NodeHmrManager] Selected strategy: ${strategy.constructor.name}`);
|
|
204
|
-
|
|
205
|
-
const action = await strategy.process(filePath);
|
|
206
|
-
const shouldBroadcast = options.broadcast ?? true;
|
|
207
|
-
|
|
208
|
-
if (shouldBroadcast && action.type === 'broadcast') {
|
|
209
|
-
if (action.events) {
|
|
210
|
-
for (const event of action.events) {
|
|
211
|
-
this.broadcast(event);
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
public getOutputUrl(entrypointPath: string): string | undefined {
|
|
218
|
-
return this.watchedFiles.get(entrypointPath);
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
public getWatchedFiles(): Map<string, string> {
|
|
222
|
-
return this.watchedFiles;
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
public getDistDir(): string {
|
|
226
|
-
return this.distDir;
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
public getPlugins(): EcoBuildPlugin[] {
|
|
230
|
-
return this.plugins;
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
public getDefaultContext(): DefaultHmrContext {
|
|
234
|
-
return {
|
|
235
|
-
getWatchedFiles: () => this.watchedFiles,
|
|
236
|
-
getDistDir: () => this.distDir,
|
|
237
|
-
getPlugins: () => this.plugins,
|
|
238
|
-
getSrcDir: () => this.appConfig.absolutePaths.srcDir,
|
|
239
|
-
getLayoutsDir: () => this.appConfig.absolutePaths.layoutsDir,
|
|
240
|
-
getPagesDir: () => this.appConfig.absolutePaths.pagesDir,
|
|
241
|
-
getBuildExecutor: () => getAppBuildExecutor(this.appConfig),
|
|
242
|
-
getBrowserBundleService: () => this.browserBundleService,
|
|
243
|
-
importServerModule: async <T>(filePath: string) =>
|
|
244
|
-
await this.serverModuleTranspiler.importModule<T>({
|
|
245
|
-
filePath,
|
|
246
|
-
outdir: path.join(resolveInternalExecutionDir(this.appConfig), '.server-modules'),
|
|
247
|
-
externalPackages: true,
|
|
248
|
-
}),
|
|
249
|
-
};
|
|
250
|
-
}
|
|
251
|
-
|
|
252
|
-
private clearFailedEntrypointRegistration(entrypointPath: string): void {
|
|
253
|
-
this.watchedFiles.delete(entrypointPath);
|
|
254
|
-
this.entrypointDependencyGraph.clearEntrypointDependencies(entrypointPath);
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
/**
|
|
258
|
-
* Registers one integration-owned page entrypoint.
|
|
259
|
-
*
|
|
260
|
-
* @remarks
|
|
261
|
-
* Concurrent callers share one in-flight registration. The registration is
|
|
262
|
-
* removed from the dedupe map once it resolves or fails so later requests do
|
|
263
|
-
* not inherit stale state.
|
|
264
|
-
*/
|
|
265
|
-
public async registerEntrypoint(entrypointPath: string): Promise<string> {
|
|
266
|
-
return await this.entrypointRegistrar.registerEntrypoint(entrypointPath, {
|
|
267
|
-
emit: async (normalizedEntrypoint) => await this.emitStrictEntrypoint(normalizedEntrypoint),
|
|
268
|
-
getMissingOutputError: (normalizedEntrypoint, outputPath) =>
|
|
269
|
-
new Error(
|
|
270
|
-
`[HMR] Integration failed to emit entrypoint ${normalizedEntrypoint} to ${outputPath}. Page entrypoints must be produced by their owning integration.`,
|
|
271
|
-
),
|
|
272
|
-
});
|
|
273
|
-
}
|
|
274
|
-
|
|
275
|
-
/**
|
|
276
|
-
* Registers one generic script entrypoint.
|
|
277
|
-
*
|
|
278
|
-
* @remarks
|
|
279
|
-
* This path is intentionally separate from page entrypoints so non-framework
|
|
280
|
-
* scripts can still use the generic build fallback without weakening the page
|
|
281
|
-
* ownership contract.
|
|
282
|
-
*/
|
|
283
|
-
public async registerScriptEntrypoint(entrypointPath: string): Promise<string> {
|
|
284
|
-
return await this.entrypointRegistrar.registerEntrypoint(entrypointPath, {
|
|
285
|
-
emit: async (normalizedEntrypoint, outputPath) =>
|
|
286
|
-
await this.emitScriptEntrypoint(normalizedEntrypoint, outputPath),
|
|
287
|
-
getMissingOutputError: (normalizedEntrypoint) =>
|
|
288
|
-
new Error(`[HMR] Failed to register script entrypoint: ${normalizedEntrypoint}`),
|
|
289
|
-
});
|
|
290
|
-
}
|
|
291
|
-
|
|
292
|
-
/**
|
|
293
|
-
* Performs strict integration-owned entrypoint registration for one normalized source path.
|
|
294
|
-
*
|
|
295
|
-
* @remarks
|
|
296
|
-
* The flow is:
|
|
297
|
-
* 1. Reserve the output URL in the watched map.
|
|
298
|
-
* 2. Remove any stale emitted file from an earlier process or failed build.
|
|
299
|
-
* 3. Let the strategy chain try to emit the entrypoint without broadcasting.
|
|
300
|
-
* 4. Fail if the owning integration did not emit the expected output.
|
|
301
|
-
*/
|
|
302
|
-
private async emitStrictEntrypoint(entrypointPath: string): Promise<void> {
|
|
303
|
-
await this.handleFileChange(entrypointPath, { broadcast: false });
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
/**
|
|
307
|
-
* Performs registration for a generic script asset.
|
|
308
|
-
*
|
|
309
|
-
* @remarks
|
|
310
|
-
* This path performs a targeted browser bundle for the requested script
|
|
311
|
-
* entrypoint only. The resulting dependency graph is retained so later file
|
|
312
|
-
* changes can invalidate just the affected script entrypoints.
|
|
313
|
-
*/
|
|
314
|
-
private async emitScriptEntrypoint(entrypointPath: string, outputPath: string): Promise<void> {
|
|
315
|
-
const naming = path.relative(this.distDir, outputPath).split(path.sep).join('/');
|
|
316
|
-
const buildResult = await this.browserBundleService.bundle({
|
|
317
|
-
profile: 'hmr-entrypoint',
|
|
318
|
-
entrypoints: [entrypointPath],
|
|
319
|
-
outdir: this.distDir,
|
|
320
|
-
naming,
|
|
321
|
-
minify: false,
|
|
322
|
-
plugins: this.plugins,
|
|
323
|
-
});
|
|
324
|
-
|
|
325
|
-
if (!buildResult.success) {
|
|
326
|
-
appLogger.error(`[HMR] Generic script entrypoint build failed for ${entrypointPath}:`, buildResult.logs);
|
|
327
|
-
return;
|
|
328
|
-
}
|
|
329
|
-
|
|
330
|
-
const entrypointDependencies = buildResult.dependencyGraph?.entrypoints?.[entrypointPath];
|
|
331
|
-
if (entrypointDependencies) {
|
|
332
|
-
this.entrypointDependencyGraph.setEntrypointDependencies(entrypointPath, entrypointDependencies);
|
|
333
|
-
}
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
/**
|
|
337
|
-
* Stops active watchers and releases retained registration state.
|
|
338
|
-
*
|
|
339
|
-
* @remarks
|
|
340
|
-
* The manager intentionally does not remove emitted `_hmr` files from disk
|
|
341
|
-
* because multiple app processes may share the same dist directory during test
|
|
342
|
-
* runs. It does clear in-memory indexes so old entrypoints and dependencies
|
|
343
|
-
* cannot leak across a reused manager instance.
|
|
344
|
-
*/
|
|
345
|
-
public stop() {
|
|
346
|
-
this.entrypointRegistrations.clear();
|
|
347
|
-
for (const watcher of this.watchers.values()) {
|
|
348
|
-
watcher.close();
|
|
349
|
-
}
|
|
350
|
-
this.watchers.clear();
|
|
351
|
-
this.watchedFiles.clear();
|
|
352
|
-
this.entrypointDependencyGraph.reset();
|
|
353
|
-
this.plugins = [];
|
|
354
|
-
}
|
|
355
|
-
}
|