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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ftmocks-utils",
3
- "version": "1.3.6",
3
+ "version": "1.3.7",
4
4
  "description": "Util functions for FtMocks",
5
5
  "main": "src/index.js",
6
6
  "scripts": {
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 (route, testName, ftmocksConifg) => {
6
- const urlObj = new URL(route.request().url());
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
 
@@ -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(route.request().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
- route,
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: route.request().method(),
266
+ method: currentRequest.method(),
262
267
  request: {
263
268
  headers: excludeHeaders(
264
- await route.request().headers(),
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: route.request().postData()
278
+ postData: currentRequest.postData()
274
279
  ? {
275
280
  mimeType: "application/json",
276
- text: route.request().postData(),
281
+ text: currentRequest.postData(),
277
282
  }
278
283
  : null,
279
284
  },
280
285
  response: {
281
286
  file: fileName,
282
- status: (await route.fetch()).status(),
283
- headers: (await route.fetch()).headers(),
284
- content: fileName ? null : await (await route.fetch()).text(),
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.continue();
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
- await route.continue();
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
  }