ftmocks-utils 1.3.6 → 1.3.7
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/package.json +1 -1
- package/src/file-utils.js +7 -4
- package/src/playwright-utils.js +28 -11
package/package.json
CHANGED
package/src/file-utils.js
CHANGED
|
@@ -2,8 +2,13 @@ const path = require("path");
|
|
|
2
2
|
const fs = require("fs");
|
|
3
3
|
const { getMockDir, nameToFolder } = require("./common-utils");
|
|
4
4
|
|
|
5
|
-
const saveIfItIsFile = async (
|
|
6
|
-
|
|
5
|
+
const saveIfItIsFile = async (
|
|
6
|
+
currentRequest,
|
|
7
|
+
response,
|
|
8
|
+
testName,
|
|
9
|
+
ftmocksConifg
|
|
10
|
+
) => {
|
|
11
|
+
const urlObj = new URL(currentRequest.url());
|
|
7
12
|
|
|
8
13
|
// Check if URL contains file extension like .js, .png, .css etc
|
|
9
14
|
const fileExtMatch = urlObj.pathname.match(/\.[a-zA-Z0-9]+$/);
|
|
@@ -11,7 +16,6 @@ const saveIfItIsFile = async (route, testName, ftmocksConifg) => {
|
|
|
11
16
|
let fileExt = null;
|
|
12
17
|
if (!fileExtMatch) {
|
|
13
18
|
// Try to get extension from content-type header
|
|
14
|
-
const response = await route.fetch();
|
|
15
19
|
const contentType = response.headers()["content-type"];
|
|
16
20
|
if (contentType) {
|
|
17
21
|
// Map common mime types to extensions
|
|
@@ -59,7 +63,6 @@ const saveIfItIsFile = async (route, testName, ftmocksConifg) => {
|
|
|
59
63
|
const fileName = `${id}${fileExt}`;
|
|
60
64
|
const filePath = path.join(dirPath, fileName);
|
|
61
65
|
|
|
62
|
-
const response = await route.fetch();
|
|
63
66
|
const buffer = await response.body();
|
|
64
67
|
fs.writeFileSync(filePath, buffer);
|
|
65
68
|
|
package/src/playwright-utils.js
CHANGED
|
@@ -234,8 +234,10 @@ async function recordPlaywrightRoutes(
|
|
|
234
234
|
}
|
|
235
235
|
) {
|
|
236
236
|
await page.route(config.mockPath, async (route) => {
|
|
237
|
+
const currentRequest = route.request();
|
|
238
|
+
let response = null;
|
|
237
239
|
try {
|
|
238
|
-
const urlObj = new URL(
|
|
240
|
+
const urlObj = new URL(currentRequest.url());
|
|
239
241
|
if (config.pattern && config.pattern.length > 0) {
|
|
240
242
|
const patternRegex = new RegExp(config.pattern);
|
|
241
243
|
if (!patternRegex.test(urlObj.pathname)) {
|
|
@@ -249,8 +251,11 @@ async function recordPlaywrightRoutes(
|
|
|
249
251
|
await createTest(ftmocksConifg, config.testName);
|
|
250
252
|
}
|
|
251
253
|
|
|
254
|
+
response = await route.fetch();
|
|
255
|
+
|
|
252
256
|
const fileName = await saveIfItIsFile(
|
|
253
|
-
|
|
257
|
+
currentRequest,
|
|
258
|
+
response,
|
|
254
259
|
config.testName,
|
|
255
260
|
ftmocksConifg
|
|
256
261
|
);
|
|
@@ -258,10 +263,10 @@ async function recordPlaywrightRoutes(
|
|
|
258
263
|
const mockData = {
|
|
259
264
|
url: urlObj.pathname + urlObj.search,
|
|
260
265
|
time: new Date().toString(),
|
|
261
|
-
method:
|
|
266
|
+
method: currentRequest.method(),
|
|
262
267
|
request: {
|
|
263
268
|
headers: excludeHeaders(
|
|
264
|
-
await
|
|
269
|
+
await currentRequest.headers(),
|
|
265
270
|
ftmocksConifg
|
|
266
271
|
),
|
|
267
272
|
queryString: Array.from(urlObj.searchParams.entries()).map(
|
|
@@ -270,18 +275,18 @@ async function recordPlaywrightRoutes(
|
|
|
270
275
|
value,
|
|
271
276
|
})
|
|
272
277
|
),
|
|
273
|
-
postData:
|
|
278
|
+
postData: currentRequest.postData()
|
|
274
279
|
? {
|
|
275
280
|
mimeType: "application/json",
|
|
276
|
-
text:
|
|
281
|
+
text: currentRequest.postData(),
|
|
277
282
|
}
|
|
278
283
|
: null,
|
|
279
284
|
},
|
|
280
285
|
response: {
|
|
281
286
|
file: fileName,
|
|
282
|
-
status:
|
|
283
|
-
headers:
|
|
284
|
-
content: fileName ? null : await
|
|
287
|
+
status: response.status(),
|
|
288
|
+
headers: response.headers(),
|
|
289
|
+
content: fileName ? null : await response.text(),
|
|
285
290
|
},
|
|
286
291
|
id: crypto.randomUUID(),
|
|
287
292
|
served: false,
|
|
@@ -350,10 +355,22 @@ async function recordPlaywrightRoutes(
|
|
|
350
355
|
`mock_${mockData.id}.json`
|
|
351
356
|
);
|
|
352
357
|
fs.writeFileSync(mocDataPath, JSON.stringify(mockData, null, 2));
|
|
353
|
-
await route.
|
|
358
|
+
await route.fulfill({
|
|
359
|
+
status: response.status(),
|
|
360
|
+
headers: response.headers(),
|
|
361
|
+
body: await response.body(),
|
|
362
|
+
});
|
|
354
363
|
} catch (error) {
|
|
355
364
|
console.error(error);
|
|
356
|
-
|
|
365
|
+
if (!response) {
|
|
366
|
+
await route.continue();
|
|
367
|
+
} else {
|
|
368
|
+
await route.fulfill({
|
|
369
|
+
status: response.status(),
|
|
370
|
+
headers: response.headers(),
|
|
371
|
+
body: await response.body(),
|
|
372
|
+
});
|
|
373
|
+
}
|
|
357
374
|
}
|
|
358
375
|
});
|
|
359
376
|
}
|