msw 1.3.2 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +45 -29
- package/browser/package.json +5 -0
- package/cli/init.js +3 -3
- package/config/constants.js +1 -2
- package/lib/browser/index.d.ts +104 -0
- package/lib/browser/index.js +752 -0
- package/lib/browser/index.mjs +734 -0
- package/lib/core/GraphQLHandler-b42ca96f.d.ts +74 -0
- package/lib/core/HttpResponse.d.ts +2 -0
- package/lib/core/HttpResponse.js +94 -0
- package/lib/core/HttpResponse.mjs +77 -0
- package/lib/core/RequestHandler-1a5dbdc7.d.ts +172 -0
- package/lib/core/SetupApi.d.ts +26 -0
- package/lib/core/SetupApi.js +83 -0
- package/lib/core/SetupApi.mjs +63 -0
- package/lib/core/bypass.d.ts +16 -0
- package/lib/core/bypass.js +36 -0
- package/lib/core/bypass.mjs +16 -0
- package/lib/core/delay.d.ts +18 -0
- package/lib/core/delay.js +92 -0
- package/lib/core/delay.mjs +72 -0
- package/lib/core/graphql.d.ts +109 -0
- package/lib/core/graphql.js +112 -0
- package/lib/core/graphql.mjs +96 -0
- package/lib/core/handlers/GraphQLHandler.d.ts +5 -0
- package/lib/core/handlers/GraphQLHandler.js +145 -0
- package/lib/core/handlers/GraphQLHandler.mjs +130 -0
- package/lib/core/handlers/HttpHandler.d.ts +62 -0
- package/lib/core/handlers/HttpHandler.js +149 -0
- package/lib/core/handlers/HttpHandler.mjs +133 -0
- package/lib/core/handlers/RequestHandler.d.ts +2 -0
- package/lib/core/handlers/RequestHandler.js +180 -0
- package/lib/core/handlers/RequestHandler.mjs +162 -0
- package/lib/core/http.d.ts +26 -0
- package/lib/core/http.js +39 -0
- package/lib/core/http.mjs +22 -0
- package/lib/core/http.spec.d.ts +2 -0
- package/lib/core/http.spec.js +15 -0
- package/lib/core/http.spec.mjs +14 -0
- package/lib/core/index.d.ts +18 -0
- package/lib/core/index.js +49 -0
- package/lib/core/index.mjs +28 -0
- package/lib/core/passthrough.d.ts +17 -0
- package/lib/core/passthrough.js +32 -0
- package/lib/core/passthrough.mjs +12 -0
- package/lib/core/sharedOptions.d.ts +66 -0
- package/lib/core/sharedOptions.js +16 -0
- package/lib/core/sharedOptions.mjs +0 -0
- package/lib/core/typeUtils.d.ts +7 -0
- package/lib/core/typeUtils.js +16 -0
- package/lib/core/typeUtils.mjs +0 -0
- package/lib/core/utils/HttpResponse/decorators.d.ts +12 -0
- package/lib/core/utils/HttpResponse/decorators.js +80 -0
- package/lib/core/utils/HttpResponse/decorators.mjs +52 -0
- package/lib/core/utils/getResponse.d.ts +2 -0
- package/lib/core/utils/getResponse.js +64 -0
- package/lib/core/utils/getResponse.mjs +44 -0
- package/lib/core/utils/handleRequest.d.ts +30 -0
- package/lib/core/utils/handleRequest.js +102 -0
- package/lib/core/utils/handleRequest.mjs +82 -0
- package/lib/core/utils/internal/Disposable.d.ts +7 -0
- package/lib/core/utils/internal/Disposable.js +53 -0
- package/lib/core/utils/internal/Disposable.mjs +33 -0
- package/lib/core/utils/internal/checkGlobals.d.ts +3 -0
- package/lib/core/utils/internal/checkGlobals.js +33 -0
- package/lib/core/utils/internal/checkGlobals.mjs +13 -0
- package/lib/core/utils/internal/devUtils.d.ts +19 -0
- package/lib/core/utils/internal/devUtils.js +40 -0
- package/lib/core/utils/internal/devUtils.mjs +20 -0
- package/lib/core/utils/internal/getCallFrame.d.ts +6 -0
- package/lib/core/utils/internal/getCallFrame.js +40 -0
- package/lib/core/utils/internal/getCallFrame.mjs +20 -0
- package/lib/core/utils/internal/isIterable.d.ts +6 -0
- package/lib/core/utils/internal/isIterable.js +29 -0
- package/lib/core/utils/internal/isIterable.mjs +9 -0
- package/lib/core/utils/internal/isObject.d.ts +6 -0
- package/lib/core/utils/internal/isObject.js +26 -0
- package/lib/core/utils/internal/isObject.mjs +6 -0
- package/lib/core/utils/internal/isStringEqual.d.ts +6 -0
- package/lib/core/utils/internal/isStringEqual.js +26 -0
- package/lib/core/utils/internal/isStringEqual.mjs +6 -0
- package/lib/core/utils/internal/jsonParse.d.ts +7 -0
- package/lib/core/utils/internal/jsonParse.js +30 -0
- package/lib/core/utils/internal/jsonParse.mjs +10 -0
- package/lib/core/utils/internal/mergeRight.d.ts +7 -0
- package/lib/core/utils/internal/mergeRight.js +39 -0
- package/lib/core/utils/internal/mergeRight.mjs +19 -0
- package/lib/core/utils/internal/parseGraphQLRequest.d.ts +5 -0
- package/lib/core/utils/internal/parseGraphQLRequest.js +184 -0
- package/lib/core/utils/internal/parseGraphQLRequest.mjs +165 -0
- package/lib/core/utils/internal/parseMultipartData.d.ts +10 -0
- package/lib/core/utils/internal/parseMultipartData.js +81 -0
- package/lib/core/utils/internal/parseMultipartData.mjs +61 -0
- package/lib/core/utils/internal/pipeEvents.d.ts +8 -0
- package/lib/core/utils/internal/pipeEvents.js +34 -0
- package/lib/core/utils/internal/pipeEvents.mjs +14 -0
- package/lib/core/utils/internal/requestHandlerUtils.d.ts +8 -0
- package/lib/core/utils/internal/requestHandlerUtils.js +36 -0
- package/lib/core/utils/internal/requestHandlerUtils.mjs +16 -0
- package/lib/core/utils/internal/toReadonlyArray.d.ts +6 -0
- package/lib/core/utils/internal/toReadonlyArray.js +28 -0
- package/lib/core/utils/internal/toReadonlyArray.mjs +8 -0
- package/lib/core/utils/internal/tryCatch.d.ts +3 -0
- package/lib/core/utils/internal/tryCatch.js +31 -0
- package/lib/core/utils/internal/tryCatch.mjs +11 -0
- package/lib/core/utils/internal/uuidv4.d.ts +3 -0
- package/lib/core/utils/internal/uuidv4.js +26 -0
- package/lib/core/utils/internal/uuidv4.mjs +6 -0
- package/lib/core/utils/logging/getStatusCodeColor.d.ts +11 -0
- package/lib/core/utils/logging/getStatusCodeColor.js +39 -0
- package/lib/core/utils/logging/getStatusCodeColor.mjs +19 -0
- package/lib/core/utils/logging/getTimestamp.d.ts +6 -0
- package/lib/core/utils/logging/getTimestamp.js +27 -0
- package/lib/core/utils/logging/getTimestamp.mjs +7 -0
- package/lib/core/utils/logging/serializeRequest.d.ts +12 -0
- package/lib/core/utils/logging/serializeRequest.js +55 -0
- package/lib/core/utils/logging/serializeRequest.mjs +35 -0
- package/lib/core/utils/logging/serializeResponse.d.ts +9 -0
- package/lib/core/utils/logging/serializeResponse.js +69 -0
- package/lib/core/utils/logging/serializeResponse.mjs +39 -0
- package/lib/core/utils/matching/matchRequestUrl.d.ts +19 -0
- package/lib/core/utils/matching/matchRequestUrl.js +50 -0
- package/lib/core/utils/matching/matchRequestUrl.mjs +30 -0
- package/lib/core/utils/matching/normalizePath.d.ts +12 -0
- package/lib/core/utils/matching/normalizePath.js +32 -0
- package/lib/core/utils/matching/normalizePath.mjs +12 -0
- package/lib/core/utils/request/getPublicUrlFromRequest.d.ts +7 -0
- package/lib/core/utils/request/getPublicUrlFromRequest.js +30 -0
- package/lib/core/utils/request/getPublicUrlFromRequest.mjs +10 -0
- package/lib/core/utils/request/getRequestCookies.d.ts +8 -0
- package/lib/core/utils/request/getRequestCookies.js +88 -0
- package/lib/core/utils/request/getRequestCookies.mjs +60 -0
- package/lib/core/utils/request/onUnhandledRequest.d.ts +12 -0
- package/lib/core/utils/request/onUnhandledRequest.js +193 -0
- package/lib/core/utils/request/onUnhandledRequest.mjs +165 -0
- package/lib/core/utils/request/readResponseCookies.d.ts +3 -0
- package/lib/core/utils/request/readResponseCookies.js +45 -0
- package/lib/core/utils/request/readResponseCookies.mjs +27 -0
- package/lib/core/utils/toResponseInit.d.ts +3 -0
- package/lib/core/utils/toResponseInit.js +30 -0
- package/lib/core/utils/toResponseInit.mjs +10 -0
- package/lib/core/utils/url/cleanUrl.d.ts +7 -0
- package/lib/core/utils/url/cleanUrl.js +31 -0
- package/lib/core/utils/url/cleanUrl.mjs +11 -0
- package/lib/core/utils/url/getAbsoluteUrl.d.ts +6 -0
- package/lib/core/utils/url/getAbsoluteUrl.js +37 -0
- package/lib/core/utils/url/getAbsoluteUrl.mjs +17 -0
- package/lib/core/utils/url/isAbsoluteUrl.d.ts +6 -0
- package/lib/core/utils/url/isAbsoluteUrl.js +26 -0
- package/lib/core/utils/url/isAbsoluteUrl.mjs +6 -0
- package/lib/iife/index.js +6204 -12360
- package/lib/mockServiceWorker.js +82 -93
- package/lib/native/index.d.ts +67 -7
- package/lib/native/index.js +74 -1500
- package/lib/native/index.mjs +69 -1514
- package/lib/node/index.d.ts +68 -9
- package/lib/node/index.js +77 -1508
- package/lib/node/index.mjs +71 -1521
- package/native/package.json +2 -1
- package/node/package.json +2 -1
- package/package.json +53 -23
- package/lib/SetupServerApi-1855d9c6.d.ts +0 -20
- package/lib/glossary-de6278a9.d.ts +0 -385
- package/lib/iife/index.js.map +0 -1
- package/lib/index.d.ts +0 -365
- package/lib/index.js +0 -2295
- package/lib/index.js.map +0 -1
- package/lib/node/index.js.map +0 -1
- package/lib/node/index.mjs.map +0 -1
package/lib/index.js
DELETED
|
@@ -1,2295 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
-
mod
|
|
23
|
-
));
|
|
24
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
25
|
-
|
|
26
|
-
// src/index.ts
|
|
27
|
-
var src_exports = {};
|
|
28
|
-
__export(src_exports, {
|
|
29
|
-
GraphQLHandler: () => GraphQLHandler,
|
|
30
|
-
MockedRequest: () => MockedRequest,
|
|
31
|
-
RESTMethods: () => RESTMethods,
|
|
32
|
-
RequestHandler: () => RequestHandler,
|
|
33
|
-
RestHandler: () => RestHandler,
|
|
34
|
-
SetupApi: () => SetupApi,
|
|
35
|
-
SetupWorkerApi: () => SetupWorkerApi,
|
|
36
|
-
cleanUrl: () => cleanUrl,
|
|
37
|
-
compose: () => compose,
|
|
38
|
-
context: () => context_exports,
|
|
39
|
-
createResponseComposition: () => createResponseComposition,
|
|
40
|
-
defaultContext: () => defaultContext,
|
|
41
|
-
defaultResponse: () => defaultResponse,
|
|
42
|
-
graphql: () => graphql,
|
|
43
|
-
graphqlContext: () => graphqlContext,
|
|
44
|
-
handleRequest: () => handleRequest,
|
|
45
|
-
matchRequestUrl: () => matchRequestUrl,
|
|
46
|
-
response: () => response,
|
|
47
|
-
rest: () => rest,
|
|
48
|
-
restContext: () => restContext,
|
|
49
|
-
setupWorker: () => setupWorker
|
|
50
|
-
});
|
|
51
|
-
module.exports = __toCommonJS(src_exports);
|
|
52
|
-
|
|
53
|
-
// src/context/index.ts
|
|
54
|
-
var context_exports = {};
|
|
55
|
-
__export(context_exports, {
|
|
56
|
-
body: () => body,
|
|
57
|
-
cookie: () => cookie,
|
|
58
|
-
data: () => data,
|
|
59
|
-
delay: () => delay,
|
|
60
|
-
errors: () => errors,
|
|
61
|
-
extensions: () => extensions,
|
|
62
|
-
fetch: () => fetch,
|
|
63
|
-
json: () => json,
|
|
64
|
-
set: () => set,
|
|
65
|
-
status: () => status,
|
|
66
|
-
text: () => text,
|
|
67
|
-
xml: () => xml
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
// node_modules/.pnpm/statuses@2.0.1/node_modules/statuses/codes.json
|
|
71
|
-
var codes_default = {
|
|
72
|
-
"100": "Continue",
|
|
73
|
-
"101": "Switching Protocols",
|
|
74
|
-
"102": "Processing",
|
|
75
|
-
"103": "Early Hints",
|
|
76
|
-
"200": "OK",
|
|
77
|
-
"201": "Created",
|
|
78
|
-
"202": "Accepted",
|
|
79
|
-
"203": "Non-Authoritative Information",
|
|
80
|
-
"204": "No Content",
|
|
81
|
-
"205": "Reset Content",
|
|
82
|
-
"206": "Partial Content",
|
|
83
|
-
"207": "Multi-Status",
|
|
84
|
-
"208": "Already Reported",
|
|
85
|
-
"226": "IM Used",
|
|
86
|
-
"300": "Multiple Choices",
|
|
87
|
-
"301": "Moved Permanently",
|
|
88
|
-
"302": "Found",
|
|
89
|
-
"303": "See Other",
|
|
90
|
-
"304": "Not Modified",
|
|
91
|
-
"305": "Use Proxy",
|
|
92
|
-
"307": "Temporary Redirect",
|
|
93
|
-
"308": "Permanent Redirect",
|
|
94
|
-
"400": "Bad Request",
|
|
95
|
-
"401": "Unauthorized",
|
|
96
|
-
"402": "Payment Required",
|
|
97
|
-
"403": "Forbidden",
|
|
98
|
-
"404": "Not Found",
|
|
99
|
-
"405": "Method Not Allowed",
|
|
100
|
-
"406": "Not Acceptable",
|
|
101
|
-
"407": "Proxy Authentication Required",
|
|
102
|
-
"408": "Request Timeout",
|
|
103
|
-
"409": "Conflict",
|
|
104
|
-
"410": "Gone",
|
|
105
|
-
"411": "Length Required",
|
|
106
|
-
"412": "Precondition Failed",
|
|
107
|
-
"413": "Payload Too Large",
|
|
108
|
-
"414": "URI Too Long",
|
|
109
|
-
"415": "Unsupported Media Type",
|
|
110
|
-
"416": "Range Not Satisfiable",
|
|
111
|
-
"417": "Expectation Failed",
|
|
112
|
-
"418": "I'm a Teapot",
|
|
113
|
-
"421": "Misdirected Request",
|
|
114
|
-
"422": "Unprocessable Entity",
|
|
115
|
-
"423": "Locked",
|
|
116
|
-
"424": "Failed Dependency",
|
|
117
|
-
"425": "Too Early",
|
|
118
|
-
"426": "Upgrade Required",
|
|
119
|
-
"428": "Precondition Required",
|
|
120
|
-
"429": "Too Many Requests",
|
|
121
|
-
"431": "Request Header Fields Too Large",
|
|
122
|
-
"451": "Unavailable For Legal Reasons",
|
|
123
|
-
"500": "Internal Server Error",
|
|
124
|
-
"501": "Not Implemented",
|
|
125
|
-
"502": "Bad Gateway",
|
|
126
|
-
"503": "Service Unavailable",
|
|
127
|
-
"504": "Gateway Timeout",
|
|
128
|
-
"505": "HTTP Version Not Supported",
|
|
129
|
-
"506": "Variant Also Negotiates",
|
|
130
|
-
"507": "Insufficient Storage",
|
|
131
|
-
"508": "Loop Detected",
|
|
132
|
-
"509": "Bandwidth Limit Exceeded",
|
|
133
|
-
"510": "Not Extended",
|
|
134
|
-
"511": "Network Authentication Required"
|
|
135
|
-
};
|
|
136
|
-
|
|
137
|
-
// src/context/status.ts
|
|
138
|
-
var status = (statusCode, statusText) => {
|
|
139
|
-
return (res) => {
|
|
140
|
-
res.status = statusCode;
|
|
141
|
-
res.statusText = statusText || codes_default[String(statusCode)];
|
|
142
|
-
return res;
|
|
143
|
-
};
|
|
144
|
-
};
|
|
145
|
-
|
|
146
|
-
// src/context/set.ts
|
|
147
|
-
var import_headers_polyfill = require("headers-polyfill");
|
|
148
|
-
function set(...args) {
|
|
149
|
-
return (res) => {
|
|
150
|
-
const [name, value] = args;
|
|
151
|
-
if (typeof name === "string") {
|
|
152
|
-
res.headers.append(name, value);
|
|
153
|
-
} else {
|
|
154
|
-
const headers = (0, import_headers_polyfill.objectToHeaders)(name);
|
|
155
|
-
headers.forEach((value2, name2) => {
|
|
156
|
-
res.headers.append(name2, value2);
|
|
157
|
-
});
|
|
158
|
-
}
|
|
159
|
-
return res;
|
|
160
|
-
};
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
// src/context/cookie.ts
|
|
164
|
-
var cookieUtils = __toESM(require("cookie"));
|
|
165
|
-
var cookie = (name, value, options) => {
|
|
166
|
-
return (res) => {
|
|
167
|
-
const serializedCookie = cookieUtils.serialize(name, value, options);
|
|
168
|
-
res.headers.append("Set-Cookie", serializedCookie);
|
|
169
|
-
if (typeof document !== "undefined") {
|
|
170
|
-
document.cookie = serializedCookie;
|
|
171
|
-
}
|
|
172
|
-
return res;
|
|
173
|
-
};
|
|
174
|
-
};
|
|
175
|
-
|
|
176
|
-
// src/context/body.ts
|
|
177
|
-
var body = (value) => {
|
|
178
|
-
return (res) => {
|
|
179
|
-
res.body = value;
|
|
180
|
-
return res;
|
|
181
|
-
};
|
|
182
|
-
};
|
|
183
|
-
|
|
184
|
-
// src/utils/internal/jsonParse.ts
|
|
185
|
-
function jsonParse(value) {
|
|
186
|
-
try {
|
|
187
|
-
return JSON.parse(value);
|
|
188
|
-
} catch (error2) {
|
|
189
|
-
return void 0;
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
// src/utils/internal/isObject.ts
|
|
194
|
-
function isObject(value) {
|
|
195
|
-
return value != null && typeof value === "object" && !Array.isArray(value);
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
// src/utils/internal/mergeRight.ts
|
|
199
|
-
function mergeRight(left, right) {
|
|
200
|
-
return Object.entries(right).reduce((result, [key, rightValue]) => {
|
|
201
|
-
const leftValue = result[key];
|
|
202
|
-
if (Array.isArray(leftValue) && Array.isArray(rightValue)) {
|
|
203
|
-
result[key] = leftValue.concat(rightValue);
|
|
204
|
-
return result;
|
|
205
|
-
}
|
|
206
|
-
if (isObject(leftValue) && isObject(rightValue)) {
|
|
207
|
-
result[key] = mergeRight(leftValue, rightValue);
|
|
208
|
-
return result;
|
|
209
|
-
}
|
|
210
|
-
result[key] = rightValue;
|
|
211
|
-
return result;
|
|
212
|
-
}, Object.assign({}, left));
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
// src/context/json.ts
|
|
216
|
-
var json = (body2) => {
|
|
217
|
-
return (res) => {
|
|
218
|
-
res.headers.set("Content-Type", "application/json");
|
|
219
|
-
res.body = JSON.stringify(body2);
|
|
220
|
-
return res;
|
|
221
|
-
};
|
|
222
|
-
};
|
|
223
|
-
|
|
224
|
-
// src/context/data.ts
|
|
225
|
-
var data = (payload) => {
|
|
226
|
-
return (res) => {
|
|
227
|
-
const prevBody = jsonParse(res.body) || {};
|
|
228
|
-
const nextBody = mergeRight(prevBody, { data: payload });
|
|
229
|
-
return json(nextBody)(res);
|
|
230
|
-
};
|
|
231
|
-
};
|
|
232
|
-
|
|
233
|
-
// src/context/extensions.ts
|
|
234
|
-
var extensions = (payload) => {
|
|
235
|
-
return (res) => {
|
|
236
|
-
const prevBody = jsonParse(res.body) || {};
|
|
237
|
-
const nextBody = mergeRight(prevBody, { extensions: payload });
|
|
238
|
-
return json(nextBody)(res);
|
|
239
|
-
};
|
|
240
|
-
};
|
|
241
|
-
|
|
242
|
-
// src/context/delay.ts
|
|
243
|
-
var import_is_node_process = require("is-node-process");
|
|
244
|
-
var SET_TIMEOUT_MAX_ALLOWED_INT = 2147483647;
|
|
245
|
-
var MIN_SERVER_RESPONSE_TIME = 100;
|
|
246
|
-
var MAX_SERVER_RESPONSE_TIME = 400;
|
|
247
|
-
var NODE_SERVER_RESPONSE_TIME = 5;
|
|
248
|
-
var getRandomServerResponseTime = () => {
|
|
249
|
-
if ((0, import_is_node_process.isNodeProcess)()) {
|
|
250
|
-
return NODE_SERVER_RESPONSE_TIME;
|
|
251
|
-
}
|
|
252
|
-
return Math.floor(
|
|
253
|
-
Math.random() * (MAX_SERVER_RESPONSE_TIME - MIN_SERVER_RESPONSE_TIME) + MIN_SERVER_RESPONSE_TIME
|
|
254
|
-
);
|
|
255
|
-
};
|
|
256
|
-
var delay = (durationOrMode) => {
|
|
257
|
-
return (res) => {
|
|
258
|
-
let delayTime;
|
|
259
|
-
if (typeof durationOrMode === "string") {
|
|
260
|
-
switch (durationOrMode) {
|
|
261
|
-
case "infinite": {
|
|
262
|
-
delayTime = SET_TIMEOUT_MAX_ALLOWED_INT;
|
|
263
|
-
break;
|
|
264
|
-
}
|
|
265
|
-
case "real": {
|
|
266
|
-
delayTime = getRandomServerResponseTime();
|
|
267
|
-
break;
|
|
268
|
-
}
|
|
269
|
-
default: {
|
|
270
|
-
throw new Error(
|
|
271
|
-
`Failed to delay a response: unknown delay mode "${durationOrMode}". Please make sure you provide one of the supported modes ("real", "infinite") or a number to "ctx.delay".`
|
|
272
|
-
);
|
|
273
|
-
}
|
|
274
|
-
}
|
|
275
|
-
} else if (typeof durationOrMode === "undefined") {
|
|
276
|
-
delayTime = getRandomServerResponseTime();
|
|
277
|
-
} else {
|
|
278
|
-
if (durationOrMode > SET_TIMEOUT_MAX_ALLOWED_INT) {
|
|
279
|
-
throw new Error(
|
|
280
|
-
`Failed to delay a response: provided delay duration (${durationOrMode}) exceeds the maximum allowed duration for "setTimeout" (${SET_TIMEOUT_MAX_ALLOWED_INT}). This will cause the response to be returned immediately. Please use a number within the allowed range to delay the response by exact duration, or consider the "infinite" delay mode to delay the response indefinitely.`
|
|
281
|
-
);
|
|
282
|
-
}
|
|
283
|
-
delayTime = durationOrMode;
|
|
284
|
-
}
|
|
285
|
-
res.delay = delayTime;
|
|
286
|
-
return res;
|
|
287
|
-
};
|
|
288
|
-
};
|
|
289
|
-
|
|
290
|
-
// src/context/errors.ts
|
|
291
|
-
var errors = (errorsList) => {
|
|
292
|
-
return (res) => {
|
|
293
|
-
if (errorsList == null) {
|
|
294
|
-
return res;
|
|
295
|
-
}
|
|
296
|
-
const prevBody = jsonParse(res.body) || {};
|
|
297
|
-
const nextBody = mergeRight(prevBody, { errors: errorsList });
|
|
298
|
-
return json(nextBody)(res);
|
|
299
|
-
};
|
|
300
|
-
};
|
|
301
|
-
|
|
302
|
-
// src/context/fetch.ts
|
|
303
|
-
var import_is_node_process2 = require("is-node-process");
|
|
304
|
-
var import_headers_polyfill2 = require("headers-polyfill");
|
|
305
|
-
var useFetch = (0, import_is_node_process2.isNodeProcess)() ? (input, init) => Promise.resolve().then(() => __toESM(require("node-fetch"))).then(
|
|
306
|
-
({ default: nodeFetch }) => nodeFetch(input, init)
|
|
307
|
-
) : globalThis.fetch;
|
|
308
|
-
var augmentRequestInit = (requestInit) => {
|
|
309
|
-
const headers = new import_headers_polyfill2.Headers(requestInit.headers);
|
|
310
|
-
headers.set("x-msw-bypass", "true");
|
|
311
|
-
return {
|
|
312
|
-
...requestInit,
|
|
313
|
-
headers: headers.all()
|
|
314
|
-
};
|
|
315
|
-
};
|
|
316
|
-
var createFetchRequestParameters = (input) => {
|
|
317
|
-
const { body: body2, method } = input;
|
|
318
|
-
const requestParameters = {
|
|
319
|
-
...input,
|
|
320
|
-
body: void 0
|
|
321
|
-
};
|
|
322
|
-
if (["GET", "HEAD"].includes(method)) {
|
|
323
|
-
return requestParameters;
|
|
324
|
-
}
|
|
325
|
-
if (typeof body2 === "object" || typeof body2 === "number" || typeof body2 === "boolean") {
|
|
326
|
-
requestParameters.body = JSON.stringify(body2);
|
|
327
|
-
} else {
|
|
328
|
-
requestParameters.body = body2;
|
|
329
|
-
}
|
|
330
|
-
return requestParameters;
|
|
331
|
-
};
|
|
332
|
-
var fetch = (input, requestInit = {}) => {
|
|
333
|
-
if (typeof input === "string") {
|
|
334
|
-
return useFetch(input, augmentRequestInit(requestInit));
|
|
335
|
-
}
|
|
336
|
-
const requestParameters = createFetchRequestParameters(input);
|
|
337
|
-
const derivedRequestInit = augmentRequestInit(requestParameters);
|
|
338
|
-
return useFetch(input.url.href, derivedRequestInit);
|
|
339
|
-
};
|
|
340
|
-
|
|
341
|
-
// src/context/text.ts
|
|
342
|
-
var text = (body2) => {
|
|
343
|
-
return (res) => {
|
|
344
|
-
res.headers.set("Content-Type", "text/plain");
|
|
345
|
-
res.body = body2;
|
|
346
|
-
return res;
|
|
347
|
-
};
|
|
348
|
-
};
|
|
349
|
-
|
|
350
|
-
// src/context/xml.ts
|
|
351
|
-
var xml = (body2) => {
|
|
352
|
-
return (res) => {
|
|
353
|
-
res.headers.set("Content-Type", "text/xml");
|
|
354
|
-
res.body = body2;
|
|
355
|
-
return res;
|
|
356
|
-
};
|
|
357
|
-
};
|
|
358
|
-
|
|
359
|
-
// src/utils/internal/checkGlobals.ts
|
|
360
|
-
var import_outvariant2 = require("outvariant");
|
|
361
|
-
|
|
362
|
-
// src/utils/internal/devUtils.ts
|
|
363
|
-
var import_outvariant = require("outvariant");
|
|
364
|
-
var LIBRARY_PREFIX = "[MSW]";
|
|
365
|
-
function formatMessage(message, ...positionals) {
|
|
366
|
-
const interpolatedMessage = (0, import_outvariant.format)(message, ...positionals);
|
|
367
|
-
return `${LIBRARY_PREFIX} ${interpolatedMessage}`;
|
|
368
|
-
}
|
|
369
|
-
function warn(message, ...positionals) {
|
|
370
|
-
console.warn(formatMessage(message, ...positionals));
|
|
371
|
-
}
|
|
372
|
-
function error(message, ...positionals) {
|
|
373
|
-
console.error(formatMessage(message, ...positionals));
|
|
374
|
-
}
|
|
375
|
-
var devUtils = {
|
|
376
|
-
formatMessage,
|
|
377
|
-
warn,
|
|
378
|
-
error
|
|
379
|
-
};
|
|
380
|
-
|
|
381
|
-
// src/utils/internal/checkGlobals.ts
|
|
382
|
-
function checkGlobals() {
|
|
383
|
-
(0, import_outvariant2.invariant)(
|
|
384
|
-
typeof URL !== "undefined",
|
|
385
|
-
devUtils.formatMessage(
|
|
386
|
-
`Global "URL" class is not defined. This likely means that you're running MSW in an environment that doesn't support all Node.js standard API (e.g. React Native). If that's the case, please use an appropriate polyfill for the "URL" class, like "react-native-url-polyfill".`
|
|
387
|
-
)
|
|
388
|
-
);
|
|
389
|
-
}
|
|
390
|
-
|
|
391
|
-
// src/setupWorker/setupWorker.ts
|
|
392
|
-
var import_outvariant5 = require("outvariant");
|
|
393
|
-
var import_is_node_process3 = require("is-node-process");
|
|
394
|
-
|
|
395
|
-
// src/setupWorker/start/createStartHandler.ts
|
|
396
|
-
var import_until4 = require("@open-draft/until");
|
|
397
|
-
|
|
398
|
-
// src/setupWorker/start/utils/getWorkerInstance.ts
|
|
399
|
-
var import_until = require("@open-draft/until");
|
|
400
|
-
|
|
401
|
-
// src/setupWorker/start/utils/getWorkerByRegistration.ts
|
|
402
|
-
function getWorkerByRegistration(registration, absoluteWorkerUrl, findWorker) {
|
|
403
|
-
const allStates = [
|
|
404
|
-
registration.active,
|
|
405
|
-
registration.installing,
|
|
406
|
-
registration.waiting
|
|
407
|
-
];
|
|
408
|
-
const relevantStates = allStates.filter((state) => {
|
|
409
|
-
return state != null;
|
|
410
|
-
});
|
|
411
|
-
const worker = relevantStates.find((worker2) => {
|
|
412
|
-
return findWorker(worker2.scriptURL, absoluteWorkerUrl);
|
|
413
|
-
});
|
|
414
|
-
return worker || null;
|
|
415
|
-
}
|
|
416
|
-
|
|
417
|
-
// src/utils/url/getAbsoluteWorkerUrl.ts
|
|
418
|
-
function getAbsoluteWorkerUrl(workerUrl) {
|
|
419
|
-
return new URL(workerUrl, location.href).href;
|
|
420
|
-
}
|
|
421
|
-
|
|
422
|
-
// src/setupWorker/start/utils/getWorkerInstance.ts
|
|
423
|
-
var getWorkerInstance = async (url, options = {}, findWorker) => {
|
|
424
|
-
const absoluteWorkerUrl = getAbsoluteWorkerUrl(url);
|
|
425
|
-
const mockRegistrations = await navigator.serviceWorker.getRegistrations().then(
|
|
426
|
-
(registrations) => registrations.filter(
|
|
427
|
-
(registration) => getWorkerByRegistration(registration, absoluteWorkerUrl, findWorker)
|
|
428
|
-
)
|
|
429
|
-
);
|
|
430
|
-
if (!navigator.serviceWorker.controller && mockRegistrations.length > 0) {
|
|
431
|
-
location.reload();
|
|
432
|
-
}
|
|
433
|
-
const [existingRegistration] = mockRegistrations;
|
|
434
|
-
if (existingRegistration) {
|
|
435
|
-
return existingRegistration.update().then(() => {
|
|
436
|
-
return [
|
|
437
|
-
getWorkerByRegistration(
|
|
438
|
-
existingRegistration,
|
|
439
|
-
absoluteWorkerUrl,
|
|
440
|
-
findWorker
|
|
441
|
-
),
|
|
442
|
-
existingRegistration
|
|
443
|
-
];
|
|
444
|
-
});
|
|
445
|
-
}
|
|
446
|
-
const [error2, instance] = await (0, import_until.until)(
|
|
447
|
-
async () => {
|
|
448
|
-
const registration = await navigator.serviceWorker.register(url, options);
|
|
449
|
-
return [
|
|
450
|
-
getWorkerByRegistration(registration, absoluteWorkerUrl, findWorker),
|
|
451
|
-
registration
|
|
452
|
-
];
|
|
453
|
-
}
|
|
454
|
-
);
|
|
455
|
-
if (error2) {
|
|
456
|
-
const isWorkerMissing = error2.message.includes("(404)");
|
|
457
|
-
if (isWorkerMissing) {
|
|
458
|
-
const scopeUrl = new URL((options == null ? void 0 : options.scope) || "/", location.href);
|
|
459
|
-
throw new Error(
|
|
460
|
-
devUtils.formatMessage(`Failed to register a Service Worker for scope ('${scopeUrl.href}') with script ('${absoluteWorkerUrl}'): Service Worker script does not exist at the given path.
|
|
461
|
-
|
|
462
|
-
Did you forget to run "npx msw init <PUBLIC_DIR>"?
|
|
463
|
-
|
|
464
|
-
Learn more about creating the Service Worker script: https://mswjs.io/docs/cli/init`)
|
|
465
|
-
);
|
|
466
|
-
}
|
|
467
|
-
throw new Error(
|
|
468
|
-
devUtils.formatMessage(
|
|
469
|
-
"Failed to register the Service Worker:\n\n%s",
|
|
470
|
-
error2.message
|
|
471
|
-
)
|
|
472
|
-
);
|
|
473
|
-
}
|
|
474
|
-
return instance;
|
|
475
|
-
};
|
|
476
|
-
|
|
477
|
-
// src/setupWorker/start/utils/printStartMessage.ts
|
|
478
|
-
function printStartMessage(args = {}) {
|
|
479
|
-
if (args.quiet) {
|
|
480
|
-
return;
|
|
481
|
-
}
|
|
482
|
-
const message = args.message || "Mocking enabled.";
|
|
483
|
-
console.groupCollapsed(
|
|
484
|
-
`%c${devUtils.formatMessage(message)}`,
|
|
485
|
-
"color:orangered;font-weight:bold;"
|
|
486
|
-
);
|
|
487
|
-
console.log(
|
|
488
|
-
"%cDocumentation: %chttps://mswjs.io/docs",
|
|
489
|
-
"font-weight:bold",
|
|
490
|
-
"font-weight:normal"
|
|
491
|
-
);
|
|
492
|
-
console.log("Found an issue? https://github.com/mswjs/msw/issues");
|
|
493
|
-
if (args.workerUrl) {
|
|
494
|
-
console.log("Worker script URL:", args.workerUrl);
|
|
495
|
-
}
|
|
496
|
-
if (args.workerScope) {
|
|
497
|
-
console.log("Worker scope:", args.workerScope);
|
|
498
|
-
}
|
|
499
|
-
console.groupEnd();
|
|
500
|
-
}
|
|
501
|
-
|
|
502
|
-
// src/setupWorker/start/utils/enableMocking.ts
|
|
503
|
-
async function enableMocking(context, options) {
|
|
504
|
-
var _a, _b;
|
|
505
|
-
context.workerChannel.send("MOCK_ACTIVATE");
|
|
506
|
-
await context.events.once("MOCKING_ENABLED");
|
|
507
|
-
if (context.isMockingEnabled) {
|
|
508
|
-
devUtils.warn(
|
|
509
|
-
`Found a redundant "worker.start()" call. Note that starting the worker while mocking is already enabled will have no effect. Consider removing this "worker.start()" call.`
|
|
510
|
-
);
|
|
511
|
-
return;
|
|
512
|
-
}
|
|
513
|
-
context.isMockingEnabled = true;
|
|
514
|
-
printStartMessage({
|
|
515
|
-
quiet: options.quiet,
|
|
516
|
-
workerScope: (_a = context.registration) == null ? void 0 : _a.scope,
|
|
517
|
-
workerUrl: (_b = context.worker) == null ? void 0 : _b.scriptURL
|
|
518
|
-
});
|
|
519
|
-
}
|
|
520
|
-
|
|
521
|
-
// src/setupWorker/start/utils/createMessageChannel.ts
|
|
522
|
-
var WorkerChannel = class {
|
|
523
|
-
constructor(port) {
|
|
524
|
-
this.port = port;
|
|
525
|
-
}
|
|
526
|
-
postMessage(event, ...rest2) {
|
|
527
|
-
const [data2, transfer] = rest2;
|
|
528
|
-
this.port.postMessage({ type: event, data: data2 }, { transfer });
|
|
529
|
-
}
|
|
530
|
-
};
|
|
531
|
-
|
|
532
|
-
// src/utils/NetworkError.ts
|
|
533
|
-
var NetworkError = class extends Error {
|
|
534
|
-
constructor(message) {
|
|
535
|
-
super(message);
|
|
536
|
-
this.name = "NetworkError";
|
|
537
|
-
}
|
|
538
|
-
};
|
|
539
|
-
|
|
540
|
-
// src/utils/request/parseWorkerRequest.ts
|
|
541
|
-
var import_interceptors2 = require("@mswjs/interceptors");
|
|
542
|
-
var import_headers_polyfill5 = require("headers-polyfill");
|
|
543
|
-
|
|
544
|
-
// src/utils/request/MockedRequest.ts
|
|
545
|
-
var cookieUtils3 = __toESM(require("cookie"));
|
|
546
|
-
var import_cookies = require("@mswjs/cookies");
|
|
547
|
-
var import_interceptors = require("@mswjs/interceptors");
|
|
548
|
-
var import_bufferUtils = require("@mswjs/interceptors/lib/utils/bufferUtils.js");
|
|
549
|
-
var import_headers_polyfill4 = require("headers-polyfill");
|
|
550
|
-
|
|
551
|
-
// src/utils/request/getRequestCookies.ts
|
|
552
|
-
var cookieUtils2 = __toESM(require("cookie"));
|
|
553
|
-
function getAllCookies() {
|
|
554
|
-
return cookieUtils2.parse(document.cookie);
|
|
555
|
-
}
|
|
556
|
-
function getRequestCookies(request) {
|
|
557
|
-
if (typeof document === "undefined" || typeof location === "undefined") {
|
|
558
|
-
return {};
|
|
559
|
-
}
|
|
560
|
-
switch (request.credentials) {
|
|
561
|
-
case "same-origin": {
|
|
562
|
-
return location.origin === request.url.origin ? getAllCookies() : {};
|
|
563
|
-
}
|
|
564
|
-
case "include": {
|
|
565
|
-
return getAllCookies();
|
|
566
|
-
}
|
|
567
|
-
default: {
|
|
568
|
-
return {};
|
|
569
|
-
}
|
|
570
|
-
}
|
|
571
|
-
}
|
|
572
|
-
|
|
573
|
-
// src/utils/internal/parseMultipartData.ts
|
|
574
|
-
var import_headers_polyfill3 = require("headers-polyfill");
|
|
575
|
-
function parseContentHeaders(headersString) {
|
|
576
|
-
var _a, _b;
|
|
577
|
-
const headers = (0, import_headers_polyfill3.stringToHeaders)(headersString);
|
|
578
|
-
const contentType = headers.get("content-type") || "text/plain";
|
|
579
|
-
const disposition = headers.get("content-disposition");
|
|
580
|
-
if (!disposition) {
|
|
581
|
-
throw new Error('"Content-Disposition" header is required.');
|
|
582
|
-
}
|
|
583
|
-
const directives = disposition.split(";").reduce((acc, chunk) => {
|
|
584
|
-
const [name2, ...rest2] = chunk.trim().split("=");
|
|
585
|
-
acc[name2] = rest2.join("=");
|
|
586
|
-
return acc;
|
|
587
|
-
}, {});
|
|
588
|
-
const name = (_a = directives.name) == null ? void 0 : _a.slice(1, -1);
|
|
589
|
-
const filename = (_b = directives.filename) == null ? void 0 : _b.slice(1, -1);
|
|
590
|
-
return {
|
|
591
|
-
name,
|
|
592
|
-
filename,
|
|
593
|
-
contentType
|
|
594
|
-
};
|
|
595
|
-
}
|
|
596
|
-
function parseMultipartData(data2, headers) {
|
|
597
|
-
const contentType = headers == null ? void 0 : headers.get("content-type");
|
|
598
|
-
if (!contentType) {
|
|
599
|
-
return void 0;
|
|
600
|
-
}
|
|
601
|
-
const [, ...directives] = contentType.split(/; */);
|
|
602
|
-
const boundary = directives.filter((d) => d.startsWith("boundary=")).map((s) => s.replace(/^boundary=/, ""))[0];
|
|
603
|
-
if (!boundary) {
|
|
604
|
-
return void 0;
|
|
605
|
-
}
|
|
606
|
-
const boundaryRegExp = new RegExp(`--+${boundary}`);
|
|
607
|
-
const fields = data2.split(boundaryRegExp).filter((chunk) => chunk.startsWith("\r\n") && chunk.endsWith("\r\n")).map((chunk) => chunk.trimStart().replace(/\r\n$/, ""));
|
|
608
|
-
if (!fields.length) {
|
|
609
|
-
return void 0;
|
|
610
|
-
}
|
|
611
|
-
const parsedBody = {};
|
|
612
|
-
try {
|
|
613
|
-
for (const field2 of fields) {
|
|
614
|
-
const [contentHeaders, ...rest2] = field2.split("\r\n\r\n");
|
|
615
|
-
const contentBody = rest2.join("\r\n\r\n");
|
|
616
|
-
const { contentType: contentType2, filename, name } = parseContentHeaders(contentHeaders);
|
|
617
|
-
const value = filename === void 0 ? contentBody : new File([contentBody], filename, { type: contentType2 });
|
|
618
|
-
const parsedValue = parsedBody[name];
|
|
619
|
-
if (parsedValue === void 0) {
|
|
620
|
-
parsedBody[name] = value;
|
|
621
|
-
} else if (Array.isArray(parsedValue)) {
|
|
622
|
-
parsedBody[name] = [...parsedValue, value];
|
|
623
|
-
} else {
|
|
624
|
-
parsedBody[name] = [parsedValue, value];
|
|
625
|
-
}
|
|
626
|
-
}
|
|
627
|
-
return parsedBody;
|
|
628
|
-
} catch (error2) {
|
|
629
|
-
return void 0;
|
|
630
|
-
}
|
|
631
|
-
}
|
|
632
|
-
|
|
633
|
-
// src/utils/request/parseBody.ts
|
|
634
|
-
function parseBody(body2, headers) {
|
|
635
|
-
var _a;
|
|
636
|
-
if (!body2) {
|
|
637
|
-
return body2;
|
|
638
|
-
}
|
|
639
|
-
const contentType = ((_a = headers == null ? void 0 : headers.get("content-type")) == null ? void 0 : _a.toLowerCase()) || "";
|
|
640
|
-
const hasMultipartContent = contentType.startsWith("multipart/form-data");
|
|
641
|
-
if (hasMultipartContent && typeof body2 !== "object") {
|
|
642
|
-
return parseMultipartData(body2.toString(), headers) || body2;
|
|
643
|
-
}
|
|
644
|
-
const hasJsonContent = contentType.includes("json");
|
|
645
|
-
if (hasJsonContent && typeof body2 !== "object") {
|
|
646
|
-
return jsonParse(body2.toString()) || body2;
|
|
647
|
-
}
|
|
648
|
-
return body2;
|
|
649
|
-
}
|
|
650
|
-
|
|
651
|
-
// src/utils/internal/isStringEqual.ts
|
|
652
|
-
function isStringEqual(actual, expected) {
|
|
653
|
-
return actual.toLowerCase() === expected.toLowerCase();
|
|
654
|
-
}
|
|
655
|
-
|
|
656
|
-
// src/utils/request/MockedRequest.ts
|
|
657
|
-
var MockedRequest = class extends import_interceptors.IsomorphicRequest {
|
|
658
|
-
constructor(url, init = {}) {
|
|
659
|
-
super(url, init);
|
|
660
|
-
if (init.id) {
|
|
661
|
-
this.id = init.id;
|
|
662
|
-
}
|
|
663
|
-
this.cache = init.cache || "default";
|
|
664
|
-
this.destination = init.destination || "";
|
|
665
|
-
this.integrity = init.integrity || "";
|
|
666
|
-
this.keepalive = init.keepalive || false;
|
|
667
|
-
this.mode = init.mode || "cors";
|
|
668
|
-
this.priority = init.priority || "auto";
|
|
669
|
-
this.redirect = init.redirect || "follow";
|
|
670
|
-
this.referrer = init.referrer || "";
|
|
671
|
-
this.referrerPolicy = init.referrerPolicy || "no-referrer";
|
|
672
|
-
this.cookies = init.cookies || this.getCookies();
|
|
673
|
-
}
|
|
674
|
-
get body() {
|
|
675
|
-
const text2 = (0, import_bufferUtils.decodeBuffer)(this["_body"]);
|
|
676
|
-
const body2 = parseBody(text2, this.headers);
|
|
677
|
-
if (isStringEqual(this.method, "GET") && body2 === "") {
|
|
678
|
-
return void 0;
|
|
679
|
-
}
|
|
680
|
-
return body2;
|
|
681
|
-
}
|
|
682
|
-
passthrough() {
|
|
683
|
-
return {
|
|
684
|
-
status: 101,
|
|
685
|
-
statusText: "Continue",
|
|
686
|
-
headers: new import_headers_polyfill4.Headers(),
|
|
687
|
-
body: null,
|
|
688
|
-
passthrough: true,
|
|
689
|
-
once: false
|
|
690
|
-
};
|
|
691
|
-
}
|
|
692
|
-
getCookies() {
|
|
693
|
-
var _a;
|
|
694
|
-
const requestCookiesString = this.headers.get("cookie");
|
|
695
|
-
const ownCookies = requestCookiesString ? cookieUtils3.parse(requestCookiesString) : {};
|
|
696
|
-
import_cookies.store.hydrate();
|
|
697
|
-
const cookiesFromStore = Array.from(
|
|
698
|
-
(_a = import_cookies.store.get({ ...this, url: this.url.href })) == null ? void 0 : _a.entries()
|
|
699
|
-
).reduce((cookies, [name, { value }]) => {
|
|
700
|
-
return Object.assign(cookies, { [name.trim()]: value });
|
|
701
|
-
}, {});
|
|
702
|
-
const cookiesFromDocument = getRequestCookies(this);
|
|
703
|
-
const forwardedCookies = {
|
|
704
|
-
...cookiesFromDocument,
|
|
705
|
-
...cookiesFromStore
|
|
706
|
-
};
|
|
707
|
-
for (const [name, value] of Object.entries(forwardedCookies)) {
|
|
708
|
-
this.headers.append("cookie", `${name}=${value}`);
|
|
709
|
-
}
|
|
710
|
-
return {
|
|
711
|
-
...forwardedCookies,
|
|
712
|
-
...ownCookies
|
|
713
|
-
};
|
|
714
|
-
}
|
|
715
|
-
};
|
|
716
|
-
|
|
717
|
-
// src/utils/request/parseWorkerRequest.ts
|
|
718
|
-
function parseWorkerRequest(rawRequest) {
|
|
719
|
-
const url = new URL(rawRequest.url);
|
|
720
|
-
const headers = new import_headers_polyfill5.Headers(rawRequest.headers);
|
|
721
|
-
return new MockedRequest(url, {
|
|
722
|
-
...rawRequest,
|
|
723
|
-
body: (0, import_interceptors2.encodeBuffer)(rawRequest.body || ""),
|
|
724
|
-
headers
|
|
725
|
-
});
|
|
726
|
-
}
|
|
727
|
-
|
|
728
|
-
// src/utils/handleRequest.ts
|
|
729
|
-
var import_until2 = require("@open-draft/until");
|
|
730
|
-
|
|
731
|
-
// src/utils/getResponse.ts
|
|
732
|
-
var getResponse = async (request, handlers, resolutionContext) => {
|
|
733
|
-
const relevantHandlers = handlers.filter((handler) => {
|
|
734
|
-
return handler.test(request, resolutionContext);
|
|
735
|
-
});
|
|
736
|
-
if (relevantHandlers.length === 0) {
|
|
737
|
-
return {
|
|
738
|
-
handler: void 0,
|
|
739
|
-
response: void 0
|
|
740
|
-
};
|
|
741
|
-
}
|
|
742
|
-
const result = await relevantHandlers.reduce(async (executionResult, handler) => {
|
|
743
|
-
const previousResults = await executionResult;
|
|
744
|
-
if (!!(previousResults == null ? void 0 : previousResults.response)) {
|
|
745
|
-
return executionResult;
|
|
746
|
-
}
|
|
747
|
-
const result2 = await handler.run(request, resolutionContext);
|
|
748
|
-
if (result2 === null || result2.handler.shouldSkip) {
|
|
749
|
-
return null;
|
|
750
|
-
}
|
|
751
|
-
if (!result2.response) {
|
|
752
|
-
return {
|
|
753
|
-
request: result2.request,
|
|
754
|
-
handler: result2.handler,
|
|
755
|
-
response: void 0,
|
|
756
|
-
parsedResult: result2.parsedResult
|
|
757
|
-
};
|
|
758
|
-
}
|
|
759
|
-
if (result2.response.once) {
|
|
760
|
-
handler.markAsSkipped(true);
|
|
761
|
-
}
|
|
762
|
-
return result2;
|
|
763
|
-
}, Promise.resolve(null));
|
|
764
|
-
if (!result) {
|
|
765
|
-
return {
|
|
766
|
-
handler: void 0,
|
|
767
|
-
response: void 0
|
|
768
|
-
};
|
|
769
|
-
}
|
|
770
|
-
return {
|
|
771
|
-
handler: result.handler,
|
|
772
|
-
publicRequest: result.request,
|
|
773
|
-
parsedRequest: result.parsedResult,
|
|
774
|
-
response: result.response
|
|
775
|
-
};
|
|
776
|
-
};
|
|
777
|
-
|
|
778
|
-
// src/utils/request/onUnhandledRequest.ts
|
|
779
|
-
var import_js_levenshtein = __toESM(require("js-levenshtein"));
|
|
780
|
-
|
|
781
|
-
// src/utils/internal/parseGraphQLRequest.ts
|
|
782
|
-
var import_graphql = require("graphql");
|
|
783
|
-
|
|
784
|
-
// src/utils/request/getPublicUrlFromRequest.ts
|
|
785
|
-
var getPublicUrlFromRequest = (request) => {
|
|
786
|
-
return request.referrer.startsWith(request.url.origin) ? request.url.pathname : new URL(
|
|
787
|
-
request.url.pathname,
|
|
788
|
-
`${request.url.protocol}//${request.url.host}`
|
|
789
|
-
).href;
|
|
790
|
-
};
|
|
791
|
-
|
|
792
|
-
// src/utils/internal/parseGraphQLRequest.ts
|
|
793
|
-
function parseDocumentNode(node) {
|
|
794
|
-
var _a;
|
|
795
|
-
const operationDef = node.definitions.find((def) => {
|
|
796
|
-
return def.kind === "OperationDefinition";
|
|
797
|
-
});
|
|
798
|
-
return {
|
|
799
|
-
operationType: operationDef == null ? void 0 : operationDef.operation,
|
|
800
|
-
operationName: (_a = operationDef == null ? void 0 : operationDef.name) == null ? void 0 : _a.value
|
|
801
|
-
};
|
|
802
|
-
}
|
|
803
|
-
function parseQuery(query) {
|
|
804
|
-
try {
|
|
805
|
-
const ast = (0, import_graphql.parse)(query);
|
|
806
|
-
return parseDocumentNode(ast);
|
|
807
|
-
} catch (error2) {
|
|
808
|
-
return error2;
|
|
809
|
-
}
|
|
810
|
-
}
|
|
811
|
-
function extractMultipartVariables(variables, map, files) {
|
|
812
|
-
const operations = { variables };
|
|
813
|
-
for (const [key, pathArray] of Object.entries(map)) {
|
|
814
|
-
if (!(key in files)) {
|
|
815
|
-
throw new Error(`Given files do not have a key '${key}' .`);
|
|
816
|
-
}
|
|
817
|
-
for (const dotPath of pathArray) {
|
|
818
|
-
const [lastPath, ...reversedPaths] = dotPath.split(".").reverse();
|
|
819
|
-
const paths = reversedPaths.reverse();
|
|
820
|
-
let target = operations;
|
|
821
|
-
for (const path of paths) {
|
|
822
|
-
if (!(path in target)) {
|
|
823
|
-
throw new Error(`Property '${paths}' is not in operations.`);
|
|
824
|
-
}
|
|
825
|
-
target = target[path];
|
|
826
|
-
}
|
|
827
|
-
target[lastPath] = files[key];
|
|
828
|
-
}
|
|
829
|
-
}
|
|
830
|
-
return operations.variables;
|
|
831
|
-
}
|
|
832
|
-
function getGraphQLInput(request) {
|
|
833
|
-
var _a, _b;
|
|
834
|
-
switch (request.method) {
|
|
835
|
-
case "GET": {
|
|
836
|
-
const query = request.url.searchParams.get("query");
|
|
837
|
-
const variables = request.url.searchParams.get("variables") || "";
|
|
838
|
-
return {
|
|
839
|
-
query,
|
|
840
|
-
variables: jsonParse(variables)
|
|
841
|
-
};
|
|
842
|
-
}
|
|
843
|
-
case "POST": {
|
|
844
|
-
if ((_a = request.body) == null ? void 0 : _a.query) {
|
|
845
|
-
const { query, variables } = request.body;
|
|
846
|
-
return {
|
|
847
|
-
query,
|
|
848
|
-
variables
|
|
849
|
-
};
|
|
850
|
-
}
|
|
851
|
-
if ((_b = request.body) == null ? void 0 : _b.operations) {
|
|
852
|
-
const { operations, map, ...files } = request.body;
|
|
853
|
-
const parsedOperations = jsonParse(
|
|
854
|
-
operations
|
|
855
|
-
) || {};
|
|
856
|
-
if (!parsedOperations.query) {
|
|
857
|
-
return null;
|
|
858
|
-
}
|
|
859
|
-
const parsedMap = jsonParse(map || "") || {};
|
|
860
|
-
const variables = parsedOperations.variables ? extractMultipartVariables(
|
|
861
|
-
parsedOperations.variables,
|
|
862
|
-
parsedMap,
|
|
863
|
-
files
|
|
864
|
-
) : {};
|
|
865
|
-
return {
|
|
866
|
-
query: parsedOperations.query,
|
|
867
|
-
variables
|
|
868
|
-
};
|
|
869
|
-
}
|
|
870
|
-
}
|
|
871
|
-
default:
|
|
872
|
-
return null;
|
|
873
|
-
}
|
|
874
|
-
}
|
|
875
|
-
function parseGraphQLRequest(request) {
|
|
876
|
-
const input = getGraphQLInput(request);
|
|
877
|
-
if (!input || !input.query) {
|
|
878
|
-
return void 0;
|
|
879
|
-
}
|
|
880
|
-
const { query, variables } = input;
|
|
881
|
-
const parsedResult = parseQuery(query);
|
|
882
|
-
if (parsedResult instanceof Error) {
|
|
883
|
-
const requestPublicUrl = getPublicUrlFromRequest(request);
|
|
884
|
-
throw new Error(
|
|
885
|
-
devUtils.formatMessage(
|
|
886
|
-
'Failed to intercept a GraphQL request to "%s %s": cannot parse query. See the error message from the parser below.\n\n%s',
|
|
887
|
-
request.method,
|
|
888
|
-
requestPublicUrl,
|
|
889
|
-
parsedResult.message
|
|
890
|
-
)
|
|
891
|
-
);
|
|
892
|
-
}
|
|
893
|
-
return {
|
|
894
|
-
operationType: parsedResult.operationType,
|
|
895
|
-
operationName: parsedResult.operationName,
|
|
896
|
-
variables
|
|
897
|
-
};
|
|
898
|
-
}
|
|
899
|
-
|
|
900
|
-
// src/utils/logging/getStatusCodeColor.ts
|
|
901
|
-
function getStatusCodeColor(status2) {
|
|
902
|
-
if (status2 < 300) {
|
|
903
|
-
return "#69AB32" /* Success */;
|
|
904
|
-
}
|
|
905
|
-
if (status2 < 400) {
|
|
906
|
-
return "#F0BB4B" /* Warning */;
|
|
907
|
-
}
|
|
908
|
-
return "#E95F5D" /* Danger */;
|
|
909
|
-
}
|
|
910
|
-
|
|
911
|
-
// src/utils/logging/getTimestamp.ts
|
|
912
|
-
function getTimestamp() {
|
|
913
|
-
const now = new Date();
|
|
914
|
-
return [now.getHours(), now.getMinutes(), now.getSeconds()].map(String).map((chunk) => chunk.slice(0, 2)).map((chunk) => chunk.padStart(2, "0")).join(":");
|
|
915
|
-
}
|
|
916
|
-
|
|
917
|
-
// src/utils/logging/prepareRequest.ts
|
|
918
|
-
function prepareRequest(request) {
|
|
919
|
-
return {
|
|
920
|
-
...request,
|
|
921
|
-
body: request.body,
|
|
922
|
-
headers: request.headers.all()
|
|
923
|
-
};
|
|
924
|
-
}
|
|
925
|
-
|
|
926
|
-
// src/utils/logging/prepareResponse.ts
|
|
927
|
-
var import_headers_polyfill6 = require("headers-polyfill");
|
|
928
|
-
function prepareResponse(res) {
|
|
929
|
-
const responseHeaders = (0, import_headers_polyfill6.objectToHeaders)(res.headers);
|
|
930
|
-
const parsedBody = parseBody(res.body, responseHeaders);
|
|
931
|
-
return {
|
|
932
|
-
...res,
|
|
933
|
-
body: parsedBody
|
|
934
|
-
};
|
|
935
|
-
}
|
|
936
|
-
|
|
937
|
-
// src/utils/matching/matchRequestUrl.ts
|
|
938
|
-
var import_path_to_regexp = require("path-to-regexp");
|
|
939
|
-
var import_getCleanUrl = require("@mswjs/interceptors/lib/utils/getCleanUrl.js");
|
|
940
|
-
|
|
941
|
-
// src/utils/url/cleanUrl.ts
|
|
942
|
-
var REDUNDANT_CHARACTERS_EXP = /[\?|#].*$/g;
|
|
943
|
-
function getSearchParams(path) {
|
|
944
|
-
return new URL(`/${path}`, "http://localhost").searchParams;
|
|
945
|
-
}
|
|
946
|
-
function cleanUrl(path) {
|
|
947
|
-
return path.replace(REDUNDANT_CHARACTERS_EXP, "");
|
|
948
|
-
}
|
|
949
|
-
|
|
950
|
-
// src/utils/url/isAbsoluteUrl.ts
|
|
951
|
-
function isAbsoluteUrl(url) {
|
|
952
|
-
return /^([a-z][a-z\d\+\-\.]*:)?\/\//i.test(url);
|
|
953
|
-
}
|
|
954
|
-
|
|
955
|
-
// src/utils/url/getAbsoluteUrl.ts
|
|
956
|
-
function getAbsoluteUrl(path, baseUrl) {
|
|
957
|
-
if (isAbsoluteUrl(path)) {
|
|
958
|
-
return path;
|
|
959
|
-
}
|
|
960
|
-
if (path.startsWith("*")) {
|
|
961
|
-
return path;
|
|
962
|
-
}
|
|
963
|
-
const origin = baseUrl || typeof document !== "undefined" && document.baseURI;
|
|
964
|
-
return origin ? decodeURI(new URL(encodeURI(path), origin).href) : path;
|
|
965
|
-
}
|
|
966
|
-
|
|
967
|
-
// src/utils/matching/normalizePath.ts
|
|
968
|
-
function normalizePath(path, baseUrl) {
|
|
969
|
-
if (path instanceof RegExp) {
|
|
970
|
-
return path;
|
|
971
|
-
}
|
|
972
|
-
const maybeAbsoluteUrl = getAbsoluteUrl(path, baseUrl);
|
|
973
|
-
return cleanUrl(maybeAbsoluteUrl);
|
|
974
|
-
}
|
|
975
|
-
|
|
976
|
-
// src/utils/matching/matchRequestUrl.ts
|
|
977
|
-
function coercePath(path) {
|
|
978
|
-
return path.replace(
|
|
979
|
-
/([:a-zA-Z_-]*)(\*{1,2})+/g,
|
|
980
|
-
(_, parameterName, wildcard) => {
|
|
981
|
-
const expression = "(.*)";
|
|
982
|
-
if (!parameterName) {
|
|
983
|
-
return expression;
|
|
984
|
-
}
|
|
985
|
-
return parameterName.startsWith(":") ? `${parameterName}${wildcard}` : `${parameterName}${expression}`;
|
|
986
|
-
}
|
|
987
|
-
).replace(/([^\/])(:)(?=\d+)/, "$1\\$2").replace(/^([^\/]+)(:)(?=\/\/)/, "$1\\$2");
|
|
988
|
-
}
|
|
989
|
-
function matchRequestUrl(url, path, baseUrl) {
|
|
990
|
-
const normalizedPath = normalizePath(path, baseUrl);
|
|
991
|
-
const cleanPath = typeof normalizedPath === "string" ? coercePath(normalizedPath) : normalizedPath;
|
|
992
|
-
const cleanUrl2 = (0, import_getCleanUrl.getCleanUrl)(url);
|
|
993
|
-
const result = (0, import_path_to_regexp.match)(cleanPath, { decode: decodeURIComponent })(cleanUrl2);
|
|
994
|
-
const params = result && result.params || {};
|
|
995
|
-
return {
|
|
996
|
-
matches: result !== false,
|
|
997
|
-
params
|
|
998
|
-
};
|
|
999
|
-
}
|
|
1000
|
-
|
|
1001
|
-
// src/handlers/RequestHandler.ts
|
|
1002
|
-
var import_headers_polyfill8 = require("headers-polyfill");
|
|
1003
|
-
|
|
1004
|
-
// src/response.ts
|
|
1005
|
-
var import_headers_polyfill7 = require("headers-polyfill");
|
|
1006
|
-
|
|
1007
|
-
// src/utils/internal/compose.ts
|
|
1008
|
-
function compose(...fns) {
|
|
1009
|
-
return (...args) => {
|
|
1010
|
-
return fns.reduceRight((leftFn, rightFn) => {
|
|
1011
|
-
return leftFn instanceof Promise ? Promise.resolve(leftFn).then(rightFn) : rightFn(leftFn);
|
|
1012
|
-
}, args[0]);
|
|
1013
|
-
};
|
|
1014
|
-
}
|
|
1015
|
-
|
|
1016
|
-
// src/response.ts
|
|
1017
|
-
var defaultResponse = {
|
|
1018
|
-
status: 200,
|
|
1019
|
-
statusText: "OK",
|
|
1020
|
-
body: null,
|
|
1021
|
-
delay: 0,
|
|
1022
|
-
once: false,
|
|
1023
|
-
passthrough: false
|
|
1024
|
-
};
|
|
1025
|
-
var defaultResponseTransformers = [];
|
|
1026
|
-
function createResponseComposition(responseOverrides, defaultTransformers = defaultResponseTransformers) {
|
|
1027
|
-
return async (...transformers) => {
|
|
1028
|
-
const initialResponse = Object.assign(
|
|
1029
|
-
{},
|
|
1030
|
-
defaultResponse,
|
|
1031
|
-
{
|
|
1032
|
-
headers: new import_headers_polyfill7.Headers({
|
|
1033
|
-
"x-powered-by": "msw"
|
|
1034
|
-
})
|
|
1035
|
-
},
|
|
1036
|
-
responseOverrides
|
|
1037
|
-
);
|
|
1038
|
-
const resolvedTransformers = [
|
|
1039
|
-
...defaultTransformers,
|
|
1040
|
-
...transformers
|
|
1041
|
-
].filter(Boolean);
|
|
1042
|
-
const resolvedResponse = resolvedTransformers.length > 0 ? compose(...resolvedTransformers)(initialResponse) : initialResponse;
|
|
1043
|
-
return resolvedResponse;
|
|
1044
|
-
};
|
|
1045
|
-
}
|
|
1046
|
-
var response = Object.assign(createResponseComposition(), {
|
|
1047
|
-
once: createResponseComposition({ once: true }),
|
|
1048
|
-
networkError(message) {
|
|
1049
|
-
throw new NetworkError(message);
|
|
1050
|
-
}
|
|
1051
|
-
});
|
|
1052
|
-
|
|
1053
|
-
// src/utils/internal/getCallFrame.ts
|
|
1054
|
-
var SOURCE_FRAME = /[\/\\]msw[\/\\]src[\/\\](.+)/;
|
|
1055
|
-
var BUILD_FRAME = /(node_modules)?[\/\\]lib[\/\\](umd|esm|iief|cjs)[\/\\]|^[^\/\\]*$/;
|
|
1056
|
-
function getCallFrame(error2) {
|
|
1057
|
-
const stack = error2.stack;
|
|
1058
|
-
if (!stack) {
|
|
1059
|
-
return;
|
|
1060
|
-
}
|
|
1061
|
-
const frames = stack.split("\n").slice(1);
|
|
1062
|
-
const declarationFrame = frames.find((frame) => {
|
|
1063
|
-
return !(SOURCE_FRAME.test(frame) || BUILD_FRAME.test(frame));
|
|
1064
|
-
});
|
|
1065
|
-
if (!declarationFrame) {
|
|
1066
|
-
return;
|
|
1067
|
-
}
|
|
1068
|
-
const declarationPath = declarationFrame.replace(/\s*at [^()]*\(([^)]+)\)/, "$1").replace(/^@/, "");
|
|
1069
|
-
return declarationPath;
|
|
1070
|
-
}
|
|
1071
|
-
|
|
1072
|
-
// src/utils/internal/isIterable.ts
|
|
1073
|
-
function isIterable(fn) {
|
|
1074
|
-
if (!fn) {
|
|
1075
|
-
return false;
|
|
1076
|
-
}
|
|
1077
|
-
return typeof fn[Symbol.iterator] == "function";
|
|
1078
|
-
}
|
|
1079
|
-
|
|
1080
|
-
// src/handlers/RequestHandler.ts
|
|
1081
|
-
var defaultContext = {
|
|
1082
|
-
status,
|
|
1083
|
-
set,
|
|
1084
|
-
delay,
|
|
1085
|
-
fetch
|
|
1086
|
-
};
|
|
1087
|
-
var RequestHandler = class {
|
|
1088
|
-
constructor(options) {
|
|
1089
|
-
this.shouldSkip = false;
|
|
1090
|
-
this.ctx = options.ctx || defaultContext;
|
|
1091
|
-
this.resolver = options.resolver;
|
|
1092
|
-
const callFrame = getCallFrame(new Error());
|
|
1093
|
-
this.info = {
|
|
1094
|
-
...options.info,
|
|
1095
|
-
callFrame
|
|
1096
|
-
};
|
|
1097
|
-
}
|
|
1098
|
-
parse(_request, _resolutionContext) {
|
|
1099
|
-
return null;
|
|
1100
|
-
}
|
|
1101
|
-
test(request, resolutionContext) {
|
|
1102
|
-
return this.predicate(
|
|
1103
|
-
request,
|
|
1104
|
-
this.parse(request, resolutionContext),
|
|
1105
|
-
resolutionContext
|
|
1106
|
-
);
|
|
1107
|
-
}
|
|
1108
|
-
getPublicRequest(request, _parsedResult) {
|
|
1109
|
-
return request;
|
|
1110
|
-
}
|
|
1111
|
-
markAsSkipped(shouldSkip = true) {
|
|
1112
|
-
this.shouldSkip = shouldSkip;
|
|
1113
|
-
}
|
|
1114
|
-
async run(request, resolutionContext) {
|
|
1115
|
-
if (this.shouldSkip) {
|
|
1116
|
-
return null;
|
|
1117
|
-
}
|
|
1118
|
-
const parsedResult = this.parse(request, resolutionContext);
|
|
1119
|
-
const shouldIntercept = this.predicate(
|
|
1120
|
-
request,
|
|
1121
|
-
parsedResult,
|
|
1122
|
-
resolutionContext
|
|
1123
|
-
);
|
|
1124
|
-
if (!shouldIntercept) {
|
|
1125
|
-
return null;
|
|
1126
|
-
}
|
|
1127
|
-
const publicRequest = this.getPublicRequest(request, parsedResult);
|
|
1128
|
-
const executeResolver = this.wrapResolver(this.resolver);
|
|
1129
|
-
const mockedResponse = await executeResolver(
|
|
1130
|
-
publicRequest,
|
|
1131
|
-
response,
|
|
1132
|
-
this.ctx
|
|
1133
|
-
);
|
|
1134
|
-
return this.createExecutionResult(
|
|
1135
|
-
parsedResult,
|
|
1136
|
-
publicRequest,
|
|
1137
|
-
mockedResponse
|
|
1138
|
-
);
|
|
1139
|
-
}
|
|
1140
|
-
wrapResolver(resolver) {
|
|
1141
|
-
return async (req, res, ctx) => {
|
|
1142
|
-
const result = this.resolverGenerator || await resolver(req, res, ctx);
|
|
1143
|
-
if (isIterable(result)) {
|
|
1144
|
-
const { value, done } = result[Symbol.iterator]().next();
|
|
1145
|
-
const nextResponse = await value;
|
|
1146
|
-
if (!nextResponse && done) {
|
|
1147
|
-
return this.resolverGeneratorResult;
|
|
1148
|
-
}
|
|
1149
|
-
if (!this.resolverGenerator) {
|
|
1150
|
-
this.resolverGenerator = result;
|
|
1151
|
-
}
|
|
1152
|
-
this.resolverGeneratorResult = nextResponse;
|
|
1153
|
-
return nextResponse;
|
|
1154
|
-
}
|
|
1155
|
-
return result;
|
|
1156
|
-
};
|
|
1157
|
-
}
|
|
1158
|
-
createExecutionResult(parsedResult, request, response2) {
|
|
1159
|
-
return {
|
|
1160
|
-
handler: this,
|
|
1161
|
-
parsedResult: parsedResult || null,
|
|
1162
|
-
request,
|
|
1163
|
-
response: response2 || null
|
|
1164
|
-
};
|
|
1165
|
-
}
|
|
1166
|
-
};
|
|
1167
|
-
|
|
1168
|
-
// src/handlers/RestHandler.ts
|
|
1169
|
-
var RESTMethods = /* @__PURE__ */ ((RESTMethods2) => {
|
|
1170
|
-
RESTMethods2["HEAD"] = "HEAD";
|
|
1171
|
-
RESTMethods2["GET"] = "GET";
|
|
1172
|
-
RESTMethods2["POST"] = "POST";
|
|
1173
|
-
RESTMethods2["PUT"] = "PUT";
|
|
1174
|
-
RESTMethods2["PATCH"] = "PATCH";
|
|
1175
|
-
RESTMethods2["OPTIONS"] = "OPTIONS";
|
|
1176
|
-
RESTMethods2["DELETE"] = "DELETE";
|
|
1177
|
-
return RESTMethods2;
|
|
1178
|
-
})(RESTMethods || {});
|
|
1179
|
-
var restContext = {
|
|
1180
|
-
...defaultContext,
|
|
1181
|
-
cookie,
|
|
1182
|
-
body,
|
|
1183
|
-
text,
|
|
1184
|
-
json,
|
|
1185
|
-
xml
|
|
1186
|
-
};
|
|
1187
|
-
var RestRequest = class extends MockedRequest {
|
|
1188
|
-
constructor(request, params) {
|
|
1189
|
-
super(request.url, {
|
|
1190
|
-
...request,
|
|
1191
|
-
body: request["_body"]
|
|
1192
|
-
});
|
|
1193
|
-
this.params = params;
|
|
1194
|
-
this.id = request.id;
|
|
1195
|
-
}
|
|
1196
|
-
};
|
|
1197
|
-
var RestHandler = class extends RequestHandler {
|
|
1198
|
-
constructor(method, path, resolver) {
|
|
1199
|
-
super({
|
|
1200
|
-
info: {
|
|
1201
|
-
header: `${method} ${path}`,
|
|
1202
|
-
path,
|
|
1203
|
-
method
|
|
1204
|
-
},
|
|
1205
|
-
ctx: restContext,
|
|
1206
|
-
resolver
|
|
1207
|
-
});
|
|
1208
|
-
this.checkRedundantQueryParameters();
|
|
1209
|
-
}
|
|
1210
|
-
checkRedundantQueryParameters() {
|
|
1211
|
-
const { method, path } = this.info;
|
|
1212
|
-
if (path instanceof RegExp) {
|
|
1213
|
-
return;
|
|
1214
|
-
}
|
|
1215
|
-
const url = cleanUrl(path);
|
|
1216
|
-
if (url === path) {
|
|
1217
|
-
return;
|
|
1218
|
-
}
|
|
1219
|
-
const searchParams = getSearchParams(path);
|
|
1220
|
-
const queryParams = [];
|
|
1221
|
-
searchParams.forEach((_, paramName) => {
|
|
1222
|
-
queryParams.push(paramName);
|
|
1223
|
-
});
|
|
1224
|
-
devUtils.warn(
|
|
1225
|
-
`Found a redundant usage of query parameters in the request handler URL for "${method} ${path}". Please match against a path instead and access query parameters in the response resolver function using "req.url.searchParams".`
|
|
1226
|
-
);
|
|
1227
|
-
}
|
|
1228
|
-
parse(request, resolutionContext) {
|
|
1229
|
-
return matchRequestUrl(
|
|
1230
|
-
request.url,
|
|
1231
|
-
this.info.path,
|
|
1232
|
-
resolutionContext == null ? void 0 : resolutionContext.baseUrl
|
|
1233
|
-
);
|
|
1234
|
-
}
|
|
1235
|
-
getPublicRequest(request, parsedResult) {
|
|
1236
|
-
return new RestRequest(request, parsedResult.params || {});
|
|
1237
|
-
}
|
|
1238
|
-
predicate(request, parsedResult) {
|
|
1239
|
-
const matchesMethod = this.info.method instanceof RegExp ? this.info.method.test(request.method) : isStringEqual(this.info.method, request.method);
|
|
1240
|
-
return matchesMethod && parsedResult.matches;
|
|
1241
|
-
}
|
|
1242
|
-
log(request, response2) {
|
|
1243
|
-
const publicUrl = getPublicUrlFromRequest(request);
|
|
1244
|
-
const loggedRequest = prepareRequest(request);
|
|
1245
|
-
const loggedResponse = prepareResponse(response2);
|
|
1246
|
-
const statusColor = getStatusCodeColor(response2.status);
|
|
1247
|
-
console.groupCollapsed(
|
|
1248
|
-
devUtils.formatMessage("%s %s %s (%c%s%c)"),
|
|
1249
|
-
getTimestamp(),
|
|
1250
|
-
request.method,
|
|
1251
|
-
publicUrl,
|
|
1252
|
-
`color:${statusColor}`,
|
|
1253
|
-
`${response2.status} ${response2.statusText}`,
|
|
1254
|
-
"color:inherit"
|
|
1255
|
-
);
|
|
1256
|
-
console.log("Request", loggedRequest);
|
|
1257
|
-
console.log("Handler:", this);
|
|
1258
|
-
console.log("Response", loggedResponse);
|
|
1259
|
-
console.groupEnd();
|
|
1260
|
-
}
|
|
1261
|
-
};
|
|
1262
|
-
|
|
1263
|
-
// src/context/field.ts
|
|
1264
|
-
var import_outvariant3 = require("outvariant");
|
|
1265
|
-
var field = (fieldName, fieldValue) => {
|
|
1266
|
-
return (res) => {
|
|
1267
|
-
validateFieldName(fieldName);
|
|
1268
|
-
const prevBody = jsonParse(res.body) || {};
|
|
1269
|
-
const nextBody = mergeRight(prevBody, { [fieldName]: fieldValue });
|
|
1270
|
-
return json(nextBody)(res);
|
|
1271
|
-
};
|
|
1272
|
-
};
|
|
1273
|
-
function validateFieldName(fieldName) {
|
|
1274
|
-
(0, import_outvariant3.invariant)(
|
|
1275
|
-
fieldName.trim() !== "",
|
|
1276
|
-
devUtils.formatMessage(
|
|
1277
|
-
"Failed to set a custom field on a GraphQL response: field name cannot be empty."
|
|
1278
|
-
)
|
|
1279
|
-
);
|
|
1280
|
-
(0, import_outvariant3.invariant)(
|
|
1281
|
-
fieldName !== "data",
|
|
1282
|
-
devUtils.formatMessage(
|
|
1283
|
-
'Failed to set a custom "%s" field on a mocked GraphQL response: forbidden field name. Did you mean to call "ctx.data()" instead?',
|
|
1284
|
-
fieldName
|
|
1285
|
-
)
|
|
1286
|
-
);
|
|
1287
|
-
(0, import_outvariant3.invariant)(
|
|
1288
|
-
fieldName !== "errors",
|
|
1289
|
-
devUtils.formatMessage(
|
|
1290
|
-
'Failed to set a custom "%s" field on a mocked GraphQL response: forbidden field name. Did you mean to call "ctx.errors()" instead?',
|
|
1291
|
-
fieldName
|
|
1292
|
-
)
|
|
1293
|
-
);
|
|
1294
|
-
(0, import_outvariant3.invariant)(
|
|
1295
|
-
fieldName !== "extensions",
|
|
1296
|
-
devUtils.formatMessage(
|
|
1297
|
-
'Failed to set a custom "%s" field on a mocked GraphQL response: forbidden field name. Did you mean to call "ctx.extensions()" instead?',
|
|
1298
|
-
fieldName
|
|
1299
|
-
)
|
|
1300
|
-
);
|
|
1301
|
-
}
|
|
1302
|
-
|
|
1303
|
-
// src/utils/internal/tryCatch.ts
|
|
1304
|
-
function tryCatch(fn, onException) {
|
|
1305
|
-
try {
|
|
1306
|
-
const result = fn();
|
|
1307
|
-
return result;
|
|
1308
|
-
} catch (error2) {
|
|
1309
|
-
onException == null ? void 0 : onException(error2);
|
|
1310
|
-
}
|
|
1311
|
-
}
|
|
1312
|
-
|
|
1313
|
-
// src/handlers/GraphQLHandler.ts
|
|
1314
|
-
var graphqlContext = {
|
|
1315
|
-
...defaultContext,
|
|
1316
|
-
data,
|
|
1317
|
-
extensions,
|
|
1318
|
-
errors,
|
|
1319
|
-
cookie,
|
|
1320
|
-
field
|
|
1321
|
-
};
|
|
1322
|
-
function isDocumentNode(value) {
|
|
1323
|
-
if (value == null) {
|
|
1324
|
-
return false;
|
|
1325
|
-
}
|
|
1326
|
-
return typeof value === "object" && "kind" in value && "definitions" in value;
|
|
1327
|
-
}
|
|
1328
|
-
var GraphQLRequest = class extends MockedRequest {
|
|
1329
|
-
constructor(request, variables, operationName) {
|
|
1330
|
-
super(request.url, {
|
|
1331
|
-
...request,
|
|
1332
|
-
body: request["_body"]
|
|
1333
|
-
});
|
|
1334
|
-
this.variables = variables;
|
|
1335
|
-
this.operationName = operationName;
|
|
1336
|
-
}
|
|
1337
|
-
};
|
|
1338
|
-
var GraphQLHandler = class extends RequestHandler {
|
|
1339
|
-
constructor(operationType, operationName, endpoint, resolver) {
|
|
1340
|
-
let resolvedOperationName = operationName;
|
|
1341
|
-
if (isDocumentNode(operationName)) {
|
|
1342
|
-
const parsedNode = parseDocumentNode(operationName);
|
|
1343
|
-
if (parsedNode.operationType !== operationType) {
|
|
1344
|
-
throw new Error(
|
|
1345
|
-
`Failed to create a GraphQL handler: provided a DocumentNode with a mismatched operation type (expected "${operationType}", but got "${parsedNode.operationType}").`
|
|
1346
|
-
);
|
|
1347
|
-
}
|
|
1348
|
-
if (!parsedNode.operationName) {
|
|
1349
|
-
throw new Error(
|
|
1350
|
-
`Failed to create a GraphQL handler: provided a DocumentNode with no operation name.`
|
|
1351
|
-
);
|
|
1352
|
-
}
|
|
1353
|
-
resolvedOperationName = parsedNode.operationName;
|
|
1354
|
-
}
|
|
1355
|
-
const header = operationType === "all" ? `${operationType} (origin: ${endpoint.toString()})` : `${operationType} ${resolvedOperationName} (origin: ${endpoint.toString()})`;
|
|
1356
|
-
super({
|
|
1357
|
-
info: {
|
|
1358
|
-
header,
|
|
1359
|
-
operationType,
|
|
1360
|
-
operationName: resolvedOperationName
|
|
1361
|
-
},
|
|
1362
|
-
ctx: graphqlContext,
|
|
1363
|
-
resolver
|
|
1364
|
-
});
|
|
1365
|
-
this.endpoint = endpoint;
|
|
1366
|
-
}
|
|
1367
|
-
parse(request) {
|
|
1368
|
-
return tryCatch(
|
|
1369
|
-
() => parseGraphQLRequest(request),
|
|
1370
|
-
(error2) => console.error(error2.message)
|
|
1371
|
-
);
|
|
1372
|
-
}
|
|
1373
|
-
getPublicRequest(request, parsedResult) {
|
|
1374
|
-
var _a, _b;
|
|
1375
|
-
return new GraphQLRequest(
|
|
1376
|
-
request,
|
|
1377
|
-
(_a = parsedResult == null ? void 0 : parsedResult.variables) != null ? _a : {},
|
|
1378
|
-
(_b = parsedResult == null ? void 0 : parsedResult.operationName) != null ? _b : ""
|
|
1379
|
-
);
|
|
1380
|
-
}
|
|
1381
|
-
predicate(request, parsedResult) {
|
|
1382
|
-
if (!parsedResult) {
|
|
1383
|
-
return false;
|
|
1384
|
-
}
|
|
1385
|
-
if (!parsedResult.operationName && this.info.operationType !== "all") {
|
|
1386
|
-
const publicUrl = getPublicUrlFromRequest(request);
|
|
1387
|
-
devUtils.warn(`Failed to intercept a GraphQL request at "${request.method} ${publicUrl}": anonymous GraphQL operations are not supported.
|
|
1388
|
-
|
|
1389
|
-
Consider naming this operation or using "graphql.operation()" request handler to intercept GraphQL requests regardless of their operation name/type. Read more: https://mswjs.io/docs/api/graphql/operation `);
|
|
1390
|
-
return false;
|
|
1391
|
-
}
|
|
1392
|
-
const hasMatchingUrl = matchRequestUrl(request.url, this.endpoint);
|
|
1393
|
-
const hasMatchingOperationType = this.info.operationType === "all" || parsedResult.operationType === this.info.operationType;
|
|
1394
|
-
const hasMatchingOperationName = this.info.operationName instanceof RegExp ? this.info.operationName.test(parsedResult.operationName || "") : parsedResult.operationName === this.info.operationName;
|
|
1395
|
-
return hasMatchingUrl.matches && hasMatchingOperationType && hasMatchingOperationName;
|
|
1396
|
-
}
|
|
1397
|
-
log(request, response2, parsedRequest) {
|
|
1398
|
-
const loggedRequest = prepareRequest(request);
|
|
1399
|
-
const loggedResponse = prepareResponse(response2);
|
|
1400
|
-
const statusColor = getStatusCodeColor(response2.status);
|
|
1401
|
-
const requestInfo = (parsedRequest == null ? void 0 : parsedRequest.operationName) ? `${parsedRequest == null ? void 0 : parsedRequest.operationType} ${parsedRequest == null ? void 0 : parsedRequest.operationName}` : `anonymous ${parsedRequest == null ? void 0 : parsedRequest.operationType}`;
|
|
1402
|
-
console.groupCollapsed(
|
|
1403
|
-
devUtils.formatMessage("%s %s (%c%s%c)"),
|
|
1404
|
-
getTimestamp(),
|
|
1405
|
-
`${requestInfo}`,
|
|
1406
|
-
`color:${statusColor}`,
|
|
1407
|
-
`${response2.status} ${response2.statusText}`,
|
|
1408
|
-
"color:inherit"
|
|
1409
|
-
);
|
|
1410
|
-
console.log("Request:", loggedRequest);
|
|
1411
|
-
console.log("Handler:", this);
|
|
1412
|
-
console.log("Response:", loggedResponse);
|
|
1413
|
-
console.groupEnd();
|
|
1414
|
-
}
|
|
1415
|
-
};
|
|
1416
|
-
|
|
1417
|
-
// src/utils/request/onUnhandledRequest.ts
|
|
1418
|
-
var MAX_MATCH_SCORE = 3;
|
|
1419
|
-
var MAX_SUGGESTION_COUNT = 4;
|
|
1420
|
-
var TYPE_MATCH_DELTA = 0.5;
|
|
1421
|
-
function groupHandlersByType(handlers) {
|
|
1422
|
-
return handlers.reduce(
|
|
1423
|
-
(groups, handler) => {
|
|
1424
|
-
if (handler instanceof RestHandler) {
|
|
1425
|
-
groups.rest.push(handler);
|
|
1426
|
-
}
|
|
1427
|
-
if (handler instanceof GraphQLHandler) {
|
|
1428
|
-
groups.graphql.push(handler);
|
|
1429
|
-
}
|
|
1430
|
-
return groups;
|
|
1431
|
-
},
|
|
1432
|
-
{
|
|
1433
|
-
rest: [],
|
|
1434
|
-
graphql: []
|
|
1435
|
-
}
|
|
1436
|
-
);
|
|
1437
|
-
}
|
|
1438
|
-
function getRestHandlerScore() {
|
|
1439
|
-
return (request, handler) => {
|
|
1440
|
-
const { path, method } = handler.info;
|
|
1441
|
-
if (path instanceof RegExp || method instanceof RegExp) {
|
|
1442
|
-
return Infinity;
|
|
1443
|
-
}
|
|
1444
|
-
const hasSameMethod = isStringEqual(request.method, method);
|
|
1445
|
-
const methodScoreDelta = hasSameMethod ? TYPE_MATCH_DELTA : 0;
|
|
1446
|
-
const requestPublicUrl = getPublicUrlFromRequest(request);
|
|
1447
|
-
const score = (0, import_js_levenshtein.default)(requestPublicUrl, path);
|
|
1448
|
-
return score - methodScoreDelta;
|
|
1449
|
-
};
|
|
1450
|
-
}
|
|
1451
|
-
function getGraphQLHandlerScore(parsedQuery) {
|
|
1452
|
-
return (_, handler) => {
|
|
1453
|
-
if (typeof parsedQuery.operationName === "undefined") {
|
|
1454
|
-
return Infinity;
|
|
1455
|
-
}
|
|
1456
|
-
const { operationType, operationName } = handler.info;
|
|
1457
|
-
if (typeof operationName !== "string") {
|
|
1458
|
-
return Infinity;
|
|
1459
|
-
}
|
|
1460
|
-
const hasSameOperationType = parsedQuery.operationType === operationType;
|
|
1461
|
-
const operationTypeScoreDelta = hasSameOperationType ? TYPE_MATCH_DELTA : 0;
|
|
1462
|
-
const score = (0, import_js_levenshtein.default)(parsedQuery.operationName, operationName);
|
|
1463
|
-
return score - operationTypeScoreDelta;
|
|
1464
|
-
};
|
|
1465
|
-
}
|
|
1466
|
-
function getSuggestedHandler(request, handlers, getScore) {
|
|
1467
|
-
const suggestedHandlers = handlers.reduce((suggestions, handler) => {
|
|
1468
|
-
const score = getScore(request, handler);
|
|
1469
|
-
return suggestions.concat([[score, handler]]);
|
|
1470
|
-
}, []).sort(([leftScore], [rightScore]) => leftScore - rightScore).filter(([score]) => score <= MAX_MATCH_SCORE).slice(0, MAX_SUGGESTION_COUNT).map(([, handler]) => handler);
|
|
1471
|
-
return suggestedHandlers;
|
|
1472
|
-
}
|
|
1473
|
-
function getSuggestedHandlersMessage(handlers) {
|
|
1474
|
-
if (handlers.length > 1) {
|
|
1475
|
-
return `Did you mean to request one of the following resources instead?
|
|
1476
|
-
|
|
1477
|
-
${handlers.map((handler) => ` \u2022 ${handler.info.header}`).join("\n")}`;
|
|
1478
|
-
}
|
|
1479
|
-
return `Did you mean to request "${handlers[0].info.header}" instead?`;
|
|
1480
|
-
}
|
|
1481
|
-
function onUnhandledRequest(request, handlers, strategy = "warn") {
|
|
1482
|
-
const parsedGraphQLQuery = tryCatch(() => parseGraphQLRequest(request));
|
|
1483
|
-
function generateHandlerSuggestion() {
|
|
1484
|
-
const handlerGroups = groupHandlersByType(handlers);
|
|
1485
|
-
const relevantHandlers = parsedGraphQLQuery ? handlerGroups.graphql : handlerGroups.rest;
|
|
1486
|
-
const suggestedHandlers = getSuggestedHandler(
|
|
1487
|
-
request,
|
|
1488
|
-
relevantHandlers,
|
|
1489
|
-
parsedGraphQLQuery ? getGraphQLHandlerScore(parsedGraphQLQuery) : getRestHandlerScore()
|
|
1490
|
-
);
|
|
1491
|
-
return suggestedHandlers.length > 0 ? getSuggestedHandlersMessage(suggestedHandlers) : "";
|
|
1492
|
-
}
|
|
1493
|
-
function generateUnhandledRequestMessage() {
|
|
1494
|
-
const publicUrl = getPublicUrlFromRequest(request);
|
|
1495
|
-
const requestHeader = parsedGraphQLQuery ? `${parsedGraphQLQuery.operationType} ${parsedGraphQLQuery.operationName} (${request.method} ${publicUrl})` : `${request.method} ${publicUrl}`;
|
|
1496
|
-
const handlerSuggestion = generateHandlerSuggestion();
|
|
1497
|
-
const messageTemplate = [
|
|
1498
|
-
`captured a request without a matching request handler:`,
|
|
1499
|
-
` \u2022 ${requestHeader}`,
|
|
1500
|
-
handlerSuggestion,
|
|
1501
|
-
`If you still wish to intercept this unhandled request, please create a request handler for it.
|
|
1502
|
-
Read more: https://mswjs.io/docs/getting-started/mocks`
|
|
1503
|
-
].filter(Boolean);
|
|
1504
|
-
return messageTemplate.join("\n\n");
|
|
1505
|
-
}
|
|
1506
|
-
function applyStrategy(strategy2) {
|
|
1507
|
-
const message = generateUnhandledRequestMessage();
|
|
1508
|
-
switch (strategy2) {
|
|
1509
|
-
case "error": {
|
|
1510
|
-
devUtils.error("Error: %s", message);
|
|
1511
|
-
throw new Error(
|
|
1512
|
-
devUtils.formatMessage(
|
|
1513
|
-
'Cannot bypass a request when using the "error" strategy for the "onUnhandledRequest" option.'
|
|
1514
|
-
)
|
|
1515
|
-
);
|
|
1516
|
-
}
|
|
1517
|
-
case "warn": {
|
|
1518
|
-
devUtils.warn("Warning: %s", message);
|
|
1519
|
-
break;
|
|
1520
|
-
}
|
|
1521
|
-
case "bypass":
|
|
1522
|
-
break;
|
|
1523
|
-
default:
|
|
1524
|
-
throw new Error(
|
|
1525
|
-
devUtils.formatMessage(
|
|
1526
|
-
'Failed to react to an unhandled request: unknown strategy "%s". Please provide one of the supported strategies ("bypass", "warn", "error") or a custom callback function as the value of the "onUnhandledRequest" option.',
|
|
1527
|
-
strategy2
|
|
1528
|
-
)
|
|
1529
|
-
);
|
|
1530
|
-
}
|
|
1531
|
-
}
|
|
1532
|
-
if (typeof strategy === "function") {
|
|
1533
|
-
strategy(request, {
|
|
1534
|
-
warning: applyStrategy.bind(null, "warn"),
|
|
1535
|
-
error: applyStrategy.bind(null, "error")
|
|
1536
|
-
});
|
|
1537
|
-
return;
|
|
1538
|
-
}
|
|
1539
|
-
applyStrategy(strategy);
|
|
1540
|
-
}
|
|
1541
|
-
|
|
1542
|
-
// src/utils/request/readResponseCookies.ts
|
|
1543
|
-
var import_cookies2 = require("@mswjs/cookies");
|
|
1544
|
-
function readResponseCookies(request, response2) {
|
|
1545
|
-
import_cookies2.store.add({ ...request, url: request.url.toString() }, response2);
|
|
1546
|
-
import_cookies2.store.persist();
|
|
1547
|
-
}
|
|
1548
|
-
|
|
1549
|
-
// src/utils/handleRequest.ts
|
|
1550
|
-
async function handleRequest(request, handlers, options, emitter, handleRequestOptions) {
|
|
1551
|
-
var _a, _b, _c, _d, _e, _f;
|
|
1552
|
-
emitter.emit("request:start", request);
|
|
1553
|
-
if (request.headers.get("x-msw-bypass") === "true") {
|
|
1554
|
-
emitter.emit("request:end", request);
|
|
1555
|
-
(_a = handleRequestOptions == null ? void 0 : handleRequestOptions.onPassthroughResponse) == null ? void 0 : _a.call(handleRequestOptions, request);
|
|
1556
|
-
return;
|
|
1557
|
-
}
|
|
1558
|
-
const [lookupError, lookupResult] = await (0, import_until2.until)(() => {
|
|
1559
|
-
return getResponse(
|
|
1560
|
-
request,
|
|
1561
|
-
handlers,
|
|
1562
|
-
handleRequestOptions == null ? void 0 : handleRequestOptions.resolutionContext
|
|
1563
|
-
);
|
|
1564
|
-
});
|
|
1565
|
-
if (lookupError) {
|
|
1566
|
-
emitter.emit("unhandledException", lookupError, request);
|
|
1567
|
-
throw lookupError;
|
|
1568
|
-
}
|
|
1569
|
-
const { handler, response: response2 } = lookupResult;
|
|
1570
|
-
if (!handler) {
|
|
1571
|
-
onUnhandledRequest(request, handlers, options.onUnhandledRequest);
|
|
1572
|
-
emitter.emit("request:unhandled", request);
|
|
1573
|
-
emitter.emit("request:end", request);
|
|
1574
|
-
(_b = handleRequestOptions == null ? void 0 : handleRequestOptions.onPassthroughResponse) == null ? void 0 : _b.call(handleRequestOptions, request);
|
|
1575
|
-
return;
|
|
1576
|
-
}
|
|
1577
|
-
if (!response2) {
|
|
1578
|
-
devUtils.warn(
|
|
1579
|
-
`Expected response resolver to return a mocked response Object, but got %s. The original response is going to be used instead.
|
|
1580
|
-
|
|
1581
|
-
\u2022 %s
|
|
1582
|
-
%s`,
|
|
1583
|
-
response2,
|
|
1584
|
-
handler.info.header,
|
|
1585
|
-
handler.info.callFrame
|
|
1586
|
-
);
|
|
1587
|
-
emitter.emit("request:end", request);
|
|
1588
|
-
(_c = handleRequestOptions == null ? void 0 : handleRequestOptions.onPassthroughResponse) == null ? void 0 : _c.call(handleRequestOptions, request);
|
|
1589
|
-
return;
|
|
1590
|
-
}
|
|
1591
|
-
if (response2.passthrough) {
|
|
1592
|
-
emitter.emit("request:end", request);
|
|
1593
|
-
(_d = handleRequestOptions == null ? void 0 : handleRequestOptions.onPassthroughResponse) == null ? void 0 : _d.call(handleRequestOptions, request);
|
|
1594
|
-
return;
|
|
1595
|
-
}
|
|
1596
|
-
readResponseCookies(request, response2);
|
|
1597
|
-
emitter.emit("request:match", request);
|
|
1598
|
-
const requiredLookupResult = lookupResult;
|
|
1599
|
-
const transformedResponse = ((_e = handleRequestOptions == null ? void 0 : handleRequestOptions.transformResponse) == null ? void 0 : _e.call(handleRequestOptions, response2)) || response2;
|
|
1600
|
-
(_f = handleRequestOptions == null ? void 0 : handleRequestOptions.onMockedResponse) == null ? void 0 : _f.call(
|
|
1601
|
-
handleRequestOptions,
|
|
1602
|
-
transformedResponse,
|
|
1603
|
-
requiredLookupResult
|
|
1604
|
-
);
|
|
1605
|
-
emitter.emit("request:end", request);
|
|
1606
|
-
return transformedResponse;
|
|
1607
|
-
}
|
|
1608
|
-
|
|
1609
|
-
// src/utils/logging/serializeResponse.ts
|
|
1610
|
-
var import_headers_polyfill9 = require("headers-polyfill");
|
|
1611
|
-
async function serializeResponse(response2) {
|
|
1612
|
-
return {
|
|
1613
|
-
status: response2.status,
|
|
1614
|
-
statusText: response2.statusText,
|
|
1615
|
-
headers: (0, import_headers_polyfill9.flattenHeadersObject)((0, import_headers_polyfill9.headersToObject)(response2.headers)),
|
|
1616
|
-
body: await response2.clone().text()
|
|
1617
|
-
};
|
|
1618
|
-
}
|
|
1619
|
-
|
|
1620
|
-
// src/setupWorker/start/createRequestListener.ts
|
|
1621
|
-
var createRequestListener = (context, options) => {
|
|
1622
|
-
return async (event, message) => {
|
|
1623
|
-
var _a;
|
|
1624
|
-
const messageChannel = new WorkerChannel(event.ports[0]);
|
|
1625
|
-
const request = parseWorkerRequest(message.payload);
|
|
1626
|
-
try {
|
|
1627
|
-
await handleRequest(
|
|
1628
|
-
request,
|
|
1629
|
-
context.requestHandlers,
|
|
1630
|
-
options,
|
|
1631
|
-
context.emitter,
|
|
1632
|
-
{
|
|
1633
|
-
transformResponse,
|
|
1634
|
-
onPassthroughResponse() {
|
|
1635
|
-
messageChannel.postMessage("NOT_FOUND");
|
|
1636
|
-
},
|
|
1637
|
-
async onMockedResponse(response2, { handler, publicRequest, parsedRequest }) {
|
|
1638
|
-
if (response2.body instanceof ReadableStream) {
|
|
1639
|
-
throw new Error(
|
|
1640
|
-
devUtils.formatMessage(
|
|
1641
|
-
'Failed to construct a mocked response with a "ReadableStream" body: mocked streams are not supported. Follow https://github.com/mswjs/msw/issues/1336 for more details.'
|
|
1642
|
-
)
|
|
1643
|
-
);
|
|
1644
|
-
}
|
|
1645
|
-
const responseInstance = new Response(response2.body, response2);
|
|
1646
|
-
const responseForLogs = responseInstance.clone();
|
|
1647
|
-
const responseBodyBuffer = await responseInstance.arrayBuffer();
|
|
1648
|
-
const responseBody = response2.body == null ? null : responseBodyBuffer;
|
|
1649
|
-
messageChannel.postMessage(
|
|
1650
|
-
"MOCK_RESPONSE",
|
|
1651
|
-
{
|
|
1652
|
-
...response2,
|
|
1653
|
-
body: responseBody
|
|
1654
|
-
},
|
|
1655
|
-
[responseBodyBuffer]
|
|
1656
|
-
);
|
|
1657
|
-
if (!options.quiet) {
|
|
1658
|
-
context.emitter.once("response:mocked", async () => {
|
|
1659
|
-
handler.log(
|
|
1660
|
-
publicRequest,
|
|
1661
|
-
await serializeResponse(responseForLogs),
|
|
1662
|
-
parsedRequest
|
|
1663
|
-
);
|
|
1664
|
-
});
|
|
1665
|
-
}
|
|
1666
|
-
}
|
|
1667
|
-
}
|
|
1668
|
-
);
|
|
1669
|
-
} catch (error2) {
|
|
1670
|
-
if (error2 instanceof NetworkError) {
|
|
1671
|
-
messageChannel.postMessage("NETWORK_ERROR", {
|
|
1672
|
-
name: error2.name,
|
|
1673
|
-
message: error2.message
|
|
1674
|
-
});
|
|
1675
|
-
return;
|
|
1676
|
-
}
|
|
1677
|
-
if (error2 instanceof Error) {
|
|
1678
|
-
devUtils.error(
|
|
1679
|
-
`Uncaught exception in the request handler for "%s %s":
|
|
1680
|
-
|
|
1681
|
-
%s
|
|
1682
|
-
|
|
1683
|
-
This exception has been gracefully handled as a 500 response, however, it's strongly recommended to resolve this error, as it indicates a mistake in your code. If you wish to mock an error response, please see this guide: https://mswjs.io/docs/recipes/mocking-error-responses`,
|
|
1684
|
-
request.method,
|
|
1685
|
-
request.url,
|
|
1686
|
-
(_a = error2.stack) != null ? _a : error2
|
|
1687
|
-
);
|
|
1688
|
-
messageChannel.postMessage("MOCK_RESPONSE", {
|
|
1689
|
-
status: 500,
|
|
1690
|
-
statusText: "Request Handler Error",
|
|
1691
|
-
headers: {
|
|
1692
|
-
"Content-Type": "application/json"
|
|
1693
|
-
},
|
|
1694
|
-
body: JSON.stringify({
|
|
1695
|
-
name: error2.name,
|
|
1696
|
-
message: error2.message,
|
|
1697
|
-
stack: error2.stack
|
|
1698
|
-
})
|
|
1699
|
-
});
|
|
1700
|
-
}
|
|
1701
|
-
}
|
|
1702
|
-
};
|
|
1703
|
-
};
|
|
1704
|
-
function transformResponse(response2) {
|
|
1705
|
-
return {
|
|
1706
|
-
status: response2.status,
|
|
1707
|
-
statusText: response2.statusText,
|
|
1708
|
-
headers: response2.headers.all(),
|
|
1709
|
-
body: response2.body,
|
|
1710
|
-
delay: response2.delay
|
|
1711
|
-
};
|
|
1712
|
-
}
|
|
1713
|
-
|
|
1714
|
-
// src/utils/internal/requestIntegrityCheck.ts
|
|
1715
|
-
async function requestIntegrityCheck(context, serviceWorker) {
|
|
1716
|
-
context.workerChannel.send("INTEGRITY_CHECK_REQUEST");
|
|
1717
|
-
const { payload: actualChecksum } = await context.events.once(
|
|
1718
|
-
"INTEGRITY_CHECK_RESPONSE"
|
|
1719
|
-
);
|
|
1720
|
-
if (actualChecksum !== "3d6b9f06410d179a7f7404d4bf4c3c70") {
|
|
1721
|
-
throw new Error(
|
|
1722
|
-
`Currently active Service Worker (${actualChecksum}) is behind the latest published one (${"3d6b9f06410d179a7f7404d4bf4c3c70"}).`
|
|
1723
|
-
);
|
|
1724
|
-
}
|
|
1725
|
-
return serviceWorker;
|
|
1726
|
-
}
|
|
1727
|
-
|
|
1728
|
-
// src/utils/deferNetworkRequestsUntil.ts
|
|
1729
|
-
var import_until3 = require("@open-draft/until");
|
|
1730
|
-
function deferNetworkRequestsUntil(predicatePromise) {
|
|
1731
|
-
const originalXhrSend = window.XMLHttpRequest.prototype.send;
|
|
1732
|
-
window.XMLHttpRequest.prototype.send = function(...args) {
|
|
1733
|
-
(0, import_until3.until)(() => predicatePromise).then(() => {
|
|
1734
|
-
window.XMLHttpRequest.prototype.send = originalXhrSend;
|
|
1735
|
-
this.send(...args);
|
|
1736
|
-
});
|
|
1737
|
-
};
|
|
1738
|
-
const originalFetch = window.fetch;
|
|
1739
|
-
window.fetch = async (...args) => {
|
|
1740
|
-
await (0, import_until3.until)(() => predicatePromise);
|
|
1741
|
-
window.fetch = originalFetch;
|
|
1742
|
-
return window.fetch(...args);
|
|
1743
|
-
};
|
|
1744
|
-
}
|
|
1745
|
-
|
|
1746
|
-
// src/setupWorker/start/createResponseListener.ts
|
|
1747
|
-
function createResponseListener(context) {
|
|
1748
|
-
return (_, message) => {
|
|
1749
|
-
var _a;
|
|
1750
|
-
const { payload: responseJson } = message;
|
|
1751
|
-
if ((_a = responseJson.type) == null ? void 0 : _a.includes("opaque")) {
|
|
1752
|
-
return;
|
|
1753
|
-
}
|
|
1754
|
-
const response2 = new Response(responseJson.body || null, responseJson);
|
|
1755
|
-
const isMockedResponse = response2.headers.get("x-powered-by") === "msw";
|
|
1756
|
-
if (isMockedResponse) {
|
|
1757
|
-
context.emitter.emit("response:mocked", response2, responseJson.requestId);
|
|
1758
|
-
} else {
|
|
1759
|
-
context.emitter.emit("response:bypass", response2, responseJson.requestId);
|
|
1760
|
-
}
|
|
1761
|
-
};
|
|
1762
|
-
}
|
|
1763
|
-
|
|
1764
|
-
// src/setupWorker/start/utils/validateWorkerScope.ts
|
|
1765
|
-
function validateWorkerScope(registration, options) {
|
|
1766
|
-
if (!(options == null ? void 0 : options.quiet) && !location.href.startsWith(registration.scope)) {
|
|
1767
|
-
devUtils.warn(
|
|
1768
|
-
`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.
|
|
1769
|
-
|
|
1770
|
-
- (Recommended) Register the worker at the root level ("/") of your application.
|
|
1771
|
-
- Set the "Service-Worker-Allowed" response header to allow out-of-scope workers.`
|
|
1772
|
-
);
|
|
1773
|
-
}
|
|
1774
|
-
}
|
|
1775
|
-
|
|
1776
|
-
// src/setupWorker/start/createStartHandler.ts
|
|
1777
|
-
var createStartHandler = (context) => {
|
|
1778
|
-
return function start(options, customOptions) {
|
|
1779
|
-
const startWorkerInstance = async () => {
|
|
1780
|
-
context.events.removeAllListeners();
|
|
1781
|
-
context.workerChannel.on(
|
|
1782
|
-
"REQUEST",
|
|
1783
|
-
createRequestListener(context, options)
|
|
1784
|
-
);
|
|
1785
|
-
context.workerChannel.on("RESPONSE", createResponseListener(context));
|
|
1786
|
-
const instance = await getWorkerInstance(
|
|
1787
|
-
options.serviceWorker.url,
|
|
1788
|
-
options.serviceWorker.options,
|
|
1789
|
-
options.findWorker
|
|
1790
|
-
);
|
|
1791
|
-
const [worker, registration] = instance;
|
|
1792
|
-
if (!worker) {
|
|
1793
|
-
const missingWorkerMessage = (customOptions == null ? void 0 : customOptions.findWorker) ? devUtils.formatMessage(
|
|
1794
|
-
`Failed to locate the Service Worker registration using a custom "findWorker" predicate.
|
|
1795
|
-
|
|
1796
|
-
Please ensure that the custom predicate properly locates the Service Worker registration at "%s".
|
|
1797
|
-
More details: https://mswjs.io/docs/api/setup-worker/start#findworker
|
|
1798
|
-
`,
|
|
1799
|
-
options.serviceWorker.url
|
|
1800
|
-
) : devUtils.formatMessage(
|
|
1801
|
-
`Failed to locate the Service Worker registration.
|
|
1802
|
-
|
|
1803
|
-
This most likely means that the worker script URL "%s" cannot resolve against the actual public hostname (%s). This may happen if your application runs behind a proxy, or has a dynamic hostname.
|
|
1804
|
-
|
|
1805
|
-
Please consider using a custom "serviceWorker.url" option to point to the actual worker script location, or a custom "findWorker" option to resolve the Service Worker registration manually. More details: https://mswjs.io/docs/api/setup-worker/start`,
|
|
1806
|
-
options.serviceWorker.url,
|
|
1807
|
-
location.host
|
|
1808
|
-
);
|
|
1809
|
-
throw new Error(missingWorkerMessage);
|
|
1810
|
-
}
|
|
1811
|
-
context.worker = worker;
|
|
1812
|
-
context.registration = registration;
|
|
1813
|
-
context.events.addListener(window, "beforeunload", () => {
|
|
1814
|
-
if (worker.state !== "redundant") {
|
|
1815
|
-
context.workerChannel.send("CLIENT_CLOSED");
|
|
1816
|
-
}
|
|
1817
|
-
window.clearInterval(context.keepAliveInterval);
|
|
1818
|
-
});
|
|
1819
|
-
const [integrityError] = await (0, import_until4.until)(
|
|
1820
|
-
() => requestIntegrityCheck(context, worker)
|
|
1821
|
-
);
|
|
1822
|
-
if (integrityError) {
|
|
1823
|
-
devUtils.error(`Detected outdated Service Worker: ${integrityError.message}
|
|
1824
|
-
|
|
1825
|
-
The mocking is still enabled, but it's highly recommended that you update your Service Worker by running:
|
|
1826
|
-
|
|
1827
|
-
$ npx msw init <PUBLIC_DIR>
|
|
1828
|
-
|
|
1829
|
-
This is necessary to ensure that the Service Worker is in sync with the library to guarantee its stability.
|
|
1830
|
-
If this message still persists after updating, please report an issue: https://github.com/open-draft/msw/issues `);
|
|
1831
|
-
}
|
|
1832
|
-
context.keepAliveInterval = window.setInterval(
|
|
1833
|
-
() => context.workerChannel.send("KEEPALIVE_REQUEST"),
|
|
1834
|
-
5e3
|
|
1835
|
-
);
|
|
1836
|
-
validateWorkerScope(registration, context.startOptions);
|
|
1837
|
-
return registration;
|
|
1838
|
-
};
|
|
1839
|
-
const workerRegistration = startWorkerInstance().then(
|
|
1840
|
-
async (registration) => {
|
|
1841
|
-
const pendingInstance = registration.installing || registration.waiting;
|
|
1842
|
-
if (pendingInstance) {
|
|
1843
|
-
await new Promise((resolve) => {
|
|
1844
|
-
pendingInstance.addEventListener("statechange", () => {
|
|
1845
|
-
if (pendingInstance.state === "activated") {
|
|
1846
|
-
return resolve();
|
|
1847
|
-
}
|
|
1848
|
-
});
|
|
1849
|
-
});
|
|
1850
|
-
}
|
|
1851
|
-
await enableMocking(context, options).catch((error2) => {
|
|
1852
|
-
throw new Error(`Failed to enable mocking: ${error2 == null ? void 0 : error2.message}`);
|
|
1853
|
-
});
|
|
1854
|
-
return registration;
|
|
1855
|
-
}
|
|
1856
|
-
);
|
|
1857
|
-
if (options.waitUntilReady) {
|
|
1858
|
-
deferNetworkRequestsUntil(workerRegistration);
|
|
1859
|
-
}
|
|
1860
|
-
return workerRegistration;
|
|
1861
|
-
};
|
|
1862
|
-
};
|
|
1863
|
-
|
|
1864
|
-
// src/setupWorker/stop/utils/printStopMessage.ts
|
|
1865
|
-
function printStopMessage(args = {}) {
|
|
1866
|
-
if (args.quiet) {
|
|
1867
|
-
return;
|
|
1868
|
-
}
|
|
1869
|
-
console.log(
|
|
1870
|
-
`%c${devUtils.formatMessage("Mocking disabled.")}`,
|
|
1871
|
-
"color:orangered;font-weight:bold;"
|
|
1872
|
-
);
|
|
1873
|
-
}
|
|
1874
|
-
|
|
1875
|
-
// src/setupWorker/stop/createStop.ts
|
|
1876
|
-
var createStop = (context) => {
|
|
1877
|
-
return function stop() {
|
|
1878
|
-
var _a;
|
|
1879
|
-
if (!context.isMockingEnabled) {
|
|
1880
|
-
devUtils.warn(
|
|
1881
|
-
'Found a redundant "worker.stop()" call. Note that stopping the worker while mocking already stopped has no effect. Consider removing this "worker.stop()" call.'
|
|
1882
|
-
);
|
|
1883
|
-
return;
|
|
1884
|
-
}
|
|
1885
|
-
context.workerChannel.send("MOCK_DEACTIVATE");
|
|
1886
|
-
context.isMockingEnabled = false;
|
|
1887
|
-
window.clearInterval(context.keepAliveInterval);
|
|
1888
|
-
printStopMessage({ quiet: (_a = context.startOptions) == null ? void 0 : _a.quiet });
|
|
1889
|
-
};
|
|
1890
|
-
};
|
|
1891
|
-
|
|
1892
|
-
// src/setupWorker/start/utils/prepareStartHandler.ts
|
|
1893
|
-
var DEFAULT_START_OPTIONS = {
|
|
1894
|
-
serviceWorker: {
|
|
1895
|
-
url: "/mockServiceWorker.js",
|
|
1896
|
-
options: null
|
|
1897
|
-
},
|
|
1898
|
-
quiet: false,
|
|
1899
|
-
waitUntilReady: true,
|
|
1900
|
-
onUnhandledRequest: "warn",
|
|
1901
|
-
findWorker(scriptURL, mockServiceWorkerUrl) {
|
|
1902
|
-
return scriptURL === mockServiceWorkerUrl;
|
|
1903
|
-
}
|
|
1904
|
-
};
|
|
1905
|
-
|
|
1906
|
-
// src/setupWorker/start/createFallbackRequestListener.ts
|
|
1907
|
-
var import_interceptors3 = require("@mswjs/interceptors");
|
|
1908
|
-
var import_fetch3 = require("@mswjs/interceptors/lib/interceptors/fetch");
|
|
1909
|
-
var import_XMLHttpRequest = require("@mswjs/interceptors/lib/interceptors/XMLHttpRequest");
|
|
1910
|
-
|
|
1911
|
-
// src/utils/request/createResponseFromIsomorphicResponse.ts
|
|
1912
|
-
function createResponseFromIsomorphicResponse(response2) {
|
|
1913
|
-
return new Response(response2.body, {
|
|
1914
|
-
status: response2.status,
|
|
1915
|
-
statusText: response2.statusText,
|
|
1916
|
-
headers: response2.headers
|
|
1917
|
-
});
|
|
1918
|
-
}
|
|
1919
|
-
|
|
1920
|
-
// src/setupWorker/start/createFallbackRequestListener.ts
|
|
1921
|
-
function createFallbackRequestListener(context, options) {
|
|
1922
|
-
const interceptor = new import_interceptors3.BatchInterceptor({
|
|
1923
|
-
name: "fallback",
|
|
1924
|
-
interceptors: [new import_fetch3.FetchInterceptor(), new import_XMLHttpRequest.XMLHttpRequestInterceptor()]
|
|
1925
|
-
});
|
|
1926
|
-
interceptor.on("request", async (request) => {
|
|
1927
|
-
const mockedRequest = new MockedRequest(request.url, {
|
|
1928
|
-
...request,
|
|
1929
|
-
body: await request.arrayBuffer()
|
|
1930
|
-
});
|
|
1931
|
-
const response2 = await handleRequest(
|
|
1932
|
-
mockedRequest,
|
|
1933
|
-
context.requestHandlers,
|
|
1934
|
-
options,
|
|
1935
|
-
context.emitter,
|
|
1936
|
-
{
|
|
1937
|
-
transformResponse(response3) {
|
|
1938
|
-
return {
|
|
1939
|
-
status: response3.status,
|
|
1940
|
-
statusText: response3.statusText,
|
|
1941
|
-
headers: response3.headers.all(),
|
|
1942
|
-
body: response3.body,
|
|
1943
|
-
delay: response3.delay
|
|
1944
|
-
};
|
|
1945
|
-
},
|
|
1946
|
-
onMockedResponse(_, { handler, publicRequest, parsedRequest }) {
|
|
1947
|
-
if (!options.quiet) {
|
|
1948
|
-
context.emitter.once("response:mocked", async (response3) => {
|
|
1949
|
-
handler.log(
|
|
1950
|
-
publicRequest,
|
|
1951
|
-
await serializeResponse(response3),
|
|
1952
|
-
parsedRequest
|
|
1953
|
-
);
|
|
1954
|
-
});
|
|
1955
|
-
}
|
|
1956
|
-
}
|
|
1957
|
-
}
|
|
1958
|
-
);
|
|
1959
|
-
if (response2) {
|
|
1960
|
-
request.respondWith(response2);
|
|
1961
|
-
}
|
|
1962
|
-
});
|
|
1963
|
-
interceptor.on("response", (request, response2) => {
|
|
1964
|
-
if (!request.id) {
|
|
1965
|
-
return;
|
|
1966
|
-
}
|
|
1967
|
-
const browserResponse = createResponseFromIsomorphicResponse(response2);
|
|
1968
|
-
if (response2.headers.get("x-powered-by") === "msw") {
|
|
1969
|
-
context.emitter.emit("response:mocked", browserResponse, request.id);
|
|
1970
|
-
} else {
|
|
1971
|
-
context.emitter.emit("response:bypass", browserResponse, request.id);
|
|
1972
|
-
}
|
|
1973
|
-
});
|
|
1974
|
-
interceptor.apply();
|
|
1975
|
-
return interceptor;
|
|
1976
|
-
}
|
|
1977
|
-
|
|
1978
|
-
// src/setupWorker/start/createFallbackStart.ts
|
|
1979
|
-
function createFallbackStart(context) {
|
|
1980
|
-
return async function start(options) {
|
|
1981
|
-
context.fallbackInterceptor = createFallbackRequestListener(
|
|
1982
|
-
context,
|
|
1983
|
-
options
|
|
1984
|
-
);
|
|
1985
|
-
printStartMessage({
|
|
1986
|
-
message: "Mocking enabled (fallback mode).",
|
|
1987
|
-
quiet: options.quiet
|
|
1988
|
-
});
|
|
1989
|
-
return void 0;
|
|
1990
|
-
};
|
|
1991
|
-
}
|
|
1992
|
-
|
|
1993
|
-
// src/setupWorker/stop/createFallbackStop.ts
|
|
1994
|
-
function createFallbackStop(context) {
|
|
1995
|
-
return function stop() {
|
|
1996
|
-
var _a, _b;
|
|
1997
|
-
(_a = context.fallbackInterceptor) == null ? void 0 : _a.dispose();
|
|
1998
|
-
printStopMessage({ quiet: (_b = context.startOptions) == null ? void 0 : _b.quiet });
|
|
1999
|
-
};
|
|
2000
|
-
}
|
|
2001
|
-
|
|
2002
|
-
// src/SetupApi.ts
|
|
2003
|
-
var import_outvariant4 = require("outvariant");
|
|
2004
|
-
var import_strict_event_emitter = require("strict-event-emitter");
|
|
2005
|
-
|
|
2006
|
-
// src/utils/internal/pipeEvents.ts
|
|
2007
|
-
function pipeEvents(source, destination) {
|
|
2008
|
-
const rawEmit = source.emit;
|
|
2009
|
-
if (rawEmit._isPiped) {
|
|
2010
|
-
return;
|
|
2011
|
-
}
|
|
2012
|
-
source.emit = function(event, ...data2) {
|
|
2013
|
-
destination.emit(event, ...data2);
|
|
2014
|
-
return rawEmit.call(this, event, ...data2);
|
|
2015
|
-
};
|
|
2016
|
-
source.emit._isPiped = true;
|
|
2017
|
-
}
|
|
2018
|
-
|
|
2019
|
-
// src/utils/internal/toReadonlyArray.ts
|
|
2020
|
-
function toReadonlyArray(source) {
|
|
2021
|
-
const clone = [...source];
|
|
2022
|
-
Object.freeze(clone);
|
|
2023
|
-
return clone;
|
|
2024
|
-
}
|
|
2025
|
-
|
|
2026
|
-
// src/SetupApi.ts
|
|
2027
|
-
var SetupApi = class {
|
|
2028
|
-
constructor(...initialHandlers) {
|
|
2029
|
-
this.validateHandlers(...initialHandlers);
|
|
2030
|
-
this.initialHandlers = toReadonlyArray(initialHandlers);
|
|
2031
|
-
this.currentHandlers = [...initialHandlers];
|
|
2032
|
-
this.emitter = new import_strict_event_emitter.Emitter();
|
|
2033
|
-
this.publicEmitter = new import_strict_event_emitter.Emitter();
|
|
2034
|
-
pipeEvents(this.emitter, this.publicEmitter);
|
|
2035
|
-
this.events = this.createLifeCycleEvents();
|
|
2036
|
-
}
|
|
2037
|
-
validateHandlers(...handlers) {
|
|
2038
|
-
for (const handler of handlers) {
|
|
2039
|
-
(0, import_outvariant4.invariant)(
|
|
2040
|
-
!Array.isArray(handler),
|
|
2041
|
-
devUtils.formatMessage(
|
|
2042
|
-
'Failed to construct "%s" given an Array of request handlers. Make sure you spread the request handlers when calling the respective setup function.'
|
|
2043
|
-
),
|
|
2044
|
-
this.constructor.name
|
|
2045
|
-
);
|
|
2046
|
-
}
|
|
2047
|
-
}
|
|
2048
|
-
dispose() {
|
|
2049
|
-
this.emitter.removeAllListeners();
|
|
2050
|
-
this.publicEmitter.removeAllListeners();
|
|
2051
|
-
}
|
|
2052
|
-
use(...runtimeHandlers) {
|
|
2053
|
-
this.currentHandlers.unshift(...runtimeHandlers);
|
|
2054
|
-
}
|
|
2055
|
-
restoreHandlers() {
|
|
2056
|
-
this.currentHandlers.forEach((handler) => {
|
|
2057
|
-
handler.markAsSkipped(false);
|
|
2058
|
-
});
|
|
2059
|
-
}
|
|
2060
|
-
resetHandlers(...nextHandlers) {
|
|
2061
|
-
this.currentHandlers = nextHandlers.length > 0 ? [...nextHandlers] : [...this.initialHandlers];
|
|
2062
|
-
}
|
|
2063
|
-
listHandlers() {
|
|
2064
|
-
return toReadonlyArray(this.currentHandlers);
|
|
2065
|
-
}
|
|
2066
|
-
createLifeCycleEvents() {
|
|
2067
|
-
return {
|
|
2068
|
-
on: (...args) => {
|
|
2069
|
-
return this.publicEmitter.on(...args);
|
|
2070
|
-
},
|
|
2071
|
-
removeListener: (...args) => {
|
|
2072
|
-
return this.publicEmitter.removeListener(...args);
|
|
2073
|
-
},
|
|
2074
|
-
removeAllListeners: (...args) => {
|
|
2075
|
-
return this.publicEmitter.removeAllListeners(...args);
|
|
2076
|
-
}
|
|
2077
|
-
};
|
|
2078
|
-
}
|
|
2079
|
-
};
|
|
2080
|
-
|
|
2081
|
-
// src/setupWorker/setupWorker.ts
|
|
2082
|
-
var SetupWorkerApi = class extends SetupApi {
|
|
2083
|
-
constructor(...handlers) {
|
|
2084
|
-
super(...handlers);
|
|
2085
|
-
this.startHandler = null;
|
|
2086
|
-
this.stopHandler = null;
|
|
2087
|
-
(0, import_outvariant5.invariant)(
|
|
2088
|
-
!(0, import_is_node_process3.isNodeProcess)(),
|
|
2089
|
-
devUtils.formatMessage(
|
|
2090
|
-
"Failed to execute `setupWorker` in a non-browser environment. Consider using `setupServer` for Node.js environment instead."
|
|
2091
|
-
)
|
|
2092
|
-
);
|
|
2093
|
-
this.listeners = [];
|
|
2094
|
-
this.context = this.createWorkerContext();
|
|
2095
|
-
}
|
|
2096
|
-
createWorkerContext() {
|
|
2097
|
-
const context = {
|
|
2098
|
-
isMockingEnabled: false,
|
|
2099
|
-
startOptions: null,
|
|
2100
|
-
worker: null,
|
|
2101
|
-
registration: null,
|
|
2102
|
-
requestHandlers: this.currentHandlers,
|
|
2103
|
-
emitter: this.emitter,
|
|
2104
|
-
workerChannel: {
|
|
2105
|
-
on: (eventType, callback) => {
|
|
2106
|
-
this.context.events.addListener(
|
|
2107
|
-
navigator.serviceWorker,
|
|
2108
|
-
"message",
|
|
2109
|
-
(event) => {
|
|
2110
|
-
if (event.source !== this.context.worker) {
|
|
2111
|
-
return;
|
|
2112
|
-
}
|
|
2113
|
-
const message = event.data;
|
|
2114
|
-
if (!message) {
|
|
2115
|
-
return;
|
|
2116
|
-
}
|
|
2117
|
-
if (message.type === eventType) {
|
|
2118
|
-
callback(event, message);
|
|
2119
|
-
}
|
|
2120
|
-
}
|
|
2121
|
-
);
|
|
2122
|
-
},
|
|
2123
|
-
send: (type) => {
|
|
2124
|
-
var _a;
|
|
2125
|
-
(_a = this.context.worker) == null ? void 0 : _a.postMessage(type);
|
|
2126
|
-
}
|
|
2127
|
-
},
|
|
2128
|
-
events: {
|
|
2129
|
-
addListener: (target, eventType, callback) => {
|
|
2130
|
-
target.addEventListener(eventType, callback);
|
|
2131
|
-
this.listeners.push({ eventType, target, callback });
|
|
2132
|
-
return () => {
|
|
2133
|
-
target.removeEventListener(eventType, callback);
|
|
2134
|
-
};
|
|
2135
|
-
},
|
|
2136
|
-
removeAllListeners: () => {
|
|
2137
|
-
for (const { target, eventType, callback } of this.listeners) {
|
|
2138
|
-
target.removeEventListener(eventType, callback);
|
|
2139
|
-
}
|
|
2140
|
-
this.listeners = [];
|
|
2141
|
-
},
|
|
2142
|
-
once: (eventType) => {
|
|
2143
|
-
const bindings = [];
|
|
2144
|
-
return new Promise((resolve, reject) => {
|
|
2145
|
-
const handleIncomingMessage = (event) => {
|
|
2146
|
-
try {
|
|
2147
|
-
const message = event.data;
|
|
2148
|
-
if (message.type === eventType) {
|
|
2149
|
-
resolve(message);
|
|
2150
|
-
}
|
|
2151
|
-
} catch (error2) {
|
|
2152
|
-
reject(error2);
|
|
2153
|
-
}
|
|
2154
|
-
};
|
|
2155
|
-
bindings.push(
|
|
2156
|
-
this.context.events.addListener(
|
|
2157
|
-
navigator.serviceWorker,
|
|
2158
|
-
"message",
|
|
2159
|
-
handleIncomingMessage
|
|
2160
|
-
),
|
|
2161
|
-
this.context.events.addListener(
|
|
2162
|
-
navigator.serviceWorker,
|
|
2163
|
-
"messageerror",
|
|
2164
|
-
reject
|
|
2165
|
-
)
|
|
2166
|
-
);
|
|
2167
|
-
}).finally(() => {
|
|
2168
|
-
bindings.forEach((unbind) => unbind());
|
|
2169
|
-
});
|
|
2170
|
-
}
|
|
2171
|
-
},
|
|
2172
|
-
useFallbackMode: !("serviceWorker" in navigator) || location.protocol === "file:"
|
|
2173
|
-
};
|
|
2174
|
-
Object.defineProperties(context, {
|
|
2175
|
-
requestHandlers: {
|
|
2176
|
-
get: () => this.currentHandlers
|
|
2177
|
-
}
|
|
2178
|
-
});
|
|
2179
|
-
this.startHandler = context.useFallbackMode ? createFallbackStart(context) : createStartHandler(context);
|
|
2180
|
-
this.stopHandler = context.useFallbackMode ? createFallbackStop(context) : createStop(context);
|
|
2181
|
-
return context;
|
|
2182
|
-
}
|
|
2183
|
-
async start(options = {}) {
|
|
2184
|
-
this.context.startOptions = mergeRight(
|
|
2185
|
-
DEFAULT_START_OPTIONS,
|
|
2186
|
-
options
|
|
2187
|
-
);
|
|
2188
|
-
return await this.startHandler(this.context.startOptions, options);
|
|
2189
|
-
}
|
|
2190
|
-
printHandlers() {
|
|
2191
|
-
const handlers = this.listHandlers();
|
|
2192
|
-
handlers.forEach((handler) => {
|
|
2193
|
-
const { header, callFrame } = handler.info;
|
|
2194
|
-
const pragma = handler.info.hasOwnProperty("operationType") ? "[graphql]" : "[rest]";
|
|
2195
|
-
console.groupCollapsed(`${pragma} ${header}`);
|
|
2196
|
-
if (callFrame) {
|
|
2197
|
-
console.log(`Declaration: ${callFrame}`);
|
|
2198
|
-
}
|
|
2199
|
-
console.log("Handler:", handler);
|
|
2200
|
-
console.groupEnd();
|
|
2201
|
-
});
|
|
2202
|
-
}
|
|
2203
|
-
stop() {
|
|
2204
|
-
super.dispose();
|
|
2205
|
-
this.context.events.removeAllListeners();
|
|
2206
|
-
this.context.emitter.removeAllListeners();
|
|
2207
|
-
this.stopHandler();
|
|
2208
|
-
}
|
|
2209
|
-
};
|
|
2210
|
-
function setupWorker(...handlers) {
|
|
2211
|
-
return new SetupWorkerApi(...handlers);
|
|
2212
|
-
}
|
|
2213
|
-
|
|
2214
|
-
// src/rest.ts
|
|
2215
|
-
function createRestHandler(method) {
|
|
2216
|
-
return (path, resolver) => {
|
|
2217
|
-
return new RestHandler(method, path, resolver);
|
|
2218
|
-
};
|
|
2219
|
-
}
|
|
2220
|
-
var rest = {
|
|
2221
|
-
all: createRestHandler(/.+/),
|
|
2222
|
-
head: createRestHandler("HEAD" /* HEAD */),
|
|
2223
|
-
get: createRestHandler("GET" /* GET */),
|
|
2224
|
-
post: createRestHandler("POST" /* POST */),
|
|
2225
|
-
put: createRestHandler("PUT" /* PUT */),
|
|
2226
|
-
delete: createRestHandler("DELETE" /* DELETE */),
|
|
2227
|
-
patch: createRestHandler("PATCH" /* PATCH */),
|
|
2228
|
-
options: createRestHandler("OPTIONS" /* OPTIONS */)
|
|
2229
|
-
};
|
|
2230
|
-
|
|
2231
|
-
// src/graphql.ts
|
|
2232
|
-
function createScopedGraphQLHandler(operationType, url) {
|
|
2233
|
-
return (operationName, resolver) => {
|
|
2234
|
-
return new GraphQLHandler(
|
|
2235
|
-
operationType,
|
|
2236
|
-
operationName,
|
|
2237
|
-
url,
|
|
2238
|
-
resolver
|
|
2239
|
-
);
|
|
2240
|
-
};
|
|
2241
|
-
}
|
|
2242
|
-
function createGraphQLOperationHandler(url) {
|
|
2243
|
-
return (resolver) => {
|
|
2244
|
-
return new GraphQLHandler(
|
|
2245
|
-
"all",
|
|
2246
|
-
new RegExp(".*"),
|
|
2247
|
-
url,
|
|
2248
|
-
resolver
|
|
2249
|
-
);
|
|
2250
|
-
};
|
|
2251
|
-
}
|
|
2252
|
-
var standardGraphQLHandlers = {
|
|
2253
|
-
operation: createGraphQLOperationHandler("*"),
|
|
2254
|
-
query: createScopedGraphQLHandler("query", "*"),
|
|
2255
|
-
mutation: createScopedGraphQLHandler("mutation", "*")
|
|
2256
|
-
};
|
|
2257
|
-
function createGraphQLLink(url) {
|
|
2258
|
-
return {
|
|
2259
|
-
operation: createGraphQLOperationHandler(url),
|
|
2260
|
-
query: createScopedGraphQLHandler("query", url),
|
|
2261
|
-
mutation: createScopedGraphQLHandler("mutation", url)
|
|
2262
|
-
};
|
|
2263
|
-
}
|
|
2264
|
-
var graphql = {
|
|
2265
|
-
...standardGraphQLHandlers,
|
|
2266
|
-
link: createGraphQLLink
|
|
2267
|
-
};
|
|
2268
|
-
|
|
2269
|
-
// src/index.ts
|
|
2270
|
-
checkGlobals();
|
|
2271
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
2272
|
-
0 && (module.exports = {
|
|
2273
|
-
GraphQLHandler,
|
|
2274
|
-
MockedRequest,
|
|
2275
|
-
RESTMethods,
|
|
2276
|
-
RequestHandler,
|
|
2277
|
-
RestHandler,
|
|
2278
|
-
SetupApi,
|
|
2279
|
-
SetupWorkerApi,
|
|
2280
|
-
cleanUrl,
|
|
2281
|
-
compose,
|
|
2282
|
-
context,
|
|
2283
|
-
createResponseComposition,
|
|
2284
|
-
defaultContext,
|
|
2285
|
-
defaultResponse,
|
|
2286
|
-
graphql,
|
|
2287
|
-
graphqlContext,
|
|
2288
|
-
handleRequest,
|
|
2289
|
-
matchRequestUrl,
|
|
2290
|
-
response,
|
|
2291
|
-
rest,
|
|
2292
|
-
restContext,
|
|
2293
|
-
setupWorker
|
|
2294
|
-
});
|
|
2295
|
-
//# sourceMappingURL=index.js.map
|