one 1.17.9 → 1.17.10
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/dist/cjs/Root.native.js.map +1 -1
- package/dist/cjs/__mocks__/@react-navigation/native-stack.native.js.map +1 -1
- package/dist/cjs/__mocks__/expo-linking.native.js.map +1 -1
- package/dist/cjs/__mocks__/expo-modules-core.native.js.map +1 -1
- package/dist/cjs/__mocks__/react-native-screens.native.js.map +1 -1
- package/dist/cjs/babel-plugins/environment-guard.native.js.map +1 -1
- package/dist/cjs/babel-plugins/inline-one-server-url.native.js.map +1 -1
- package/dist/cjs/babel-plugins/one-router-metro.native.js.map +1 -1
- package/dist/cjs/babel-plugins/one-router-metro.test.native.js.map +1 -1
- package/dist/cjs/babel-plugins/remove-server-code.native.js.map +1 -1
- package/dist/cjs/babel-preset/index.cjs +7 -2
- package/dist/cjs/babel-preset/index.native.js +7 -2
- package/dist/cjs/babel-preset/index.native.js.map +1 -1
- package/dist/cjs/babel-preset/index.test.cjs +13 -0
- package/dist/cjs/babel-preset/index.test.native.js +13 -0
- package/dist/cjs/babel-preset/index.test.native.js.map +1 -1
- package/dist/cjs/babel-preset/integration.test.native.js.map +1 -1
- package/dist/cjs/cli/build.cjs +14 -11
- package/dist/cjs/cli/build.native.js +14 -11
- package/dist/cjs/cli/build.native.js.map +1 -1
- package/dist/cjs/cli/buildPage.cjs +2 -1
- package/dist/cjs/cli/buildPage.native.js +2 -1
- package/dist/cjs/cli/buildPage.native.js.map +1 -1
- package/dist/cjs/cli/buildPageWorker.native.js.map +1 -1
- package/dist/cjs/cli/checkNodeVersion.native.js.map +1 -1
- package/dist/cjs/cli/daemon.native.js.map +1 -1
- package/dist/cjs/cli/dev.native.js.map +1 -1
- package/dist/cjs/cli/generateBundlerConfig.native.js.map +1 -1
- package/dist/cjs/cli/generateBundlerConfig.test.native.js.map +1 -1
- package/dist/cjs/cli/generateRoutes.native.js.map +1 -1
- package/dist/cjs/cli/generateSitemap.native.js.map +1 -1
- package/dist/cjs/cli/generateSitemap.test.native.js.map +1 -1
- package/dist/cjs/cli/install-error-handlers.native.js.map +1 -1
- package/dist/cjs/cli/label-process.native.js.map +1 -1
- package/dist/cjs/cli/main.native.js.map +1 -1
- package/dist/cjs/cli/patch.native.js.map +1 -1
- package/dist/cjs/cli/patch.test.native.js.map +1 -1
- package/dist/cjs/cli/prebuild.native.js.map +1 -1
- package/dist/cjs/cli/runAndroid.native.js.map +1 -1
- package/dist/cjs/cli/runIos.native.js.map +1 -1
- package/dist/cjs/cli/securityScan.native.js.map +1 -1
- package/dist/cjs/cli/workerPool.native.js.map +1 -1
- package/dist/cjs/cli.native.js.map +1 -1
- package/dist/cjs/clientLoaderResolver.native.js.map +1 -1
- package/dist/cjs/config.native.js.map +1 -1
- package/dist/cjs/constants.cjs +17 -5
- package/dist/cjs/constants.native.js +13 -1
- package/dist/cjs/constants.native.js.map +1 -1
- package/dist/cjs/constants.test.cjs +60 -0
- package/dist/cjs/constants.test.native.js +63 -0
- package/dist/cjs/constants.test.native.js.map +1 -0
- package/dist/cjs/createAPIRoute.native.js.map +1 -1
- package/dist/cjs/createApp.cjs +3 -2
- package/dist/cjs/createHandleRequest.native.js.map +1 -1
- package/dist/cjs/createHandleRequest.test.native.js.map +1 -1
- package/dist/cjs/createMiddleware.native.js.map +1 -1
- package/dist/cjs/daemon/index.native.js.map +1 -1
- package/dist/cjs/daemon/ipc.native.js.map +1 -1
- package/dist/cjs/daemon/picker.native.js.map +1 -1
- package/dist/cjs/daemon/proxy.native.js.map +1 -1
- package/dist/cjs/daemon/registry.native.js.map +1 -1
- package/dist/cjs/daemon/server.cjs +23 -0
- package/dist/cjs/daemon/server.native.js +61 -0
- package/dist/cjs/daemon/server.native.js.map +1 -1
- package/dist/cjs/daemon/tui.native.js.map +1 -1
- package/dist/cjs/daemon/types.native.js.map +1 -1
- package/dist/cjs/daemon/utils.native.js.map +1 -1
- package/dist/cjs/devtools/registry.native.js.map +1 -1
- package/dist/cjs/drawer.native.js.map +1 -1
- package/dist/cjs/fallbackViews/Sitemap.native.js.map +1 -1
- package/dist/cjs/fallbackViews/Unmatched.native.js.map +1 -1
- package/dist/cjs/fork/NavigationContainer.native.js.map +1 -1
- package/dist/cjs/fork/SSRNavigationContainer.native.js.map +1 -1
- package/dist/cjs/fork/__tests__/getPathFromState.test.native.js.map +1 -1
- package/dist/cjs/fork/__tests__/getStateFromPath.test.native.js.map +1 -1
- package/dist/cjs/fork/_shared.native.js.map +1 -1
- package/dist/cjs/fork/createMemoryHistory.native.js.map +1 -1
- package/dist/cjs/fork/createMemoryHistory.test.native.js.map +1 -1
- package/dist/cjs/fork/extractPathFromURL.native.js.map +1 -1
- package/dist/cjs/fork/extractPathFromURL.test.native.js.map +1 -1
- package/dist/cjs/fork/findFocusedRoute.native.js.map +1 -1
- package/dist/cjs/fork/getPathFromState-mods.native.js.map +1 -1
- package/dist/cjs/fork/getPathFromState.native.js.map +1 -1
- package/dist/cjs/fork/getPathFromState.test.native.js.map +1 -1
- package/dist/cjs/fork/getStateFromPath-mods.native.js.map +1 -1
- package/dist/cjs/fork/getStateFromPath.native.js.map +1 -1
- package/dist/cjs/fork/getStateFromPath.test.native.js.map +1 -1
- package/dist/cjs/fork/useThenable.native.js.map +1 -1
- package/dist/cjs/fork/validatePathConfig.native.js.map +1 -1
- package/dist/cjs/getReactNavigationConfig.native.js.map +1 -1
- package/dist/cjs/head/Head.native.js.map +1 -1
- package/dist/cjs/head/HeadModule.native.js.map +1 -1
- package/dist/cjs/head/index.native.js.map +1 -1
- package/dist/cjs/head/types.native.js.map +1 -1
- package/dist/cjs/head/url.native.js.map +1 -1
- package/dist/cjs/headless-server.native.js.map +1 -1
- package/dist/cjs/headless.native.js.map +1 -1
- package/dist/cjs/hooks.native.js.map +1 -1
- package/dist/cjs/hooks.test.native.js.map +1 -1
- package/dist/cjs/href.native.js.map +1 -1
- package/dist/cjs/image/getImageData.native.js.map +1 -1
- package/dist/cjs/image.native.js.map +1 -1
- package/dist/cjs/index.cjs +6 -0
- package/dist/cjs/index.native.js +7 -1
- package/dist/cjs/index.native.js.map +1 -1
- package/dist/cjs/interfaces/router.native.js.map +1 -1
- package/dist/cjs/layouts/Drawer.native.js.map +1 -1
- package/dist/cjs/layouts/NativeTabs.native.js.map +1 -1
- package/dist/cjs/layouts/Stack.native.js +1 -1
- package/dist/cjs/layouts/Stack.native.js.map +1 -1
- package/dist/cjs/layouts/Tabs.native.js.map +1 -1
- package/dist/cjs/layouts/stack-utils/StackHeaderBackButton.native.js.map +1 -1
- package/dist/cjs/layouts/stack-utils/StackHeaderComponent.native.js.map +1 -1
- package/dist/cjs/layouts/stack-utils/StackHeaderLeft.native.js.map +1 -1
- package/dist/cjs/layouts/stack-utils/StackHeaderRight.native.js.map +1 -1
- package/dist/cjs/layouts/stack-utils/StackHeaderSearchBar.native.js.map +1 -1
- package/dist/cjs/layouts/stack-utils/StackHeaderTitle.native.js.map +1 -1
- package/dist/cjs/layouts/stack-utils/StackScreen.native.js.map +1 -1
- package/dist/cjs/layouts/stack-utils/__tests__/composition.test.native.js.map +1 -1
- package/dist/cjs/layouts/stack-utils/index.native.js.map +1 -1
- package/dist/cjs/layouts/withLayoutContext.native.js.map +1 -1
- package/dist/cjs/lazyWithRetry.cjs +32 -0
- package/dist/cjs/lazyWithRetry.native.js +37 -0
- package/dist/cjs/lazyWithRetry.native.js.map +1 -0
- package/dist/cjs/link/Link.native.js.map +1 -1
- package/dist/cjs/link/Redirect.native.js.map +1 -1
- package/dist/cjs/link/getLinking.native.js.map +1 -1
- package/dist/cjs/link/href.native.js.map +1 -1
- package/dist/cjs/link/path.native.js.map +1 -1
- package/dist/cjs/link/prefetchIntent.native.js.map +1 -1
- package/dist/cjs/link/prefetchIntent.test.native.js.map +1 -1
- package/dist/cjs/link/prefetchViewport.native.js.map +1 -1
- package/dist/cjs/link/prefetchViewport.test.native.js.map +1 -1
- package/dist/cjs/link/useLinkTo.native.js.map +1 -1
- package/dist/cjs/link/useLoadedNavigation.native.js.map +1 -1
- package/dist/cjs/metro-config/buildOneMetroResolverOverrides.native.js.map +1 -1
- package/dist/cjs/metro-config/getViteMetroPluginOptions.integration.test.native.js.map +1 -1
- package/dist/cjs/metro-config/getViteMetroPluginOptions.native.js +1 -1
- package/dist/cjs/metro-config/getViteMetroPluginOptions.native.js.map +1 -1
- package/dist/cjs/metro-config/withOne.native.js.map +1 -1
- package/dist/cjs/metro-config/withOne.test.native.js.map +1 -1
- package/dist/cjs/native-tabs.native.js.map +1 -1
- package/dist/cjs/notFoundState.native.js.map +1 -1
- package/dist/cjs/polyfills-mobile.native.js.map +1 -1
- package/dist/cjs/polyfills-server.native.js.map +1 -1
- package/dist/cjs/router/FlagsContext.native.js.map +1 -1
- package/dist/cjs/router/Route.native.js.map +1 -1
- package/dist/cjs/router/RouteInfoContext.native.js.map +1 -1
- package/dist/cjs/router/RouterStore.native.js.map +1 -1
- package/dist/cjs/router/SpaShellContext.native.js.map +1 -1
- package/dist/cjs/router/createRoute.native.js.map +1 -1
- package/dist/cjs/router/filterRootHTML.native.js.map +1 -1
- package/dist/cjs/router/findRouteNode.native.js.map +1 -1
- package/dist/cjs/router/getLinkingConfig.native.js.map +1 -1
- package/dist/cjs/router/getLinkingConfig.test.native.js.map +1 -1
- package/dist/cjs/router/getNormalizedStatePath.native.js.map +1 -1
- package/dist/cjs/router/getRouteInfo.native.js.map +1 -1
- package/dist/cjs/router/getRoutes.native.js.map +1 -1
- package/dist/cjs/router/getRoutes.test.native.js.map +1 -1
- package/dist/cjs/router/glob-patterns.native.js.map +1 -1
- package/dist/cjs/router/imperative-api.native.js.map +1 -1
- package/dist/cjs/router/interceptRoutes.native.js.map +1 -1
- package/dist/cjs/router/isIndexPath.native.js.map +1 -1
- package/dist/cjs/router/lastAction.native.js.map +1 -1
- package/dist/cjs/router/linkingConfig.native.js.map +1 -1
- package/dist/cjs/router/matchers.native.js.map +1 -1
- package/dist/cjs/router/matchers.test.native.js.map +1 -1
- package/dist/cjs/router/params.native.js.map +1 -1
- package/dist/cjs/router/router.cjs +22 -7
- package/dist/cjs/router/router.native.js.map +1 -1
- package/dist/cjs/router/serverLocationContext.native.js.map +1 -1
- package/dist/cjs/router/sitemap.native.js.map +1 -1
- package/dist/cjs/router/sitemap.test.native.js.map +1 -1
- package/dist/cjs/router/sortRoutes.native.js.map +1 -1
- package/dist/cjs/router/useInitializeOneRouter.native.js.map +1 -1
- package/dist/cjs/router/useNavigation.native.js.map +1 -1
- package/dist/cjs/router/useScreens.cjs +17 -2
- package/dist/cjs/router/useScreens.native.js +24 -4
- package/dist/cjs/router/useScreens.native.js.map +1 -1
- package/dist/cjs/router/useViteRoutes.native.js.map +1 -1
- package/dist/cjs/router/utils/getNavigateAction.native.js.map +1 -1
- package/dist/cjs/router/utils/getNavigateAction.test.native.js.map +1 -1
- package/dist/cjs/screensFeatureFlags.native.js.map +1 -1
- package/dist/cjs/serve-worker.native.js.map +1 -1
- package/dist/cjs/serve.cjs +2 -1
- package/dist/cjs/serve.native.js +2 -1
- package/dist/cjs/serve.native.js.map +1 -1
- package/dist/cjs/server/ServerContextScript.cjs +4 -3
- package/dist/cjs/server/ServerContextScript.native.js +6 -4
- package/dist/cjs/server/ServerContextScript.native.js.map +1 -1
- package/dist/cjs/server/createRoutesManifest.native.js.map +1 -1
- package/dist/cjs/server/getServerManifest.native.js.map +1 -1
- package/dist/cjs/server/getServerManifest.test.native.js.map +1 -1
- package/dist/cjs/server/oneServe.cjs +21 -8
- package/dist/cjs/server/oneServe.native.js +21 -8
- package/dist/cjs/server/oneServe.native.js.map +1 -1
- package/dist/cjs/server/setServerGlobals.native.js.map +1 -1
- package/dist/cjs/server/setupBuildOptions.cjs +6 -1
- package/dist/cjs/server/setupBuildOptions.native.js +10 -4
- package/dist/cjs/server/setupBuildOptions.native.js.map +1 -1
- package/dist/cjs/server/setupServerGlobals.native.js.map +1 -1
- package/dist/cjs/server/ssrLoaderData.native.js.map +1 -1
- package/dist/cjs/server/staticHtmlFetcher.native.js.map +1 -1
- package/dist/cjs/server/workerHandler.cjs +2 -2
- package/dist/cjs/server/workerHandler.native.js +2 -2
- package/dist/cjs/server/workerHandler.native.js.map +1 -1
- package/dist/cjs/server-render.native.js.map +1 -1
- package/dist/cjs/skewProtection.native.js.map +1 -1
- package/dist/cjs/testing-utils.native.js.map +1 -1
- package/dist/cjs/typed-routes/generateRouteTypes.native.js.map +1 -1
- package/dist/cjs/typed-routes/generateRouteTypes.test.native.js.map +1 -1
- package/dist/cjs/typed-routes/getTypedRoutesDeclarationFile.native.js.map +1 -1
- package/dist/cjs/typed-routes/getTypedRoutesDeclarationFile.test.native.js.map +1 -1
- package/dist/cjs/typed-routes/injectRouteHelpers.native.js.map +1 -1
- package/dist/cjs/types.native.js.map +1 -1
- package/dist/cjs/ui/Slot.native.js.map +1 -1
- package/dist/cjs/ui/TabContext.native.js.map +1 -1
- package/dist/cjs/ui/TabList.native.js.map +1 -1
- package/dist/cjs/ui/TabRouter.native.js.map +1 -1
- package/dist/cjs/ui/TabSlot.native.js.map +1 -1
- package/dist/cjs/ui/TabTrigger.native.js.map +1 -1
- package/dist/cjs/ui/Tabs.native.js.map +1 -1
- package/dist/cjs/ui/common.native.js.map +1 -1
- package/dist/cjs/ui/index.native.js.map +1 -1
- package/dist/cjs/ui/useComponent.native.js.map +1 -1
- package/dist/cjs/useFocusEffect.native.js.map +1 -1
- package/dist/cjs/useLoader.cjs +30 -7
- package/dist/cjs/useLoader.native.js +30 -7
- package/dist/cjs/useLoader.native.js.map +1 -1
- package/dist/cjs/useMatches.native.js.map +1 -1
- package/dist/cjs/useMatches.test.native.js.map +1 -1
- package/dist/cjs/useServerHeadInsertion.native.js.map +1 -1
- package/dist/cjs/utils/assertIsReady.native.js.map +1 -1
- package/dist/cjs/utils/buildOutputPointer.cjs +81 -0
- package/dist/cjs/utils/buildOutputPointer.native.js +92 -0
- package/dist/cjs/utils/buildOutputPointer.native.js.map +1 -0
- package/dist/cjs/utils/buildOutputPointer.test.cjs +94 -0
- package/dist/cjs/utils/buildOutputPointer.test.native.js +97 -0
- package/dist/cjs/utils/buildOutputPointer.test.native.js.map +1 -0
- package/dist/cjs/utils/children.native.js.map +1 -1
- package/dist/cjs/utils/cleanUrl.native.js.map +1 -1
- package/dist/cjs/utils/cleanUrl.test.native.js.map +1 -1
- package/dist/cjs/utils/dynamicImport.cjs +32 -6
- package/dist/cjs/utils/dynamicImport.native.js +35 -2
- package/dist/cjs/utils/dynamicImport.native.js.map +1 -1
- package/dist/cjs/utils/dynamicImport.test.cjs +87 -0
- package/dist/cjs/utils/dynamicImport.test.native.js +108 -0
- package/dist/cjs/utils/dynamicImport.test.native.js.map +1 -0
- package/dist/cjs/utils/ensureExists.native.js.map +1 -1
- package/dist/cjs/utils/evictOldest.native.js.map +1 -1
- package/dist/cjs/utils/existsAsync.native.js.map +1 -1
- package/dist/cjs/utils/findRootLayout.native.js.map +1 -1
- package/dist/cjs/utils/getPageExport.native.js.map +1 -1
- package/dist/cjs/utils/getPathnameFromFilePath.native.js.map +1 -1
- package/dist/cjs/utils/getPathnameFromFilePath.test.native.js.map +1 -1
- package/dist/cjs/utils/getRouterRootFromOneOptions.native.js.map +1 -1
- package/dist/cjs/utils/globDir.native.js.map +1 -1
- package/dist/cjs/utils/hashString.native.js.map +1 -1
- package/dist/cjs/utils/htmlEscape.native.js.map +1 -1
- package/dist/cjs/utils/isResponse.native.js.map +1 -1
- package/dist/cjs/utils/isRolldown.native.js.map +1 -1
- package/dist/cjs/utils/isStatus.native.js.map +1 -1
- package/dist/cjs/utils/pLimit.native.js.map +1 -1
- package/dist/cjs/utils/posixPathContract.test.cjs +66 -0
- package/dist/cjs/utils/posixPathContract.test.native.js +89 -0
- package/dist/cjs/utils/posixPathContract.test.native.js.map +1 -0
- package/dist/cjs/utils/promiseWithResolvers.native.js.map +1 -1
- package/dist/cjs/utils/rand.native.js.map +1 -1
- package/dist/cjs/utils/redirect.native.js.map +1 -1
- package/dist/cjs/utils/removeParams.native.js.map +1 -1
- package/dist/cjs/utils/removeSearch.native.js.map +1 -1
- package/dist/cjs/utils/removeUndefined.native.js.map +1 -1
- package/dist/cjs/utils/routeFileWatch.native.js.map +1 -1
- package/dist/cjs/utils/routeFileWatch.test.native.js.map +1 -1
- package/dist/cjs/utils/style.native.js.map +1 -1
- package/dist/cjs/utils/toAbsolute.native.js.map +1 -1
- package/dist/cjs/utils/toServerOutputPath.cjs +36 -0
- package/dist/cjs/utils/toServerOutputPath.native.js +39 -0
- package/dist/cjs/utils/toServerOutputPath.native.js.map +1 -0
- package/dist/cjs/utils/toServerOutputPath.test.cjs +27 -0
- package/dist/cjs/utils/toServerOutputPath.test.native.js +30 -0
- package/dist/cjs/utils/toServerOutputPath.test.native.js.map +1 -0
- package/dist/cjs/utils/trackLoaderDependencies.native.js.map +1 -1
- package/dist/cjs/utils/url.native.js.map +1 -1
- package/dist/cjs/utils/useConstant.native.js.map +1 -1
- package/dist/cjs/utils/watchFile.native.js.map +1 -1
- package/dist/cjs/utils/weakKey.native.js.map +1 -1
- package/dist/cjs/utils/weakMemo.native.js.map +1 -1
- package/dist/cjs/utils/withStaticProperties.native.js.map +1 -1
- package/dist/cjs/utils/workerImport.native.js.map +1 -1
- package/dist/cjs/validateParams.native.js.map +1 -1
- package/dist/cjs/validateSearch.native.js.map +1 -1
- package/dist/cjs/vercel/build/buildVercelOutputDirectory.native.js.map +1 -1
- package/dist/cjs/vercel/build/config/vc-build-output-config-base.native.js.map +1 -1
- package/dist/cjs/vercel/build/config/vc-config-base.native.js.map +1 -1
- package/dist/cjs/vercel/build/config/vc-package-base.native.js.map +1 -1
- package/dist/cjs/vercel/build/generate/createApiServerlessFunction.native.js.map +1 -1
- package/dist/cjs/vercel/build/generate/createSsrServerlessFunction.native.js.map +1 -1
- package/dist/cjs/vercel/build/getPathFromRoute.native.js.map +1 -1
- package/dist/cjs/views/EmptyRoute.native.js.map +1 -1
- package/dist/cjs/views/ErrorBoundary.native.js.map +1 -1
- package/dist/cjs/views/LoadProgressBar.native.js.map +1 -1
- package/dist/cjs/views/Navigator.native.js.map +1 -1
- package/dist/cjs/views/OneStackRouter.native.js.map +1 -1
- package/dist/cjs/views/Protected.native.js.map +1 -1
- package/dist/cjs/views/RootErrorBoundary.native.js.map +1 -1
- package/dist/cjs/views/Screen.native.js.map +1 -1
- package/dist/cjs/views/ScrollBehavior.native.js.map +1 -1
- package/dist/cjs/views/SourceInspector.native.js.map +1 -1
- package/dist/cjs/views/Try.native.js.map +1 -1
- package/dist/cjs/vite/DevHead.native.js.map +1 -1
- package/dist/cjs/vite/constants.native.js.map +1 -1
- package/dist/cjs/vite/customNodeExternals.native.js.map +1 -1
- package/dist/cjs/vite/ensureTsConfig.native.js.map +1 -1
- package/dist/cjs/vite/findDepsToOptimize.native.js.map +1 -1
- package/dist/cjs/vite/getManifest.native.js.map +1 -1
- package/dist/cjs/vite/getManifest.test.cjs +46 -0
- package/dist/cjs/vite/getManifest.test.native.js +52 -0
- package/dist/cjs/vite/getManifest.test.native.js.map +1 -0
- package/dist/cjs/vite/loadConfig.native.js.map +1 -1
- package/dist/cjs/vite/makePluginWebOnly.native.js.map +1 -1
- package/dist/cjs/vite/one-server-only.test.native.js.map +1 -1
- package/dist/cjs/vite/one.cjs +4 -3
- package/dist/cjs/vite/one.native.js +4 -3
- package/dist/cjs/vite/one.native.js.map +1 -1
- package/dist/cjs/vite/plugins/SSRCSSPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/clientTreeShakePlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/clientTreeShakePlugin.test.native.js.map +1 -1
- package/dist/cjs/vite/plugins/criticalCSSPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/criticalCSSPlugin.test.native.js.map +1 -1
- package/dist/cjs/vite/plugins/devtoolsPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/environmentGuardPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/environmentGuardPlugin.test.native.js.map +1 -1
- package/dist/cjs/vite/plugins/fileSystemRouterPlugin.cjs +25 -16
- package/dist/cjs/vite/plugins/fileSystemRouterPlugin.native.js +25 -16
- package/dist/cjs/vite/plugins/fileSystemRouterPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/fileSystemRouterPlugin.test.native.js.map +1 -1
- package/dist/cjs/vite/plugins/fixDependenciesPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/generateFileSystemRouteTypesPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/imageDataPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/imageDataPlugin.test.native.js.map +1 -1
- package/dist/cjs/vite/plugins/removeReactNativeWebAnimatedPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/sourceInspectorPlugin.cjs +1 -1
- package/dist/cjs/vite/plugins/sourceInspectorPlugin.native.js +1 -1
- package/dist/cjs/vite/plugins/sourceInspectorPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/sourceInspectorPlugin.test.native.js.map +1 -1
- package/dist/cjs/vite/plugins/useDomPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/virtualEntryConstants.native.js.map +1 -1
- package/dist/cjs/vite/plugins/virtualEntryPlugin.cjs +2 -1
- package/dist/cjs/vite/plugins/virtualEntryPlugin.native.js +2 -1
- package/dist/cjs/vite/plugins/virtualEntryPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/virtualEntryPlugin.test.native.js.map +1 -1
- package/dist/cjs/vite/plugins/warmRoutesPlugin.native.js.map +1 -1
- package/dist/cjs/vite/replaceLoader.native.js.map +1 -1
- package/dist/cjs/vite/resolveResponse.native.js.map +1 -1
- package/dist/cjs/vite/types.native.js.map +1 -1
- package/dist/cjs/vite-auto-warm.native.js.map +1 -1
- package/dist/cjs/vite.native.js.map +1 -1
- package/dist/cjs/zero/getQueryKey.native.js.map +1 -1
- package/dist/cjs/zero/isZeroQuery.native.js.map +1 -1
- package/dist/cjs/zero/resolveQuery.native.js.map +1 -1
- package/dist/cjs/zero/subscribeToQuery.native.js.map +1 -1
- package/dist/cjs/zero/types.native.js.map +1 -1
- package/dist/cjs/zero/useQuery.native.js.map +1 -1
- package/dist/cjs/zero/useQueryZero.native.js.map +1 -1
- package/dist/cjs/zero.native.js.map +1 -1
- package/dist/esm/babel-preset/index.mjs +7 -2
- package/dist/esm/babel-preset/index.mjs.map +1 -1
- package/dist/esm/babel-preset/index.native.js +7 -2
- package/dist/esm/babel-preset/index.native.js.map +1 -1
- package/dist/esm/babel-preset/index.test.mjs +13 -0
- package/dist/esm/babel-preset/index.test.mjs.map +1 -1
- package/dist/esm/babel-preset/index.test.native.js +13 -0
- package/dist/esm/babel-preset/index.test.native.js.map +1 -1
- package/dist/esm/cli/build.mjs +15 -12
- package/dist/esm/cli/build.mjs.map +1 -1
- package/dist/esm/cli/build.native.js +15 -12
- package/dist/esm/cli/build.native.js.map +1 -1
- package/dist/esm/cli/buildPage.mjs +2 -1
- package/dist/esm/cli/buildPage.mjs.map +1 -1
- package/dist/esm/cli/buildPage.native.js +2 -1
- package/dist/esm/cli/buildPage.native.js.map +1 -1
- package/dist/esm/constants.mjs +14 -5
- package/dist/esm/constants.mjs.map +1 -1
- package/dist/esm/constants.native.js +10 -1
- package/dist/esm/constants.native.js.map +1 -1
- package/dist/esm/constants.test.mjs +37 -0
- package/dist/esm/constants.test.mjs.map +1 -0
- package/dist/esm/constants.test.native.js +37 -0
- package/dist/esm/constants.test.native.js.map +1 -0
- package/dist/esm/createApp.mjs +3 -2
- package/dist/esm/createApp.mjs.map +1 -1
- package/dist/esm/daemon/server.mjs +23 -0
- package/dist/esm/daemon/server.mjs.map +1 -1
- package/dist/esm/daemon/server.native.js +61 -0
- package/dist/esm/daemon/server.native.js.map +1 -1
- package/dist/esm/index.js +3 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/index.mjs +3 -1
- package/dist/esm/index.mjs.map +1 -1
- package/dist/esm/index.native.js +3 -1
- package/dist/esm/index.native.js.map +1 -1
- package/dist/esm/lazyWithRetry.mjs +7 -0
- package/dist/esm/lazyWithRetry.mjs.map +1 -0
- package/dist/esm/lazyWithRetry.native.js +9 -0
- package/dist/esm/lazyWithRetry.native.js.map +1 -0
- package/dist/esm/router/router.mjs +22 -7
- package/dist/esm/router/router.mjs.map +1 -1
- package/dist/esm/router/router.native.js.map +1 -1
- package/dist/esm/router/useScreens.mjs +18 -3
- package/dist/esm/router/useScreens.mjs.map +1 -1
- package/dist/esm/router/useScreens.native.js +25 -5
- package/dist/esm/router/useScreens.native.js.map +1 -1
- package/dist/esm/serve.mjs +2 -1
- package/dist/esm/serve.mjs.map +1 -1
- package/dist/esm/serve.native.js +2 -1
- package/dist/esm/serve.native.js.map +1 -1
- package/dist/esm/server/ServerContextScript.mjs +4 -3
- package/dist/esm/server/ServerContextScript.mjs.map +1 -1
- package/dist/esm/server/ServerContextScript.native.js +6 -4
- package/dist/esm/server/ServerContextScript.native.js.map +1 -1
- package/dist/esm/server/oneServe.mjs +23 -10
- package/dist/esm/server/oneServe.mjs.map +1 -1
- package/dist/esm/server/oneServe.native.js +23 -10
- package/dist/esm/server/oneServe.native.js.map +1 -1
- package/dist/esm/server/setupBuildOptions.mjs +6 -1
- package/dist/esm/server/setupBuildOptions.mjs.map +1 -1
- package/dist/esm/server/setupBuildOptions.native.js +10 -4
- package/dist/esm/server/setupBuildOptions.native.js.map +1 -1
- package/dist/esm/server/workerHandler.mjs +3 -3
- package/dist/esm/server/workerHandler.mjs.map +1 -1
- package/dist/esm/server/workerHandler.native.js +3 -3
- package/dist/esm/server/workerHandler.native.js.map +1 -1
- package/dist/esm/useLoader.mjs +30 -7
- package/dist/esm/useLoader.mjs.map +1 -1
- package/dist/esm/useLoader.native.js +30 -7
- package/dist/esm/useLoader.native.js.map +1 -1
- package/dist/esm/utils/buildOutputPointer.mjs +43 -0
- package/dist/esm/utils/buildOutputPointer.mjs.map +1 -0
- package/dist/esm/utils/buildOutputPointer.native.js +51 -0
- package/dist/esm/utils/buildOutputPointer.native.js.map +1 -0
- package/dist/esm/utils/buildOutputPointer.test.mjs +71 -0
- package/dist/esm/utils/buildOutputPointer.test.mjs.map +1 -0
- package/dist/esm/utils/buildOutputPointer.test.native.js +71 -0
- package/dist/esm/utils/buildOutputPointer.test.native.js.map +1 -0
- package/dist/esm/utils/dynamicImport.mjs +29 -6
- package/dist/esm/utils/dynamicImport.mjs.map +1 -1
- package/dist/esm/utils/dynamicImport.native.js +32 -2
- package/dist/esm/utils/dynamicImport.native.js.map +1 -1
- package/dist/esm/utils/dynamicImport.test.mjs +88 -0
- package/dist/esm/utils/dynamicImport.test.mjs.map +1 -0
- package/dist/esm/utils/dynamicImport.test.native.js +106 -0
- package/dist/esm/utils/dynamicImport.test.native.js.map +1 -0
- package/dist/esm/utils/posixPathContract.test.mjs +67 -0
- package/dist/esm/utils/posixPathContract.test.mjs.map +1 -0
- package/dist/esm/utils/posixPathContract.test.native.js +87 -0
- package/dist/esm/utils/posixPathContract.test.native.js.map +1 -0
- package/dist/esm/utils/toServerOutputPath.mjs +11 -0
- package/dist/esm/utils/toServerOutputPath.mjs.map +1 -0
- package/dist/esm/utils/toServerOutputPath.native.js +11 -0
- package/dist/esm/utils/toServerOutputPath.native.js.map +1 -0
- package/dist/esm/utils/toServerOutputPath.test.mjs +28 -0
- package/dist/esm/utils/toServerOutputPath.test.mjs.map +1 -0
- package/dist/esm/utils/toServerOutputPath.test.native.js +28 -0
- package/dist/esm/utils/toServerOutputPath.test.native.js.map +1 -0
- package/dist/esm/vite/getManifest.test.mjs +47 -0
- package/dist/esm/vite/getManifest.test.mjs.map +1 -0
- package/dist/esm/vite/getManifest.test.native.js +50 -0
- package/dist/esm/vite/getManifest.test.native.js.map +1 -0
- package/dist/esm/vite/one.mjs +4 -3
- package/dist/esm/vite/one.mjs.map +1 -1
- package/dist/esm/vite/one.native.js +4 -3
- package/dist/esm/vite/one.native.js.map +1 -1
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.mjs +26 -17
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.mjs.map +1 -1
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.native.js +26 -17
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.native.js.map +1 -1
- package/dist/esm/vite/plugins/sourceInspectorPlugin.mjs +1 -1
- package/dist/esm/vite/plugins/sourceInspectorPlugin.mjs.map +1 -1
- package/dist/esm/vite/plugins/sourceInspectorPlugin.native.js +1 -1
- package/dist/esm/vite/plugins/sourceInspectorPlugin.native.js.map +1 -1
- package/dist/esm/vite/plugins/virtualEntryPlugin.mjs +2 -1
- package/dist/esm/vite/plugins/virtualEntryPlugin.mjs.map +1 -1
- package/dist/esm/vite/plugins/virtualEntryPlugin.native.js +2 -1
- package/dist/esm/vite/plugins/virtualEntryPlugin.native.js.map +1 -1
- package/package.json +23 -9
- package/src/babel-preset/index.test.ts +20 -0
- package/src/babel-preset/index.ts +21 -4
- package/src/cli/build.ts +23 -15
- package/src/cli/buildPage.ts +3 -1
- package/src/constants.test.ts +55 -0
- package/src/constants.ts +32 -4
- package/src/createApp.tsx +7 -2
- package/src/daemon/server.ts +30 -0
- package/src/index.ts +9 -0
- package/src/lazyWithRetry.tsx +21 -0
- package/src/router/router.ts +32 -7
- package/src/router/useScreens.tsx +22 -3
- package/src/serve.ts +2 -2
- package/src/server/ServerContextScript.tsx +9 -3
- package/src/server/oneServe.ts +33 -15
- package/src/server/setupBuildOptions.ts +11 -2
- package/src/server/workerHandler.ts +9 -5
- package/src/useLoader.ts +41 -6
- package/src/utils/buildOutputPointer.test.ts +97 -0
- package/src/utils/buildOutputPointer.ts +71 -0
- package/src/utils/dynamicImport.test.ts +92 -0
- package/src/utils/dynamicImport.ts +80 -13
- package/src/utils/posixPathContract.test.ts +97 -0
- package/src/utils/toServerOutputPath.test.ts +49 -0
- package/src/utils/toServerOutputPath.ts +11 -0
- package/src/vite/getManifest.test.ts +49 -0
- package/src/vite/one.ts +9 -5
- package/src/vite/plugins/fileSystemRouterPlugin.tsx +31 -17
- package/src/vite/plugins/sourceInspectorPlugin.ts +2 -1
- package/src/vite/plugins/virtualEntryPlugin.ts +5 -2
- package/types/babel-preset/index.d.ts.map +1 -1
- package/types/cli/build.d.ts.map +1 -1
- package/types/cli/buildPage.d.ts.map +1 -1
- package/types/constants.d.ts +7 -4
- package/types/constants.d.ts.map +1 -1
- package/types/constants.test.d.ts +2 -0
- package/types/constants.test.d.ts.map +1 -0
- package/types/createApp.d.ts.map +1 -1
- package/types/daemon/server.d.ts.map +1 -1
- package/types/index.d.ts +2 -0
- package/types/index.d.ts.map +1 -1
- package/types/lazyWithRetry.d.ts +6 -0
- package/types/lazyWithRetry.d.ts.map +1 -0
- package/types/router/router.d.ts.map +1 -1
- package/types/router/useScreens.d.ts.map +1 -1
- package/types/serve.d.ts.map +1 -1
- package/types/server/ServerContextScript.d.ts.map +1 -1
- package/types/server/oneServe.d.ts.map +1 -1
- package/types/server/setupBuildOptions.d.ts.map +1 -1
- package/types/server/workerHandler.d.ts.map +1 -1
- package/types/useLoader.d.ts.map +1 -1
- package/types/utils/buildOutputPointer.d.ts +4 -0
- package/types/utils/buildOutputPointer.d.ts.map +1 -0
- package/types/utils/buildOutputPointer.test.d.ts +2 -0
- package/types/utils/buildOutputPointer.test.d.ts.map +1 -0
- package/types/utils/dynamicImport.d.ts +10 -2
- package/types/utils/dynamicImport.d.ts.map +1 -1
- package/types/utils/dynamicImport.test.d.ts +2 -0
- package/types/utils/dynamicImport.test.d.ts.map +1 -0
- package/types/utils/posixPathContract.test.d.ts +2 -0
- package/types/utils/posixPathContract.test.d.ts.map +1 -0
- package/types/utils/toServerOutputPath.d.ts +2 -0
- package/types/utils/toServerOutputPath.d.ts.map +1 -0
- package/types/utils/toServerOutputPath.test.d.ts +2 -0
- package/types/utils/toServerOutputPath.test.d.ts.map +1 -0
- package/types/vite/getManifest.test.d.ts +2 -0
- package/types/vite/getManifest.test.d.ts.map +1 -0
- package/types/vite/one.d.ts.map +1 -1
- package/types/vite/plugins/fileSystemRouterPlugin.d.ts.map +1 -1
- package/types/vite/plugins/sourceInspectorPlugin.d.ts.map +1 -1
- package/types/vite/plugins/virtualEntryPlugin.d.ts.map +1 -1
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { dirname, join } from "path";
|
|
2
|
+
import FSExtra from "fs-extra";
|
|
3
|
+
import { toAbsolute } from "./toAbsolute.native.js";
|
|
4
|
+
function _instanceof(left, right) {
|
|
5
|
+
if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
|
|
6
|
+
return !!right[Symbol.hasInstance](left);
|
|
7
|
+
} else {
|
|
8
|
+
return left instanceof right;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
var buildOutputPointerPath = join("node_modules", ".cache", "one", "build-pointer.json");
|
|
12
|
+
async function writeBuildOutputPointer(outDir) {
|
|
13
|
+
try {
|
|
14
|
+
var pointerPath = toAbsolute(buildOutputPointerPath);
|
|
15
|
+
await FSExtra.ensureDir(dirname(pointerPath));
|
|
16
|
+
await FSExtra.writeJSON(pointerPath, {
|
|
17
|
+
outDir
|
|
18
|
+
});
|
|
19
|
+
} catch (err) {
|
|
20
|
+
console.warn(`[one build] could not write build-output pointer (${buildOutputPointerPath}). \`one serve\` will fall back to 'dist/' unless you pass --outDir.`, _instanceof(err, Error) ? err.message : err);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
async function resolveServeOutDir(outDir) {
|
|
24
|
+
if (outDir) {
|
|
25
|
+
return outDir;
|
|
26
|
+
}
|
|
27
|
+
if (FSExtra.existsSync("buildInfo.json")) {
|
|
28
|
+
return ".";
|
|
29
|
+
}
|
|
30
|
+
var pointer;
|
|
31
|
+
try {
|
|
32
|
+
pointer = await FSExtra.readJSON(buildOutputPointerPath);
|
|
33
|
+
} catch (err) {
|
|
34
|
+
if ((err === null || err === void 0 ? void 0 : err.code) && err.code !== "ENOENT") {
|
|
35
|
+
var _err_message;
|
|
36
|
+
console.warn(`[one serve] could not read build-output pointer (${buildOutputPointerPath}):`, (_err_message = err.message) !== null && _err_message !== void 0 ? _err_message : err);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
if (pointer === null || pointer === void 0 ? void 0 : pointer.outDir) {
|
|
40
|
+
if (await FSExtra.pathExists(join(pointer.outDir, "buildInfo.json"))) {
|
|
41
|
+
return pointer.outDir;
|
|
42
|
+
}
|
|
43
|
+
console.warn(`[one serve] build-pointer.json points to '${pointer.outDir}/' but no buildInfo.json was found there. run \`one build\` to refresh the marker.`);
|
|
44
|
+
}
|
|
45
|
+
if (!FSExtra.existsSync("dist/buildInfo.json")) {
|
|
46
|
+
console.warn(`[one serve] no build-output pointer and no 'dist/buildInfo.json'. did \`one build\` run from this cwd? pass --outDir to point at the build output.`);
|
|
47
|
+
}
|
|
48
|
+
return "dist";
|
|
49
|
+
}
|
|
50
|
+
export { buildOutputPointerPath, resolveServeOutDir, writeBuildOutputPointer };
|
|
51
|
+
//# sourceMappingURL=buildOutputPointer.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["dirname","join","FSExtra","toAbsolute","_instanceof","left","right","Symbol","hasInstance","buildOutputPointerPath","writeBuildOutputPointer","outDir","pointerPath","ensureDir","writeJSON","err","console","warn","Error","message","resolveServeOutDir","existsSync","pointer","readJSON","code","_err_message","pathExists"],"sources":["../../../src/utils/buildOutputPointer.ts"],"sourcesContent":[null],"mappings":"AAAA,SAASA,OAAA,EAASC,IAAA,QAAY;AAC9B,OAAOC,OAAA,MAAa;AACpB,SAASC,UAAA,QAAkB;AAGpB,SAAMC,YAAAC,IAAA,EAAAC,KAAyB;EACpC,IAAAA,KAAA,mBAAAC,MAAA,oBAAAD,KAAA,CAAAC,MAAA,CAAAC,WAAA;IACA,SAAAF,KAAA,CAAAC,MAAA,CAAAC,WAAA,EAAAH,IAAA;EACA;IACA,OAAAA,IAAA,YAAAC,KAAA;EACF;AAMA;AACE,IAAAG,sBAAI,GAAAR,IAAA;AACF,eAAMS,uBAAyBA,CAAAC,MAAA;EAC/B;IACA,IAAAC,WAAc,GAAAT,UAAU,CAAAM,sBAAuB;IACjD,MAAAP,OAAc,CAAAW,SAAA,CAAAb,OAAA,CAAAY,WAAA;IAGZ,MAAAV,OAAQ,CAAAY,SAAA,CAAAF,WAAA;MACND;IAA2E,EAC3E;EAAqC,EACvC,OAAAI,GAAA;IACFC,OAAA,CAAAC,IAAA,sDAAAR,sBAAA,wEAAAL,WAAA,CAAAW,GAAA,EAAAG,KAAA,IAAAH,GAAA,CAAAI,OAAA,GAAAJ,GAAA;EACF;AAEA;AACE,eAAYK,mBAAAT,MAAA;EACV,IAAAA,MAAO;IACT,OAAAA,MAAA;EAEA;EACE,IAAAT,OAAO,CAAAmB,UAAA;IACT;EAIA;EACA,IAAIC,OAAA;EACF;IACFA,OAAS,SAAUpB,OAAA,CAAAqB,QAAA,CAAAd,sBAAA;EACjB,SAAIM,GAAK;IACP,KAAAA,GAAA,KAAQ,QAAAA,GAAA,uBAAAA,GAAA,CAAAS,IAAA,KAAAT,GAAA,CAAAS,IAAA;MAAA,IACNC,YAAA;MAA0ET,OACtE,CAAAC,IAAA,qDAAWR,sBAAA,OAAAgB,YAAA,GAAAV,GAAA,CAAAI,OAAA,cAAAM,YAAA,cAAAA,YAAA,GAAAV,GAAA;IAAA;EACjB;EAEJ,IAAAO,OAAA,aAAAA,OAAA,uBAAAA,OAAA,CAAAX,MAAA;IAEA,IAAI,MAAAT,OAAS,CAAAwB,UAAQ,CAAAzB,IAAA,CAAAqB,OAAA,CAAAX,MAAA;MACnB,OAAIW,OAAM,CAAAX,MAAQ;IAChB;IACFK,OAAA,CAAAC,IAAA,8CAAAK,OAAA,CAAAX,MAAA;EACA;EAAQ,IACN,CAAAT,OAAA,CAAAmB,UAAA;IACFL,OAAA,CAAAC,IAAA;EACF;EAEA,OAAK,MAAQ;AACX;AAAQ,SACNR,sBACF,EACFW,kBAAA,EAEAV,uBAAO","ignoreList":[]}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { mkdtempSync } from "node:fs";
|
|
2
|
+
import { tmpdir } from "node:os";
|
|
3
|
+
import { join } from "node:path";
|
|
4
|
+
import FSExtra from "fs-extra";
|
|
5
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
6
|
+
import { buildOutputPointerPath, resolveServeOutDir, writeBuildOutputPointer } from "./buildOutputPointer.mjs";
|
|
7
|
+
describe("build output pointer", () => {
|
|
8
|
+
const originalCwd = process.cwd();
|
|
9
|
+
let tempRoot = "";
|
|
10
|
+
beforeEach(() => {
|
|
11
|
+
tempRoot = mkdtempSync(join(tmpdir(), "one-build-pointer-"));
|
|
12
|
+
process.chdir(tempRoot);
|
|
13
|
+
});
|
|
14
|
+
afterEach(async () => {
|
|
15
|
+
process.chdir(originalCwd);
|
|
16
|
+
vi.restoreAllMocks();
|
|
17
|
+
await FSExtra.remove(tempRoot);
|
|
18
|
+
});
|
|
19
|
+
it("prefers an explicit serve outDir", async () => {
|
|
20
|
+
await FSExtra.ensureDir("build-out");
|
|
21
|
+
await FSExtra.writeJSON(join("build-out", "buildInfo.json"), {});
|
|
22
|
+
await writeBuildOutputPointer("build-out");
|
|
23
|
+
expect(await resolveServeOutDir("manual-out")).toBe("manual-out");
|
|
24
|
+
});
|
|
25
|
+
it("preserves serving from inside the output directory", async () => {
|
|
26
|
+
await FSExtra.writeJSON("buildInfo.json", {});
|
|
27
|
+
await FSExtra.ensureDir("build-out");
|
|
28
|
+
await FSExtra.writeJSON(join("build-out", "buildInfo.json"), {});
|
|
29
|
+
await writeBuildOutputPointer("build-out");
|
|
30
|
+
expect(await resolveServeOutDir()).toBe(".");
|
|
31
|
+
});
|
|
32
|
+
it("resolves the outDir written by build", async () => {
|
|
33
|
+
await FSExtra.ensureDir("build-out");
|
|
34
|
+
await FSExtra.writeJSON(join("build-out", "buildInfo.json"), {});
|
|
35
|
+
await writeBuildOutputPointer("build-out");
|
|
36
|
+
expect(await FSExtra.readJSON(buildOutputPointerPath)).toEqual({
|
|
37
|
+
outDir: "build-out"
|
|
38
|
+
});
|
|
39
|
+
expect(await resolveServeOutDir()).toBe("build-out");
|
|
40
|
+
});
|
|
41
|
+
it("falls back to dist when the pointer is stale", async () => {
|
|
42
|
+
const warn = vi.spyOn(console, "warn").mockImplementation(() => {});
|
|
43
|
+
await writeBuildOutputPointer("missing-out");
|
|
44
|
+
expect(await resolveServeOutDir()).toBe("dist");
|
|
45
|
+
expect(warn).toHaveBeenCalledTimes(2);
|
|
46
|
+
expect(warn.mock.calls[0][0]).toMatch(/build-pointer\.json points to/);
|
|
47
|
+
expect(warn.mock.calls[1][0]).toMatch(/no build-output pointer/);
|
|
48
|
+
});
|
|
49
|
+
it("falls back to dist when no pointer exists and warns about missing dist", async () => {
|
|
50
|
+
const warn = vi.spyOn(console, "warn").mockImplementation(() => {});
|
|
51
|
+
expect(await resolveServeOutDir()).toBe("dist");
|
|
52
|
+
expect(warn).toHaveBeenCalledOnce();
|
|
53
|
+
expect(warn.mock.calls[0][0]).toMatch(/no build-output pointer/);
|
|
54
|
+
});
|
|
55
|
+
it("does not warn when falling back to an existing dist/ build", async () => {
|
|
56
|
+
const warn = vi.spyOn(console, "warn").mockImplementation(() => {});
|
|
57
|
+
await FSExtra.ensureDir("dist");
|
|
58
|
+
await FSExtra.writeJSON(join("dist", "buildInfo.json"), {});
|
|
59
|
+
expect(await resolveServeOutDir()).toBe("dist");
|
|
60
|
+
expect(warn).not.toHaveBeenCalled();
|
|
61
|
+
});
|
|
62
|
+
it("warns when the pointer write fails", async () => {
|
|
63
|
+
const warn = vi.spyOn(console, "warn").mockImplementation(() => {});
|
|
64
|
+
const writeSpy = vi.spyOn(FSExtra, "writeJSON").mockRejectedValueOnce(new Error("permission denied"));
|
|
65
|
+
await writeBuildOutputPointer("build-out");
|
|
66
|
+
expect(writeSpy).toHaveBeenCalled();
|
|
67
|
+
expect(warn).toHaveBeenCalledOnce();
|
|
68
|
+
expect(warn.mock.calls[0][0]).toMatch(/could not write build-output pointer/);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
//# sourceMappingURL=buildOutputPointer.test.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["mkdtempSync","tmpdir","join","FSExtra","afterEach","beforeEach","describe","expect","it","vi","buildOutputPointerPath","resolveServeOutDir","writeBuildOutputPointer","originalCwd","process","cwd","tempRoot","chdir","restoreAllMocks","remove","ensureDir","writeJSON","toBe","readJSON","toEqual","outDir","warn","spyOn","console","mockImplementation","toHaveBeenCalledTimes","mock","calls","toMatch","toHaveBeenCalledOnce","not","toHaveBeenCalled","writeSpy","mockRejectedValueOnce","Error"],"sources":["../../../src/utils/buildOutputPointer.test.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { mkdtempSync } from "fs";
|
|
2
|
+
import { tmpdir } from "os";
|
|
3
|
+
import { join } from "path";
|
|
4
|
+
import FSExtra from "fs-extra";
|
|
5
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
6
|
+
import { buildOutputPointerPath, resolveServeOutDir, writeBuildOutputPointer } from "./buildOutputPointer.native.js";
|
|
7
|
+
describe("build output pointer", function () {
|
|
8
|
+
var originalCwd = process.cwd();
|
|
9
|
+
var tempRoot = "";
|
|
10
|
+
beforeEach(function () {
|
|
11
|
+
tempRoot = mkdtempSync(join(tmpdir(), "one-build-pointer-"));
|
|
12
|
+
process.chdir(tempRoot);
|
|
13
|
+
});
|
|
14
|
+
afterEach(async function () {
|
|
15
|
+
process.chdir(originalCwd);
|
|
16
|
+
vi.restoreAllMocks();
|
|
17
|
+
await FSExtra.remove(tempRoot);
|
|
18
|
+
});
|
|
19
|
+
it("prefers an explicit serve outDir", async function () {
|
|
20
|
+
await FSExtra.ensureDir("build-out");
|
|
21
|
+
await FSExtra.writeJSON(join("build-out", "buildInfo.json"), {});
|
|
22
|
+
await writeBuildOutputPointer("build-out");
|
|
23
|
+
expect(await resolveServeOutDir("manual-out")).toBe("manual-out");
|
|
24
|
+
});
|
|
25
|
+
it("preserves serving from inside the output directory", async function () {
|
|
26
|
+
await FSExtra.writeJSON("buildInfo.json", {});
|
|
27
|
+
await FSExtra.ensureDir("build-out");
|
|
28
|
+
await FSExtra.writeJSON(join("build-out", "buildInfo.json"), {});
|
|
29
|
+
await writeBuildOutputPointer("build-out");
|
|
30
|
+
expect(await resolveServeOutDir()).toBe(".");
|
|
31
|
+
});
|
|
32
|
+
it("resolves the outDir written by build", async function () {
|
|
33
|
+
await FSExtra.ensureDir("build-out");
|
|
34
|
+
await FSExtra.writeJSON(join("build-out", "buildInfo.json"), {});
|
|
35
|
+
await writeBuildOutputPointer("build-out");
|
|
36
|
+
expect(await FSExtra.readJSON(buildOutputPointerPath)).toEqual({
|
|
37
|
+
outDir: "build-out"
|
|
38
|
+
});
|
|
39
|
+
expect(await resolveServeOutDir()).toBe("build-out");
|
|
40
|
+
});
|
|
41
|
+
it("falls back to dist when the pointer is stale", async function () {
|
|
42
|
+
var warn = vi.spyOn(console, "warn").mockImplementation(function () {});
|
|
43
|
+
await writeBuildOutputPointer("missing-out");
|
|
44
|
+
expect(await resolveServeOutDir()).toBe("dist");
|
|
45
|
+
expect(warn).toHaveBeenCalledTimes(2);
|
|
46
|
+
expect(warn.mock.calls[0][0]).toMatch(/build-pointer\.json points to/);
|
|
47
|
+
expect(warn.mock.calls[1][0]).toMatch(/no build-output pointer/);
|
|
48
|
+
});
|
|
49
|
+
it("falls back to dist when no pointer exists and warns about missing dist", async function () {
|
|
50
|
+
var warn = vi.spyOn(console, "warn").mockImplementation(function () {});
|
|
51
|
+
expect(await resolveServeOutDir()).toBe("dist");
|
|
52
|
+
expect(warn).toHaveBeenCalledOnce();
|
|
53
|
+
expect(warn.mock.calls[0][0]).toMatch(/no build-output pointer/);
|
|
54
|
+
});
|
|
55
|
+
it("does not warn when falling back to an existing dist/ build", async function () {
|
|
56
|
+
var warn = vi.spyOn(console, "warn").mockImplementation(function () {});
|
|
57
|
+
await FSExtra.ensureDir("dist");
|
|
58
|
+
await FSExtra.writeJSON(join("dist", "buildInfo.json"), {});
|
|
59
|
+
expect(await resolveServeOutDir()).toBe("dist");
|
|
60
|
+
expect(warn).not.toHaveBeenCalled();
|
|
61
|
+
});
|
|
62
|
+
it("warns when the pointer write fails", async function () {
|
|
63
|
+
var warn = vi.spyOn(console, "warn").mockImplementation(function () {});
|
|
64
|
+
var writeSpy = vi.spyOn(FSExtra, "writeJSON").mockRejectedValueOnce(new Error("permission denied"));
|
|
65
|
+
await writeBuildOutputPointer("build-out");
|
|
66
|
+
expect(writeSpy).toHaveBeenCalled();
|
|
67
|
+
expect(warn).toHaveBeenCalledOnce();
|
|
68
|
+
expect(warn.mock.calls[0][0]).toMatch(/could not write build-output pointer/);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
//# sourceMappingURL=buildOutputPointer.test.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["mkdtempSync","tmpdir","join","FSExtra","afterEach","beforeEach","describe","expect","it","vi","buildOutputPointerPath","resolveServeOutDir","writeBuildOutputPointer","originalCwd","process","cwd","tempRoot","chdir","restoreAllMocks","remove","ensureDir","writeJSON","toBe","readJSON","toEqual","outDir","warn","spyOn","console","mockImplementation","toHaveBeenCalledTimes","mock","calls","toMatch","toHaveBeenCalledOnce","not","toHaveBeenCalled","writeSpy","mockRejectedValueOnce","Error"],"sources":["../../../src/utils/buildOutputPointer.test.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
const dynamicImport = path => {
|
|
2
|
-
return import(/* @vite-ignore */
|
|
3
|
-
path)
|
|
4
|
-
|
|
5
|
-
throw err;
|
|
2
|
+
return loadWithRetry(() => import(/* @vite-ignore */
|
|
3
|
+
path), {
|
|
4
|
+
onChunkErrorExhausted: () => process.env.ONE_SKEW_PROTECTION !== "false" ? handleSkewError() : false
|
|
6
5
|
});
|
|
7
6
|
};
|
|
8
7
|
const CHUNK_ERROR_PATTERNS = ["Failed to fetch dynamically imported module", "error loading dynamically imported module", "Importing a module script failed"];
|
|
@@ -11,13 +10,37 @@ function isChunkLoadError(err) {
|
|
|
11
10
|
return CHUNK_ERROR_PATTERNS.some(p => msg.includes(p));
|
|
12
11
|
}
|
|
13
12
|
function handleSkewError() {
|
|
14
|
-
if (typeof window === "undefined") return;
|
|
13
|
+
if (typeof window === "undefined") return false;
|
|
15
14
|
const key = "__one_skew_reload";
|
|
16
15
|
const last = sessionStorage.getItem(key);
|
|
17
16
|
if (!last || Date.now() - Number(last) > 1e4) {
|
|
18
17
|
sessionStorage.setItem(key, String(Date.now()));
|
|
19
18
|
window.location.reload();
|
|
19
|
+
return true;
|
|
20
20
|
}
|
|
21
|
+
return false;
|
|
21
22
|
}
|
|
22
|
-
|
|
23
|
+
const CHUNK_RETRY_ATTEMPTS = 3;
|
|
24
|
+
const CHUNK_RETRY_DELAY_MS = 500;
|
|
25
|
+
const realDelay = ms => new Promise(resolve => setTimeout(resolve, ms));
|
|
26
|
+
async function loadWithRetry(loader, options = {}) {
|
|
27
|
+
const attempts = options.attempts ?? CHUNK_RETRY_ATTEMPTS;
|
|
28
|
+
const delayMs = options.delayMs ?? CHUNK_RETRY_DELAY_MS;
|
|
29
|
+
const delay = options.delay ?? realDelay;
|
|
30
|
+
const recover = options.onChunkErrorExhausted ?? handleSkewError;
|
|
31
|
+
const attempt = async retriesLeft => {
|
|
32
|
+
try {
|
|
33
|
+
return await loader();
|
|
34
|
+
} catch (err) {
|
|
35
|
+
if (retriesLeft > 0) {
|
|
36
|
+
await delay(delayMs);
|
|
37
|
+
return attempt(retriesLeft - 1);
|
|
38
|
+
}
|
|
39
|
+
if (isChunkLoadError(err) && recover()) return new Promise(() => {});
|
|
40
|
+
throw err;
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
return attempt(attempts);
|
|
44
|
+
}
|
|
45
|
+
export { CHUNK_RETRY_ATTEMPTS, CHUNK_RETRY_DELAY_MS, dynamicImport, handleSkewError, isChunkLoadError, loadWithRetry };
|
|
23
46
|
//# sourceMappingURL=dynamicImport.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["dynamicImport","path","
|
|
1
|
+
{"version":3,"names":["dynamicImport","path","loadWithRetry","onChunkErrorExhausted","process","env","ONE_SKEW_PROTECTION","handleSkewError","CHUNK_ERROR_PATTERNS","isChunkLoadError","err","msg","Error","message","String","some","p","includes","window","key","last","sessionStorage","getItem","Date","now","Number","setItem","location","reload","CHUNK_RETRY_ATTEMPTS","CHUNK_RETRY_DELAY_MS","realDelay","ms","Promise","resolve","setTimeout","loader","options","attempts","delayMs","delay","recover","attempt","retriesLeft"],"sources":["../../../src/utils/dynamicImport.ts"],"sourcesContent":[null],"mappings":"AAEO,MAAMA,aAAA,GAAiBC,IAAA,IAAiB;EAC7C,OAAIC,aAAY,cAGd;EAEAD,IAAgC,GAClC;IAAAE,qBAAA,EAAAA,CAAA,KAAAC,OAAA,CAAAC,GAAA,CAAAC,mBAAA,eAAAC,eAAA;EAAA;AAQA;AAAO,MACLC,oBACE,8FAEE;AAEJ,SACEC,iBAAAC,GAAuB;EAC6C,MACtEC,GAAA,GAAAD,GAAA,YAAAE,KAAA,GAAAF,GAAA,CAAAG,OAAA,GAAAC,MAAA,CAAAJ,GAAA;EAAA,OACFF,oBAAA,CAAAO,IAAA,CAAAC,CAAA,IAAAL,GAAA,CAAAM,QAAA,CAAAD,CAAA;AACF;AAEA,SAAMT,gBAAA;EAAuB,IAC3B,OAAAW,MAAA;EAAA,MAAAC,GAAA;EAAA,MACAC,IAAA,GAAAC,cAAA,CAAAC,OAAA,CAAAH,GAAA;EAAA,KAAAC,IAAA,IAAAG,IAAA,CAAAC,GAAA,KAAAC,MAAA,CAAAL,IAAA;IACAC,cAAA,CAAAK,OAAA,CAAAP,GAAA,EAAAL,MAAA,CAAAS,IAAA,CAAAC,GAAA;IAAAN,MAAA,CAAAS,QAAA,CAAAC,MAAA;IACF;EAEO;EACL,OAAM;AACN;AACF,MAAAC,oBAAA;AAOO,MAAAC,oBAAS,GAA2B;AACzC,MAAIC,SAAO,GAAAC,EAAA,IAAW,IAAAC,OAAa,CAAAC,OAAO,IAAAC,UAAA,CAAAD,OAAA,EAAAF,EAAA;AAC1C,eAAY9B,cAAAkC,MAAA,EAAAC,OAAA;EACZ,MAAAC,QAAa,GAAAD,OAAA,CAAAC,QAAe,IAAQT,oBAAG;EACvC,MAAKU,OAAA,GAAQF,OAAS,CAAAE,OAAI,IAAOT,oBAAgB;EAC/C,MAAAU,KAAA,GAAAH,OAAe,CAAAG,KAAQ,IAAKT,SAAO;EACnC,MAAAU,OAAO,GAAAJ,OAAS,CAAAlC,qBAAO,IAAAI,eAAA;EACvB,MAAAmC,OAAO,SAAAC,WAAA;IACT;MACA,OAAO,MAAAP,MAAA;IACT,SAAA1B,GAAA;MAKO,IAAMiC,WAAA;QAGN,MAAMH,KAAA,CAAAD,OAAA;QAEb,OAAMG,OAAY,CAACC,WAAmB;MAUtC;MASE,IAAAlC,gBAAiB,CAAAC,GAAQ,KAAA+B,OAAY,eAAAR,OAAA;MACrC,MAAMvB,GAAA;IACN;EACA;EAEA,OAAMgC,OAAA,CAAAJ,QAAU,CAAO;AACrB;AACE,SAAAT,oBAAoB,EAAAC,oBAAA,EAAA9B,aAAA,EAAAO,eAAA,EAAAE,gBAAA,EAAAP,aAAA","ignoreList":[]}
|
|
@@ -13,13 +13,43 @@ function isChunkLoadError(err) {
|
|
|
13
13
|
});
|
|
14
14
|
}
|
|
15
15
|
function handleSkewError() {
|
|
16
|
-
if (typeof window === "undefined") return;
|
|
16
|
+
if (typeof window === "undefined") return false;
|
|
17
17
|
var key = "__one_skew_reload";
|
|
18
18
|
var last = sessionStorage.getItem(key);
|
|
19
19
|
if (!last || Date.now() - Number(last) > 1e4) {
|
|
20
20
|
sessionStorage.setItem(key, String(Date.now()));
|
|
21
21
|
window.location.reload();
|
|
22
|
+
return true;
|
|
22
23
|
}
|
|
24
|
+
return false;
|
|
23
25
|
}
|
|
24
|
-
|
|
26
|
+
var CHUNK_RETRY_ATTEMPTS = 3;
|
|
27
|
+
var CHUNK_RETRY_DELAY_MS = 500;
|
|
28
|
+
var realDelay = function (ms) {
|
|
29
|
+
return new Promise(function (resolve) {
|
|
30
|
+
return setTimeout(resolve, ms);
|
|
31
|
+
});
|
|
32
|
+
};
|
|
33
|
+
async function loadWithRetry(loader) {
|
|
34
|
+
var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
|
|
35
|
+
var _options_attempts, _options_delayMs, _options_delay, _options_onChunkErrorExhausted;
|
|
36
|
+
var attempts = (_options_attempts = options.attempts) !== null && _options_attempts !== void 0 ? _options_attempts : CHUNK_RETRY_ATTEMPTS;
|
|
37
|
+
var delayMs = (_options_delayMs = options.delayMs) !== null && _options_delayMs !== void 0 ? _options_delayMs : CHUNK_RETRY_DELAY_MS;
|
|
38
|
+
var delay = (_options_delay = options.delay) !== null && _options_delay !== void 0 ? _options_delay : realDelay;
|
|
39
|
+
var recover = (_options_onChunkErrorExhausted = options.onChunkErrorExhausted) !== null && _options_onChunkErrorExhausted !== void 0 ? _options_onChunkErrorExhausted : handleSkewError;
|
|
40
|
+
var attempt = async function (retriesLeft) {
|
|
41
|
+
try {
|
|
42
|
+
return await loader();
|
|
43
|
+
} catch (err) {
|
|
44
|
+
if (retriesLeft > 0) {
|
|
45
|
+
await delay(delayMs);
|
|
46
|
+
return attempt(retriesLeft - 1);
|
|
47
|
+
}
|
|
48
|
+
if (isChunkLoadError(err) && recover()) return new Promise(function () {});
|
|
49
|
+
throw err;
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
return attempt(attempts);
|
|
53
|
+
}
|
|
54
|
+
export { CHUNK_RETRY_ATTEMPTS, CHUNK_RETRY_DELAY_MS, dynamicImport, handleSkewError, isChunkLoadError, loadWithRetry };
|
|
25
55
|
//# sourceMappingURL=dynamicImport.native.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_instanceof","left","right","Symbol","hasInstance","dynamicImport","path","console","info","Promise","resolve","CHUNK_ERROR_PATTERNS","isChunkLoadError","err","msg","Error","message","String","some","p","includes","handleSkewError","window","key","last","sessionStorage","getItem","Date","now","Number","setItem","location","reload"],"sources":["../../../src/utils/dynamicImport.ts"],"sourcesContent":[null],"mappings":"AAEO,SAAMA,YAAAC,IAAiB,EAAAC,KAAiB;EAC7C,IAAAA,KAAI,IAAQ,IAAI,WAAAC,MAAA,KAAmB,WAAU,IAAAD,KAAA,CAAAC,MAAA,CAAAC,WAAA,YAAAF,KAAA,CAAAC,MAAA,CAAAC,WAAA,EAAAH,IAAA,OAG3C,OAAQA,IAAK,YAAAC,KAAA;AAEb;AAAgC,IAClCG,aAAA,YAAAA,CAAAC,IAAA;
|
|
1
|
+
{"version":3,"names":["_instanceof","left","right","Symbol","hasInstance","dynamicImport","path","console","info","Promise","resolve","CHUNK_ERROR_PATTERNS","isChunkLoadError","err","msg","Error","message","String","some","p","includes","handleSkewError","window","key","last","sessionStorage","getItem","Date","now","Number","setItem","location","reload","CHUNK_RETRY_ATTEMPTS","CHUNK_RETRY_DELAY_MS","realDelay","ms","setTimeout","loadWithRetry","loader","options","arguments","length","_options_attempts","_options_delayMs","_options_delay","_options_onChunkErrorExhausted","attempts","delayMs","delay","recover","onChunkErrorExhausted","attempt","retriesLeft"],"sources":["../../../src/utils/dynamicImport.ts"],"sourcesContent":[null],"mappings":"AAEO,SAAMA,YAAAC,IAAiB,EAAAC,KAAiB;EAC7C,IAAAA,KAAI,IAAQ,IAAI,WAAAC,MAAA,KAAmB,WAAU,IAAAD,KAAA,CAAAC,MAAA,CAAAC,WAAA,YAAAF,KAAA,CAAAC,MAAA,CAAAC,WAAA,EAAAH,IAAA,OAG3C,OAAQA,IAAK,YAAAC,KAAA;AAEb;AAAgC,IAClCG,aAAA,YAAAA,CAAAC,IAAA;EAQAC,OAAA,CAAOC,IAAA,uBAAAF,IAAA;EAAA,OACLG,OACE,CAAAC,OAAA;AAAA;AAAA,IAAAC,oBAEE,8FAEJ,oCAEI,CAAkE;AACtE,SACFC,iBAAAC,GAAA;EACF,IAAAC,GAAA,GAAAd,WAAA,CAAAa,GAAA,EAAAE,KAAA,IAAAF,GAAA,CAAAG,OAAA,GAAAC,MAAA,CAAAJ,GAAA;EAEA,OAAMF,oBAAA,CAAuBO,IAAA,WAAAC,CAAA;IAC3B,OAAAL,GAAA,CAAAM,QAAA,CAAAD,CAAA;EAAA;AAAA;AACA,SAAAE,gBAAA;EAAA,IACA,OAAAC,MAAA;EAAA,IAAAC,GAAA;EACF,IAAAC,IAAA,GAAAC,cAAA,CAAAC,OAAA,CAAAH,GAAA;EAEO,KAAAC,IAAS,IAAAG,IAAA,CAAAC,GAAA,KAAiBC,MAAuB,CAAAL,IAAA;IACtDC,cAAY,CAAAK,OAAA,CAAAP,GAAA,EAAeN,MAAA,CAAQU,IAAI,CAAAC,GAAA;IACvCN,MAAA,CAAOS,QAAA,CAAAC,MAAA;IACT;EAOO;EACL,OAAI,KAAO;AACX;AACA,IAAAC,oBAAa;AACb,IAAAC,oBAAsB,MAAI;AACxB,IAAAC,SAAA,YAAAA,CAAeC,EAAQ;EACvB,WAAO3B,OAAA,CAAS,UAAOC,OAAA;IACvB,OAAA2B,UAAO,CAAA3B,OAAA,EAAA0B,EAAA;EAAA,CACT;AACA;AACF,eAAAE,cAAAC,MAAA;EAKO,IAAAC,OAAM,GAAAC,SAAA,CAAAC,MAAuB,QAAAD,SAAA,iBAAAA,SAAA;EAG7B,IAAAE,iBAAM,EAAAC,gBAAuB,EAAAC,cAAA,EAAAC,8BAAA;EAEpC,IAAAC,QAAM,IAAAJ,iBAAgC,GAAAH,OAAe,CAAAO,QAAY,UAAW,IAAAJ,iBAAY,cAAAA,iBAAA,GAAAV,oBAAA;EAUxF,IAAAe,OAAA,GAAsB,CAAAJ,gBACpB,GAAAJ,OACA,CAAAQ,OAKK,MACO,QAAAJ,gBAAA,cAAAA,gBAAA,GAAAV,oBAAA;EACZ,IAAAe,KAAM,IAAAJ,cAAmB,GAAAL,OAAA,CAAYS,KAAA,cAAAJ,cAAA,cAAAA,cAAA,GAAAV,SAAA;EACrC,IAAAe,OAAM,IAAAJ,8BAA6B,GAAAN,OAAA,CAAAW,qBAAA,cAAAL,8BAAA,cAAAA,8BAAA,GAAAzB,eAAA;EACnC,IAAA+B,OAAM,kBAAAA,CAAgBC,WAAS;IAC/B;MAEA,OAAM,MAAAd,MAAU;IACd,SAAI1B,GAAA;MACF,IAAAwC,WAAO,GAAM;QACf,MAAAJ,KAAS,CAAAD,OAAK;QACZ,OAAII,OAAA,CAAAC,WAAiB;MACnB;MACA,IAAAzC,gBAAe,CAAAC,GAAA,KAAAqC,OAAe,eAAAzC,OAAA;MAAA,MAChCI,GAAA;IAMA;EACE;EAA4B,OAACuC,OAAC,CAAAL,QAAA;AAAA;AAEhC,SAAAd,oBAAM,EAAAC,oBAAA,EAAA7B,aAAA,EAAAgB,eAAA,EAAAT,gBAAA,EAAA0B,aAAA","ignoreList":[]}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from "vitest";
|
|
2
|
+
import { isChunkLoadError, loadWithRetry } from "./dynamicImport.mjs";
|
|
3
|
+
const instantDelay = () => Promise.resolve();
|
|
4
|
+
const chunkError = () => new Error("Failed to fetch dynamically imported module: /assets/EditorPane.js");
|
|
5
|
+
const drain = () => new Promise(r => setTimeout(r, 0));
|
|
6
|
+
describe("isChunkLoadError", () => {
|
|
7
|
+
it("matches the chrome / firefox / safari chunk-load messages, nothing else", () => {
|
|
8
|
+
expect(isChunkLoadError(new Error("Failed to fetch dynamically imported module: /a"))).toBe(true);
|
|
9
|
+
expect(isChunkLoadError(new Error("error loading dynamically imported module: /a"))).toBe(true);
|
|
10
|
+
expect(isChunkLoadError(new Error("Importing a module script failed."))).toBe(true);
|
|
11
|
+
expect(isChunkLoadError("Failed to fetch dynamically imported module")).toBe(true);
|
|
12
|
+
expect(isChunkLoadError(new Error("TypeError: x is not a function"))).toBe(false);
|
|
13
|
+
});
|
|
14
|
+
});
|
|
15
|
+
describe("loadWithRetry", () => {
|
|
16
|
+
it("resolves on first success without retrying or recovering", async () => {
|
|
17
|
+
const loader = vi.fn().mockResolvedValue({
|
|
18
|
+
default: "ok"
|
|
19
|
+
});
|
|
20
|
+
const delay = vi.fn(instantDelay);
|
|
21
|
+
const onChunkErrorExhausted = vi.fn(() => false);
|
|
22
|
+
await expect(loadWithRetry(loader, {
|
|
23
|
+
delay,
|
|
24
|
+
onChunkErrorExhausted
|
|
25
|
+
})).resolves.toEqual({
|
|
26
|
+
default: "ok"
|
|
27
|
+
});
|
|
28
|
+
expect(loader).toHaveBeenCalledTimes(1);
|
|
29
|
+
expect(delay).not.toHaveBeenCalled();
|
|
30
|
+
expect(onChunkErrorExhausted).not.toHaveBeenCalled();
|
|
31
|
+
});
|
|
32
|
+
it("retries a transient rejection then resolves, re-invoking the loader each attempt", async () => {
|
|
33
|
+
const loader = vi.fn().mockRejectedValueOnce(chunkError()).mockRejectedValueOnce(chunkError()).mockResolvedValue({
|
|
34
|
+
default: "ok"
|
|
35
|
+
});
|
|
36
|
+
const delay = vi.fn(instantDelay);
|
|
37
|
+
const onChunkErrorExhausted = vi.fn(() => false);
|
|
38
|
+
await expect(loadWithRetry(loader, {
|
|
39
|
+
attempts: 3,
|
|
40
|
+
delay,
|
|
41
|
+
onChunkErrorExhausted
|
|
42
|
+
})).resolves.toEqual({
|
|
43
|
+
default: "ok"
|
|
44
|
+
});
|
|
45
|
+
expect(loader).toHaveBeenCalledTimes(3);
|
|
46
|
+
expect(delay).toHaveBeenCalledTimes(2);
|
|
47
|
+
expect(onChunkErrorExhausted).not.toHaveBeenCalled();
|
|
48
|
+
});
|
|
49
|
+
it("exhausts retries on a persistent chunk error, recovers once, and stays pending", async () => {
|
|
50
|
+
const loader = vi.fn().mockRejectedValue(chunkError());
|
|
51
|
+
const delay = vi.fn(instantDelay);
|
|
52
|
+
const onChunkErrorExhausted = vi.fn(() => true);
|
|
53
|
+
const settled = vi.fn();
|
|
54
|
+
void loadWithRetry(loader, {
|
|
55
|
+
attempts: 2,
|
|
56
|
+
delay,
|
|
57
|
+
onChunkErrorExhausted
|
|
58
|
+
}).then(settled, settled);
|
|
59
|
+
await drain();
|
|
60
|
+
expect(loader).toHaveBeenCalledTimes(3);
|
|
61
|
+
expect(onChunkErrorExhausted).toHaveBeenCalledTimes(1);
|
|
62
|
+
expect(settled).not.toHaveBeenCalled();
|
|
63
|
+
});
|
|
64
|
+
it("rethrows a non-chunk error without recovering", async () => {
|
|
65
|
+
const loader = vi.fn().mockRejectedValue(new Error("boom: a real bug"));
|
|
66
|
+
const delay = vi.fn(instantDelay);
|
|
67
|
+
const onChunkErrorExhausted = vi.fn(() => true);
|
|
68
|
+
await expect(loadWithRetry(loader, {
|
|
69
|
+
attempts: 1,
|
|
70
|
+
delay,
|
|
71
|
+
onChunkErrorExhausted
|
|
72
|
+
})).rejects.toThrow("boom: a real bug");
|
|
73
|
+
expect(loader).toHaveBeenCalledTimes(2);
|
|
74
|
+
expect(onChunkErrorExhausted).not.toHaveBeenCalled();
|
|
75
|
+
});
|
|
76
|
+
it("rethrows a chunk error when the reload was debounced away", async () => {
|
|
77
|
+
const loader = vi.fn().mockRejectedValue(chunkError());
|
|
78
|
+
const delay = vi.fn(instantDelay);
|
|
79
|
+
const onChunkErrorExhausted = vi.fn(() => false);
|
|
80
|
+
await expect(loadWithRetry(loader, {
|
|
81
|
+
attempts: 1,
|
|
82
|
+
delay,
|
|
83
|
+
onChunkErrorExhausted
|
|
84
|
+
})).rejects.toThrow("Failed to fetch dynamically imported module");
|
|
85
|
+
expect(onChunkErrorExhausted).toHaveBeenCalledTimes(1);
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
//# sourceMappingURL=dynamicImport.test.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["describe","expect","it","vi","isChunkLoadError","loadWithRetry","instantDelay","Promise","resolve","chunkError","Error","drain","r","setTimeout","toBe","loader","fn","mockResolvedValue","default","delay","onChunkErrorExhausted","resolves","toEqual","toHaveBeenCalledTimes","not","toHaveBeenCalled","mockRejectedValueOnce","attempts","mockRejectedValue","settled","then","rejects","toThrow"],"sources":["../../../src/utils/dynamicImport.test.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from "vitest";
|
|
2
|
+
import { isChunkLoadError, loadWithRetry } from "./dynamicImport.native.js";
|
|
3
|
+
var instantDelay = function () {
|
|
4
|
+
return Promise.resolve();
|
|
5
|
+
};
|
|
6
|
+
var chunkError = function () {
|
|
7
|
+
return new Error("Failed to fetch dynamically imported module: /assets/EditorPane.js");
|
|
8
|
+
};
|
|
9
|
+
var drain = function () {
|
|
10
|
+
return new Promise(function (r) {
|
|
11
|
+
return setTimeout(r, 0);
|
|
12
|
+
});
|
|
13
|
+
};
|
|
14
|
+
describe("isChunkLoadError", function () {
|
|
15
|
+
it("matches the chrome / firefox / safari chunk-load messages, nothing else", function () {
|
|
16
|
+
expect(isChunkLoadError(new Error("Failed to fetch dynamically imported module: /a"))).toBe(true);
|
|
17
|
+
expect(isChunkLoadError(new Error("error loading dynamically imported module: /a"))).toBe(true);
|
|
18
|
+
expect(isChunkLoadError(new Error("Importing a module script failed."))).toBe(true);
|
|
19
|
+
expect(isChunkLoadError("Failed to fetch dynamically imported module")).toBe(true);
|
|
20
|
+
expect(isChunkLoadError(new Error("TypeError: x is not a function"))).toBe(false);
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
describe("loadWithRetry", function () {
|
|
24
|
+
it("resolves on first success without retrying or recovering", async function () {
|
|
25
|
+
var loader = vi.fn().mockResolvedValue({
|
|
26
|
+
default: "ok"
|
|
27
|
+
});
|
|
28
|
+
var delay = vi.fn(instantDelay);
|
|
29
|
+
var onChunkErrorExhausted = vi.fn(function () {
|
|
30
|
+
return false;
|
|
31
|
+
});
|
|
32
|
+
await expect(loadWithRetry(loader, {
|
|
33
|
+
delay,
|
|
34
|
+
onChunkErrorExhausted
|
|
35
|
+
})).resolves.toEqual({
|
|
36
|
+
default: "ok"
|
|
37
|
+
});
|
|
38
|
+
expect(loader).toHaveBeenCalledTimes(1);
|
|
39
|
+
expect(delay).not.toHaveBeenCalled();
|
|
40
|
+
expect(onChunkErrorExhausted).not.toHaveBeenCalled();
|
|
41
|
+
});
|
|
42
|
+
it("retries a transient rejection then resolves, re-invoking the loader each attempt", async function () {
|
|
43
|
+
var loader = vi.fn().mockRejectedValueOnce(chunkError()).mockRejectedValueOnce(chunkError()).mockResolvedValue({
|
|
44
|
+
default: "ok"
|
|
45
|
+
});
|
|
46
|
+
var delay = vi.fn(instantDelay);
|
|
47
|
+
var onChunkErrorExhausted = vi.fn(function () {
|
|
48
|
+
return false;
|
|
49
|
+
});
|
|
50
|
+
await expect(loadWithRetry(loader, {
|
|
51
|
+
attempts: 3,
|
|
52
|
+
delay,
|
|
53
|
+
onChunkErrorExhausted
|
|
54
|
+
})).resolves.toEqual({
|
|
55
|
+
default: "ok"
|
|
56
|
+
});
|
|
57
|
+
expect(loader).toHaveBeenCalledTimes(3);
|
|
58
|
+
expect(delay).toHaveBeenCalledTimes(2);
|
|
59
|
+
expect(onChunkErrorExhausted).not.toHaveBeenCalled();
|
|
60
|
+
});
|
|
61
|
+
it("exhausts retries on a persistent chunk error, recovers once, and stays pending", async function () {
|
|
62
|
+
var loader = vi.fn().mockRejectedValue(chunkError());
|
|
63
|
+
var delay = vi.fn(instantDelay);
|
|
64
|
+
var onChunkErrorExhausted = vi.fn(function () {
|
|
65
|
+
return true;
|
|
66
|
+
});
|
|
67
|
+
var settled = vi.fn();
|
|
68
|
+
void loadWithRetry(loader, {
|
|
69
|
+
attempts: 2,
|
|
70
|
+
delay,
|
|
71
|
+
onChunkErrorExhausted
|
|
72
|
+
}).then(settled, settled);
|
|
73
|
+
await drain();
|
|
74
|
+
expect(loader).toHaveBeenCalledTimes(3);
|
|
75
|
+
expect(onChunkErrorExhausted).toHaveBeenCalledTimes(1);
|
|
76
|
+
expect(settled).not.toHaveBeenCalled();
|
|
77
|
+
});
|
|
78
|
+
it("rethrows a non-chunk error without recovering", async function () {
|
|
79
|
+
var loader = vi.fn().mockRejectedValue(new Error("boom: a real bug"));
|
|
80
|
+
var delay = vi.fn(instantDelay);
|
|
81
|
+
var onChunkErrorExhausted = vi.fn(function () {
|
|
82
|
+
return true;
|
|
83
|
+
});
|
|
84
|
+
await expect(loadWithRetry(loader, {
|
|
85
|
+
attempts: 1,
|
|
86
|
+
delay,
|
|
87
|
+
onChunkErrorExhausted
|
|
88
|
+
})).rejects.toThrow("boom: a real bug");
|
|
89
|
+
expect(loader).toHaveBeenCalledTimes(2);
|
|
90
|
+
expect(onChunkErrorExhausted).not.toHaveBeenCalled();
|
|
91
|
+
});
|
|
92
|
+
it("rethrows a chunk error when the reload was debounced away", async function () {
|
|
93
|
+
var loader = vi.fn().mockRejectedValue(chunkError());
|
|
94
|
+
var delay = vi.fn(instantDelay);
|
|
95
|
+
var onChunkErrorExhausted = vi.fn(function () {
|
|
96
|
+
return false;
|
|
97
|
+
});
|
|
98
|
+
await expect(loadWithRetry(loader, {
|
|
99
|
+
attempts: 1,
|
|
100
|
+
delay,
|
|
101
|
+
onChunkErrorExhausted
|
|
102
|
+
})).rejects.toThrow("Failed to fetch dynamically imported module");
|
|
103
|
+
expect(onChunkErrorExhausted).toHaveBeenCalledTimes(1);
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
//# sourceMappingURL=dynamicImport.test.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["describe","expect","it","vi","isChunkLoadError","loadWithRetry","instantDelay","Promise","resolve","chunkError","Error","drain","r","setTimeout","toBe","loader","fn","mockResolvedValue","default","delay","onChunkErrorExhausted","resolves","toEqual","toHaveBeenCalledTimes","not","toHaveBeenCalled","mockRejectedValueOnce","attempts","mockRejectedValue","settled","then"],"sources":["../../../src/utils/dynamicImport.test.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { posix } from "node:path";
|
|
2
|
+
import { pathToFileURL } from "node:url";
|
|
3
|
+
import { describe, expect, it } from "vitest";
|
|
4
|
+
import { normalizePath } from "vite";
|
|
5
|
+
import { toServerOutputPath } from "./toServerOutputPath.mjs";
|
|
6
|
+
describe("path.posix.join \u2014 forward-slash output on every platform", () => {
|
|
7
|
+
it("joins server-output paths", () => {
|
|
8
|
+
expect(posix.join("dist", "server", "foo.js")).toBe("dist/server/foo.js");
|
|
9
|
+
});
|
|
10
|
+
it("joins middleware-output paths", () => {
|
|
11
|
+
expect(posix.join("dist", "middlewares", "mw-hash.js")).toBe("dist/middlewares/mw-hash.js");
|
|
12
|
+
});
|
|
13
|
+
it("strips redundant `./` segments", () => {
|
|
14
|
+
expect(posix.join("./app", "./_layout.tsx")).toBe("app/_layout.tsx");
|
|
15
|
+
});
|
|
16
|
+
it("produces a bare filename for a `.` directory component", () => {
|
|
17
|
+
expect(posix.join(".", "foo-[hash].cjs")).toBe("foo-[hash].cjs");
|
|
18
|
+
});
|
|
19
|
+
it("preserves nested-chunk subdirectories", () => {
|
|
20
|
+
expect(posix.join("subdir", "foo-[hash].cjs")).toBe("subdir/foo-[hash].cjs");
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
describe("pathToFileURL \u2014 canonical file:// URL specifier", () => {
|
|
24
|
+
it("produces a forward-slash href on every platform", () => {
|
|
25
|
+
const href = pathToFileURL("/proj/src/setup.ts").href;
|
|
26
|
+
expect(href.startsWith("file://")).toBe(true);
|
|
27
|
+
expect(href.includes("\\")).toBe(false);
|
|
28
|
+
});
|
|
29
|
+
it("round-trips through JSON.stringify without backslashes leaking in", () => {
|
|
30
|
+
const href = pathToFileURL("/proj/src/setup.ts").href;
|
|
31
|
+
const stringified = JSON.stringify(href);
|
|
32
|
+
expect(stringified.includes("\\\\")).toBe(false);
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
describe("Vite normalizePath \u2014 converts on Windows, no-op on POSIX", () => {
|
|
36
|
+
it("preserves a forward-slash path unchanged", () => {
|
|
37
|
+
expect(normalizePath("/proj/src/foo.tsx")).toBe("/proj/src/foo.tsx");
|
|
38
|
+
});
|
|
39
|
+
it("converts backslashes (Windows-shaped input)", () => {
|
|
40
|
+
const input = String.raw`C:\proj\src\foo.tsx`;
|
|
41
|
+
const out = normalizePath(input);
|
|
42
|
+
if (process.platform === "win32") {
|
|
43
|
+
expect(out).toBe("C:/proj/src/foo.tsx");
|
|
44
|
+
} else {
|
|
45
|
+
expect(out).toBe(input);
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
describe("toServerOutputPath \u2014 cross-platform parity", () => {
|
|
50
|
+
const cases = [["foo.js", "dist", "dist/server/foo.js"], ["subdir/bar.js", "dist", "dist/server/subdir/bar.js"], ["dist/server/foo.js", "dist", "dist/server/foo.js"], [String.raw`dist\server\foo.js`, "dist", "dist/server/foo.js"], [String.raw`subdir\bar.js`, "dist", "dist/server/subdir/bar.js"], ["foo/dist/server/bar.js", "dist", "dist/server/foo/dist/server/bar.js"], ["dist/server", "dist", "dist/server"], ["baz.js", "build", "build/server/baz.js"]];
|
|
51
|
+
for (const [input, outDir, expected] of cases) {
|
|
52
|
+
it(`("${input}", "${outDir}") \u2192 "${expected}"`, () => {
|
|
53
|
+
expect(toServerOutputPath(input, outDir)).toBe(expected);
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
describe("seed bug regression \u2014 SSR loader path doubling on Windows", () => {
|
|
58
|
+
it("does not double-prefix backslash-shaped server-output input", () => {
|
|
59
|
+
const windowsShapedInput = String.raw`dist\server\assets\time_ssr-COqAsxju.js`;
|
|
60
|
+
expect(toServerOutputPath(windowsShapedInput, "dist")).toBe("dist/server/assets/time_ssr-COqAsxju.js");
|
|
61
|
+
});
|
|
62
|
+
it("does not double-prefix already-forward-slashed input", () => {
|
|
63
|
+
const posixInput = "dist/server/assets/time_ssr-COqAsxju.js";
|
|
64
|
+
expect(toServerOutputPath(posixInput, "dist")).toBe(posixInput);
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
//# sourceMappingURL=posixPathContract.test.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["posix","pathToFileURL","describe","expect","it","normalizePath","toServerOutputPath","join","toBe","href","startsWith","includes","stringified","JSON","stringify","input","String","raw","out","process","platform","cases","outDir","expected","windowsShapedInput","posixInput"],"sources":["../../../src/utils/posixPathContract.test.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|