msw 2.12.13 → 2.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (272) hide show
  1. package/lib/browser/index.d.mts +29 -19
  2. package/lib/browser/index.d.ts +29 -19
  3. package/lib/browser/index.js +1763 -1321
  4. package/lib/browser/index.js.map +1 -1
  5. package/lib/browser/index.mjs +1769 -1321
  6. package/lib/browser/index.mjs.map +1 -1
  7. package/lib/core/{HttpResponse-Dj6ibgFJ.d.ts → HttpResponse-CksOMVAa.d.ts} +5 -5
  8. package/lib/core/{HttpResponse-Be4eT3x6.d.mts → HttpResponse-DlRR1D-f.d.mts} +5 -5
  9. package/lib/core/HttpResponse.d.mts +1 -1
  10. package/lib/core/HttpResponse.d.ts +1 -1
  11. package/lib/core/experimental/compat.d.mts +17 -0
  12. package/lib/core/experimental/compat.d.ts +17 -0
  13. package/lib/core/experimental/compat.js +54 -0
  14. package/lib/core/experimental/compat.js.map +1 -0
  15. package/lib/core/experimental/compat.mjs +36 -0
  16. package/lib/core/experimental/compat.mjs.map +1 -0
  17. package/lib/core/experimental/define-network.d.mts +75 -0
  18. package/lib/core/experimental/define-network.d.ts +75 -0
  19. package/lib/core/experimental/define-network.js +124 -0
  20. package/lib/core/experimental/define-network.js.map +1 -0
  21. package/lib/core/experimental/define-network.mjs +107 -0
  22. package/lib/core/experimental/define-network.mjs.map +1 -0
  23. package/lib/core/experimental/frames/http-frame.d.mts +77 -0
  24. package/lib/core/experimental/frames/http-frame.d.ts +77 -0
  25. package/lib/core/experimental/frames/http-frame.js +194 -0
  26. package/lib/core/experimental/frames/http-frame.js.map +1 -0
  27. package/lib/core/experimental/frames/http-frame.mjs +176 -0
  28. package/lib/core/experimental/frames/http-frame.mjs.map +1 -0
  29. package/lib/core/experimental/frames/network-frame.d.mts +12 -0
  30. package/lib/core/experimental/frames/network-frame.d.ts +12 -0
  31. package/lib/core/{handlers/common.js → experimental/frames/network-frame.js} +19 -3
  32. package/lib/core/experimental/frames/network-frame.js.map +1 -0
  33. package/lib/core/experimental/frames/network-frame.mjs +13 -0
  34. package/lib/core/experimental/frames/network-frame.mjs.map +1 -0
  35. package/lib/core/experimental/frames/websocket-frame.d.mts +55 -0
  36. package/lib/core/experimental/frames/websocket-frame.d.ts +55 -0
  37. package/lib/core/experimental/frames/websocket-frame.js +129 -0
  38. package/lib/core/experimental/frames/websocket-frame.js.map +1 -0
  39. package/lib/core/experimental/frames/websocket-frame.mjs +116 -0
  40. package/lib/core/experimental/frames/websocket-frame.mjs.map +1 -0
  41. package/lib/core/experimental/handlers-controller.d.mts +35 -0
  42. package/lib/core/experimental/handlers-controller.d.ts +35 -0
  43. package/lib/core/experimental/handlers-controller.js +121 -0
  44. package/lib/core/experimental/handlers-controller.js.map +1 -0
  45. package/lib/core/experimental/handlers-controller.mjs +101 -0
  46. package/lib/core/experimental/handlers-controller.mjs.map +1 -0
  47. package/lib/core/experimental/index.d.mts +17 -0
  48. package/lib/core/experimental/index.d.ts +17 -0
  49. package/lib/core/experimental/index.js +36 -0
  50. package/lib/core/experimental/index.js.map +1 -0
  51. package/lib/core/experimental/index.mjs +20 -0
  52. package/lib/core/experimental/index.mjs.map +1 -0
  53. package/lib/core/experimental/on-unhandled-frame.d.mts +12 -0
  54. package/lib/core/experimental/on-unhandled-frame.d.ts +12 -0
  55. package/lib/core/experimental/on-unhandled-frame.js +90 -0
  56. package/lib/core/experimental/on-unhandled-frame.js.map +1 -0
  57. package/lib/core/experimental/on-unhandled-frame.mjs +70 -0
  58. package/lib/core/experimental/on-unhandled-frame.mjs.map +1 -0
  59. package/lib/core/experimental/request-utils.d.mts +12 -0
  60. package/lib/core/experimental/request-utils.d.ts +12 -0
  61. package/lib/core/experimental/request-utils.js +50 -0
  62. package/lib/core/experimental/request-utils.js.map +1 -0
  63. package/lib/core/experimental/request-utils.mjs +30 -0
  64. package/lib/core/experimental/request-utils.mjs.map +1 -0
  65. package/lib/core/experimental/setup-api.d.mts +33 -0
  66. package/lib/core/experimental/setup-api.d.ts +33 -0
  67. package/lib/core/experimental/setup-api.js +61 -0
  68. package/lib/core/experimental/setup-api.js.map +1 -0
  69. package/lib/core/experimental/setup-api.mjs +43 -0
  70. package/lib/core/experimental/setup-api.mjs.map +1 -0
  71. package/lib/core/experimental/sources/interceptor-source.d.mts +28 -0
  72. package/lib/core/experimental/sources/interceptor-source.d.ts +28 -0
  73. package/lib/core/experimental/sources/interceptor-source.js +142 -0
  74. package/lib/core/experimental/sources/interceptor-source.js.map +1 -0
  75. package/lib/core/experimental/sources/interceptor-source.mjs +124 -0
  76. package/lib/core/experimental/sources/interceptor-source.mjs.map +1 -0
  77. package/lib/core/experimental/sources/network-source.d.mts +31 -0
  78. package/lib/core/experimental/sources/network-source.d.ts +31 -0
  79. package/lib/core/experimental/sources/network-source.js +50 -0
  80. package/lib/core/experimental/sources/network-source.js.map +1 -0
  81. package/lib/core/experimental/sources/network-source.mjs +30 -0
  82. package/lib/core/experimental/sources/network-source.mjs.map +1 -0
  83. package/lib/core/getResponse.d.mts +1 -1
  84. package/lib/core/getResponse.d.ts +1 -1
  85. package/lib/core/graphql.d.mts +1 -1
  86. package/lib/core/graphql.d.ts +1 -1
  87. package/lib/core/handlers/GraphQLHandler.d.mts +1 -1
  88. package/lib/core/handlers/GraphQLHandler.d.ts +1 -1
  89. package/lib/core/handlers/HttpHandler.d.mts +1 -1
  90. package/lib/core/handlers/HttpHandler.d.ts +1 -1
  91. package/lib/core/handlers/RequestHandler.d.mts +1 -1
  92. package/lib/core/handlers/RequestHandler.d.ts +1 -1
  93. package/lib/core/handlers/RequestHandler.js +5 -6
  94. package/lib/core/handlers/RequestHandler.js.map +1 -1
  95. package/lib/core/handlers/RequestHandler.mjs +5 -6
  96. package/lib/core/handlers/RequestHandler.mjs.map +1 -1
  97. package/lib/core/handlers/WebSocketHandler.d.mts +8 -4
  98. package/lib/core/handlers/WebSocketHandler.d.ts +8 -4
  99. package/lib/core/handlers/WebSocketHandler.js +18 -5
  100. package/lib/core/handlers/WebSocketHandler.js.map +1 -1
  101. package/lib/core/handlers/WebSocketHandler.mjs +18 -5
  102. package/lib/core/handlers/WebSocketHandler.mjs.map +1 -1
  103. package/lib/core/http.d.mts +1 -1
  104. package/lib/core/http.d.ts +1 -1
  105. package/lib/core/index.d.mts +7 -12
  106. package/lib/core/index.d.ts +7 -12
  107. package/lib/core/index.js +2 -2
  108. package/lib/core/index.js.map +1 -1
  109. package/lib/core/index.mjs +1 -1
  110. package/lib/core/index.mjs.map +1 -1
  111. package/lib/core/network-frame-B7A0ggXE.d.mts +56 -0
  112. package/lib/core/network-frame-usYiHS0K.d.ts +56 -0
  113. package/lib/core/passthrough.d.mts +1 -1
  114. package/lib/core/passthrough.d.ts +1 -1
  115. package/lib/core/sharedOptions.d.mts +6 -2
  116. package/lib/core/sharedOptions.d.ts +6 -2
  117. package/lib/core/sharedOptions.js.map +1 -1
  118. package/lib/core/sse.d.mts +1 -1
  119. package/lib/core/sse.d.ts +1 -1
  120. package/lib/core/sse.js.map +1 -1
  121. package/lib/core/sse.mjs.map +1 -1
  122. package/lib/core/utils/HttpResponse/decorators.d.mts +1 -1
  123. package/lib/core/utils/HttpResponse/decorators.d.ts +1 -1
  124. package/lib/core/utils/cookieStore.js.map +1 -1
  125. package/lib/core/utils/cookieStore.mjs.map +1 -1
  126. package/lib/core/utils/executeHandlers.d.mts +1 -1
  127. package/lib/core/utils/executeHandlers.d.ts +1 -1
  128. package/lib/core/utils/handleRequest.d.mts +2 -1
  129. package/lib/core/utils/handleRequest.d.ts +2 -1
  130. package/lib/core/utils/internal/isHandlerKind.d.mts +3 -3
  131. package/lib/core/utils/internal/isHandlerKind.d.ts +3 -3
  132. package/lib/core/utils/internal/isHandlerKind.js +2 -1
  133. package/lib/core/utils/internal/isHandlerKind.js.map +1 -1
  134. package/lib/core/utils/internal/isHandlerKind.mjs +2 -1
  135. package/lib/core/utils/internal/isHandlerKind.mjs.map +1 -1
  136. package/lib/core/utils/internal/parseGraphQLRequest.d.mts +1 -1
  137. package/lib/core/utils/internal/parseGraphQLRequest.d.ts +1 -1
  138. package/lib/core/utils/internal/parseMultipartData.d.mts +1 -1
  139. package/lib/core/utils/internal/parseMultipartData.d.ts +1 -1
  140. package/lib/core/utils/internal/requestHandlerUtils.d.mts +1 -1
  141. package/lib/core/utils/internal/requestHandlerUtils.d.ts +1 -1
  142. package/lib/core/utils/matching/matchRequestUrl.js +1 -1
  143. package/lib/core/utils/matching/matchRequestUrl.js.map +1 -1
  144. package/lib/core/utils/matching/matchRequestUrl.mjs +1 -1
  145. package/lib/core/utils/matching/matchRequestUrl.mjs.map +1 -1
  146. package/lib/core/utils/request/onUnhandledRequest.d.mts +2 -2
  147. package/lib/core/utils/request/onUnhandledRequest.d.ts +2 -2
  148. package/lib/core/utils/request/onUnhandledRequest.js.map +1 -1
  149. package/lib/core/utils/request/onUnhandledRequest.mjs.map +1 -1
  150. package/lib/core/ws/handleWebSocketEvent.d.mts +1 -1
  151. package/lib/core/ws/handleWebSocketEvent.d.ts +1 -1
  152. package/lib/core/ws/handleWebSocketEvent.js +1 -1
  153. package/lib/core/ws/handleWebSocketEvent.js.map +1 -1
  154. package/lib/core/ws/handleWebSocketEvent.mjs +1 -1
  155. package/lib/core/ws/handleWebSocketEvent.mjs.map +1 -1
  156. package/lib/core/ws/utils/attachWebSocketLogger.d.mts +1 -1
  157. package/lib/core/ws/utils/attachWebSocketLogger.d.ts +1 -1
  158. package/lib/core/ws/utils/attachWebSocketLogger.js +39 -10
  159. package/lib/core/ws/utils/attachWebSocketLogger.js.map +1 -1
  160. package/lib/core/ws/utils/attachWebSocketLogger.mjs +39 -10
  161. package/lib/core/ws/utils/attachWebSocketLogger.mjs.map +1 -1
  162. package/lib/core/ws.d.mts +3 -3
  163. package/lib/core/ws.d.ts +3 -3
  164. package/lib/core/ws.js.map +1 -1
  165. package/lib/core/ws.mjs.map +1 -1
  166. package/lib/iife/index.js +2022 -1433
  167. package/lib/iife/index.js.map +1 -1
  168. package/lib/mockServiceWorker.js +1 -1
  169. package/lib/native/index.d.mts +21 -29
  170. package/lib/native/index.d.ts +21 -29
  171. package/lib/native/index.js +48 -116
  172. package/lib/native/index.js.map +1 -1
  173. package/lib/native/index.mjs +51 -118
  174. package/lib/native/index.mjs.map +1 -1
  175. package/lib/node/index.d.mts +55 -33
  176. package/lib/node/index.d.ts +55 -33
  177. package/lib/node/index.js +152 -154
  178. package/lib/node/index.js.map +1 -1
  179. package/lib/node/index.mjs +156 -156
  180. package/lib/node/index.mjs.map +1 -1
  181. package/package.json +10 -2
  182. package/src/browser/{setupWorker/glossary.ts → glossary.ts} +16 -33
  183. package/src/browser/index.ts +2 -3
  184. package/src/browser/{setupWorker/setupWorker.node.test.ts → setup-worker.node.test.ts} +2 -4
  185. package/src/browser/setup-worker.ts +148 -0
  186. package/src/browser/sources/fallback-http-source.ts +56 -0
  187. package/src/browser/sources/service-worker-source.ts +455 -0
  188. package/src/browser/tsconfig.browser.json +7 -2
  189. package/src/browser/utils/deserializeRequest.ts +1 -1
  190. package/src/browser/{setupWorker/start/utils/getWorkerByRegistration.ts → utils/get-worker-by-registration.ts} +3 -1
  191. package/src/browser/{setupWorker/start/utils/getWorkerInstance.ts → utils/get-worker-instance.ts} +4 -4
  192. package/src/browser/utils/pruneGetRequestBody.test.ts +1 -3
  193. package/src/browser/utils/pruneGetRequestBody.ts +1 -1
  194. package/src/browser/utils/validate-worker-scope.ts +19 -0
  195. package/src/browser/utils/workerChannel.ts +2 -2
  196. package/src/core/experimental/compat.ts +50 -0
  197. package/src/core/experimental/define-network.test.ts +124 -0
  198. package/src/core/experimental/define-network.ts +215 -0
  199. package/src/core/experimental/frames/http-frame.test.ts +360 -0
  200. package/src/core/experimental/frames/http-frame.ts +271 -0
  201. package/src/core/experimental/frames/network-frame.ts +64 -0
  202. package/src/core/experimental/frames/websocket-frame.test.ts +280 -0
  203. package/src/core/experimental/frames/websocket-frame.ts +188 -0
  204. package/src/core/experimental/handlers-controller.test.ts +198 -0
  205. package/src/core/experimental/handlers-controller.ts +145 -0
  206. package/src/core/experimental/index.ts +16 -0
  207. package/src/core/experimental/on-unhandled-frame.test.ts +360 -0
  208. package/src/core/experimental/on-unhandled-frame.ts +110 -0
  209. package/src/core/experimental/request-utils.test.ts +70 -0
  210. package/src/core/experimental/request-utils.ts +39 -0
  211. package/src/core/experimental/setup-api.ts +59 -0
  212. package/src/core/experimental/sources/interceptor-source.ts +185 -0
  213. package/src/core/experimental/sources/network-source.test.ts +74 -0
  214. package/src/core/experimental/sources/network-source.ts +56 -0
  215. package/src/core/handlers/RequestHandler.ts +9 -10
  216. package/src/core/handlers/WebSocketHandler.ts +27 -11
  217. package/src/core/index.ts +3 -7
  218. package/src/core/sharedOptions.ts +9 -4
  219. package/src/core/sse.ts +1 -1
  220. package/src/core/utils/cookieStore.ts +2 -1
  221. package/src/core/utils/internal/isHandlerKind.test.ts +20 -22
  222. package/src/core/utils/internal/isHandlerKind.ts +5 -9
  223. package/src/core/utils/matching/matchRequestUrl.test.ts +87 -3
  224. package/src/core/utils/matching/matchRequestUrl.ts +2 -2
  225. package/src/core/utils/request/onUnhandledRequest.ts +2 -2
  226. package/src/core/ws/WebSocketClientManager.test.ts +2 -10
  227. package/src/core/ws/handleWebSocketEvent.ts +5 -1
  228. package/src/core/ws/utils/attachWebSocketLogger.ts +43 -11
  229. package/src/core/ws.test.ts +1 -3
  230. package/src/core/ws.ts +6 -6
  231. package/src/iife/index.ts +1 -1
  232. package/src/native/index.ts +34 -11
  233. package/src/node/async-handlers-controller.test.ts +50 -0
  234. package/src/node/async-handlers-controller.ts +69 -0
  235. package/src/node/glossary.ts +19 -18
  236. package/src/node/index.ts +6 -2
  237. package/src/node/setup-server-common.ts +100 -0
  238. package/src/node/setup-server.ts +91 -0
  239. package/src/tsconfig.core.json +8 -0
  240. package/src/tsconfig.node.json +8 -3
  241. package/src/tsconfig.src.json +0 -2
  242. package/src/tsconfig.worker.json +2 -1
  243. package/lib/core/SetupApi.d.mts +0 -44
  244. package/lib/core/SetupApi.d.ts +0 -44
  245. package/lib/core/SetupApi.js +0 -112
  246. package/lib/core/SetupApi.js.map +0 -1
  247. package/lib/core/SetupApi.mjs +0 -92
  248. package/lib/core/SetupApi.mjs.map +0 -1
  249. package/lib/core/handlers/common.d.mts +0 -3
  250. package/lib/core/handlers/common.d.ts +0 -3
  251. package/lib/core/handlers/common.js.map +0 -1
  252. package/lib/core/handlers/common.mjs +0 -1
  253. package/lib/core/handlers/common.mjs.map +0 -1
  254. package/src/browser/setupWorker/setupWorker.ts +0 -184
  255. package/src/browser/setupWorker/start/createFallbackRequestListener.ts +0 -71
  256. package/src/browser/setupWorker/start/createRequestListener.ts +0 -138
  257. package/src/browser/setupWorker/start/createResponseListener.ts +0 -57
  258. package/src/browser/setupWorker/start/createStartHandler.ts +0 -137
  259. package/src/browser/setupWorker/start/utils/enableMocking.ts +0 -30
  260. package/src/browser/setupWorker/start/utils/prepareStartHandler.test.ts +0 -59
  261. package/src/browser/setupWorker/start/utils/prepareStartHandler.ts +0 -44
  262. package/src/browser/setupWorker/start/utils/printStartMessage.test.ts +0 -84
  263. package/src/browser/setupWorker/start/utils/printStartMessage.ts +0 -51
  264. package/src/browser/setupWorker/start/utils/validateWorkerScope.ts +0 -18
  265. package/src/browser/setupWorker/stop/utils/printStopMessage.test.ts +0 -26
  266. package/src/browser/setupWorker/stop/utils/printStopMessage.ts +0 -13
  267. package/src/browser/utils/checkWorkerIntegrity.ts +0 -42
  268. package/src/core/SetupApi.ts +0 -127
  269. package/src/core/handlers/common.ts +0 -1
  270. package/src/node/SetupServerApi.ts +0 -87
  271. package/src/node/SetupServerCommonApi.ts +0 -169
  272. package/src/node/setupServer.ts +0 -15
