@azure/playwright 1.1.2 → 1.1.3-alpha.20260310.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/dist/browser/common/types.d.ts +1 -1
- package/dist/browser/common/types.d.ts.map +1 -1
- package/dist/browser/common/types.js.map +1 -1
- package/dist/browser/index.d.ts +1 -1
- package/dist/browser/index.d.ts.map +1 -1
- package/dist/browser/index.js.map +1 -1
- package/dist/browser/utils/PlaywrightServiceClient.d.ts +1 -1
- package/dist/browser/utils/PlaywrightServiceClient.d.ts.map +1 -1
- package/dist/browser/utils/PlaywrightServiceClient.js.map +1 -1
- package/dist/browser/utils/playwrightReporterStorageManager.d.ts.map +1 -1
- package/dist/browser/utils/playwrightReporterStorageManager.js.map +1 -1
- package/dist/browser/utils/utils.d.ts +2 -2
- package/dist/browser/utils/utils.d.ts.map +1 -1
- package/dist/browser/utils/utils.js.map +1 -1
- package/dist/commonjs/common/constants.js +127 -95
- package/dist/commonjs/common/constants.js.map +7 -1
- package/dist/commonjs/common/customerConfig.js +31 -14
- package/dist/commonjs/common/customerConfig.js.map +7 -1
- package/dist/commonjs/common/entraIdAccessToken.js +106 -83
- package/dist/commonjs/common/entraIdAccessToken.js.map +7 -1
- package/dist/commonjs/common/environmentVariables.js +43 -24
- package/dist/commonjs/common/environmentVariables.js.map +7 -1
- package/dist/commonjs/common/executor.js +88 -67
- package/dist/commonjs/common/executor.js.map +7 -1
- package/dist/commonjs/common/httpService.js +54 -35
- package/dist/commonjs/common/httpService.js.map +7 -1
- package/dist/commonjs/common/logger.js +28 -8
- package/dist/commonjs/common/logger.js.map +7 -1
- package/dist/commonjs/common/messages.js +189 -169
- package/dist/commonjs/common/messages.js.map +7 -1
- package/dist/commonjs/common/playwrightServiceConfig.js +113 -98
- package/dist/commonjs/common/playwrightServiceConfig.js.map +7 -1
- package/dist/commonjs/common/state.js +30 -10
- package/dist/commonjs/common/state.js.map +7 -1
- package/dist/commonjs/common/types.d.ts +1 -1
- package/dist/commonjs/common/types.d.ts.map +1 -1
- package/dist/commonjs/common/types.js +15 -5
- package/dist/commonjs/common/types.js.map +7 -1
- package/dist/commonjs/core/global/playwright-service-global-setup.js +52 -26
- package/dist/commonjs/core/global/playwright-service-global-setup.js.map +7 -1
- package/dist/commonjs/core/global/playwright-service-global-teardown.js +49 -20
- package/dist/commonjs/core/global/playwright-service-global-teardown.js.map +7 -1
- package/dist/commonjs/core/initializePlaywrightServiceTestRun.js +39 -27
- package/dist/commonjs/core/initializePlaywrightServiceTestRun.js.map +7 -1
- package/dist/commonjs/core/playwrightService.js +166 -205
- package/dist/commonjs/core/playwrightService.js.map +7 -1
- package/dist/commonjs/core/playwrightServiceEntra.js +67 -48
- package/dist/commonjs/core/playwrightServiceEntra.js.map +7 -1
- package/dist/commonjs/core/playwrightServiceUtils.d.ts +1 -1
- package/dist/commonjs/core/playwrightServiceUtils.d.ts.map +1 -0
- package/dist/commonjs/core/playwrightServiceUtils.js +44 -11
- package/dist/commonjs/core/playwrightServiceUtils.js.map +7 -0
- package/dist/commonjs/index.d.ts +1 -1
- package/dist/commonjs/index.d.ts.map +1 -1
- package/dist/commonjs/index.js +36 -18
- package/dist/commonjs/index.js.map +7 -1
- package/dist/commonjs/reporter/index.js +34 -15
- package/dist/commonjs/reporter/index.js.map +7 -1
- package/dist/commonjs/reporter/playwrightReporter.js +222 -216
- package/dist/commonjs/reporter/playwrightReporter.js.map +7 -1
- package/dist/commonjs/tsdoc-metadata.json +1 -1
- package/dist/commonjs/utils/PlaywrightServiceClient.d.ts +1 -1
- package/dist/commonjs/utils/PlaywrightServiceClient.d.ts.map +1 -1
- package/dist/commonjs/utils/PlaywrightServiceClient.js +140 -91
- package/dist/commonjs/utils/PlaywrightServiceClient.js.map +7 -1
- package/dist/commonjs/utils/cIInfoProvider.js +81 -74
- package/dist/commonjs/utils/cIInfoProvider.js.map +7 -1
- package/dist/commonjs/utils/getPackageVersion.d.ts +1 -1
- package/dist/commonjs/utils/getPackageVersion.d.ts.map +1 -0
- package/dist/commonjs/utils/getPackageVersion.js +50 -19
- package/dist/commonjs/utils/getPackageVersion.js.map +7 -0
- package/dist/commonjs/utils/getPlaywrightVersion.js +42 -21
- package/dist/commonjs/utils/getPlaywrightVersion.js.map +7 -1
- package/dist/commonjs/utils/packageManager.js +59 -40
- package/dist/commonjs/utils/packageManager.js.map +7 -1
- package/dist/commonjs/utils/parseJwt.js +37 -17
- package/dist/commonjs/utils/parseJwt.js.map +7 -1
- package/dist/commonjs/utils/playwrightReporterStorageManager.d.ts.map +1 -1
- package/dist/commonjs/utils/playwrightReporterStorageManager.js +381 -342
- package/dist/commonjs/utils/playwrightReporterStorageManager.js.map +7 -1
- package/dist/commonjs/utils/utils.d.ts +2 -2
- package/dist/commonjs/utils/utils.d.ts.map +1 -1
- package/dist/commonjs/utils/utils.js +417 -369
- package/dist/commonjs/utils/utils.js.map +7 -1
- package/dist/esm/common/constants.js +92 -92
- package/dist/esm/common/constants.js.map +7 -1
- package/dist/esm/common/customerConfig.js +11 -11
- package/dist/esm/common/customerConfig.js.map +7 -1
- package/dist/esm/common/entraIdAccessToken.js +85 -77
- package/dist/esm/common/entraIdAccessToken.js.map +7 -1
- package/dist/esm/common/environmentVariables.js +19 -19
- package/dist/esm/common/environmentVariables.js.map +7 -1
- package/dist/esm/common/executor.js +51 -58
- package/dist/esm/common/executor.js.map +7 -1
- package/dist/esm/common/httpService.js +34 -29
- package/dist/esm/common/httpService.js.map +7 -1
- package/dist/esm/common/logger.js +4 -4
- package/dist/esm/common/logger.js.map +7 -1
- package/dist/esm/common/messages.js +166 -166
- package/dist/esm/common/messages.js.map +7 -1
- package/dist/esm/common/playwrightServiceConfig.js +91 -91
- package/dist/esm/common/playwrightServiceConfig.js.map +7 -1
- package/dist/esm/common/state.js +7 -7
- package/dist/esm/common/state.js.map +7 -1
- package/dist/esm/common/types.d.ts +1 -1
- package/dist/esm/common/types.d.ts.map +1 -1
- package/dist/esm/common/types.js +0 -4
- package/dist/esm/common/types.js.map +7 -1
- package/dist/esm/core/global/playwright-service-global-setup.js +17 -17
- package/dist/esm/core/global/playwright-service-global-setup.js.map +7 -1
- package/dist/esm/core/global/playwright-service-global-teardown.js +16 -13
- package/dist/esm/core/global/playwright-service-global-teardown.js.map +7 -1
- package/dist/esm/core/initializePlaywrightServiceTestRun.js +13 -21
- package/dist/esm/core/initializePlaywrightServiceTestRun.js.map +7 -1
- package/dist/esm/core/playwrightService.js +144 -195
- package/dist/esm/core/playwrightService.js.map +7 -1
- package/dist/esm/core/playwrightServiceEntra.js +44 -42
- package/dist/esm/core/playwrightServiceEntra.js.map +7 -1
- package/dist/esm/core/playwrightServiceUtils.js +6 -8
- package/dist/esm/core/playwrightServiceUtils.js.map +7 -1
- package/dist/esm/index.d.ts +1 -1
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +7 -9
- package/dist/esm/index.js.map +7 -1
- package/dist/esm/reporter/index.js +4 -11
- package/dist/esm/reporter/index.js.map +7 -1
- package/dist/esm/reporter/playwrightReporter.js +202 -207
- package/dist/esm/reporter/playwrightReporter.js.map +7 -1
- package/dist/esm/utils/PlaywrightServiceClient.d.ts +1 -1
- package/dist/esm/utils/PlaywrightServiceClient.d.ts.map +1 -1
- package/dist/esm/utils/PlaywrightServiceClient.js +120 -85
- package/dist/esm/utils/PlaywrightServiceClient.js.map +7 -1
- package/dist/esm/utils/cIInfoProvider.js +58 -71
- package/dist/esm/utils/cIInfoProvider.js.map +7 -1
- package/dist/esm/utils/getPackageVersion.js +12 -17
- package/dist/esm/utils/getPackageVersion.js.map +7 -1
- package/dist/esm/utils/getPlaywrightVersion.js +15 -13
- package/dist/esm/utils/getPlaywrightVersion.js.map +7 -1
- package/dist/esm/utils/packageManager.js +37 -37
- package/dist/esm/utils/packageManager.js.map +7 -1
- package/dist/esm/utils/parseJwt.js +15 -14
- package/dist/esm/utils/parseJwt.js.map +7 -1
- package/dist/esm/utils/playwrightReporterStorageManager.d.ts.map +1 -1
- package/dist/esm/utils/playwrightReporterStorageManager.js +358 -333
- package/dist/esm/utils/playwrightReporterStorageManager.js.map +7 -1
- package/dist/esm/utils/utils.d.ts +2 -2
- package/dist/esm/utils/utils.d.ts.map +1 -1
- package/dist/esm/utils/utils.js +377 -350
- package/dist/esm/utils/utils.js.map +7 -1
- package/dist/react-native/common/types.d.ts +1 -1
- package/dist/react-native/common/types.d.ts.map +1 -1
- package/dist/react-native/common/types.js.map +1 -1
- package/dist/react-native/index.d.ts +1 -1
- package/dist/react-native/index.d.ts.map +1 -1
- package/dist/react-native/index.js.map +1 -1
- package/dist/react-native/utils/PlaywrightServiceClient.d.ts +1 -1
- package/dist/react-native/utils/PlaywrightServiceClient.d.ts.map +1 -1
- package/dist/react-native/utils/PlaywrightServiceClient.js.map +1 -1
- package/dist/react-native/utils/playwrightReporterStorageManager.d.ts.map +1 -1
- package/dist/react-native/utils/playwrightReporterStorageManager.js.map +1 -1
- package/dist/react-native/utils/utils.d.ts +2 -2
- package/dist/react-native/utils/utils.d.ts.map +1 -1
- package/dist/react-native/utils/utils.js.map +1 -1
- package/package.json +6 -24
- package/dist/commonjs/core/playwrightServiceUtils-cjs.cjs.map +0 -1
- package/dist/commonjs/core/playwrightServiceUtils-cjs.d.cts.map +0 -1
- package/dist/commonjs/utils/getPackageVersion-cjs.cjs.map +0 -1
- package/dist/commonjs/utils/getPackageVersion-cjs.d.cts.map +0 -1
|
@@ -1,92 +1,127 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import {
|
|
2
|
+
getTestRunApiUrl,
|
|
3
|
+
getAccessToken,
|
|
4
|
+
extractErrorMessage,
|
|
5
|
+
getWorkspaceMetaDataApiUrl
|
|
6
|
+
} from "./utils.js";
|
|
4
7
|
import { ServiceErrorMessageConstants } from "../common/messages.js";
|
|
5
8
|
import { HttpService } from "../common/httpService.js";
|
|
6
9
|
import { Constants, InternalEnvironmentVariables, ArmConstants } from "../common/constants.js";
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
10
|
+
class PlaywrightServiceClient {
|
|
11
|
+
httpService;
|
|
12
|
+
constructor(httpService) {
|
|
13
|
+
this.httpService = httpService ?? new HttpService();
|
|
14
|
+
}
|
|
15
|
+
async createOrUpdateTestRun(payload) {
|
|
16
|
+
try {
|
|
17
|
+
const baseUrl = getTestRunApiUrl();
|
|
18
|
+
const token = getAccessToken();
|
|
19
|
+
if (!token) {
|
|
20
|
+
throw new Error("PLAYWRIGHT_SERVICE_ACCESS_TOKEN environment variable is not set.");
|
|
21
|
+
}
|
|
22
|
+
const url = new URL(baseUrl);
|
|
23
|
+
url.searchParams.set("api-version", Constants.LatestAPIVersion);
|
|
24
|
+
const method = "PATCH";
|
|
25
|
+
const data = JSON.stringify(payload);
|
|
26
|
+
const contentType = "application/merge-patch+json";
|
|
27
|
+
const correlationId = crypto.randomUUID();
|
|
28
|
+
const response = await this.httpService.callAPI(
|
|
29
|
+
method,
|
|
30
|
+
url.toString(),
|
|
31
|
+
data,
|
|
32
|
+
token,
|
|
33
|
+
contentType,
|
|
34
|
+
correlationId
|
|
35
|
+
);
|
|
36
|
+
if (response.status !== 200) {
|
|
37
|
+
const errorMessage = extractErrorMessage(response?.bodyAsText ?? "");
|
|
38
|
+
process.env[InternalEnvironmentVariables.TEST_RUN_CREATION_SUCCESS] = "false";
|
|
39
|
+
console.error(
|
|
40
|
+
ServiceErrorMessageConstants.TEST_RUN_CREATION_FAILED.formatWithErrorDetails(
|
|
41
|
+
errorMessage || "Unknown error"
|
|
42
|
+
)
|
|
43
|
+
);
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
console.log("Test run created successfully.");
|
|
47
|
+
process.env[InternalEnvironmentVariables.TEST_RUN_CREATION_SUCCESS] = "true";
|
|
48
|
+
} catch (error) {
|
|
49
|
+
const errorMessage = error instanceof Error ? error.message : "Unknown error occurred during test run creation";
|
|
50
|
+
process.env[InternalEnvironmentVariables.TEST_RUN_CREATION_SUCCESS] = "false";
|
|
51
|
+
console.error(
|
|
52
|
+
ServiceErrorMessageConstants.TEST_RUN_CREATION_FAILED.formatWithErrorDetails(errorMessage)
|
|
53
|
+
);
|
|
11
54
|
}
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
55
|
+
}
|
|
56
|
+
async getWorkspaceMetadata() {
|
|
57
|
+
try {
|
|
58
|
+
const baseUrl = getWorkspaceMetaDataApiUrl();
|
|
59
|
+
const token = getAccessToken();
|
|
60
|
+
if (!token) {
|
|
61
|
+
throw new Error("PLAYWRIGHT_SERVICE_ACCESS_TOKEN environment variable is not set.");
|
|
62
|
+
}
|
|
63
|
+
const url = new URL(baseUrl);
|
|
64
|
+
url.searchParams.set("api-version", Constants.LatestAPIVersion);
|
|
65
|
+
const method = "GET";
|
|
66
|
+
const correlationId = crypto.randomUUID();
|
|
67
|
+
const response = await this.httpService.callAPI(
|
|
68
|
+
method,
|
|
69
|
+
url.toString(),
|
|
70
|
+
null,
|
|
71
|
+
token,
|
|
72
|
+
"",
|
|
73
|
+
correlationId
|
|
74
|
+
);
|
|
75
|
+
if (response.status !== 200) {
|
|
76
|
+
const errorMessage = extractErrorMessage(response?.bodyAsText ?? "");
|
|
77
|
+
throw new Error(
|
|
78
|
+
ServiceErrorMessageConstants.FAILED_TO_GET_WORKSPACE_METADATA.formatWithError(
|
|
79
|
+
errorMessage || `HTTP ${response.status}: Failed to retrieve workspace details`
|
|
80
|
+
)
|
|
81
|
+
);
|
|
82
|
+
}
|
|
83
|
+
return response.bodyAsText ? JSON.parse(response.bodyAsText) : {};
|
|
84
|
+
} catch (error) {
|
|
85
|
+
if (error instanceof Error) {
|
|
86
|
+
throw error;
|
|
87
|
+
}
|
|
88
|
+
throw new Error(ServiceErrorMessageConstants.FAILED_TO_GET_WORKSPACE_METADATA.message);
|
|
40
89
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
url.searchParams.set("api-version", ArmConstants.TenantsApiVersion);
|
|
74
|
-
const method = "GET";
|
|
75
|
-
const correlationId = crypto.randomUUID();
|
|
76
|
-
const response = await this.httpService.callAPI(method, url.toString(), null, token, "", correlationId);
|
|
77
|
-
if (response.status !== 200) {
|
|
78
|
-
const errorMessage = extractErrorMessage(response?.bodyAsText ?? "");
|
|
79
|
-
throw new Error(errorMessage || `HTTP ${response.status}: Failed to retrieve tenant information`);
|
|
80
|
-
}
|
|
81
|
-
const responseBody = response.bodyAsText ? JSON.parse(response.bodyAsText) : {};
|
|
82
|
-
return responseBody.value ?? [];
|
|
83
|
-
}
|
|
84
|
-
catch (error) {
|
|
85
|
-
if (error instanceof Error) {
|
|
86
|
-
throw error;
|
|
87
|
-
}
|
|
88
|
-
throw new Error("Failed to retrieve tenant information.");
|
|
89
|
-
}
|
|
90
|
+
}
|
|
91
|
+
async getTenants() {
|
|
92
|
+
try {
|
|
93
|
+
const token = getAccessToken();
|
|
94
|
+
if (!token) {
|
|
95
|
+
throw new Error("PLAYWRIGHT_SERVICE_ACCESS_TOKEN environment variable is not set.");
|
|
96
|
+
}
|
|
97
|
+
const url = new URL(ArmConstants.TenantsApiUrl);
|
|
98
|
+
url.searchParams.set("api-version", ArmConstants.TenantsApiVersion);
|
|
99
|
+
const method = "GET";
|
|
100
|
+
const correlationId = crypto.randomUUID();
|
|
101
|
+
const response = await this.httpService.callAPI(
|
|
102
|
+
method,
|
|
103
|
+
url.toString(),
|
|
104
|
+
null,
|
|
105
|
+
token,
|
|
106
|
+
"",
|
|
107
|
+
correlationId
|
|
108
|
+
);
|
|
109
|
+
if (response.status !== 200) {
|
|
110
|
+
const errorMessage = extractErrorMessage(response?.bodyAsText ?? "");
|
|
111
|
+
throw new Error(
|
|
112
|
+
errorMessage || `HTTP ${response.status}: Failed to retrieve tenant information`
|
|
113
|
+
);
|
|
114
|
+
}
|
|
115
|
+
const responseBody = response.bodyAsText ? JSON.parse(response.bodyAsText) : {};
|
|
116
|
+
return responseBody.value ?? [];
|
|
117
|
+
} catch (error) {
|
|
118
|
+
if (error instanceof Error) {
|
|
119
|
+
throw error;
|
|
120
|
+
}
|
|
121
|
+
throw new Error("Failed to retrieve tenant information.");
|
|
90
122
|
}
|
|
123
|
+
}
|
|
91
124
|
}
|
|
92
|
-
|
|
125
|
+
export {
|
|
126
|
+
PlaywrightServiceClient
|
|
127
|
+
};
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["/mnt/vss/_work/1/s/sdk/loadtesting/playwright/src/utils/PlaywrightServiceClient.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport {\n getTestRunApiUrl,\n getAccessToken,\n extractErrorMessage,\n getWorkspaceMetaDataApiUrl,\n} from \"./utils.js\";\nimport { ServiceErrorMessageConstants } from \"../common/messages.js\";\nimport { HttpService } from \"../common/httpService.js\";\nimport type { TestRunCreatePayload, WorkspaceMetaData, TenantInfo } from \"../common/types.js\";\nimport { Constants, InternalEnvironmentVariables, ArmConstants } from \"../common/constants.js\";\n\nexport class PlaywrightServiceClient {\n private httpService: HttpService;\n\n constructor(httpService?: HttpService) {\n this.httpService = httpService ?? new HttpService();\n }\n\n async createOrUpdateTestRun(payload: TestRunCreatePayload): Promise<void> {\n try {\n const baseUrl = getTestRunApiUrl();\n const token = getAccessToken();\n if (!token) {\n throw new Error(\"PLAYWRIGHT_SERVICE_ACCESS_TOKEN environment variable is not set.\");\n }\n const url = new URL(baseUrl);\n url.searchParams.set(\"api-version\", Constants.LatestAPIVersion);\n const method = \"PATCH\";\n const data = JSON.stringify(payload);\n const contentType = \"application/merge-patch+json\";\n const correlationId = crypto.randomUUID();\n\n const response = await this.httpService.callAPI(\n method,\n url.toString(),\n data,\n token,\n contentType,\n correlationId,\n );\n\n if (response.status !== 200) {\n const errorMessage = extractErrorMessage(response?.bodyAsText ?? \"\");\n process.env[InternalEnvironmentVariables.TEST_RUN_CREATION_SUCCESS] = \"false\";\n console.error(\n ServiceErrorMessageConstants.TEST_RUN_CREATION_FAILED.formatWithErrorDetails(\n errorMessage || \"Unknown error\",\n ),\n );\n return;\n }\n\n console.log(\"Test run created successfully.\");\n process.env[InternalEnvironmentVariables.TEST_RUN_CREATION_SUCCESS] = \"true\";\n } catch (error) {\n const errorMessage =\n error instanceof Error ? error.message : \"Unknown error occurred during test run creation\";\n process.env[InternalEnvironmentVariables.TEST_RUN_CREATION_SUCCESS] = \"false\";\n console.error(\n ServiceErrorMessageConstants.TEST_RUN_CREATION_FAILED.formatWithErrorDetails(errorMessage),\n );\n }\n }\n\n async getWorkspaceMetadata(): Promise<WorkspaceMetaData> {\n try {\n const baseUrl = getWorkspaceMetaDataApiUrl();\n const token = getAccessToken();\n if (!token) {\n throw new Error(\"PLAYWRIGHT_SERVICE_ACCESS_TOKEN environment variable is not set.\");\n }\n const url = new URL(baseUrl);\n url.searchParams.set(\"api-version\", Constants.LatestAPIVersion);\n const method = \"GET\";\n const correlationId = crypto.randomUUID();\n\n const response = await this.httpService.callAPI(\n method,\n url.toString(),\n null,\n token,\n \"\",\n correlationId,\n );\n\n if (response.status !== 200) {\n const errorMessage = extractErrorMessage(response?.bodyAsText ?? \"\");\n throw new Error(\n ServiceErrorMessageConstants.FAILED_TO_GET_WORKSPACE_METADATA.formatWithError(\n errorMessage || `HTTP ${response.status}: Failed to retrieve workspace details`,\n ),\n );\n }\n\n return response.bodyAsText ? JSON.parse(response.bodyAsText) : {};\n } catch (error) {\n if (error instanceof Error) {\n throw error;\n }\n throw new Error(ServiceErrorMessageConstants.FAILED_TO_GET_WORKSPACE_METADATA.message);\n }\n }\n\n async getTenants(): Promise<TenantInfo[]> {\n try {\n const token = getAccessToken();\n if (!token) {\n throw new Error(\"PLAYWRIGHT_SERVICE_ACCESS_TOKEN environment variable is not set.\");\n }\n const url = new URL(ArmConstants.TenantsApiUrl);\n url.searchParams.set(\"api-version\", ArmConstants.TenantsApiVersion);\n const method = \"GET\";\n const correlationId = crypto.randomUUID();\n\n const response = await this.httpService.callAPI(\n method,\n url.toString(),\n null,\n token,\n \"\",\n correlationId,\n );\n if (response.status !== 200) {\n const errorMessage = extractErrorMessage(response?.bodyAsText ?? \"\");\n throw new Error(\n errorMessage || `HTTP ${response.status}: Failed to retrieve tenant information`,\n );\n }\n const responseBody = response.bodyAsText ? JSON.parse(response.bodyAsText) : {};\n return responseBody.value ?? [];\n } catch (error) {\n if (error instanceof Error) {\n throw error;\n }\n throw new Error(\"Failed to retrieve tenant information.\");\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -1,75 +1,62 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
1
|
+
var CI_PROVIDERS = /* @__PURE__ */ ((CI_PROVIDERS2) => {
|
|
2
|
+
CI_PROVIDERS2["GITHUB"] = "GITHUB";
|
|
3
|
+
CI_PROVIDERS2["ADO"] = "ADO";
|
|
4
|
+
CI_PROVIDERS2["DEFAULT"] = "DEFAULT";
|
|
5
|
+
return CI_PROVIDERS2;
|
|
6
|
+
})(CI_PROVIDERS || {});
|
|
7
|
+
class CIInfoProvider {
|
|
8
|
+
static isGitHubActions() {
|
|
9
|
+
return process.env["GITHUB_ACTIONS"] === "true";
|
|
10
|
+
}
|
|
11
|
+
static getCIProvider() {
|
|
12
|
+
if (CIInfoProvider.isGitHubActions()) {
|
|
13
|
+
return "GITHUB" /* GITHUB */;
|
|
14
|
+
} else if (CIInfoProvider.isAzureDevOps()) {
|
|
15
|
+
return "ADO" /* ADO */;
|
|
16
|
+
} else {
|
|
17
|
+
return "DEFAULT" /* DEFAULT */;
|
|
13
18
|
}
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
}
|
|
19
|
+
}
|
|
20
|
+
static getCIInfo() {
|
|
21
|
+
const ciProvider = CIInfoProvider.getCIProvider();
|
|
22
|
+
if (ciProvider === "GITHUB" /* GITHUB */) {
|
|
23
|
+
return {
|
|
24
|
+
providerName: "GITHUB" /* GITHUB */,
|
|
25
|
+
branch: this.getGHBranchName() || null,
|
|
26
|
+
author: process.env["GITHUB_ACTOR"] || null,
|
|
27
|
+
commitId: process.env["GITHUB_SHA"] || null,
|
|
28
|
+
revisionUrl: process.env["GITHUB_SERVER_URL"] ? `${process.env["GITHUB_SERVER_URL"]}/${process.env["GITHUB_REPOSITORY"]}/commit/${process.env["GITHUB_SHA"]}` : null
|
|
29
|
+
};
|
|
30
|
+
} else if (ciProvider === "ADO" /* ADO */) {
|
|
31
|
+
return {
|
|
32
|
+
providerName: "ADO" /* ADO */,
|
|
33
|
+
branch: process.env["BUILD_SOURCEBRANCH"] || null,
|
|
34
|
+
author: process.env["BUILD_REQUESTEDFOR"] || null,
|
|
35
|
+
commitId: process.env["BUILD_SOURCEVERSION"] || null,
|
|
36
|
+
revisionUrl: process.env["SYSTEM_TEAMFOUNDATIONCOLLECTIONURI"] ? `${process.env["SYSTEM_TEAMFOUNDATIONCOLLECTIONURI"]}${process.env["SYSTEM_TEAMPROJECT"]}/_git/${process.env["BUILD_REPOSITORY_NAME"]}/commit/${process.env["BUILD_SOURCEVERSION"]}` : null
|
|
37
|
+
};
|
|
38
|
+
} else {
|
|
39
|
+
return {
|
|
40
|
+
providerName: "DEFAULT" /* DEFAULT */,
|
|
41
|
+
branch: process.env["BRANCH"] ?? null,
|
|
42
|
+
author: process.env["AUTHOR"] ?? null,
|
|
43
|
+
commitId: process.env["COMMIT_ID"] ?? null,
|
|
44
|
+
revisionUrl: process.env["REVISION_URL"] ?? null
|
|
45
|
+
};
|
|
24
46
|
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
revisionUrl: process.env["GITHUB_SERVER_URL"]
|
|
35
|
-
? `${process.env["GITHUB_SERVER_URL"]}/${process.env["GITHUB_REPOSITORY"]}/commit/${process.env["GITHUB_SHA"]}`
|
|
36
|
-
: null,
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
else if (ciProvider === CI_PROVIDERS.ADO) {
|
|
40
|
-
// Logic to get Azure DevOps CIInfo
|
|
41
|
-
return {
|
|
42
|
-
providerName: CI_PROVIDERS.ADO,
|
|
43
|
-
branch: process.env["BUILD_SOURCEBRANCH"] || null,
|
|
44
|
-
author: process.env["BUILD_REQUESTEDFOR"] || null,
|
|
45
|
-
commitId: process.env["BUILD_SOURCEVERSION"] || null,
|
|
46
|
-
revisionUrl: process.env["SYSTEM_TEAMFOUNDATIONCOLLECTIONURI"]
|
|
47
|
-
? `${process.env["SYSTEM_TEAMFOUNDATIONCOLLECTIONURI"]}${process.env["SYSTEM_TEAMPROJECT"]}/_git/${process.env["BUILD_REPOSITORY_NAME"]}/commit/${process.env["BUILD_SOURCEVERSION"]}`
|
|
48
|
-
: null,
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
// Handle unsupported CI provider
|
|
53
|
-
return {
|
|
54
|
-
providerName: CI_PROVIDERS.DEFAULT,
|
|
55
|
-
branch: process.env["BRANCH"] ?? null,
|
|
56
|
-
author: process.env["AUTHOR"] ?? null,
|
|
57
|
-
commitId: process.env["COMMIT_ID"] ?? null,
|
|
58
|
-
revisionUrl: process.env["REVISION_URL"] ?? null,
|
|
59
|
-
};
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
static isAzureDevOps() {
|
|
63
|
-
return (process.env["AZURE_HTTP_USER_AGENT"] !== undefined && process.env["TF_BUILD"] !== undefined);
|
|
64
|
-
}
|
|
65
|
-
static getGHBranchName() {
|
|
66
|
-
if (process.env["GITHUB_EVENT_NAME"] === "pull_request" ||
|
|
67
|
-
process.env["GITHUB_EVENT_NAME"] === "pull_request_target") {
|
|
68
|
-
return process.env["GITHUB_HEAD_REF"];
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
return process.env["GITHUB_REF_NAME"];
|
|
72
|
-
}
|
|
47
|
+
}
|
|
48
|
+
static isAzureDevOps() {
|
|
49
|
+
return process.env["AZURE_HTTP_USER_AGENT"] !== void 0 && process.env["TF_BUILD"] !== void 0;
|
|
50
|
+
}
|
|
51
|
+
static getGHBranchName() {
|
|
52
|
+
if (process.env["GITHUB_EVENT_NAME"] === "pull_request" || process.env["GITHUB_EVENT_NAME"] === "pull_request_target") {
|
|
53
|
+
return process.env["GITHUB_HEAD_REF"];
|
|
54
|
+
} else {
|
|
55
|
+
return process.env["GITHUB_REF_NAME"];
|
|
73
56
|
}
|
|
57
|
+
}
|
|
74
58
|
}
|
|
75
|
-
|
|
59
|
+
export {
|
|
60
|
+
CIInfoProvider,
|
|
61
|
+
CI_PROVIDERS
|
|
62
|
+
};
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["/mnt/vss/_work/1/s/sdk/loadtesting/playwright/src/utils/cIInfoProvider.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport enum CI_PROVIDERS {\n GITHUB = \"GITHUB\",\n ADO = \"ADO\",\n DEFAULT = \"DEFAULT\",\n // Add more CI providers as needed\n}\n\nexport type CIInfo = {\n providerName?: CI_PROVIDERS | null;\n branch?: string | null;\n author?: string | null;\n commitId?: string | null;\n revisionUrl?: string | null;\n};\n\nexport class CIInfoProvider {\n private static isGitHubActions(): boolean {\n return process.env[\"GITHUB_ACTIONS\"] === \"true\";\n }\n\n static getCIProvider(): string | null {\n if (CIInfoProvider.isGitHubActions()) {\n return CI_PROVIDERS.GITHUB;\n } else if (CIInfoProvider.isAzureDevOps()) {\n return CI_PROVIDERS.ADO;\n } else {\n return CI_PROVIDERS.DEFAULT;\n }\n }\n\n static getCIInfo(): CIInfo {\n const ciProvider = CIInfoProvider.getCIProvider();\n if (ciProvider === CI_PROVIDERS.GITHUB) {\n // Logic to get GitHub Actions CIInfo\n return {\n providerName: CI_PROVIDERS.GITHUB,\n branch: this.getGHBranchName() || null,\n author: process.env[\"GITHUB_ACTOR\"] || null,\n commitId: process.env[\"GITHUB_SHA\"] || null,\n revisionUrl: process.env[\"GITHUB_SERVER_URL\"]\n ? `${process.env[\"GITHUB_SERVER_URL\"]}/${process.env[\"GITHUB_REPOSITORY\"]}/commit/${process.env[\"GITHUB_SHA\"]}`\n : null,\n };\n } else if (ciProvider === CI_PROVIDERS.ADO) {\n // Logic to get Azure DevOps CIInfo\n return {\n providerName: CI_PROVIDERS.ADO,\n branch: process.env[\"BUILD_SOURCEBRANCH\"] || null,\n author: process.env[\"BUILD_REQUESTEDFOR\"] || null,\n commitId: process.env[\"BUILD_SOURCEVERSION\"] || null,\n revisionUrl: process.env[\"SYSTEM_TEAMFOUNDATIONCOLLECTIONURI\"]\n ? `${process.env[\"SYSTEM_TEAMFOUNDATIONCOLLECTIONURI\"]}${process.env[\"SYSTEM_TEAMPROJECT\"]}/_git/${process.env[\"BUILD_REPOSITORY_NAME\"]}/commit/${process.env[\"BUILD_SOURCEVERSION\"]}`\n : null,\n };\n } else {\n // Handle unsupported CI provider\n return {\n providerName: CI_PROVIDERS.DEFAULT,\n branch: process.env[\"BRANCH\"] ?? null,\n author: process.env[\"AUTHOR\"] ?? null,\n commitId: process.env[\"COMMIT_ID\"] ?? null,\n revisionUrl: process.env[\"REVISION_URL\"] ?? null,\n };\n }\n }\n\n private static isAzureDevOps(): boolean {\n return (\n process.env[\"AZURE_HTTP_USER_AGENT\"] !== undefined && process.env[\"TF_BUILD\"] !== undefined\n );\n }\n\n private static getGHBranchName(): string {\n if (\n process.env[\"GITHUB_EVENT_NAME\"] === \"pull_request\" ||\n process.env[\"GITHUB_EVENT_NAME\"] === \"pull_request_target\"\n ) {\n return process.env[\"GITHUB_HEAD_REF\"]!;\n } else {\n return process.env[\"GITHUB_REF_NAME\"]!;\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "AAGO,IAAK,eAAL,kBAAKA,kBAAL;AACL,EAAAA,cAAA,YAAS;AACT,EAAAA,cAAA,SAAM;AACN,EAAAA,cAAA,aAAU;AAHA,SAAAA;AAAA,GAAA;AAeL,MAAM,eAAe;AAAA,EAC1B,OAAe,kBAA2B;AACxC,WAAO,QAAQ,IAAI,gBAAgB,MAAM;AAAA,EAC3C;AAAA,EAEA,OAAO,gBAA+B;AACpC,QAAI,eAAe,gBAAgB,GAAG;AACpC,aAAO;AAAA,IACT,WAAW,eAAe,cAAc,GAAG;AACzC,aAAO;AAAA,IACT,OAAO;AACL,aAAO;AAAA,IACT;AAAA,EACF;AAAA,EAEA,OAAO,YAAoB;AACzB,UAAM,aAAa,eAAe,cAAc;AAChD,QAAI,eAAe,uBAAqB;AAEtC,aAAO;AAAA,QACL,cAAc;AAAA,QACd,QAAQ,KAAK,gBAAgB,KAAK;AAAA,QAClC,QAAQ,QAAQ,IAAI,cAAc,KAAK;AAAA,QACvC,UAAU,QAAQ,IAAI,YAAY,KAAK;AAAA,QACvC,aAAa,QAAQ,IAAI,mBAAmB,IACxC,GAAG,QAAQ,IAAI,mBAAmB,CAAC,IAAI,QAAQ,IAAI,mBAAmB,CAAC,WAAW,QAAQ,IAAI,YAAY,CAAC,KAC3G;AAAA,MACN;AAAA,IACF,WAAW,eAAe,iBAAkB;AAE1C,aAAO;AAAA,QACL,cAAc;AAAA,QACd,QAAQ,QAAQ,IAAI,oBAAoB,KAAK;AAAA,QAC7C,QAAQ,QAAQ,IAAI,oBAAoB,KAAK;AAAA,QAC7C,UAAU,QAAQ,IAAI,qBAAqB,KAAK;AAAA,QAChD,aAAa,QAAQ,IAAI,oCAAoC,IACzD,GAAG,QAAQ,IAAI,oCAAoC,CAAC,GAAG,QAAQ,IAAI,oBAAoB,CAAC,SAAS,QAAQ,IAAI,uBAAuB,CAAC,WAAW,QAAQ,IAAI,qBAAqB,CAAC,KAClL;AAAA,MACN;AAAA,IACF,OAAO;AAEL,aAAO;AAAA,QACL,cAAc;AAAA,QACd,QAAQ,QAAQ,IAAI,QAAQ,KAAK;AAAA,QACjC,QAAQ,QAAQ,IAAI,QAAQ,KAAK;AAAA,QACjC,UAAU,QAAQ,IAAI,WAAW,KAAK;AAAA,QACtC,aAAa,QAAQ,IAAI,cAAc,KAAK;AAAA,MAC9C;AAAA,IACF;AAAA,EACF;AAAA,EAEA,OAAe,gBAAyB;AACtC,WACE,QAAQ,IAAI,uBAAuB,MAAM,UAAa,QAAQ,IAAI,UAAU,MAAM;AAAA,EAEtF;AAAA,EAEA,OAAe,kBAA0B;AACvC,QACE,QAAQ,IAAI,mBAAmB,MAAM,kBACrC,QAAQ,IAAI,mBAAmB,MAAM,uBACrC;AACA,aAAO,QAAQ,IAAI,iBAAiB;AAAA,IACtC,OAAO;AACL,aAAO,QAAQ,IAAI,iBAAiB;AAAA,IACtC;AAAA,EACF;AACF;",
|
|
6
|
+
"names": ["CI_PROVIDERS"]
|
|
7
|
+
}
|
|
@@ -1,23 +1,18 @@
|
|
|
1
|
-
// Copyright (c) Microsoft Corporation.
|
|
2
|
-
// Licensed under the MIT License.
|
|
3
1
|
import path, { dirname } from "node:path";
|
|
4
2
|
import { coreLogger } from "../common/logger.js";
|
|
5
3
|
import { fileURLToPath } from "node:url";
|
|
6
4
|
import { createRequire } from "node:module";
|
|
7
|
-
|
|
8
|
-
// @ts-ignore ESM only output
|
|
9
|
-
const require = createRequire(import.meta.url);
|
|
10
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
11
|
-
// @ts-ignore ESM only output
|
|
5
|
+
const require2 = createRequire(import.meta.url);
|
|
12
6
|
const currentDir = dirname(fileURLToPath(import.meta.url));
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
7
|
+
const getPackageVersionFromFolder = (folder) => {
|
|
8
|
+
try {
|
|
9
|
+
const version = require2(path.join(currentDir, folder, "package.json")).version;
|
|
10
|
+
return version;
|
|
11
|
+
} catch (error) {
|
|
12
|
+
coreLogger.error("Error fetching package version:", error);
|
|
13
|
+
return "";
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
export {
|
|
17
|
+
getPackageVersionFromFolder
|
|
22
18
|
};
|
|
23
|
-
//# sourceMappingURL=getPackageVersion.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["/mnt/vss/_work/1/s/sdk/loadtesting/playwright/src/utils/getPackageVersion.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport path, { dirname } from \"node:path\";\nimport { coreLogger } from \"../common/logger.js\";\nimport { fileURLToPath } from \"node:url\";\nimport { createRequire } from \"node:module\";\n\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore ESM only output\nconst require = createRequire(import.meta.url);\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore ESM only output\nconst currentDir = dirname(fileURLToPath(import.meta.url));\n\nexport const getPackageVersionFromFolder = (folder: string): string => {\n try {\n const version = require(path.join(currentDir, folder, \"package.json\")).version;\n return version;\n } catch (error) {\n coreLogger.error(\"Error fetching package version:\", error);\n return \"\";\n }\n};\n"],
|
|
5
|
+
"mappings": "AAGA,OAAO,QAAQ,eAAe;AAC9B,SAAS,kBAAkB;AAC3B,SAAS,qBAAqB;AAC9B,SAAS,qBAAqB;AAI9B,MAAMA,WAAU,cAAc,YAAY,GAAG;AAG7C,MAAM,aAAa,QAAQ,cAAc,YAAY,GAAG,CAAC;AAElD,MAAM,8BAA8B,CAAC,WAA2B;AACrE,MAAI;AACF,UAAM,UAAUA,SAAQ,KAAK,KAAK,YAAY,QAAQ,cAAc,CAAC,EAAE;AACvE,WAAO;AAAA,EACT,SAAS,OAAO;AACd,eAAW,MAAM,mCAAmC,KAAK;AACzD,WAAO;AAAA,EACT;AACF;",
|
|
6
|
+
"names": ["require"]
|
|
7
|
+
}
|
|
@@ -1,19 +1,21 @@
|
|
|
1
|
-
// Copyright (c) Microsoft Corporation.
|
|
2
|
-
// Licensed under the MIT License.
|
|
3
1
|
import { getPackageManager } from "./packageManager.js";
|
|
4
2
|
import { InternalEnvironmentVariables } from "../common/constants.js";
|
|
5
3
|
import { execSync } from "node:child_process";
|
|
6
4
|
import { coreLogger } from "../common/logger.js";
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION];
|
|
10
|
-
}
|
|
11
|
-
const packageManager = getPackageManager();
|
|
12
|
-
const command = packageManager.runCommand("playwright", "--version");
|
|
13
|
-
const stdout = execSync(command).toString().trim();
|
|
14
|
-
const version = packageManager.getVersionFromStdout(stdout);
|
|
15
|
-
process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION] = version;
|
|
16
|
-
coreLogger.info(`Playwright version being used - ${process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION]}`);
|
|
5
|
+
const getPlaywrightVersion = () => {
|
|
6
|
+
if (process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION]) {
|
|
17
7
|
return process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION];
|
|
8
|
+
}
|
|
9
|
+
const packageManager = getPackageManager();
|
|
10
|
+
const command = packageManager.runCommand("playwright", "--version");
|
|
11
|
+
const stdout = execSync(command).toString().trim();
|
|
12
|
+
const version = packageManager.getVersionFromStdout(stdout);
|
|
13
|
+
process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION] = version;
|
|
14
|
+
coreLogger.info(
|
|
15
|
+
`Playwright version being used - ${process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION]}`
|
|
16
|
+
);
|
|
17
|
+
return process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION];
|
|
18
|
+
};
|
|
19
|
+
export {
|
|
20
|
+
getPlaywrightVersion
|
|
18
21
|
};
|
|
19
|
-
//# sourceMappingURL=getPlaywrightVersion.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["/mnt/vss/_work/1/s/sdk/loadtesting/playwright/src/utils/getPlaywrightVersion.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport { getPackageManager } from \"./packageManager.js\";\nimport { InternalEnvironmentVariables } from \"../common/constants.js\";\nimport { execSync } from \"node:child_process\";\nimport { coreLogger } from \"../common/logger.js\";\n\nexport const getPlaywrightVersion = (): string => {\n if (process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION]) {\n return process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION]!;\n }\n\n const packageManager = getPackageManager();\n const command = packageManager.runCommand(\"playwright\", \"--version\");\n const stdout = execSync(command).toString().trim();\n const version = packageManager.getVersionFromStdout(stdout);\n process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION] = version;\n coreLogger.info(\n `Playwright version being used - ${process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION]}`,\n );\n return process.env[InternalEnvironmentVariables.MPT_PLAYWRIGHT_VERSION]!;\n};\n"],
|
|
5
|
+
"mappings": "AAGA,SAAS,yBAAyB;AAClC,SAAS,oCAAoC;AAC7C,SAAS,gBAAgB;AACzB,SAAS,kBAAkB;AAEpB,MAAM,uBAAuB,MAAc;AAChD,MAAI,QAAQ,IAAI,6BAA6B,sBAAsB,GAAG;AACpE,WAAO,QAAQ,IAAI,6BAA6B,sBAAsB;AAAA,EACxE;AAEA,QAAM,iBAAiB,kBAAkB;AACzC,QAAM,UAAU,eAAe,WAAW,cAAc,WAAW;AACnE,QAAM,SAAS,SAAS,OAAO,EAAE,SAAS,EAAE,KAAK;AACjD,QAAM,UAAU,eAAe,qBAAqB,MAAM;AAC1D,UAAQ,IAAI,6BAA6B,sBAAsB,IAAI;AACnE,aAAW;AAAA,IACT,mCAAmC,QAAQ,IAAI,6BAA6B,sBAAsB,CAAC;AAAA,EACrG;AACA,SAAO,QAAQ,IAAI,6BAA6B,sBAAsB;AACxE;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -1,41 +1,41 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
};
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return match ? match[1] : "Unknown version";
|
|
10
|
-
};
|
|
1
|
+
class NPM {
|
|
2
|
+
runCommand = (command, args) => {
|
|
3
|
+
return `npx ${command} ${args}`;
|
|
4
|
+
};
|
|
5
|
+
getVersionFromStdout = (stdout) => {
|
|
6
|
+
const match = stdout.match(/Version\s(\d+\.\d+\.\d+(-\w+-\d{4}-\d{2}-\d{2})?)/);
|
|
7
|
+
return match ? match[1] : "Unknown version";
|
|
8
|
+
};
|
|
11
9
|
}
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
10
|
+
class PNPM {
|
|
11
|
+
runCommand = (command, args) => {
|
|
12
|
+
return `pnpm ${command} ${args}`;
|
|
13
|
+
};
|
|
14
|
+
getVersionFromStdout = (stdout) => {
|
|
15
|
+
const match = stdout.match(/Version\s(\d+\.\d+\.\d+(-\w+-\d{4}-\d{2}-\d{2})?)/);
|
|
16
|
+
return match ? match[1] : "Unknown version";
|
|
17
|
+
};
|
|
20
18
|
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
19
|
+
class Yarn {
|
|
20
|
+
runCommand = (command, args) => {
|
|
21
|
+
return `yarn ${command} ${args}`;
|
|
22
|
+
};
|
|
23
|
+
getVersionFromStdout = (stdout) => {
|
|
24
|
+
const match = stdout.match(/Version\s(\d+\.\d+\.\d+(-\w+-\d{4}-\d{2}-\d{2})?)/);
|
|
25
|
+
return match ? match[1] : "Unknown version";
|
|
26
|
+
};
|
|
29
27
|
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
28
|
+
const getPackageManager = () => {
|
|
29
|
+
if (process.env["npm_config_user_agent"]) {
|
|
30
|
+
const userAgent = process.env["npm_config_user_agent"];
|
|
31
|
+
if (userAgent.includes("yarn")) return new Yarn();
|
|
32
|
+
if (userAgent.includes("pnpm")) return new PNPM();
|
|
33
|
+
}
|
|
34
|
+
return new NPM();
|
|
35
|
+
};
|
|
36
|
+
export {
|
|
37
|
+
NPM,
|
|
38
|
+
PNPM,
|
|
39
|
+
Yarn,
|
|
40
|
+
getPackageManager
|
|
40
41
|
};
|
|
41
|
-
//# sourceMappingURL=packageManager.js.map
|