@rangojs/router 0.0.0-experimental.124 → 0.0.0-experimental.125

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.
Files changed (1009) hide show
  1. package/dist/bin/rango.js +3 -4
  2. package/dist/vite/index.js +9 -43
  3. package/package.json +1 -1
  4. package/skills/hooks/SKILL.md +2 -2
  5. package/skills/route/SKILL.md +6 -0
  6. package/src/__internal.ts +0 -65
  7. package/src/browser/action-coordinator.ts +1 -1
  8. package/src/browser/action-fence.ts +10 -0
  9. package/src/browser/event-controller.ts +1 -83
  10. package/src/browser/navigation-store-handle.ts +3 -4
  11. package/src/browser/navigation-store.ts +0 -39
  12. package/src/browser/navigation-transaction.ts +0 -32
  13. package/src/browser/partial-update.ts +1 -83
  14. package/src/browser/prefetch/cache.ts +6 -45
  15. package/src/browser/prefetch/queue.ts +6 -3
  16. package/src/browser/rango-state.ts +2 -23
  17. package/src/browser/react/Link.tsx +0 -2
  18. package/src/browser/react/NavigationProvider.tsx +2 -1
  19. package/src/browser/react/ScrollRestoration.tsx +10 -6
  20. package/src/browser/react/filter-segment-order.ts +0 -2
  21. package/src/browser/react/index.ts +0 -45
  22. package/src/browser/react/location-state-shared.ts +0 -13
  23. package/src/browser/react/location-state.ts +0 -1
  24. package/src/browser/react/use-action.ts +6 -15
  25. package/src/browser/react/use-handle.ts +0 -5
  26. package/src/browser/react/use-link-status.ts +0 -4
  27. package/src/browser/react/use-navigation.ts +0 -3
  28. package/src/browser/react/use-params.ts +0 -2
  29. package/src/browser/react/use-search-params.ts +0 -5
  30. package/src/browser/react/use-segments.ts +0 -13
  31. package/src/browser/rsc-router.tsx +2 -2
  32. package/src/browser/types.ts +0 -1
  33. package/src/browser/validate-redirect-origin.ts +4 -5
  34. package/src/build/route-trie.ts +3 -0
  35. package/src/build/route-types/param-extraction.ts +6 -3
  36. package/src/build/route-types/router-processing.ts +0 -8
  37. package/src/cache/cache-policy.ts +0 -54
  38. package/src/cache/cache-runtime.ts +27 -24
  39. package/src/cache/cache-scope.ts +0 -27
  40. package/src/cache/cache-tag.ts +0 -37
  41. package/src/cache/cf/cf-cache-store.ts +72 -45
  42. package/src/cache/cf/index.ts +0 -24
  43. package/src/cache/document-cache.ts +0 -36
  44. package/src/cache/handle-snapshot.ts +0 -40
  45. package/src/cache/index.ts +0 -27
  46. package/src/cache/memory-segment-store.ts +0 -52
  47. package/src/cache/profile-registry.ts +7 -3
  48. package/src/cache/read-through-swr.ts +41 -11
  49. package/src/cache/segment-codec.ts +0 -16
  50. package/src/cache/types.ts +0 -98
  51. package/src/client.rsc.tsx +1 -22
  52. package/src/client.tsx +14 -32
  53. package/src/deps/ssr.ts +0 -1
  54. package/src/handle.ts +2 -12
  55. package/src/handles/MetaTags.tsx +0 -14
  56. package/src/handles/meta.ts +0 -39
  57. package/src/host/cookie-handler.ts +0 -36
  58. package/src/host/errors.ts +0 -24
  59. package/src/host/index.ts +6 -0
  60. package/src/host/pattern-matcher.ts +7 -50
  61. package/src/host/router.ts +1 -65
  62. package/src/host/testing.ts +0 -16
  63. package/src/host/types.ts +6 -2
  64. package/src/href-client.ts +0 -4
  65. package/src/index.rsc.ts +20 -2
  66. package/src/internal-debug.ts +2 -4
  67. package/src/loader.rsc.ts +4 -15
  68. package/src/loader.ts +3 -9
  69. package/src/network-error-thrower.tsx +1 -6
  70. package/src/outlet-provider.tsx +1 -5
  71. package/src/prerender/param-hash.ts +10 -11
  72. package/src/prerender/store.ts +23 -30
  73. package/src/prerender.ts +34 -0
  74. package/src/root-error-boundary.tsx +1 -19
  75. package/src/route-content-wrapper.tsx +1 -44
  76. package/src/route-definition/dsl-helpers.ts +7 -19
  77. package/src/route-definition/helpers-types.ts +3 -3
  78. package/src/route-definition/redirect.ts +11 -1
  79. package/src/route-map-builder.ts +0 -16
  80. package/src/router/content-negotiation.ts +0 -13
  81. package/src/router/error-handling.ts +12 -16
  82. package/src/router/find-match.ts +4 -30
  83. package/src/router/intercept-resolution.ts +10 -1
  84. package/src/router/lazy-includes.ts +1 -57
  85. package/src/router/loader-resolution.ts +3 -2
  86. package/src/router/logging.ts +0 -6
  87. package/src/router/manifest.ts +1 -25
  88. package/src/router/match-api.ts +0 -20
  89. package/src/router/match-context.ts +0 -22
  90. package/src/router/match-handlers.ts +0 -43
  91. package/src/router/match-middleware/background-revalidation.ts +0 -7
  92. package/src/router/match-middleware/cache-lookup.ts +1 -54
  93. package/src/router/match-middleware/cache-store.ts +0 -31
  94. package/src/router/match-middleware/intercept-resolution.ts +0 -22
  95. package/src/router/match-middleware/segment-resolution.ts +0 -21
  96. package/src/router/match-pipelines.ts +1 -42
  97. package/src/router/match-result.ts +1 -52
  98. package/src/router/metrics.ts +0 -34
  99. package/src/router/middleware-cookies.ts +0 -13
  100. package/src/router/middleware-types.ts +0 -115
  101. package/src/router/middleware.ts +7 -30
  102. package/src/router/navigation-snapshot.ts +0 -51
  103. package/src/router/params-util.ts +23 -0
  104. package/src/router/pattern-matching.ts +1 -33
  105. package/src/router/prerender-match.ts +29 -45
  106. package/src/router/request-classification.ts +1 -38
  107. package/src/router/revalidation.ts +5 -58
  108. package/src/router/router-context.ts +0 -26
  109. package/src/router/segment-resolution/fresh.ts +25 -57
  110. package/src/router/segment-resolution/helpers.ts +34 -0
  111. package/src/router/segment-resolution/loader-cache.ts +10 -13
  112. package/src/router/segment-resolution/revalidation.ts +5 -42
  113. package/src/router/segment-resolution/streamed-handler-telemetry.ts +52 -0
  114. package/src/router/segment-resolution.ts +4 -1
  115. package/src/router/telemetry-otel.ts +0 -20
  116. package/src/router/telemetry.ts +0 -22
  117. package/src/router/timeout.ts +0 -20
  118. package/src/router/trie-matching.ts +63 -40
  119. package/src/router/types.ts +1 -63
  120. package/src/router/url-params.ts +0 -5
  121. package/src/router.ts +4 -2
  122. package/src/rsc/handler.ts +11 -2
  123. package/src/rsc/helpers.ts +15 -0
  124. package/src/rsc/origin-guard.ts +0 -12
  125. package/src/rsc/progressive-enhancement.ts +2 -1
  126. package/src/rsc/rsc-rendering.ts +2 -7
  127. package/src/rsc/runtime-warnings.ts +14 -0
  128. package/src/rsc/server-action.ts +30 -28
  129. package/src/rsc/types.ts +0 -1
  130. package/src/search-params.ts +0 -16
  131. package/src/segment-loader-promise.ts +14 -2
  132. package/src/segment-system.tsx +79 -88
  133. package/src/server/handle-store.ts +7 -24
  134. package/src/server/loader-registry.ts +5 -24
  135. package/src/server/request-context.ts +6 -78
  136. package/src/ssr/index.tsx +14 -14
  137. package/src/static-handler.ts +2 -27
  138. package/src/testing/cache-status.ts +0 -47
  139. package/src/testing/collect-handle.ts +1 -24
  140. package/src/testing/e2e/index.ts +0 -22
  141. package/src/testing/e2e/matchers.ts +0 -16
  142. package/src/testing/flight-matchers.ts +0 -13
  143. package/src/testing/flight-normalize.ts +3 -30
  144. package/src/testing/flight.ts +0 -48
  145. package/src/testing/generated-routes.ts +1 -41
  146. package/src/testing/index.ts +0 -21
  147. package/src/testing/internal/context.ts +3 -45
  148. package/src/testing/internal/seed-vars.ts +0 -26
  149. package/src/testing/render-handler.ts +0 -49
  150. package/src/testing/render-route.tsx +0 -90
  151. package/src/testing/run-loader.ts +0 -96
  152. package/src/testing/run-middleware.ts +0 -26
  153. package/src/theme/ThemeProvider.tsx +0 -52
  154. package/src/theme/ThemeScript.tsx +0 -6
  155. package/src/theme/constants.ts +0 -12
  156. package/src/theme/index.ts +0 -7
  157. package/src/theme/theme-context.ts +1 -5
  158. package/src/theme/theme-script.ts +0 -14
  159. package/src/theme/use-theme.ts +0 -3
  160. package/src/types/boundaries.ts +0 -35
  161. package/src/types/error-types.ts +25 -89
  162. package/src/types/global-namespace.ts +4 -14
  163. package/src/types/handler-context.ts +0 -8
  164. package/src/types/index.ts +0 -10
  165. package/src/types/request-scope.ts +0 -19
  166. package/src/types/route-config.ts +6 -50
  167. package/src/types/route-entry.ts +0 -6
  168. package/src/types/segments.ts +0 -13
  169. package/src/urls/include-helper.ts +0 -4
  170. package/src/urls/index.ts +0 -6
  171. package/src/urls/path-helper-types.ts +2 -2
  172. package/src/urls/path-helper.ts +0 -54
  173. package/src/urls/urls-function.ts +0 -13
  174. package/src/use-loader.tsx +0 -186
  175. package/src/vite/discovery/bundle-postprocess.ts +2 -1
  176. package/src/vite/discovery/discover-routers.ts +6 -7
  177. package/src/vite/discovery/virtual-module-codegen.ts +1 -11
  178. package/src/vite/plugin-types.ts +3 -1
  179. package/src/vite/plugins/cjs-to-esm.ts +0 -11
  180. package/src/vite/plugins/client-ref-dedup.ts +0 -11
  181. package/src/vite/plugins/client-ref-hashing.ts +0 -10
  182. package/src/vite/plugins/cloudflare-protocol-stub.ts +0 -20
  183. package/src/vite/plugins/expose-action-id.ts +2 -73
  184. package/src/vite/plugins/expose-id-utils.ts +0 -55
  185. package/src/vite/plugins/expose-ids/export-analysis.ts +0 -38
  186. package/src/vite/plugins/expose-ids/handler-transform.ts +0 -15
  187. package/src/vite/plugins/expose-ids/loader-transform.ts +0 -15
  188. package/src/vite/plugins/expose-ids/router-transform.ts +0 -13
  189. package/src/vite/plugins/expose-internal-ids.ts +10 -0
  190. package/src/vite/plugins/performance-tracks.ts +0 -3
  191. package/src/vite/plugins/use-cache-transform.ts +0 -36
  192. package/src/vite/plugins/version-injector.ts +0 -20
  193. package/src/vite/plugins/version-plugin.ts +1 -49
  194. package/src/vite/plugins/virtual-entries.ts +0 -15
  195. package/src/vite/rango.ts +1 -108
  196. package/src/vite/router-discovery.ts +2 -1
  197. package/src/vite/utils/ast-handler-extract.ts +0 -16
  198. package/src/vite/utils/bundle-analysis.ts +6 -13
  199. package/src/vite/utils/client-chunks.ts +0 -6
  200. package/src/vite/utils/forward-user-plugins.ts +0 -22
  201. package/src/vite/utils/manifest-utils.ts +0 -4
  202. package/src/vite/utils/package-resolution.ts +1 -73
  203. package/src/vite/utils/prerender-utils.ts +0 -35
  204. package/src/vite/utils/shared-utils.ts +3 -35
  205. package/dist/__internal.d.ts +0 -83
  206. package/dist/__internal.d.ts.map +0 -1
  207. package/dist/__internal.js +0 -19
  208. package/dist/__internal.js.map +0 -1
  209. package/dist/__mocks__/version.d.ts +0 -7
  210. package/dist/__mocks__/version.d.ts.map +0 -1
  211. package/dist/__mocks__/version.js +0 -7
  212. package/dist/__mocks__/version.js.map +0 -1
  213. package/dist/__tests__/client-href.test.d.ts +0 -2
  214. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  215. package/dist/__tests__/client-href.test.js +0 -74
  216. package/dist/__tests__/client-href.test.js.map +0 -1
  217. package/dist/__tests__/component-utils.test.d.ts +0 -2
  218. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  219. package/dist/__tests__/component-utils.test.js +0 -51
  220. package/dist/__tests__/component-utils.test.js.map +0 -1
  221. package/dist/__tests__/event-controller.test.d.ts +0 -2
  222. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  223. package/dist/__tests__/event-controller.test.js +0 -538
  224. package/dist/__tests__/event-controller.test.js.map +0 -1
  225. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  226. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  227. package/dist/__tests__/helpers/route-tree.js +0 -374
  228. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  229. package/dist/__tests__/match-result.test.d.ts +0 -2
  230. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  231. package/dist/__tests__/match-result.test.js +0 -154
  232. package/dist/__tests__/match-result.test.js.map +0 -1
  233. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  234. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  235. package/dist/__tests__/navigation-store.test.js +0 -440
  236. package/dist/__tests__/navigation-store.test.js.map +0 -1
  237. package/dist/__tests__/partial-update.test.d.ts +0 -2
  238. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  239. package/dist/__tests__/partial-update.test.js +0 -1009
  240. package/dist/__tests__/partial-update.test.js.map +0 -1
  241. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  242. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  243. package/dist/__tests__/reverse-types.test.js +0 -656
  244. package/dist/__tests__/reverse-types.test.js.map +0 -1
  245. package/dist/__tests__/route-definition.test.d.ts +0 -2
  246. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  247. package/dist/__tests__/route-definition.test.js +0 -55
  248. package/dist/__tests__/route-definition.test.js.map +0 -1
  249. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  250. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  251. package/dist/__tests__/router-helpers.test.js +0 -377
  252. package/dist/__tests__/router-helpers.test.js.map +0 -1
  253. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  254. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  255. package/dist/__tests__/router-integration-2.test.js +0 -426
  256. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  257. package/dist/__tests__/router-integration.test.d.ts +0 -2
  258. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  259. package/dist/__tests__/router-integration.test.js +0 -1051
  260. package/dist/__tests__/router-integration.test.js.map +0 -1
  261. package/dist/__tests__/search-params.test.d.ts +0 -5
  262. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  263. package/dist/__tests__/search-params.test.js +0 -306
  264. package/dist/__tests__/search-params.test.js.map +0 -1
  265. package/dist/__tests__/segment-system.test.d.ts +0 -2
  266. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  267. package/dist/__tests__/segment-system.test.js +0 -627
  268. package/dist/__tests__/segment-system.test.js.map +0 -1
  269. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  270. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  271. package/dist/__tests__/static-handler-types.test.js +0 -63
  272. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  273. package/dist/__tests__/urls.test.d.ts +0 -2
  274. package/dist/__tests__/urls.test.d.ts.map +0 -1
  275. package/dist/__tests__/urls.test.js +0 -421
  276. package/dist/__tests__/urls.test.js.map +0 -1
  277. package/dist/__tests__/use-mount.test.d.ts +0 -2
  278. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  279. package/dist/__tests__/use-mount.test.js +0 -35
  280. package/dist/__tests__/use-mount.test.js.map +0 -1
  281. package/dist/bin/rango.d.ts +0 -2
  282. package/dist/bin/rango.d.ts.map +0 -1
  283. package/dist/bin/rango.js.map +0 -1
  284. package/dist/browser/event-controller.d.ts +0 -191
  285. package/dist/browser/event-controller.d.ts.map +0 -1
  286. package/dist/browser/event-controller.js +0 -559
  287. package/dist/browser/event-controller.js.map +0 -1
  288. package/dist/browser/index.d.ts +0 -2
  289. package/dist/browser/index.d.ts.map +0 -1
  290. package/dist/browser/index.js +0 -14
  291. package/dist/browser/index.js.map +0 -1
  292. package/dist/browser/link-interceptor.d.ts +0 -38
  293. package/dist/browser/link-interceptor.d.ts.map +0 -1
  294. package/dist/browser/link-interceptor.js +0 -99
  295. package/dist/browser/link-interceptor.js.map +0 -1
  296. package/dist/browser/logging.d.ts +0 -10
  297. package/dist/browser/logging.d.ts.map +0 -1
  298. package/dist/browser/logging.js +0 -29
  299. package/dist/browser/logging.js.map +0 -1
  300. package/dist/browser/lru-cache.d.ts +0 -17
  301. package/dist/browser/lru-cache.d.ts.map +0 -1
  302. package/dist/browser/lru-cache.js +0 -50
  303. package/dist/browser/lru-cache.js.map +0 -1
  304. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  305. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  306. package/dist/browser/merge-segment-loaders.js +0 -102
  307. package/dist/browser/merge-segment-loaders.js.map +0 -1
  308. package/dist/browser/navigation-bridge.d.ts +0 -102
  309. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  310. package/dist/browser/navigation-bridge.js +0 -708
  311. package/dist/browser/navigation-bridge.js.map +0 -1
  312. package/dist/browser/navigation-client.d.ts +0 -25
  313. package/dist/browser/navigation-client.d.ts.map +0 -1
  314. package/dist/browser/navigation-client.js +0 -157
  315. package/dist/browser/navigation-client.js.map +0 -1
  316. package/dist/browser/navigation-store.d.ts +0 -101
  317. package/dist/browser/navigation-store.d.ts.map +0 -1
  318. package/dist/browser/navigation-store.js +0 -625
  319. package/dist/browser/navigation-store.js.map +0 -1
  320. package/dist/browser/partial-update.d.ts +0 -75
  321. package/dist/browser/partial-update.d.ts.map +0 -1
  322. package/dist/browser/partial-update.js +0 -426
  323. package/dist/browser/partial-update.js.map +0 -1
  324. package/dist/browser/react/Link.d.ts +0 -86
  325. package/dist/browser/react/Link.d.ts.map +0 -1
  326. package/dist/browser/react/Link.js +0 -128
  327. package/dist/browser/react/Link.js.map +0 -1
  328. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  329. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  330. package/dist/browser/react/NavigationProvider.js +0 -216
  331. package/dist/browser/react/NavigationProvider.js.map +0 -1
  332. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  333. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  334. package/dist/browser/react/ScrollRestoration.js +0 -57
  335. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  336. package/dist/browser/react/context.d.ts +0 -46
  337. package/dist/browser/react/context.d.ts.map +0 -1
  338. package/dist/browser/react/context.js +0 -10
  339. package/dist/browser/react/context.js.map +0 -1
  340. package/dist/browser/react/index.d.ts +0 -11
  341. package/dist/browser/react/index.d.ts.map +0 -1
  342. package/dist/browser/react/index.js +0 -22
  343. package/dist/browser/react/index.js.map +0 -1
  344. package/dist/browser/react/location-state-shared.d.ts +0 -63
  345. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  346. package/dist/browser/react/location-state-shared.js +0 -81
  347. package/dist/browser/react/location-state-shared.js.map +0 -1
  348. package/dist/browser/react/location-state.d.ts +0 -23
  349. package/dist/browser/react/location-state.d.ts.map +0 -1
  350. package/dist/browser/react/location-state.js +0 -29
  351. package/dist/browser/react/location-state.js.map +0 -1
  352. package/dist/browser/react/mount-context.d.ts +0 -24
  353. package/dist/browser/react/mount-context.d.ts.map +0 -1
  354. package/dist/browser/react/mount-context.js +0 -24
  355. package/dist/browser/react/mount-context.js.map +0 -1
  356. package/dist/browser/react/use-action.d.ts +0 -64
  357. package/dist/browser/react/use-action.d.ts.map +0 -1
  358. package/dist/browser/react/use-action.js +0 -134
  359. package/dist/browser/react/use-action.js.map +0 -1
  360. package/dist/browser/react/use-client-cache.d.ts +0 -41
  361. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  362. package/dist/browser/react/use-client-cache.js +0 -39
  363. package/dist/browser/react/use-client-cache.js.map +0 -1
  364. package/dist/browser/react/use-handle.d.ts +0 -31
  365. package/dist/browser/react/use-handle.d.ts.map +0 -1
  366. package/dist/browser/react/use-handle.js +0 -144
  367. package/dist/browser/react/use-handle.js.map +0 -1
  368. package/dist/browser/react/use-href.d.ts +0 -33
  369. package/dist/browser/react/use-href.d.ts.map +0 -1
  370. package/dist/browser/react/use-href.js +0 -39
  371. package/dist/browser/react/use-href.js.map +0 -1
  372. package/dist/browser/react/use-link-status.d.ts +0 -37
  373. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  374. package/dist/browser/react/use-link-status.js +0 -99
  375. package/dist/browser/react/use-link-status.js.map +0 -1
  376. package/dist/browser/react/use-mount.d.ts +0 -25
  377. package/dist/browser/react/use-mount.d.ts.map +0 -1
  378. package/dist/browser/react/use-mount.js +0 -30
  379. package/dist/browser/react/use-mount.js.map +0 -1
  380. package/dist/browser/react/use-navigation.d.ts +0 -27
  381. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  382. package/dist/browser/react/use-navigation.js +0 -87
  383. package/dist/browser/react/use-navigation.js.map +0 -1
  384. package/dist/browser/react/use-segments.d.ts +0 -38
  385. package/dist/browser/react/use-segments.d.ts.map +0 -1
  386. package/dist/browser/react/use-segments.js +0 -130
  387. package/dist/browser/react/use-segments.js.map +0 -1
  388. package/dist/browser/request-controller.d.ts +0 -26
  389. package/dist/browser/request-controller.d.ts.map +0 -1
  390. package/dist/browser/request-controller.js +0 -147
  391. package/dist/browser/request-controller.js.map +0 -1
  392. package/dist/browser/rsc-router.d.ts +0 -129
  393. package/dist/browser/rsc-router.d.ts.map +0 -1
  394. package/dist/browser/rsc-router.js +0 -195
  395. package/dist/browser/rsc-router.js.map +0 -1
  396. package/dist/browser/scroll-restoration.d.ts +0 -93
  397. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  398. package/dist/browser/scroll-restoration.js +0 -321
  399. package/dist/browser/scroll-restoration.js.map +0 -1
  400. package/dist/browser/segment-structure-assert.d.ts +0 -17
  401. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  402. package/dist/browser/segment-structure-assert.js +0 -59
  403. package/dist/browser/segment-structure-assert.js.map +0 -1
  404. package/dist/browser/server-action-bridge.d.ts +0 -26
  405. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  406. package/dist/browser/server-action-bridge.js +0 -668
  407. package/dist/browser/server-action-bridge.js.map +0 -1
  408. package/dist/browser/shallow.d.ts +0 -12
  409. package/dist/browser/shallow.d.ts.map +0 -1
  410. package/dist/browser/shallow.js +0 -34
  411. package/dist/browser/shallow.js.map +0 -1
  412. package/dist/browser/types.d.ts +0 -369
  413. package/dist/browser/types.d.ts.map +0 -1
  414. package/dist/browser/types.js +0 -2
  415. package/dist/browser/types.js.map +0 -1
  416. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  417. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  418. package/dist/build/__tests__/generate-cli.test.js +0 -237
  419. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  420. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  421. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  422. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  423. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  424. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  425. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  426. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  427. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  428. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  429. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  430. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  431. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  432. package/dist/build/generate-manifest.d.ts +0 -81
  433. package/dist/build/generate-manifest.d.ts.map +0 -1
  434. package/dist/build/generate-manifest.js +0 -276
  435. package/dist/build/generate-manifest.js.map +0 -1
  436. package/dist/build/generate-route-types.d.ts +0 -115
  437. package/dist/build/generate-route-types.d.ts.map +0 -1
  438. package/dist/build/generate-route-types.js +0 -740
  439. package/dist/build/generate-route-types.js.map +0 -1
  440. package/dist/build/index.d.ts +0 -21
  441. package/dist/build/index.d.ts.map +0 -1
  442. package/dist/build/index.js +0 -21
  443. package/dist/build/index.js.map +0 -1
  444. package/dist/build/route-trie.d.ts +0 -71
  445. package/dist/build/route-trie.d.ts.map +0 -1
  446. package/dist/build/route-trie.js +0 -175
  447. package/dist/build/route-trie.js.map +0 -1
  448. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  449. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  450. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  451. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  452. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  453. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  454. package/dist/cache/__tests__/document-cache.test.js +0 -345
  455. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  456. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  457. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  458. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  459. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  460. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  461. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  462. package/dist/cache/__tests__/memory-store.test.js +0 -367
  463. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  464. package/dist/cache/cache-scope.d.ts +0 -102
  465. package/dist/cache/cache-scope.d.ts.map +0 -1
  466. package/dist/cache/cache-scope.js +0 -440
  467. package/dist/cache/cache-scope.js.map +0 -1
  468. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  469. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  470. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  471. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  472. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  473. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  474. package/dist/cache/cf/cf-cache-store.js +0 -242
  475. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  476. package/dist/cache/cf/index.d.ts +0 -14
  477. package/dist/cache/cf/index.d.ts.map +0 -1
  478. package/dist/cache/cf/index.js +0 -17
  479. package/dist/cache/cf/index.js.map +0 -1
  480. package/dist/cache/document-cache.d.ts +0 -64
  481. package/dist/cache/document-cache.d.ts.map +0 -1
  482. package/dist/cache/document-cache.js +0 -228
  483. package/dist/cache/document-cache.js.map +0 -1
  484. package/dist/cache/index.d.ts +0 -19
  485. package/dist/cache/index.d.ts.map +0 -1
  486. package/dist/cache/index.js +0 -21
  487. package/dist/cache/index.js.map +0 -1
  488. package/dist/cache/memory-segment-store.d.ts +0 -110
  489. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  490. package/dist/cache/memory-segment-store.js +0 -117
  491. package/dist/cache/memory-segment-store.js.map +0 -1
  492. package/dist/cache/memory-store.d.ts +0 -41
  493. package/dist/cache/memory-store.d.ts.map +0 -1
  494. package/dist/cache/memory-store.js +0 -191
  495. package/dist/cache/memory-store.js.map +0 -1
  496. package/dist/cache/types.d.ts +0 -317
  497. package/dist/cache/types.d.ts.map +0 -1
  498. package/dist/cache/types.js +0 -12
  499. package/dist/cache/types.js.map +0 -1
  500. package/dist/client.d.ts +0 -248
  501. package/dist/client.d.ts.map +0 -1
  502. package/dist/client.js +0 -367
  503. package/dist/client.js.map +0 -1
  504. package/dist/client.rsc.d.ts +0 -26
  505. package/dist/client.rsc.d.ts.map +0 -1
  506. package/dist/client.rsc.js +0 -46
  507. package/dist/client.rsc.js.map +0 -1
  508. package/dist/component-utils.d.ts +0 -36
  509. package/dist/component-utils.d.ts.map +0 -1
  510. package/dist/component-utils.js +0 -61
  511. package/dist/component-utils.js.map +0 -1
  512. package/dist/components/DefaultDocument.d.ts +0 -13
  513. package/dist/components/DefaultDocument.d.ts.map +0 -1
  514. package/dist/components/DefaultDocument.js +0 -15
  515. package/dist/components/DefaultDocument.js.map +0 -1
  516. package/dist/debug.d.ts +0 -58
  517. package/dist/debug.d.ts.map +0 -1
  518. package/dist/debug.js +0 -157
  519. package/dist/debug.js.map +0 -1
  520. package/dist/default-error-boundary.d.ts +0 -11
  521. package/dist/default-error-boundary.d.ts.map +0 -1
  522. package/dist/default-error-boundary.js +0 -45
  523. package/dist/default-error-boundary.js.map +0 -1
  524. package/dist/deps/browser.d.ts +0 -2
  525. package/dist/deps/browser.d.ts.map +0 -1
  526. package/dist/deps/browser.js +0 -3
  527. package/dist/deps/browser.js.map +0 -1
  528. package/dist/deps/html-stream-client.d.ts +0 -2
  529. package/dist/deps/html-stream-client.d.ts.map +0 -1
  530. package/dist/deps/html-stream-client.js +0 -3
  531. package/dist/deps/html-stream-client.js.map +0 -1
  532. package/dist/deps/html-stream-server.d.ts +0 -2
  533. package/dist/deps/html-stream-server.d.ts.map +0 -1
  534. package/dist/deps/html-stream-server.js +0 -3
  535. package/dist/deps/html-stream-server.js.map +0 -1
  536. package/dist/deps/rsc.d.ts +0 -2
  537. package/dist/deps/rsc.d.ts.map +0 -1
  538. package/dist/deps/rsc.js +0 -4
  539. package/dist/deps/rsc.js.map +0 -1
  540. package/dist/deps/ssr.d.ts +0 -2
  541. package/dist/deps/ssr.d.ts.map +0 -1
  542. package/dist/deps/ssr.js +0 -3
  543. package/dist/deps/ssr.js.map +0 -1
  544. package/dist/errors.d.ts +0 -174
  545. package/dist/errors.d.ts.map +0 -1
  546. package/dist/errors.js +0 -241
  547. package/dist/errors.js.map +0 -1
  548. package/dist/handle.d.ts +0 -78
  549. package/dist/handle.d.ts.map +0 -1
  550. package/dist/handle.js +0 -82
  551. package/dist/handle.js.map +0 -1
  552. package/dist/handles/MetaTags.d.ts +0 -14
  553. package/dist/handles/MetaTags.d.ts.map +0 -1
  554. package/dist/handles/MetaTags.js +0 -136
  555. package/dist/handles/MetaTags.js.map +0 -1
  556. package/dist/handles/index.d.ts +0 -6
  557. package/dist/handles/index.d.ts.map +0 -1
  558. package/dist/handles/index.js +0 -6
  559. package/dist/handles/index.js.map +0 -1
  560. package/dist/handles/meta.d.ts +0 -39
  561. package/dist/handles/meta.d.ts.map +0 -1
  562. package/dist/handles/meta.js +0 -202
  563. package/dist/handles/meta.js.map +0 -1
  564. package/dist/host/__tests__/errors.test.d.ts +0 -2
  565. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  566. package/dist/host/__tests__/errors.test.js +0 -76
  567. package/dist/host/__tests__/errors.test.js.map +0 -1
  568. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  569. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  570. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  571. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  572. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  573. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  574. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  575. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  576. package/dist/host/__tests__/router.test.d.ts +0 -2
  577. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  578. package/dist/host/__tests__/router.test.js +0 -241
  579. package/dist/host/__tests__/router.test.js.map +0 -1
  580. package/dist/host/__tests__/testing.test.d.ts +0 -2
  581. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  582. package/dist/host/__tests__/testing.test.js +0 -64
  583. package/dist/host/__tests__/testing.test.js.map +0 -1
  584. package/dist/host/__tests__/utils.test.d.ts +0 -2
  585. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  586. package/dist/host/__tests__/utils.test.js +0 -29
  587. package/dist/host/__tests__/utils.test.js.map +0 -1
  588. package/dist/host/cookie-handler.d.ts +0 -34
  589. package/dist/host/cookie-handler.d.ts.map +0 -1
  590. package/dist/host/cookie-handler.js +0 -124
  591. package/dist/host/cookie-handler.js.map +0 -1
  592. package/dist/host/errors.d.ts +0 -56
  593. package/dist/host/errors.d.ts.map +0 -1
  594. package/dist/host/errors.js +0 -79
  595. package/dist/host/errors.js.map +0 -1
  596. package/dist/host/index.d.ts +0 -29
  597. package/dist/host/index.d.ts.map +0 -1
  598. package/dist/host/index.js +0 -32
  599. package/dist/host/index.js.map +0 -1
  600. package/dist/host/pattern-matcher.d.ts +0 -36
  601. package/dist/host/pattern-matcher.d.ts.map +0 -1
  602. package/dist/host/pattern-matcher.js +0 -172
  603. package/dist/host/pattern-matcher.js.map +0 -1
  604. package/dist/host/router.d.ts +0 -26
  605. package/dist/host/router.d.ts.map +0 -1
  606. package/dist/host/router.js +0 -218
  607. package/dist/host/router.js.map +0 -1
  608. package/dist/host/testing.d.ts +0 -36
  609. package/dist/host/testing.d.ts.map +0 -1
  610. package/dist/host/testing.js +0 -55
  611. package/dist/host/testing.js.map +0 -1
  612. package/dist/host/types.d.ts +0 -115
  613. package/dist/host/types.d.ts.map +0 -1
  614. package/dist/host/types.js +0 -7
  615. package/dist/host/types.js.map +0 -1
  616. package/dist/host/utils.d.ts +0 -21
  617. package/dist/host/utils.d.ts.map +0 -1
  618. package/dist/host/utils.js +0 -23
  619. package/dist/host/utils.js.map +0 -1
  620. package/dist/href-client.d.ts +0 -131
  621. package/dist/href-client.d.ts.map +0 -1
  622. package/dist/href-client.js +0 -64
  623. package/dist/href-client.js.map +0 -1
  624. package/dist/href-context.d.ts +0 -29
  625. package/dist/href-context.d.ts.map +0 -1
  626. package/dist/href-context.js +0 -21
  627. package/dist/href-context.js.map +0 -1
  628. package/dist/index.d.ts +0 -73
  629. package/dist/index.d.ts.map +0 -1
  630. package/dist/index.js +0 -91
  631. package/dist/index.js.map +0 -1
  632. package/dist/index.rsc.d.ts +0 -32
  633. package/dist/index.rsc.d.ts.map +0 -1
  634. package/dist/index.rsc.js +0 -40
  635. package/dist/index.rsc.js.map +0 -1
  636. package/dist/internal-debug.d.ts +0 -2
  637. package/dist/internal-debug.d.ts.map +0 -1
  638. package/dist/internal-debug.js +0 -5
  639. package/dist/internal-debug.js.map +0 -1
  640. package/dist/loader.d.ts +0 -14
  641. package/dist/loader.d.ts.map +0 -1
  642. package/dist/loader.js +0 -20
  643. package/dist/loader.js.map +0 -1
  644. package/dist/loader.rsc.d.ts +0 -19
  645. package/dist/loader.rsc.d.ts.map +0 -1
  646. package/dist/loader.rsc.js +0 -99
  647. package/dist/loader.rsc.js.map +0 -1
  648. package/dist/network-error-thrower.d.ts +0 -17
  649. package/dist/network-error-thrower.d.ts.map +0 -1
  650. package/dist/network-error-thrower.js +0 -14
  651. package/dist/network-error-thrower.js.map +0 -1
  652. package/dist/outlet-context.d.ts +0 -13
  653. package/dist/outlet-context.d.ts.map +0 -1
  654. package/dist/outlet-context.js +0 -3
  655. package/dist/outlet-context.js.map +0 -1
  656. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  657. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  658. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  659. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  660. package/dist/prerender/param-hash.d.ts +0 -16
  661. package/dist/prerender/param-hash.d.ts.map +0 -1
  662. package/dist/prerender/param-hash.js +0 -36
  663. package/dist/prerender/param-hash.js.map +0 -1
  664. package/dist/prerender/store.d.ts +0 -38
  665. package/dist/prerender/store.d.ts.map +0 -1
  666. package/dist/prerender/store.js +0 -61
  667. package/dist/prerender/store.js.map +0 -1
  668. package/dist/prerender.d.ts +0 -66
  669. package/dist/prerender.d.ts.map +0 -1
  670. package/dist/prerender.js +0 -57
  671. package/dist/prerender.js.map +0 -1
  672. package/dist/reverse.d.ts +0 -196
  673. package/dist/reverse.d.ts.map +0 -1
  674. package/dist/reverse.js +0 -78
  675. package/dist/reverse.js.map +0 -1
  676. package/dist/root-error-boundary.d.ts +0 -33
  677. package/dist/root-error-boundary.d.ts.map +0 -1
  678. package/dist/root-error-boundary.js +0 -165
  679. package/dist/root-error-boundary.js.map +0 -1
  680. package/dist/route-content-wrapper.d.ts +0 -46
  681. package/dist/route-content-wrapper.d.ts.map +0 -1
  682. package/dist/route-content-wrapper.js +0 -77
  683. package/dist/route-content-wrapper.js.map +0 -1
  684. package/dist/route-definition.d.ts +0 -421
  685. package/dist/route-definition.d.ts.map +0 -1
  686. package/dist/route-definition.js +0 -868
  687. package/dist/route-definition.js.map +0 -1
  688. package/dist/route-map-builder.d.ts +0 -155
  689. package/dist/route-map-builder.d.ts.map +0 -1
  690. package/dist/route-map-builder.js +0 -237
  691. package/dist/route-map-builder.js.map +0 -1
  692. package/dist/route-types.d.ts +0 -165
  693. package/dist/route-types.d.ts.map +0 -1
  694. package/dist/route-types.js +0 -7
  695. package/dist/route-types.js.map +0 -1
  696. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  697. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  698. package/dist/router/__tests__/handler-context.test.js +0 -65
  699. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  700. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  701. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  702. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  703. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  704. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  705. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  706. package/dist/router/__tests__/match-context.test.js +0 -92
  707. package/dist/router/__tests__/match-context.test.js.map +0 -1
  708. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  709. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  710. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  711. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  712. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  713. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  714. package/dist/router/__tests__/match-result.test.js +0 -457
  715. package/dist/router/__tests__/match-result.test.js.map +0 -1
  716. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  717. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  718. package/dist/router/__tests__/on-error.test.js +0 -678
  719. package/dist/router/__tests__/on-error.test.js.map +0 -1
  720. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  721. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  722. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  723. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  724. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  725. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  726. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  727. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  728. package/dist/router/error-handling.d.ts +0 -77
  729. package/dist/router/error-handling.d.ts.map +0 -1
  730. package/dist/router/error-handling.js +0 -202
  731. package/dist/router/error-handling.js.map +0 -1
  732. package/dist/router/handler-context.d.ts +0 -20
  733. package/dist/router/handler-context.d.ts.map +0 -1
  734. package/dist/router/handler-context.js +0 -198
  735. package/dist/router/handler-context.js.map +0 -1
  736. package/dist/router/intercept-resolution.d.ts +0 -66
  737. package/dist/router/intercept-resolution.d.ts.map +0 -1
  738. package/dist/router/intercept-resolution.js +0 -246
  739. package/dist/router/intercept-resolution.js.map +0 -1
  740. package/dist/router/loader-resolution.d.ts +0 -64
  741. package/dist/router/loader-resolution.d.ts.map +0 -1
  742. package/dist/router/loader-resolution.js +0 -284
  743. package/dist/router/loader-resolution.js.map +0 -1
  744. package/dist/router/logging.d.ts +0 -15
  745. package/dist/router/logging.d.ts.map +0 -1
  746. package/dist/router/logging.js +0 -99
  747. package/dist/router/logging.js.map +0 -1
  748. package/dist/router/manifest.d.ts +0 -22
  749. package/dist/router/manifest.d.ts.map +0 -1
  750. package/dist/router/manifest.js +0 -181
  751. package/dist/router/manifest.js.map +0 -1
  752. package/dist/router/match-api.d.ts +0 -35
  753. package/dist/router/match-api.d.ts.map +0 -1
  754. package/dist/router/match-api.js +0 -406
  755. package/dist/router/match-api.js.map +0 -1
  756. package/dist/router/match-context.d.ts +0 -206
  757. package/dist/router/match-context.d.ts.map +0 -1
  758. package/dist/router/match-context.js +0 -17
  759. package/dist/router/match-context.js.map +0 -1
  760. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  761. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  762. package/dist/router/match-middleware/background-revalidation.js +0 -75
  763. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  764. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  765. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  766. package/dist/router/match-middleware/cache-lookup.js +0 -257
  767. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  768. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  769. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  770. package/dist/router/match-middleware/cache-store.js +0 -108
  771. package/dist/router/match-middleware/cache-store.js.map +0 -1
  772. package/dist/router/match-middleware/index.d.ts +0 -81
  773. package/dist/router/match-middleware/index.d.ts.map +0 -1
  774. package/dist/router/match-middleware/index.js +0 -80
  775. package/dist/router/match-middleware/index.js.map +0 -1
  776. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  777. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  778. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  779. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  780. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  781. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  782. package/dist/router/match-middleware/segment-resolution.js +0 -53
  783. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  784. package/dist/router/match-pipelines.d.ts +0 -147
  785. package/dist/router/match-pipelines.d.ts.map +0 -1
  786. package/dist/router/match-pipelines.js +0 -82
  787. package/dist/router/match-pipelines.js.map +0 -1
  788. package/dist/router/match-result.d.ts +0 -126
  789. package/dist/router/match-result.d.ts.map +0 -1
  790. package/dist/router/match-result.js +0 -93
  791. package/dist/router/match-result.js.map +0 -1
  792. package/dist/router/metrics.d.ts +0 -20
  793. package/dist/router/metrics.d.ts.map +0 -1
  794. package/dist/router/metrics.js +0 -47
  795. package/dist/router/metrics.js.map +0 -1
  796. package/dist/router/middleware.d.ts +0 -249
  797. package/dist/router/middleware.d.ts.map +0 -1
  798. package/dist/router/middleware.js +0 -434
  799. package/dist/router/middleware.js.map +0 -1
  800. package/dist/router/middleware.test.d.ts +0 -2
  801. package/dist/router/middleware.test.d.ts.map +0 -1
  802. package/dist/router/middleware.test.js +0 -816
  803. package/dist/router/middleware.test.js.map +0 -1
  804. package/dist/router/pattern-matching.d.ts +0 -149
  805. package/dist/router/pattern-matching.d.ts.map +0 -1
  806. package/dist/router/pattern-matching.js +0 -349
  807. package/dist/router/pattern-matching.js.map +0 -1
  808. package/dist/router/revalidation.d.ts +0 -44
  809. package/dist/router/revalidation.d.ts.map +0 -1
  810. package/dist/router/revalidation.js +0 -147
  811. package/dist/router/revalidation.js.map +0 -1
  812. package/dist/router/router-context.d.ts +0 -135
  813. package/dist/router/router-context.d.ts.map +0 -1
  814. package/dist/router/router-context.js +0 -36
  815. package/dist/router/router-context.js.map +0 -1
  816. package/dist/router/segment-resolution.d.ts +0 -127
  817. package/dist/router/segment-resolution.d.ts.map +0 -1
  818. package/dist/router/segment-resolution.js +0 -919
  819. package/dist/router/segment-resolution.js.map +0 -1
  820. package/dist/router/trie-matching.d.ts +0 -40
  821. package/dist/router/trie-matching.d.ts.map +0 -1
  822. package/dist/router/trie-matching.js +0 -127
  823. package/dist/router/trie-matching.js.map +0 -1
  824. package/dist/router/types.d.ts +0 -136
  825. package/dist/router/types.d.ts.map +0 -1
  826. package/dist/router/types.js +0 -7
  827. package/dist/router/types.js.map +0 -1
  828. package/dist/router.d.ts +0 -753
  829. package/dist/router.d.ts.map +0 -1
  830. package/dist/router.gen.d.ts +0 -6
  831. package/dist/router.gen.d.ts.map +0 -1
  832. package/dist/router.gen.js +0 -6
  833. package/dist/router.gen.js.map +0 -1
  834. package/dist/router.js +0 -1304
  835. package/dist/router.js.map +0 -1
  836. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  837. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  838. package/dist/rsc/__tests__/helpers.test.js +0 -140
  839. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  840. package/dist/rsc/handler.d.ts +0 -45
  841. package/dist/rsc/handler.d.ts.map +0 -1
  842. package/dist/rsc/handler.js +0 -1172
  843. package/dist/rsc/handler.js.map +0 -1
  844. package/dist/rsc/helpers.d.ts +0 -16
  845. package/dist/rsc/helpers.d.ts.map +0 -1
  846. package/dist/rsc/helpers.js +0 -55
  847. package/dist/rsc/helpers.js.map +0 -1
  848. package/dist/rsc/index.d.ts +0 -22
  849. package/dist/rsc/index.d.ts.map +0 -1
  850. package/dist/rsc/index.js +0 -23
  851. package/dist/rsc/index.js.map +0 -1
  852. package/dist/rsc/nonce.d.ts +0 -9
  853. package/dist/rsc/nonce.d.ts.map +0 -1
  854. package/dist/rsc/nonce.js +0 -18
  855. package/dist/rsc/nonce.js.map +0 -1
  856. package/dist/rsc/types.d.ts +0 -206
  857. package/dist/rsc/types.d.ts.map +0 -1
  858. package/dist/rsc/types.js +0 -8
  859. package/dist/rsc/types.js.map +0 -1
  860. package/dist/search-params.d.ts +0 -103
  861. package/dist/search-params.d.ts.map +0 -1
  862. package/dist/search-params.js +0 -74
  863. package/dist/search-params.js.map +0 -1
  864. package/dist/segment-system.d.ts +0 -75
  865. package/dist/segment-system.d.ts.map +0 -1
  866. package/dist/segment-system.js +0 -336
  867. package/dist/segment-system.js.map +0 -1
  868. package/dist/server/context.d.ts +0 -245
  869. package/dist/server/context.d.ts.map +0 -1
  870. package/dist/server/context.js +0 -197
  871. package/dist/server/context.js.map +0 -1
  872. package/dist/server/fetchable-loader-store.d.ts +0 -18
  873. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  874. package/dist/server/fetchable-loader-store.js +0 -18
  875. package/dist/server/fetchable-loader-store.js.map +0 -1
  876. package/dist/server/handle-store.d.ts +0 -85
  877. package/dist/server/handle-store.d.ts.map +0 -1
  878. package/dist/server/handle-store.js +0 -142
  879. package/dist/server/handle-store.js.map +0 -1
  880. package/dist/server/loader-registry.d.ts +0 -55
  881. package/dist/server/loader-registry.d.ts.map +0 -1
  882. package/dist/server/loader-registry.js +0 -132
  883. package/dist/server/loader-registry.js.map +0 -1
  884. package/dist/server/request-context.d.ts +0 -226
  885. package/dist/server/request-context.d.ts.map +0 -1
  886. package/dist/server/request-context.js +0 -290
  887. package/dist/server/request-context.js.map +0 -1
  888. package/dist/server/root-layout.d.ts +0 -4
  889. package/dist/server/root-layout.d.ts.map +0 -1
  890. package/dist/server/root-layout.js +0 -5
  891. package/dist/server/root-layout.js.map +0 -1
  892. package/dist/server.d.ts +0 -15
  893. package/dist/server.d.ts.map +0 -1
  894. package/dist/server.js +0 -20
  895. package/dist/server.js.map +0 -1
  896. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  897. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  898. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  899. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  900. package/dist/ssr/index.d.ts +0 -98
  901. package/dist/ssr/index.d.ts.map +0 -1
  902. package/dist/ssr/index.js +0 -158
  903. package/dist/ssr/index.js.map +0 -1
  904. package/dist/static-handler.d.ts +0 -50
  905. package/dist/static-handler.d.ts.map +0 -1
  906. package/dist/static-handler.gen.d.ts +0 -5
  907. package/dist/static-handler.gen.d.ts.map +0 -1
  908. package/dist/static-handler.gen.js +0 -5
  909. package/dist/static-handler.gen.js.map +0 -1
  910. package/dist/static-handler.js +0 -29
  911. package/dist/static-handler.js.map +0 -1
  912. package/dist/theme/ThemeProvider.d.ts +0 -20
  913. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  914. package/dist/theme/ThemeProvider.js +0 -240
  915. package/dist/theme/ThemeProvider.js.map +0 -1
  916. package/dist/theme/ThemeScript.d.ts +0 -48
  917. package/dist/theme/ThemeScript.d.ts.map +0 -1
  918. package/dist/theme/ThemeScript.js +0 -13
  919. package/dist/theme/ThemeScript.js.map +0 -1
  920. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  921. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  922. package/dist/theme/__tests__/theme.test.js +0 -103
  923. package/dist/theme/__tests__/theme.test.js.map +0 -1
  924. package/dist/theme/constants.d.ts +0 -29
  925. package/dist/theme/constants.d.ts.map +0 -1
  926. package/dist/theme/constants.js +0 -48
  927. package/dist/theme/constants.js.map +0 -1
  928. package/dist/theme/index.d.ts +0 -31
  929. package/dist/theme/index.d.ts.map +0 -1
  930. package/dist/theme/index.js +0 -36
  931. package/dist/theme/index.js.map +0 -1
  932. package/dist/theme/theme-context.d.ts +0 -40
  933. package/dist/theme/theme-context.d.ts.map +0 -1
  934. package/dist/theme/theme-context.js +0 -60
  935. package/dist/theme/theme-context.js.map +0 -1
  936. package/dist/theme/theme-script.d.ts +0 -27
  937. package/dist/theme/theme-script.d.ts.map +0 -1
  938. package/dist/theme/theme-script.js +0 -147
  939. package/dist/theme/theme-script.js.map +0 -1
  940. package/dist/theme/types.d.ts +0 -163
  941. package/dist/theme/types.d.ts.map +0 -1
  942. package/dist/theme/types.js +0 -11
  943. package/dist/theme/types.js.map +0 -1
  944. package/dist/theme/use-theme.d.ts +0 -12
  945. package/dist/theme/use-theme.d.ts.map +0 -1
  946. package/dist/theme/use-theme.js +0 -40
  947. package/dist/theme/use-theme.js.map +0 -1
  948. package/dist/types.d.ts +0 -1479
  949. package/dist/types.d.ts.map +0 -1
  950. package/dist/types.js +0 -10
  951. package/dist/types.js.map +0 -1
  952. package/dist/urls.d.ts +0 -441
  953. package/dist/urls.d.ts.map +0 -1
  954. package/dist/urls.gen.d.ts +0 -8
  955. package/dist/urls.gen.d.ts.map +0 -1
  956. package/dist/urls.gen.js +0 -8
  957. package/dist/urls.gen.js.map +0 -1
  958. package/dist/urls.js +0 -443
  959. package/dist/urls.js.map +0 -1
  960. package/dist/use-loader.d.ts +0 -127
  961. package/dist/use-loader.d.ts.map +0 -1
  962. package/dist/use-loader.js +0 -237
  963. package/dist/use-loader.js.map +0 -1
  964. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  965. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  966. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  967. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  968. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  969. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  970. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  971. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  972. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  973. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  974. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  975. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  976. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  977. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  978. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  979. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  980. package/dist/vite/ast-handler-extract.d.ts +0 -49
  981. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  982. package/dist/vite/ast-handler-extract.js +0 -249
  983. package/dist/vite/ast-handler-extract.js.map +0 -1
  984. package/dist/vite/expose-action-id.d.ts +0 -19
  985. package/dist/vite/expose-action-id.d.ts.map +0 -1
  986. package/dist/vite/expose-action-id.js +0 -250
  987. package/dist/vite/expose-action-id.js.map +0 -1
  988. package/dist/vite/expose-id-utils.d.ts +0 -69
  989. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  990. package/dist/vite/expose-id-utils.js +0 -289
  991. package/dist/vite/expose-id-utils.js.map +0 -1
  992. package/dist/vite/expose-internal-ids.d.ts +0 -22
  993. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  994. package/dist/vite/expose-internal-ids.js +0 -886
  995. package/dist/vite/expose-internal-ids.js.map +0 -1
  996. package/dist/vite/index.d.ts +0 -149
  997. package/dist/vite/index.d.ts.map +0 -1
  998. package/dist/vite/index.js.bak +0 -5448
  999. package/dist/vite/index.js.map +0 -1
  1000. package/dist/vite/index.named-routes.gen.ts +0 -103
  1001. package/dist/vite/package-resolution.d.ts +0 -43
  1002. package/dist/vite/package-resolution.d.ts.map +0 -1
  1003. package/dist/vite/package-resolution.js +0 -112
  1004. package/dist/vite/package-resolution.js.map +0 -1
  1005. package/dist/vite/virtual-entries.d.ts +0 -25
  1006. package/dist/vite/virtual-entries.d.ts.map +0 -1
  1007. package/dist/vite/virtual-entries.js +0 -110
  1008. package/dist/vite/virtual-entries.js.map +0 -1
  1009. package/src/browser/shallow.ts +0 -40