@@ -1,59 +0,0 @@
1
- import { SetupWorkerInternalContext, StartOptions } from '../../glossary'
2
- import {
3
- DEFAULT_START_OPTIONS,
4
- resolveStartOptions,
5
- prepareStartHandler,
6
- } from './prepareStartHandler'
7
-
8
- describe('resolveStartOptions', () => {
9
- test('returns default options given no custom start options', () => {
10
- expect(resolveStartOptions()).toEqual(DEFAULT_START_OPTIONS)
11
- expect(resolveStartOptions(undefined)).toEqual(DEFAULT_START_OPTIONS)
12
- expect(resolveStartOptions({})).toEqual(DEFAULT_START_OPTIONS)
13
- })
14
-
15
- test('deeply merges the default and custom start options', () => {
16
- expect(
17
- resolveStartOptions({
18
- quiet: true,
19
- serviceWorker: {
20
- url: './custom.js',
21
- },
22
- }),
23
- ).toEqual({
24
- ...DEFAULT_START_OPTIONS,
25
- quiet: true,
26
- serviceWorker: {
27
- url: './custom.js',
28
- options: null,
29
- },
30
- })
31
- })
32
- })
33
-
34
- describe('prepareStartHandler', () => {
35
- test('exposes resolved start options to the generated star handler', () => {
36
- const createStartHandler = vi.fn()
37
- const context: SetupWorkerInternalContext = {} as any
38
- const startHandler = prepareStartHandler(createStartHandler, context)
39
- expect(startHandler).toBeInstanceOf(Function)
40
-
41
- const initialOptions: StartOptions = {
42
- quiet: true,
43
- serviceWorker: {
44
- url: './custom.js',
45
- },
46
- }
47
- const resolvedOptions = resolveStartOptions(initialOptions)
48
- startHandler(initialOptions)
49
-
50
- // Calls the handler creator with both resolved and initial options.
51
- expect(createStartHandler).toHaveBeenCalledWith(
52
- resolvedOptions,
53
- initialOptions,
54
- )
55
-
56
- // Sets the resolved options on the internal context.
57
- expect(context).toHaveProperty('startOptions', resolvedOptions)
58
- })
59
- })
@@ -1,44 +0,0 @@
1
- import { RequiredDeep } from '~/core/typeUtils'
2
- import { mergeRight } from '~/core/utils/internal/mergeRight'
3
- import {
4
- SetupWorker,
5
- SetupWorkerInternalContext,
6
- StartHandler,
7
- StartOptions,
8
- } from '../../glossary'
9
-
10
- export const DEFAULT_START_OPTIONS: RequiredDeep<StartOptions> = {
11
- serviceWorker: {
12
- url: '/mockServiceWorker.js',
13
- options: null as any,
14
- },
15
- quiet: false,
16
- waitUntilReady: true,
17
- onUnhandledRequest: 'warn',
18
- findWorker(scriptURL, mockServiceWorkerUrl) {
19
- return scriptURL === mockServiceWorkerUrl
20
- },
21
- }
22
-
23
- /**
24
- * Returns resolved worker start options, merging the default options
25
- * with the given custom options.
26
- */
27
- export function resolveStartOptions(
28
- initialOptions?: StartOptions,
29
- ): RequiredDeep<StartOptions> {
30
- return mergeRight(
31
- DEFAULT_START_OPTIONS,
32
- initialOptions || {},
33
- ) as RequiredDeep<StartOptions>
34
- }
35
-
36
- export function prepareStartHandler(
37
- handler: StartHandler,
38
- context: SetupWorkerInternalContext,
39
- ): SetupWorker['start'] {
40
- return (initialOptions) => {
41
- context.startOptions = resolveStartOptions(initialOptions)
42
- return handler(context.startOptions, initialOptions || {})
43
- }
44
- }
@@ -1,84 +0,0 @@
1
- import { printStartMessage } from './printStartMessage'
2
-
3
- beforeEach(() => {
4
- vi.spyOn(console, 'groupCollapsed').mockImplementation(() => void 0)
5
- vi.spyOn(console, 'log').mockImplementation(() => void 0)
6
- })
7
-
8
- afterEach(() => {
9
- vi.restoreAllMocks()
10
- })
11
-
12
- test('prints out a default start message into console', () => {
13
- printStartMessage({
14
- workerScope: 'http://localhost:3000/',
15
- workerUrl: 'http://localhost:3000/worker.js',
16
- })
17
-
18
- expect(console.groupCollapsed).toHaveBeenCalledWith(
19
- '%c[MSW] Mocking enabled.',
20
- expect.anything(),
21
- )
22
-
23
- // Includes a link to the documentation.
24
- expect(console.log).toHaveBeenCalledWith(
25
- '%cDocumentation: %chttps://mswjs.io/docs',
26
- expect.anything(),
27
- expect.anything(),
28
- )
29
-
30
- // Includes a link to the GitHub issues page.
31
- expect(console.log).toHaveBeenCalledWith(
32
- 'Found an issue? https://github.com/mswjs/msw/issues',
33
- )
34
-
35
- // Includes service worker scope.
36
- expect(console.log).toHaveBeenCalledWith(
37
- 'Worker scope:',
38
- 'http://localhost:3000/',
39
- )
40
-
41
- // Includes service worker script location.
42
- expect(console.log).toHaveBeenCalledWith(
43
- 'Worker script URL:',
44
- 'http://localhost:3000/worker.js',
45
- )
46
- })
47
-
48
- test('supports printing a custom start message', () => {
49
- printStartMessage({ message: 'Custom start message' })
50
-
51
- expect(console.groupCollapsed).toHaveBeenCalledWith(
52
- '%c[MSW] Custom start message',
53
- expect.anything(),
54
- )
55
- })
56
-
57
- test('does not print any messages when log level is quiet', () => {
58
- printStartMessage({ quiet: true })
59
-
60
- expect(console.groupCollapsed).not.toHaveBeenCalled()
61
- expect(console.log).not.toHaveBeenCalled()
62
- })
63
-
64
- test('prints a worker scope in the start message', () => {
65
- printStartMessage({
66
- workerScope: 'http://localhost:3000/user',
67
- })
68
-
69
- expect(console.log).toHaveBeenCalledWith(
70
- 'Worker scope:',
71
- 'http://localhost:3000/user',
72
- )
73
- })
74
-
75
- test('prints a worker script url in the start message', () => {
76
- printStartMessage({
77
- workerUrl: 'http://localhost:3000/mockServiceWorker.js',
78
- })
79
-
80
- expect(console.log).toHaveBeenCalledWith(
81
- 'Worker script URL:',
82
- 'http://localhost:3000/mockServiceWorker.js',
83
- )
84
- })
@@ -1,51 +0,0 @@
1
- import type { ServiceWorkerIncomingEventsMap } from '../../glossary'
2
- import { devUtils } from '~/core/utils/internal/devUtils'
3
-
4
- interface PrintStartMessageArgs {
5
- quiet?: boolean
6
- message?: string
7
- workerUrl?: string
8
- workerScope?: string
9
- client?: ServiceWorkerIncomingEventsMap['MOCKING_ENABLED']['client']
10
- }
11
-
12
- /**
13
- * Prints a worker activation message in the browser's console.
14
- */
15
- export function printStartMessage(args: PrintStartMessageArgs = {}) {
16
- if (args.quiet) {
17
- return
18
- }
19
-
20
- const message = args.message || 'Mocking enabled.'
21
-
22
- console.groupCollapsed(
23
- `%c${devUtils.formatMessage(message)}`,
24
- 'color:orangered;font-weight:bold;',
25
- )
26
- // eslint-disable-next-line no-console
27
- console.log(
28
- '%cDocumentation: %chttps://mswjs.io/docs',
29
- 'font-weight:bold',
30
- 'font-weight:normal',
31
- )
32
- // eslint-disable-next-line no-console
33
- console.log('Found an issue? https://github.com/mswjs/msw/issues')
34
-
35
- if (args.workerUrl) {
36
- // eslint-disable-next-line no-console
37
- console.log('Worker script URL:', args.workerUrl)
38
- }
39
-
40
- if (args.workerScope) {
41
- // eslint-disable-next-line no-console
42
- console.log('Worker scope:', args.workerScope)
43
- }
44
-
45
- if (args.client) {
46
- // eslint-disable-next-line no-console
47
- console.log('Client ID: %s (%s)', args.client.id, args.client.frameType)
48
- }
49
-
50
- console.groupEnd()
51
- }
@@ -1,18 +0,0 @@
1
- import { devUtils } from '~/core/utils/internal/devUtils'
2
- import { StartOptions } from '../../glossary'
3
-
4
- export function validateWorkerScope(
5
- registration: ServiceWorkerRegistration,
6
- options?: StartOptions,
7
- ): void {
8
- if (!options?.quiet && !location.href.startsWith(registration.scope)) {
9
- devUtils.warn(
10
- `\
11
- Cannot intercept requests on this page because it's outside of the worker's scope ("${registration.scope}"). If you wish to mock API requests on this page, you must resolve this scope issue.
12
-
13
- - (Recommended) Register the worker at the root level ("/") of your application.
14
- - Set the "Service-Worker-Allowed" response header to allow out-of-scope workers.\
15
- `,
16
- )
17
- }
18
- }
@@ -1,26 +0,0 @@
1
- import { printStopMessage } from './printStopMessage'
2
-
3
- beforeAll(() => {
4
- vi.spyOn(global.console, 'log').mockImplementation(() => void 0)
5
- })
6
-
7
- afterEach(() => {
8
- vi.resetAllMocks()
9
- })
10
-
11
- afterAll(() => {
12
- vi.restoreAllMocks()
13
- })
14
-
15
- test('prints a stop message to the console', () => {
16
- printStopMessage()
17
- expect(console.log).toHaveBeenCalledWith(
18
- '%c[MSW] Mocking disabled.',
19
- 'color:orangered;font-weight:bold;',
20
- )
21
- })
22
-
23
- test('does not print any message when log level is quiet', () => {
24
- printStopMessage({ quiet: true })
25
- expect(console.log).not.toHaveBeenCalled()
26
- })
@@ -1,13 +0,0 @@
1
- import { devUtils } from '~/core/utils/internal/devUtils'
2
-
3
- export function printStopMessage(args: { quiet?: boolean } = {}): void {
4
- if (args.quiet) {
5
- return
6
- }
7
-
8
- // eslint-disable-next-line no-console
9
- console.log(
10
- `%c${devUtils.formatMessage('Mocking disabled.')}`,
11
- 'color:orangered;font-weight:bold;',
12
- )
13
- }
@@ -1,42 +0,0 @@
1
- import { devUtils } from '~/core/utils/internal/devUtils'
2
- import type { SetupWorkerInternalContext } from '../setupWorker/glossary'
3
- import { DeferredPromise } from '@open-draft/deferred-promise'
4
-
5
- /**
6
- * Check whether the registered Service Worker has been
7
- * generated by the installed version of the library.
8
- * Prints a warning message if the worker scripts mismatch.
9
- */
10
- export function checkWorkerIntegrity(
11
- context: SetupWorkerInternalContext,
12
- ): Promise<void> {
13
- const integrityCheckPromise = new DeferredPromise<void>()
14
-
15
- // Request the integrity checksum from the registered worker.
16
- context.workerChannel.postMessage('INTEGRITY_CHECK_REQUEST')
17
- context.workerChannel.once('INTEGRITY_CHECK_RESPONSE', (event) => {
18
- const { checksum, packageVersion } = event.data
19
-
20
- // Compare the response from the Service Worker and the
21
- // global variable set during the build.
22
-
23
- // The integrity is validated based on the worker script's checksum
24
- // that's derived from its minified content during the build.
25
- // The "SERVICE_WORKER_CHECKSUM" global variable is injected by the build.
26
- if (checksum !== SERVICE_WORKER_CHECKSUM) {
27
- devUtils.warn(
28
- `The currently registered Service Worker has been generated by a different version of MSW (${packageVersion}) and may not be fully compatible with the installed version.
29
-
30
- It's recommended you update your worker script by running this command:
31
-
32
- \u2022 npx msw init <PUBLIC_DIR>
33
-
34
- You can also automate this process and make the worker script update automatically upon the library installations. Read more: https://mswjs.io/docs/cli/init.`,
35
- )
36
- }
37
-
38
- integrityCheckPromise.resolve()
39
- })
40
-
41
- return integrityCheckPromise
42
- }
@@ -1,127 +0,0 @@
1
- import { invariant } from 'outvariant'
2
- import { EventMap, Emitter } from 'strict-event-emitter'
3
- import { RequestHandler } from './handlers/RequestHandler'
4
- import { LifeCycleEventEmitter } from './sharedOptions'
5
- import { devUtils } from './utils/internal/devUtils'
6
- import { pipeEvents } from './utils/internal/pipeEvents'
7
- import { toReadonlyArray } from './utils/internal/toReadonlyArray'
8
- import { Disposable } from './utils/internal/Disposable'
9
- import type { WebSocketHandler } from './handlers/WebSocketHandler'
10
-
11
- export abstract class HandlersController {
12
- abstract prepend(
13
- runtimeHandlers: Array<RequestHandler | WebSocketHandler>,
14
- ): void
15
- abstract reset(nextHandles: Array<RequestHandler | WebSocketHandler>): void
16
- abstract currentHandlers(): Array<RequestHandler | WebSocketHandler>
17
- }
18
-
19
- export class InMemoryHandlersController implements HandlersController {
20
- private handlers: Array<RequestHandler | WebSocketHandler>
21
-
22
- constructor(
23
- private initialHandlers: Array<RequestHandler | WebSocketHandler>,
24
- ) {
25
- this.handlers = [...initialHandlers]
26
- }
27
-
28
- public prepend(
29
- runtimeHandles: Array<RequestHandler | WebSocketHandler>,
30
- ): void {
31
- this.handlers.unshift(...runtimeHandles)
32
- }
33
-
34
- public reset(nextHandlers: Array<RequestHandler | WebSocketHandler>): void {
35
- this.handlers =
36
- nextHandlers.length > 0 ? [...nextHandlers] : [...this.initialHandlers]
37
- }
38
-
39
- public currentHandlers(): Array<RequestHandler | WebSocketHandler> {
40
- return this.handlers
41
- }
42
- }
43
-
44
- /**
45
- * Generic class for the mock API setup.
46
- */
47
- export abstract class SetupApi<EventsMap extends EventMap> extends Disposable {
48
- protected handlersController: HandlersController
49
- protected readonly emitter: Emitter<EventsMap>
50
- protected readonly publicEmitter: Emitter<EventsMap>
51
-
52
- public readonly events: LifeCycleEventEmitter<EventsMap>
53
-
54
- constructor(...initialHandlers: Array<RequestHandler | WebSocketHandler>) {
55
- super()
56
-
57
- invariant(
58
- this.validateHandlers(initialHandlers),
59
- devUtils.formatMessage(
60
- `Failed to apply given request handlers: invalid input. Did you forget to spread the request handlers Array?`,
61
- ),
62
- )
63
-
64
- this.handlersController = new InMemoryHandlersController(initialHandlers)
65
-
66
- this.emitter = new Emitter<EventsMap>()
67
- this.publicEmitter = new Emitter<EventsMap>()
68
- pipeEvents(this.emitter, this.publicEmitter)
69
-
70
- this.events = this.createLifeCycleEvents()
71
-
72
- this.subscriptions.push(() => {
73
- this.emitter.removeAllListeners()
74
- this.publicEmitter.removeAllListeners()
75
- })
76
- }
77
-
78
- private validateHandlers(handlers: ReadonlyArray<unknown>): boolean {
79
- // Guard against incorrect call signature of the setup API.
80
- return handlers.every((handler) => !Array.isArray(handler))
81
- }
82
-
83
- public use(
84
- ...runtimeHandlers: Array<RequestHandler | WebSocketHandler>
85
- ): void {
86
- invariant(
87
- this.validateHandlers(runtimeHandlers),
88
- devUtils.formatMessage(
89
- `Failed to call "use()" with the given request handlers: invalid input. Did you forget to spread the array of request handlers?`,
90
- ),
91
- )
92
-
93
- this.handlersController.prepend(runtimeHandlers)
94
- }
95
-
96
- public restoreHandlers(): void {
97
- this.handlersController.currentHandlers().forEach((handler) => {
98
- if ('isUsed' in handler) {
99
- handler.isUsed = false
100
- }
101
- })
102
- }
103
-
104
- public resetHandlers(
105
- ...nextHandlers: Array<RequestHandler | WebSocketHandler>
106
- ): void {
107
- this.handlersController.reset(nextHandlers)
108
- }
109
-
110
- public listHandlers(): ReadonlyArray<RequestHandler | WebSocketHandler> {
111
- return toReadonlyArray(this.handlersController.currentHandlers())
112
- }
113
-
114
- private createLifeCycleEvents(): LifeCycleEventEmitter<EventsMap> {
115
- return {
116
- on: (...args: any[]) => {
117
- return (this.publicEmitter.on as any)(...args)
118
- },
119
- removeListener: (...args: any[]) => {
120
- return (this.publicEmitter.removeListener as any)(...args)
121
- },
122
- removeAllListeners: (...args: any[]) => {
123
- return this.publicEmitter.removeAllListeners(...args)
124
- },
125
- }
126
- }
127
- }
@@ -1 +0,0 @@
1
- export type HandlerKind = 'RequestHandler' | 'EventHandler'
@@ -1,87 +0,0 @@
1
- import { AsyncLocalStorage } from 'node:async_hooks'
2
- import type { HttpRequestEventMap, Interceptor } from '@mswjs/interceptors'
3
- import { ClientRequestInterceptor } from '@mswjs/interceptors/ClientRequest'
4
- import { XMLHttpRequestInterceptor } from '@mswjs/interceptors/XMLHttpRequest'
5
- import { FetchInterceptor } from '@mswjs/interceptors/fetch'
6
- import { HandlersController } from '~/core/SetupApi'
7
- import type { RequestHandler } from '~/core/handlers/RequestHandler'
8
- import type { WebSocketHandler } from '~/core/handlers/WebSocketHandler'
9
- import type { SetupServer } from './glossary'
10
- import { SetupServerCommonApi } from './SetupServerCommonApi'
11
-
12
- const store = new AsyncLocalStorage<RequestHandlersContext>()
13
-
14
- type RequestHandlersContext = {
15
- initialHandlers: Array<RequestHandler | WebSocketHandler>
16
- handlers: Array<RequestHandler | WebSocketHandler>
17
- }
18
-
19
- /**
20
- * A handlers controller that utilizes `AsyncLocalStorage` in Node.js
21
- * to prevent the request handlers list from being a shared state
22
- * across multiple tests.
23
- */
24
- class AsyncHandlersController implements HandlersController {
25
- private rootContext: RequestHandlersContext
26
-
27
- constructor(initialHandlers: Array<RequestHandler | WebSocketHandler>) {
28
- this.rootContext = { initialHandlers, handlers: [] }
29
- }
30
-
31
- get context(): RequestHandlersContext {
32
- return store.getStore() || this.rootContext
33
- }
34
-
35
- public prepend(runtimeHandlers: Array<RequestHandler | WebSocketHandler>) {
36
- this.context.handlers.unshift(...runtimeHandlers)
37
- }
38
-
39
- public reset(nextHandlers: Array<RequestHandler | WebSocketHandler>) {
40
- const context = this.context
41
- context.handlers = []
42
- context.initialHandlers =
43
- nextHandlers.length > 0 ? nextHandlers : context.initialHandlers
44
- }
45
-
46
- public currentHandlers(): Array<RequestHandler | WebSocketHandler> {
47
- const { initialHandlers, handlers } = this.context
48
- return handlers.concat(initialHandlers)
49
- }
50
- }
51
- export class SetupServerApi
52
- extends SetupServerCommonApi
53
- implements SetupServer
54
- {
55
- constructor(
56
- handlers: Array<RequestHandler | WebSocketHandler>,
57
- interceptors: Array<Interceptor<HttpRequestEventMap>> = [
58
- new ClientRequestInterceptor(),
59
- new XMLHttpRequestInterceptor(),
60
- new FetchInterceptor(),
61
- ],
62
- ) {
63
- super(interceptors, handlers)
64
-
65
- this.handlersController = new AsyncHandlersController(handlers)
66
- }
67
-
68
- public boundary<Args extends Array<any>, R>(
69
- callback: (...args: Args) => R,
70
- ): (...args: Args) => R {
71
- return (...args: Args): R => {
72
- return store.run<any, any>(
73
- {
74
- initialHandlers: this.handlersController.currentHandlers(),
75
- handlers: [],
76
- },
77
- callback,
78
- ...args,
79
- )
80
- }
81
- }
82
-
83
- public close(): void {
84
- super.close()
85
- store.disable()
86
- }
87
- }