@@ -1,816 +0,0 @@
1
- import { describe, it, expect, vi } from "vitest";
2
- import { parsePattern, extractParams, parseCookies, serializeCookie, matchMiddleware, executeMiddleware, executeInterceptMiddleware, executeServerActionMiddleware, executeLoaderMiddleware, collectRouteMiddleware, } from "./middleware";
3
- describe("middleware", () => {
4
- describe("parsePattern", () => {
5
- it("should match all routes with *", () => {
6
- const { regex } = parsePattern("*");
7
- expect(regex.test("/")).toBe(true);
8
- expect(regex.test("/foo")).toBe(true);
9
- expect(regex.test("/foo/bar/baz")).toBe(true);
10
- });
11
- it("should match exact path", () => {
12
- const { regex } = parsePattern("/admin");
13
- expect(regex.test("/admin")).toBe(true);
14
- expect(regex.test("/admin/")).toBe(true);
15
- expect(regex.test("/admin/users")).toBe(false);
16
- expect(regex.test("/administrator")).toBe(false);
17
- });
18
- it("should match prefix with wildcard", () => {
19
- const { regex } = parsePattern("/admin/*");
20
- expect(regex.test("/admin")).toBe(true);
21
- expect(regex.test("/admin/")).toBe(true);
22
- expect(regex.test("/admin/users")).toBe(true);
23
- expect(regex.test("/admin/users/123")).toBe(true);
24
- expect(regex.test("/administrator")).toBe(false);
25
- });
26
- it("should extract params from pattern", () => {
27
- const { regex, paramNames } = parsePattern("/users/:id");
28
- expect(paramNames).toEqual(["id"]);
29
- expect(regex.test("/users/123")).toBe(true);
30
- expect(regex.test("/users/abc")).toBe(true);
31
- expect(regex.test("/users/")).toBe(false);
32
- });
33
- it("should extract multiple params", () => {
34
- const { regex, paramNames } = parsePattern("/users/:userId/posts/:postId");
35
- expect(paramNames).toEqual(["userId", "postId"]);
36
- expect(regex.test("/users/123/posts/456")).toBe(true);
37
- });
38
- it("should handle param with wildcard", () => {
39
- const { regex, paramNames } = parsePattern("/api/:version/*");
40
- expect(paramNames).toEqual(["version"]);
41
- expect(regex.test("/api/v1/users")).toBe(true);
42
- expect(regex.test("/api/v2/users/123")).toBe(true);
43
- });
44
- });
45
- describe("extractParams", () => {
46
- it("should extract single param", () => {
47
- const { regex, paramNames } = parsePattern("/users/:id");
48
- const params = extractParams("/users/123", regex, paramNames);
49
- expect(params).toEqual({ id: "123" });
50
- });
51
- it("should extract multiple params", () => {
52
- const { regex, paramNames } = parsePattern("/users/:userId/posts/:postId");
53
- const params = extractParams("/users/abc/posts/xyz", regex, paramNames);
54
- expect(params).toEqual({ userId: "abc", postId: "xyz" });
55
- });
56
- it("should return empty object for no match", () => {
57
- const { regex, paramNames } = parsePattern("/users/:id");
58
- const params = extractParams("/posts/123", regex, paramNames);
59
- expect(params).toEqual({});
60
- });
61
- });
62
- describe("parseCookies", () => {
63
- it("should parse single cookie", () => {
64
- const cookies = parseCookies("session=abc123");
65
- expect(cookies).toEqual({ session: "abc123" });
66
- });
67
- it("should parse multiple cookies", () => {
68
- const cookies = parseCookies("session=abc123; user=john; theme=dark");
69
- expect(cookies).toEqual({
70
- session: "abc123",
71
- user: "john",
72
- theme: "dark",
73
- });
74
- });
75
- it("should handle encoded values", () => {
76
- const cookies = parseCookies("data=hello%20world");
77
- expect(cookies).toEqual({ data: "hello world" });
78
- });
79
- it("should return empty object for null", () => {
80
- const cookies = parseCookies(null);
81
- expect(cookies).toEqual({});
82
- });
83
- });
84
- describe("serializeCookie", () => {
85
- it("should serialize basic cookie", () => {
86
- const cookie = serializeCookie("session", "abc123");
87
- expect(cookie).toBe("session=abc123");
88
- });
89
- it("should include all options", () => {
90
- const cookie = serializeCookie("session", "abc123", {
91
- domain: "example.com",
92
- path: "/",
93
- maxAge: 3600,
94
- httpOnly: true,
95
- secure: true,
96
- sameSite: "lax",
97
- });
98
- expect(cookie).toContain("session=abc123");
99
- expect(cookie).toContain("Domain=example.com");
100
- expect(cookie).toContain("Path=/");
101
- expect(cookie).toContain("Max-Age=3600");
102
- expect(cookie).toContain("HttpOnly");
103
- expect(cookie).toContain("Secure");
104
- expect(cookie).toContain("SameSite=lax");
105
- });
106
- it("should handle expires date", () => {
107
- const expires = new Date("2025-01-01T00:00:00Z");
108
- const cookie = serializeCookie("session", "abc123", { expires });
109
- expect(cookie).toContain("Expires=Wed, 01 Jan 2025 00:00:00 GMT");
110
- });
111
- });
112
- describe("matchMiddleware", () => {
113
- it("should match global middleware (no pattern)", () => {
114
- const entries = [
115
- {
116
- pattern: null,
117
- regex: null,
118
- paramNames: [],
119
- handler: vi.fn(),
120
- mountPrefix: null,
121
- },
122
- ];
123
- const matches = matchMiddleware("/any/path", entries);
124
- expect(matches).toHaveLength(1);
125
- });
126
- it("should match pattern-based middleware", () => {
127
- const { regex, paramNames } = parsePattern("/admin/*");
128
- const entries = [
129
- {
130
- pattern: "/admin/*",
131
- regex,
132
- paramNames,
133
- handler: vi.fn(),
134
- mountPrefix: null,
135
- },
136
- ];
137
- expect(matchMiddleware("/admin/users", entries)).toHaveLength(1);
138
- expect(matchMiddleware("/public", entries)).toHaveLength(0);
139
- });
140
- it("should extract params when matching", () => {
141
- const { regex, paramNames } = parsePattern("/users/:id/*");
142
- const entries = [
143
- {
144
- pattern: "/users/:id/*",
145
- regex,
146
- paramNames,
147
- handler: vi.fn(),
148
- mountPrefix: null,
149
- },
150
- ];
151
- const matches = matchMiddleware("/users/123/posts", entries);
152
- expect(matches).toHaveLength(1);
153
- expect(matches[0].params).toEqual({ id: "123" });
154
- });
155
- it("should return multiple matches in order", () => {
156
- const entries = [
157
- {
158
- pattern: null,
159
- regex: null,
160
- paramNames: [],
161
- handler: vi.fn(),
162
- mountPrefix: null,
163
- },
164
- {
165
- pattern: "/admin/*",
166
- ...parsePattern("/admin/*"),
167
- handler: vi.fn(),
168
- mountPrefix: null,
169
- },
170
- ];
171
- const matches = matchMiddleware("/admin/users", entries);
172
- expect(matches).toHaveLength(2);
173
- });
174
- });
175
- describe("executeMiddleware", () => {
176
- const createMockEntry = (handler) => ({
177
- entry: {
178
- pattern: null,
179
- regex: null,
180
- paramNames: [],
181
- handler,
182
- mountPrefix: null,
183
- },
184
- params: {},
185
- });
186
- it("should execute single middleware and return response", async () => {
187
- const middleware = async (ctx, next) => {
188
- const response = await next();
189
- response.headers.set("X-Test", "value");
190
- return response;
191
- };
192
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"));
193
- expect(response.headers.get("X-Test")).toBe("value");
194
- expect(await response.text()).toBe("OK");
195
- });
196
- it("should execute middleware in order", async () => {
197
- const order = [];
198
- const mw1 = async (ctx, next) => {
199
- order.push(1);
200
- await next();
201
- order.push(4);
202
- };
203
- const mw2 = async (ctx, next) => {
204
- order.push(2);
205
- await next();
206
- order.push(3);
207
- };
208
- await executeMiddleware([createMockEntry(mw1), createMockEntry(mw2)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"));
209
- expect(order).toEqual([1, 2, 3, 4]);
210
- });
211
- it("should allow ctx.res access after next()", async () => {
212
- const middleware = async (ctx, next) => {
213
- await next();
214
- ctx.res.headers.set("X-Via-Ctx", "yes");
215
- // No return - forgiving API
216
- };
217
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"));
218
- expect(response.headers.get("X-Via-Ctx")).toBe("yes");
219
- });
220
- it("should allow ctx.header() shorthand", async () => {
221
- const middleware = async (ctx, next) => {
222
- await next();
223
- ctx.header("X-Shorthand", "works");
224
- };
225
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"));
226
- expect(response.headers.get("X-Shorthand")).toBe("works");
227
- });
228
- it("should short-circuit on early Response return", async () => {
229
- const handler = vi.fn();
230
- const middleware = async () => {
231
- return new Response("Blocked", { status: 403 });
232
- };
233
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => {
234
- handler();
235
- return new Response("OK");
236
- });
237
- expect(response.status).toBe(403);
238
- expect(await response.text()).toBe("Blocked");
239
- expect(handler).not.toHaveBeenCalled();
240
- });
241
- it("should catch errors from handler", async () => {
242
- const middleware = async (ctx, next) => {
243
- try {
244
- return await next();
245
- }
246
- catch (error) {
247
- return new Response("Error caught", { status: 500 });
248
- }
249
- };
250
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => {
251
- throw new Error("Handler error");
252
- });
253
- expect(response.status).toBe(500);
254
- expect(await response.text()).toBe("Error caught");
255
- });
256
- it("should share variables with handler via ctx.set/get", async () => {
257
- const variables = {};
258
- const middleware = async (ctx, next) => {
259
- ctx.set("user", { id: "123", name: "John" });
260
- await next();
261
- };
262
- await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, variables, async () => new Response("OK"));
263
- expect(variables).toEqual({ user: { id: "123", name: "John" } });
264
- });
265
- it("should read cookies from request", async () => {
266
- let sessionValue;
267
- const middleware = async (ctx, next) => {
268
- sessionValue = ctx.cookie("session");
269
- await next();
270
- };
271
- const request = new Request("http://localhost/test", {
272
- headers: { Cookie: "session=abc123" },
273
- });
274
- await executeMiddleware([createMockEntry(middleware)], request, {}, {}, async () => new Response("OK"));
275
- expect(sessionValue).toBe("abc123");
276
- });
277
- it("should set cookies on response", async () => {
278
- const middleware = async (ctx, next) => {
279
- ctx.setCookie("session", "xyz789", { httpOnly: true });
280
- await next();
281
- };
282
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"));
283
- const setCookie = response.headers.get("Set-Cookie");
284
- expect(setCookie).toContain("session=xyz789");
285
- expect(setCookie).toContain("HttpOnly");
286
- });
287
- it("should delete cookies", async () => {
288
- const middleware = async (ctx, next) => {
289
- ctx.deleteCookie("session");
290
- await next();
291
- };
292
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"));
293
- const setCookie = response.headers.get("Set-Cookie");
294
- expect(setCookie).toContain("session=");
295
- expect(setCookie).toContain("Max-Age=0");
296
- });
297
- it("should throw if middleware doesn't call next() or return", async () => {
298
- const middleware = async () => {
299
- // Does nothing
300
- };
301
- await expect(executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"))).rejects.toThrow("Middleware must call next()");
302
- });
303
- it("should allow setting headers before next() via ctx.res", async () => {
304
- const middleware = async (ctx, next) => {
305
- // Set header before next() using stub response
306
- ctx.res.headers.set("X-Before-Next", "works");
307
- await next();
308
- // Set header after next() as well
309
- ctx.res.headers.set("X-After-Next", "also-works");
310
- };
311
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK", { headers: { "X-Handler": "original" } }));
312
- // Both headers should be present
313
- expect(response.headers.get("X-Before-Next")).toBe("works");
314
- expect(response.headers.get("X-After-Next")).toBe("also-works");
315
- expect(response.headers.get("X-Handler")).toBe("original");
316
- });
317
- it("should allow setting headers before next() via ctx.header()", async () => {
318
- const middleware = async (ctx, next) => {
319
- // Set header before next() using shorthand
320
- ctx.header("X-Request-Id", "12345");
321
- await next();
322
- };
323
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"));
324
- expect(response.headers.get("X-Request-Id")).toBe("12345");
325
- });
326
- it("should pass params to middleware context", async () => {
327
- let receivedParams = {};
328
- const middleware = async (ctx, next) => {
329
- receivedParams = ctx.params;
330
- await next();
331
- };
332
- await executeMiddleware([
333
- {
334
- entry: {
335
- pattern: "/users/:id/*",
336
- ...parsePattern("/users/:id/*"),
337
- handler: middleware,
338
- mountPrefix: null,
339
- },
340
- params: { id: "123" },
341
- },
342
- ], new Request("http://localhost/users/123/profile"), {}, {}, async () => new Response("OK"));
343
- expect(receivedParams).toEqual({ id: "123" });
344
- });
345
- it("should allow middleware to replace response via ctx.res setter", async () => {
346
- const middleware = async (ctx, next) => {
347
- await next();
348
- ctx.res = new Response("Replaced", { status: 201 });
349
- };
350
- const response = await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("Original"));
351
- expect(response.status).toBe(201);
352
- expect(await response.text()).toBe("Replaced");
353
- });
354
- it("should warn when middleware returns non-Response value", async () => {
355
- const warnSpy = vi.spyOn(console, "warn").mockImplementation(() => { });
356
- const middleware = async (ctx, next) => {
357
- await next();
358
- return "some string"; // Incorrect return type
359
- };
360
- await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"));
361
- expect(warnSpy).toHaveBeenCalledWith(expect.stringContaining('returned string instead of Response or undefined'));
362
- warnSpy.mockRestore();
363
- });
364
- it("should warn about object return values", async () => {
365
- const warnSpy = vi.spyOn(console, "warn").mockImplementation(() => { });
366
- const middleware = async (ctx, next) => {
367
- await next();
368
- return { data: "test" }; // Incorrect return type
369
- };
370
- await executeMiddleware([createMockEntry(middleware)], new Request("http://localhost/test"), {}, {}, async () => new Response("OK"));
371
- expect(warnSpy).toHaveBeenCalledWith(expect.stringContaining('returned object instead of Response or undefined'));
372
- warnSpy.mockRestore();
373
- });
374
- });
375
- describe("collectRouteMiddleware", () => {
376
- const mw1 = async (ctx, next) => { await next(); };
377
- const mw2 = async (ctx, next) => { await next(); };
378
- const mw3 = async (ctx, next) => { await next(); };
379
- const mw4 = async (ctx, next) => { await next(); };
380
- it("should return empty array for empty entries", () => {
381
- const result = collectRouteMiddleware([], { id: "123" });
382
- expect(result).toEqual([]);
383
- });
384
- it("should return empty array for entries with no middleware", () => {
385
- const entries = [
386
- { middleware: [], layout: [] },
387
- { middleware: undefined, layout: undefined },
388
- ];
389
- const result = collectRouteMiddleware(entries, { id: "123" });
390
- expect(result).toEqual([]);
391
- });
392
- it("should collect middleware from a single entry", () => {
393
- const entries = [
394
- { middleware: [mw1, mw2] },
395
- ];
396
- const params = { id: "123" };
397
- const result = collectRouteMiddleware(entries, params);
398
- expect(result).toHaveLength(2);
399
- expect(result[0].handler).toBe(mw1);
400
- expect(result[0].params).toBe(params);
401
- expect(result[1].handler).toBe(mw2);
402
- expect(result[1].params).toBe(params);
403
- });
404
- it("should collect middleware from multiple entries in order", () => {
405
- const entries = [
406
- { middleware: [mw1] },
407
- { middleware: [mw2, mw3] },
408
- ];
409
- const params = { slug: "test" };
410
- const result = collectRouteMiddleware(entries, params);
411
- expect(result).toHaveLength(3);
412
- expect(result[0].handler).toBe(mw1);
413
- expect(result[1].handler).toBe(mw2);
414
- expect(result[2].handler).toBe(mw3);
415
- // All should share the same params reference
416
- expect(result.every(r => r.params === params)).toBe(true);
417
- });
418
- it("should collect middleware from orphan layouts (recursive)", () => {
419
- const orphan1 = { middleware: [mw3] };
420
- const orphan2 = { middleware: [mw4] };
421
- const entries = [
422
- { middleware: [mw1, mw2], layout: [orphan1, orphan2] },
423
- ];
424
- const params = { id: "456" };
425
- const result = collectRouteMiddleware(entries, params);
426
- expect(result).toHaveLength(4);
427
- expect(result[0].handler).toBe(mw1);
428
- expect(result[1].handler).toBe(mw2);
429
- expect(result[2].handler).toBe(mw3);
430
- expect(result[3].handler).toBe(mw4);
431
- });
432
- it("should collect middleware from deeply nested orphan layouts", () => {
433
- const deepOrphan = { middleware: [mw4] };
434
- const orphan = {
435
- middleware: [mw3],
436
- layout: [deepOrphan]
437
- };
438
- const entries = [
439
- { middleware: [mw1], layout: [orphan] },
440
- ];
441
- const params = {};
442
- const result = collectRouteMiddleware(entries, params);
443
- expect(result).toHaveLength(3);
444
- expect(result[0].handler).toBe(mw1);
445
- expect(result[1].handler).toBe(mw3);
446
- expect(result[2].handler).toBe(mw4);
447
- });
448
- it("should handle entries with only orphan layouts (no direct middleware)", () => {
449
- const orphan = { middleware: [mw1, mw2] };
450
- const entries = [
451
- { layout: [orphan] },
452
- ];
453
- const params = { page: "1" };
454
- const result = collectRouteMiddleware(entries, params);
455
- expect(result).toHaveLength(2);
456
- expect(result[0].handler).toBe(mw1);
457
- expect(result[1].handler).toBe(mw2);
458
- });
459
- it("should work with iterable (generator) input", () => {
460
- function* generateEntries() {
461
- yield { middleware: [mw1] };
462
- yield { middleware: [mw2] };
463
- }
464
- const result = collectRouteMiddleware(generateEntries(), { id: "gen" });
465
- expect(result).toHaveLength(2);
466
- expect(result[0].handler).toBe(mw1);
467
- expect(result[1].handler).toBe(mw2);
468
- });
469
- it("should preserve params reference across all collected middleware", () => {
470
- const orphan = { middleware: [mw3] };
471
- const entries = [
472
- { middleware: [mw1], layout: [orphan] },
473
- { middleware: [mw2] },
474
- ];
475
- const params = { shared: "value" };
476
- const result = collectRouteMiddleware(entries, params);
477
- // All middleware entries should have the exact same params object
478
- expect(result).toHaveLength(3);
479
- result.forEach(r => {
480
- expect(r.params).toBe(params);
481
- });
482
- });
483
- });
484
- describe("executeInterceptMiddleware", () => {
485
- it("should return null for empty middleware array", async () => {
486
- const stubResponse = new Response(null, { status: 200 });
487
- const result = await executeInterceptMiddleware([], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
488
- expect(result).toBeNull();
489
- });
490
- it("should return null when middleware calls next() without returning Response", async () => {
491
- const stubResponse = new Response(null, { status: 200 });
492
- const middleware = async (ctx, next) => {
493
- await next();
494
- };
495
- const result = await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, { id: "123" }, {}, stubResponse);
496
- expect(result).toBeNull();
497
- });
498
- it("should return Response when middleware short-circuits", async () => {
499
- const stubResponse = new Response(null, { status: 200 });
500
- const middleware = async (ctx, next) => {
501
- return new Response("Blocked", { status: 403 });
502
- };
503
- const result = await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
504
- expect(result).toBeInstanceOf(Response);
505
- expect(result.status).toBe(403);
506
- expect(await result.text()).toBe("Blocked");
507
- });
508
- it("should apply cookies to short-circuit Response", async () => {
509
- const stubResponse = new Response(null, { status: 200 });
510
- const middleware = async (ctx, next) => {
511
- ctx.setCookie("session", "abc123", { path: "/" });
512
- return new Response("Redirecting", { status: 302 });
513
- };
514
- const result = await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
515
- expect(result).toBeInstanceOf(Response);
516
- const cookies = result.headers.get("set-cookie");
517
- expect(cookies).toContain("session=abc123");
518
- expect(cookies).toContain("Path=/");
519
- });
520
- it("should apply multiple cookies to short-circuit Response", async () => {
521
- const stubResponse = new Response(null, { status: 200 });
522
- const middleware = async (ctx, next) => {
523
- ctx.setCookie("token", "xyz", { httpOnly: true });
524
- ctx.setCookie("preference", "dark");
525
- return new Response(null, { status: 302, headers: { Location: "/login" } });
526
- };
527
- const result = await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
528
- expect(result).toBeInstanceOf(Response);
529
- const cookies = result.headers.getSetCookie();
530
- expect(cookies).toHaveLength(2);
531
- expect(cookies.some(c => c.includes("token=xyz"))).toBe(true);
532
- expect(cookies.some(c => c.includes("preference=dark"))).toBe(true);
533
- });
534
- it("should share variables between middleware and allow setting new ones", async () => {
535
- const stubResponse = new Response(null, { status: 200 });
536
- const variables = { existing: "value" };
537
- let capturedVars = {};
538
- const middleware = async (ctx, next) => {
539
- capturedVars.existing = ctx.get("existing");
540
- ctx.set("newVar", "newValue");
541
- capturedVars.newVar = ctx.get("newVar");
542
- await next();
543
- };
544
- await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, {}, variables, stubResponse);
545
- expect(capturedVars.existing).toBe("value");
546
- expect(capturedVars.newVar).toBe("newValue");
547
- expect(variables.newVar).toBe("newValue");
548
- });
549
- it("should provide params to middleware context", async () => {
550
- const stubResponse = new Response(null, { status: 200 });
551
- let capturedParams = {};
552
- const middleware = async (ctx, next) => {
553
- capturedParams = ctx.params;
554
- await next();
555
- };
556
- await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, { id: "456", slug: "test-slug" }, {}, stubResponse);
557
- expect(capturedParams).toEqual({ id: "456", slug: "test-slug" });
558
- });
559
- it("should execute multiple middleware in order", async () => {
560
- const stubResponse = new Response(null, { status: 200 });
561
- const order = [];
562
- const mw1 = async (ctx, next) => {
563
- order.push(1);
564
- await next();
565
- order.push(4);
566
- };
567
- const mw2 = async (ctx, next) => {
568
- order.push(2);
569
- await next();
570
- order.push(3);
571
- };
572
- await executeInterceptMiddleware([mw1, mw2], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
573
- expect(order).toEqual([1, 2, 3, 4]);
574
- });
575
- it("should stop execution when middleware returns Response", async () => {
576
- const stubResponse = new Response(null, { status: 200 });
577
- const order = [];
578
- const mw1 = async (ctx, next) => {
579
- order.push(1);
580
- return new Response("Stopped at mw1", { status: 401 });
581
- };
582
- const mw2 = async (ctx, next) => {
583
- order.push(2);
584
- await next();
585
- };
586
- const result = await executeInterceptMiddleware([mw1, mw2], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
587
- expect(order).toEqual([1]);
588
- expect(result.status).toBe(401);
589
- });
590
- it("should allow ctx.res access after next() without throwing", async () => {
591
- const stubResponse = new Response(null, { status: 200 });
592
- let resStatus;
593
- const middleware = async (ctx, next) => {
594
- await next();
595
- // This should not throw - ctx.res should be accessible
596
- resStatus = ctx.res.status;
597
- };
598
- const result = await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
599
- expect(resStatus).toBe(200);
600
- expect(result).toBeNull(); // No short-circuit, no modifications
601
- });
602
- it("should NOT short-circuit when middleware uses ctx.header() after next() - headers go on stubResponse", async () => {
603
- const stubResponse = new Response(null, { status: 200 });
604
- const middleware = async (ctx, next) => {
605
- await next();
606
- ctx.header("X-Custom-Header", "custom-value");
607
- };
608
- const result = await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
609
- // Should return null (no short-circuit) - headers are on stubResponse for caller to merge
610
- expect(result).toBeNull();
611
- expect(stubResponse.headers.get("X-Custom-Header")).toBe("custom-value");
612
- });
613
- it("should short-circuit when middleware replaces ctx.res after next()", async () => {
614
- const stubResponse = new Response(null, { status: 200 });
615
- const middleware = async (ctx, next) => {
616
- await next();
617
- ctx.res = new Response("Custom body", { status: 201 });
618
- };
619
- const result = await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
620
- expect(result).toBeInstanceOf(Response);
621
- expect(result.status).toBe(201);
622
- expect(await result.text()).toBe("Custom body");
623
- });
624
- it("should NOT short-circuit when cookies set after next() - cookies go on stubResponse", async () => {
625
- const stubResponse = new Response(null, { status: 200 });
626
- const middleware = async (ctx, next) => {
627
- await next();
628
- ctx.header("X-Modified", "true");
629
- ctx.setCookie("after-next", "cookie-value");
630
- };
631
- const result = await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
632
- // Should return null (no short-circuit) - headers/cookies are on stubResponse
633
- expect(result).toBeNull();
634
- expect(stubResponse.headers.get("X-Modified")).toBe("true");
635
- const cookies = stubResponse.headers.get("set-cookie");
636
- expect(cookies).toContain("after-next=cookie-value");
637
- });
638
- it("should set cookies on stubResponse when only cookies are set after next()", async () => {
639
- const stubResponse = new Response(null, { status: 200 });
640
- const middleware = async (ctx, next) => {
641
- await next();
642
- ctx.setCookie("only-cookie", "value123");
643
- };
644
- const result = await executeInterceptMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
645
- // Should return null (no short-circuit) - cookie is on stubResponse
646
- expect(result).toBeNull();
647
- const cookies = stubResponse.headers.get("set-cookie");
648
- expect(cookies).toContain("only-cookie=value123");
649
- });
650
- });
651
- describe("executeServerActionMiddleware", () => {
652
- it("should do nothing for empty middleware array", async () => {
653
- const stubResponse = new Response(null, { status: 200 });
654
- await expect(executeServerActionMiddleware([], new Request("http://localhost/test"), {}, {}, {}, stubResponse)).resolves.toBeUndefined();
655
- });
656
- it("should execute middleware and call next()", async () => {
657
- const order = [];
658
- const stubResponse = new Response(null, { status: 200 });
659
- const mw1 = async (ctx, next) => {
660
- order.push(1);
661
- await next();
662
- order.push(4);
663
- };
664
- const mw2 = async (ctx, next) => {
665
- order.push(2);
666
- await next();
667
- order.push(3);
668
- };
669
- await executeServerActionMiddleware([mw1, mw2], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
670
- expect(order).toEqual([1, 2, 3, 4]);
671
- });
672
- it("should share variables between middleware", async () => {
673
- const variables = { existing: "value" };
674
- let capturedVars = {};
675
- const stubResponse = new Response(null, { status: 200 });
676
- const mw1 = async (ctx, next) => {
677
- ctx.set("fromMw1", "hello");
678
- await next();
679
- };
680
- const mw2 = async (ctx, next) => {
681
- capturedVars.existing = ctx.get("existing");
682
- capturedVars.fromMw1 = ctx.get("fromMw1");
683
- await next();
684
- };
685
- await executeServerActionMiddleware([mw1, mw2], new Request("http://localhost/test"), {}, {}, variables, stubResponse);
686
- expect(capturedVars.existing).toBe("value");
687
- expect(capturedVars.fromMw1).toBe("hello");
688
- expect(variables.fromMw1).toBe("hello");
689
- });
690
- it("should provide params to middleware context", async () => {
691
- let capturedParams = {};
692
- const stubResponse = new Response(null, { status: 200 });
693
- const middleware = async (ctx, next) => {
694
- capturedParams = ctx.params;
695
- await next();
696
- };
697
- await executeServerActionMiddleware([middleware], new Request("http://localhost/test"), {}, { id: "789", action: "submit" }, {}, stubResponse);
698
- expect(capturedParams).toEqual({ id: "789", action: "submit" });
699
- });
700
- it("should throw error if middleware returns Response", async () => {
701
- const stubResponse = new Response(null, { status: 200 });
702
- const middleware = async (ctx, next) => {
703
- return new Response("Redirect", { status: 302 });
704
- };
705
- await expect(executeServerActionMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse)).rejects.toThrow("Server actions cannot return Response");
706
- });
707
- it("should set cookies on stub response", async () => {
708
- const stubResponse = new Response(null, { status: 200 });
709
- const middleware = async (ctx, next) => {
710
- ctx.setCookie("session", "abc123");
711
- await next();
712
- };
713
- await executeServerActionMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
714
- // Cookies are set on the stub response for later merging
715
- expect(stubResponse.headers.get("Set-Cookie")).toContain("session=abc123");
716
- });
717
- it("should set multiple cookies on stub response", async () => {
718
- const stubResponse = new Response(null, { status: 200 });
719
- const middleware = async (ctx, next) => {
720
- ctx.setCookie("token", "xyz");
721
- ctx.setCookie("preference", "dark");
722
- await next();
723
- };
724
- await executeServerActionMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, stubResponse);
725
- // Multiple cookies are appended to stub response
726
- const cookies = stubResponse.headers.getSetCookie();
727
- expect(cookies).toContain("token=xyz");
728
- expect(cookies).toContain("preference=dark");
729
- });
730
- it("should allow reading cookies without error", async () => {
731
- let readCookie;
732
- const stubResponse = new Response(null, { status: 200 });
733
- const middleware = async (ctx, next) => {
734
- readCookie = ctx.cookie("session");
735
- await next();
736
- };
737
- await executeServerActionMiddleware([middleware], new Request("http://localhost/test", {
738
- headers: { Cookie: "session=abc123" },
739
- }), {}, {}, {}, stubResponse);
740
- expect(readCookie).toBe("abc123");
741
- });
742
- });
743
- describe("executeLoaderMiddleware", () => {
744
- it("should call finalHandler directly when no middleware", async () => {
745
- const finalHandler = vi.fn().mockResolvedValue(new Response("Data"));
746
- const result = await executeLoaderMiddleware([], new Request("http://localhost/test"), {}, {}, {}, finalHandler);
747
- expect(finalHandler).toHaveBeenCalled();
748
- expect(await result.text()).toBe("Data");
749
- });
750
- it("should execute middleware before finalHandler", async () => {
751
- const order = [];
752
- const middleware = async (ctx, next) => {
753
- order.push("middleware-before");
754
- await next();
755
- order.push("middleware-after");
756
- };
757
- const finalHandler = async () => {
758
- order.push("handler");
759
- return new Response("OK");
760
- };
761
- await executeLoaderMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, finalHandler);
762
- expect(order).toEqual(["middleware-before", "handler", "middleware-after"]);
763
- });
764
- it("should share variables with finalHandler", async () => {
765
- const variables = {};
766
- let capturedVar;
767
- const middleware = async (ctx, next) => {
768
- ctx.set("userId", "user-123");
769
- await next();
770
- };
771
- const finalHandler = async () => {
772
- capturedVar = variables.userId;
773
- return new Response("OK");
774
- };
775
- await executeLoaderMiddleware([middleware], new Request("http://localhost/test"), {}, {}, variables, finalHandler);
776
- expect(capturedVar).toBe("user-123");
777
- });
778
- it("should provide params to middleware context", async () => {
779
- let capturedParams = {};
780
- const middleware = async (ctx, next) => {
781
- capturedParams = ctx.params;
782
- await next();
783
- };
784
- await executeLoaderMiddleware([middleware], new Request("http://localhost/test"), {}, { loaderId: "cart", userId: "456" }, {}, async () => new Response("OK"));
785
- expect(capturedParams).toEqual({ loaderId: "cart", userId: "456" });
786
- });
787
- it("should allow middleware to short-circuit with Response", async () => {
788
- const finalHandler = vi.fn().mockResolvedValue(new Response("Data"));
789
- const middleware = async (ctx, next) => {
790
- return new Response("Unauthorized", { status: 401 });
791
- };
792
- const result = await executeLoaderMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, finalHandler);
793
- expect(finalHandler).not.toHaveBeenCalled();
794
- expect(result.status).toBe(401);
795
- expect(await result.text()).toBe("Unauthorized");
796
- });
797
- it("should apply cookies set by middleware", async () => {
798
- const middleware = async (ctx, next) => {
799
- ctx.setCookie("session", "new-session-id");
800
- await next();
801
- };
802
- const result = await executeLoaderMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, async () => new Response("OK"));
803
- const cookies = result.headers.get("set-cookie");
804
- expect(cookies).toContain("session=new-session-id");
805
- });
806
- it("should allow middleware to modify response headers", async () => {
807
- const middleware = async (ctx, next) => {
808
- await next();
809
- ctx.header("X-Loader-Cache", "HIT");
810
- };
811
- const result = await executeLoaderMiddleware([middleware], new Request("http://localhost/test"), {}, {}, {}, async () => new Response("OK"));
812
- expect(result.headers.get("X-Loader-Cache")).toBe("HIT");
813
- });
814
- });
815
- });
816
- //# sourceMappingURL=middleware.test.js.map