checkly 0.0.0-pr.1006.b6b3be2
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 +102 -0
- package/bin/run +5 -0
- package/bin/run.cmd +3 -0
- package/constructs.d.ts +1 -0
- package/constructs.js +2 -0
- package/dist/auth/index.d.ts +15 -0
- package/dist/auth/index.js +262 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/commands/authCommand.d.ts +5 -0
- package/dist/commands/authCommand.js +37 -0
- package/dist/commands/authCommand.js.map +1 -0
- package/dist/commands/baseCommand.d.ts +13 -0
- package/dist/commands/baseCommand.js +48 -0
- package/dist/commands/baseCommand.js.map +1 -0
- package/dist/commands/deploy.d.ts +18 -0
- package/dist/commands/deploy.js +289 -0
- package/dist/commands/deploy.js.map +1 -0
- package/dist/commands/destroy.d.ts +10 -0
- package/dist/commands/destroy.js +84 -0
- package/dist/commands/destroy.js.map +1 -0
- package/dist/commands/env/add.d.ts +14 -0
- package/dist/commands/env/add.js +85 -0
- package/dist/commands/env/add.js.map +1 -0
- package/dist/commands/env/ls.d.ts +6 -0
- package/dist/commands/env/ls.js +44 -0
- package/dist/commands/env/ls.js.map +1 -0
- package/dist/commands/env/pull.d.ts +12 -0
- package/dist/commands/env/pull.js +99 -0
- package/dist/commands/env/pull.js.map +1 -0
- package/dist/commands/env/rm.d.ts +12 -0
- package/dist/commands/env/rm.js +82 -0
- package/dist/commands/env/rm.js.map +1 -0
- package/dist/commands/env/update.d.ts +14 -0
- package/dist/commands/env/update.js +88 -0
- package/dist/commands/env/update.js.map +1 -0
- package/dist/commands/help.d.ts +6 -0
- package/dist/commands/help.js +17 -0
- package/dist/commands/help.js.map +1 -0
- package/dist/commands/login.d.ts +13 -0
- package/dist/commands/login.js +134 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/logout.d.ts +9 -0
- package/dist/commands/logout.js +43 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/runtimes.d.ts +6 -0
- package/dist/commands/runtimes.js +49 -0
- package/dist/commands/runtimes.js.map +1 -0
- package/dist/commands/switch.d.ts +9 -0
- package/dist/commands/switch.js +81 -0
- package/dist/commands/switch.js.map +1 -0
- package/dist/commands/sync-playwright.d.ts +10 -0
- package/dist/commands/sync-playwright.js +98 -0
- package/dist/commands/sync-playwright.js.map +1 -0
- package/dist/commands/test.d.ts +45 -0
- package/dist/commands/test.js +366 -0
- package/dist/commands/test.js.map +1 -0
- package/dist/commands/trigger.d.ts +37 -0
- package/dist/commands/trigger.js +242 -0
- package/dist/commands/trigger.js.map +1 -0
- package/dist/commands/whoami.d.ts +6 -0
- package/dist/commands/whoami.js +42 -0
- package/dist/commands/whoami.js.map +1 -0
- package/dist/config.d.ts +31 -0
- package/dist/config.js +8 -0
- package/dist/config.js.map +1 -0
- package/dist/constants.d.ts +7 -0
- package/dist/constants.js +10 -0
- package/dist/constants.js.map +1 -0
- package/dist/constructs/alert-channel-subscription.d.ts +44 -0
- package/dist/constructs/alert-channel-subscription.js +39 -0
- package/dist/constructs/alert-channel-subscription.js.map +1 -0
- package/dist/constructs/alert-channel.d.ts +53 -0
- package/dist/constructs/alert-channel.js +55 -0
- package/dist/constructs/alert-channel.js.map +1 -0
- package/dist/constructs/alert-escalation-policy.d.ts +34 -0
- package/dist/constructs/alert-escalation-policy.js +47 -0
- package/dist/constructs/alert-escalation-policy.js.map +1 -0
- package/dist/constructs/api-check.d.ts +187 -0
- package/dist/constructs/api-check.js +279 -0
- package/dist/constructs/api-check.js.map +1 -0
- package/dist/constructs/browser-check.d.ts +90 -0
- package/dist/constructs/browser-check.js +151 -0
- package/dist/constructs/browser-check.js.map +1 -0
- package/dist/constructs/check-group.d.ts +162 -0
- package/dist/constructs/check-group.js +208 -0
- package/dist/constructs/check-group.js.map +1 -0
- package/dist/constructs/check.d.ts +144 -0
- package/dist/constructs/check.js +133 -0
- package/dist/constructs/check.js.map +1 -0
- package/dist/constructs/construct.d.ts +17 -0
- package/dist/constructs/construct.js +22 -0
- package/dist/constructs/construct.js.map +1 -0
- package/dist/constructs/dashboard.d.ts +138 -0
- package/dist/constructs/dashboard.js +126 -0
- package/dist/constructs/dashboard.js.map +1 -0
- package/dist/constructs/email-alert-channel.d.ts +26 -0
- package/dist/constructs/email-alert-channel.js +37 -0
- package/dist/constructs/email-alert-channel.js.map +1 -0
- package/dist/constructs/environment-variable.d.ts +2 -0
- package/dist/constructs/environment-variable.js +3 -0
- package/dist/constructs/environment-variable.js.map +1 -0
- package/dist/constructs/frequency.d.ts +20 -0
- package/dist/constructs/frequency.js +26 -0
- package/dist/constructs/frequency.js.map +1 -0
- package/dist/constructs/heartbeat-check.d.ts +43 -0
- package/dist/constructs/heartbeat-check.js +61 -0
- package/dist/constructs/heartbeat-check.js.map +1 -0
- package/dist/constructs/http-header.d.ts +2 -0
- package/dist/constructs/http-header.js +3 -0
- package/dist/constructs/http-header.js.map +1 -0
- package/dist/constructs/index.d.ts +27 -0
- package/dist/constructs/index.js +44 -0
- package/dist/constructs/index.js.map +1 -0
- package/dist/constructs/key-value-pair.d.ts +6 -0
- package/dist/constructs/key-value-pair.js +3 -0
- package/dist/constructs/key-value-pair.js.map +1 -0
- package/dist/constructs/maintenance-window.d.ts +61 -0
- package/dist/constructs/maintenance-window.js +47 -0
- package/dist/constructs/maintenance-window.js.map +1 -0
- package/dist/constructs/multi-step-check.d.ts +65 -0
- package/dist/constructs/multi-step-check.js +153 -0
- package/dist/constructs/multi-step-check.js.map +1 -0
- package/dist/constructs/opsgenie-alert-channel.d.ts +45 -0
- package/dist/constructs/opsgenie-alert-channel.js +44 -0
- package/dist/constructs/opsgenie-alert-channel.js.map +1 -0
- package/dist/constructs/pagerduty-alert-channel.d.ts +39 -0
- package/dist/constructs/pagerduty-alert-channel.js +42 -0
- package/dist/constructs/pagerduty-alert-channel.js.map +1 -0
- package/dist/constructs/phone-call-alert-channel.d.ts +34 -0
- package/dist/constructs/phone-call-alert-channel.js +42 -0
- package/dist/constructs/phone-call-alert-channel.js.map +1 -0
- package/dist/constructs/playwright-config.d.ts +52 -0
- package/dist/constructs/playwright-config.js +3 -0
- package/dist/constructs/playwright-config.js.map +1 -0
- package/dist/constructs/private-location-check-assignment.d.ts +29 -0
- package/dist/constructs/private-location-check-assignment.js +35 -0
- package/dist/constructs/private-location-check-assignment.js.map +1 -0
- package/dist/constructs/private-location-group-assignment.d.ts +29 -0
- package/dist/constructs/private-location-group-assignment.js +35 -0
- package/dist/constructs/private-location-group-assignment.js.map +1 -0
- package/dist/constructs/private-location.d.ts +51 -0
- package/dist/constructs/private-location.js +61 -0
- package/dist/constructs/private-location.js.map +1 -0
- package/dist/constructs/project.d.ts +66 -0
- package/dist/constructs/project.js +155 -0
- package/dist/constructs/project.js.map +1 -0
- package/dist/constructs/query-param.d.ts +2 -0
- package/dist/constructs/query-param.js +3 -0
- package/dist/constructs/query-param.js.map +1 -0
- package/dist/constructs/ref.d.ts +5 -0
- package/dist/constructs/ref.js +13 -0
- package/dist/constructs/ref.js.map +1 -0
- package/dist/constructs/retry-strategy.d.ts +50 -0
- package/dist/constructs/retry-strategy.js +51 -0
- package/dist/constructs/retry-strategy.js.map +1 -0
- package/dist/constructs/slack-alert-channel.d.ts +26 -0
- package/dist/constructs/slack-alert-channel.js +40 -0
- package/dist/constructs/slack-alert-channel.js.map +1 -0
- package/dist/constructs/sms-alert-channel.d.ts +32 -0
- package/dist/constructs/sms-alert-channel.js +40 -0
- package/dist/constructs/sms-alert-channel.js.map +1 -0
- package/dist/constructs/validator-error.d.ts +2 -0
- package/dist/constructs/validator-error.js +7 -0
- package/dist/constructs/validator-error.js.map +1 -0
- package/dist/constructs/webhook-alert-channel.d.ts +67 -0
- package/dist/constructs/webhook-alert-channel.js +52 -0
- package/dist/constructs/webhook-alert-channel.js.map +1 -0
- package/dist/help/examples.d.ts +6 -0
- package/dist/help/examples.js +22 -0
- package/dist/help/examples.js.map +1 -0
- package/dist/help/help-extension.d.ts +7 -0
- package/dist/help/help-extension.js +59 -0
- package/dist/help/help-extension.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +30 -0
- package/dist/index.js.map +1 -0
- package/dist/messages/common-messages.d.ts +5 -0
- package/dist/messages/common-messages.js +9 -0
- package/dist/messages/common-messages.js.map +1 -0
- package/dist/playwright/playwright-config-loader.d.ts +1 -0
- package/dist/playwright/playwright-config-loader.js +26 -0
- package/dist/playwright/playwright-config-loader.js.map +1 -0
- package/dist/playwright/playwright-config-template.d.ts +8 -0
- package/dist/playwright/playwright-config-template.js +78 -0
- package/dist/playwright/playwright-config-template.js.map +1 -0
- package/dist/reporters/abstract-list.d.ts +41 -0
- package/dist/reporters/abstract-list.js +171 -0
- package/dist/reporters/abstract-list.js.map +1 -0
- package/dist/reporters/ci.d.ts +12 -0
- package/dist/reporters/ci.js +34 -0
- package/dist/reporters/ci.js.map +1 -0
- package/dist/reporters/dot.d.ts +10 -0
- package/dist/reporters/dot.js +29 -0
- package/dist/reporters/dot.js.map +1 -0
- package/dist/reporters/github.d.ts +32 -0
- package/dist/reporters/github.js +119 -0
- package/dist/reporters/github.js.map +1 -0
- package/dist/reporters/json.d.ts +26 -0
- package/dist/reporters/json.js +101 -0
- package/dist/reporters/json.js.map +1 -0
- package/dist/reporters/list.d.ts +15 -0
- package/dist/reporters/list.js +85 -0
- package/dist/reporters/list.js.map +1 -0
- package/dist/reporters/reporter.d.ts +16 -0
- package/dist/reporters/reporter.js +29 -0
- package/dist/reporters/reporter.js.map +1 -0
- package/dist/reporters/util.d.ts +18 -0
- package/dist/reporters/util.js +325 -0
- package/dist/reporters/util.js.map +1 -0
- package/dist/rest/accounts.d.ts +12 -0
- package/dist/rest/accounts.js +15 -0
- package/dist/rest/accounts.js.map +1 -0
- package/dist/rest/api.d.ts +33 -0
- package/dist/rest/api.js +98 -0
- package/dist/rest/api.js.map +1 -0
- package/dist/rest/assets.d.ts +13 -0
- package/dist/rest/assets.js +30 -0
- package/dist/rest/assets.js.map +1 -0
- package/dist/rest/checkly-storage.d.ts +12 -0
- package/dist/rest/checkly-storage.js +15 -0
- package/dist/rest/checkly-storage.js.map +1 -0
- package/dist/rest/environment-variables.d.ts +17 -0
- package/dist/rest/environment-variables.js +25 -0
- package/dist/rest/environment-variables.js.map +1 -0
- package/dist/rest/heartbeat-checks.d.ts +11 -0
- package/dist/rest/heartbeat-checks.js +17 -0
- package/dist/rest/heartbeat-checks.js.map +1 -0
- package/dist/rest/locations.d.ts +11 -0
- package/dist/rest/locations.js +12 -0
- package/dist/rest/locations.js.map +1 -0
- package/dist/rest/private-locations.d.ts +10 -0
- package/dist/rest/private-locations.js +12 -0
- package/dist/rest/private-locations.js.map +1 -0
- package/dist/rest/projects.d.ts +46 -0
- package/dist/rest/projects.js +25 -0
- package/dist/rest/projects.js.map +1 -0
- package/dist/rest/runtimes.d.ts +16 -0
- package/dist/rest/runtimes.js +15 -0
- package/dist/rest/runtimes.js.map +1 -0
- package/dist/rest/test-sessions.d.ts +59 -0
- package/dist/rest/test-sessions.js +24 -0
- package/dist/rest/test-sessions.js.map +1 -0
- package/dist/rest/users.d.ts +12 -0
- package/dist/rest/users.js +12 -0
- package/dist/rest/users.js.map +1 -0
- package/dist/rest/util.d.ts +4 -0
- package/dist/rest/util.js +17 -0
- package/dist/rest/util.js.map +1 -0
- package/dist/services/abstract-check-runner.d.ts +60 -0
- package/dist/services/abstract-check-runner.js +225 -0
- package/dist/services/abstract-check-runner.js.map +1 -0
- package/dist/services/check-parser/collector.d.ts +33 -0
- package/dist/services/check-parser/collector.js +48 -0
- package/dist/services/check-parser/collector.js.map +1 -0
- package/dist/services/check-parser/errors.d.ts +8 -0
- package/dist/services/check-parser/errors.js +45 -0
- package/dist/services/check-parser/errors.js.map +1 -0
- package/dist/services/check-parser/package-files/index.d.ts +1 -0
- package/dist/services/check-parser/package-files/index.js +6 -0
- package/dist/services/check-parser/package-files/index.js.map +1 -0
- package/dist/services/check-parser/package-files/json-source-file.d.ts +13 -0
- package/dist/services/check-parser/package-files/json-source-file.js +34 -0
- package/dist/services/check-parser/package-files/json-source-file.js.map +1 -0
- package/dist/services/check-parser/package-files/loader.d.ts +7 -0
- package/dist/services/check-parser/package-files/loader.js +19 -0
- package/dist/services/check-parser/package-files/loader.js.map +1 -0
- package/dist/services/check-parser/package-files/package-json-file.d.ts +23 -0
- package/dist/services/check-parser/package-files/package-json-file.js +44 -0
- package/dist/services/check-parser/package-files/package-json-file.js.map +1 -0
- package/dist/services/check-parser/package-files/paths.d.ts +22 -0
- package/dist/services/check-parser/package-files/paths.js +108 -0
- package/dist/services/check-parser/package-files/paths.js.map +1 -0
- package/dist/services/check-parser/package-files/resolver.d.ts +32 -0
- package/dist/services/check-parser/package-files/resolver.js +186 -0
- package/dist/services/check-parser/package-files/resolver.js.map +1 -0
- package/dist/services/check-parser/package-files/source-file.d.ts +13 -0
- package/dist/services/check-parser/package-files/source-file.js +41 -0
- package/dist/services/check-parser/package-files/source-file.js.map +1 -0
- package/dist/services/check-parser/package-files/tsconfig-json-file.d.ts +68 -0
- package/dist/services/check-parser/package-files/tsconfig-json-file.js +119 -0
- package/dist/services/check-parser/package-files/tsconfig-json-file.js.map +1 -0
- package/dist/services/check-parser/parser.d.ts +32 -0
- package/dist/services/check-parser/parser.js +303 -0
- package/dist/services/check-parser/parser.js.map +1 -0
- package/dist/services/checkly-config-loader.d.ts +72 -0
- package/dist/services/checkly-config-loader.js +103 -0
- package/dist/services/checkly-config-loader.js.map +1 -0
- package/dist/services/config.d.ts +28 -0
- package/dist/services/config.js +99 -0
- package/dist/services/config.js.map +1 -0
- package/dist/services/project-parser.d.ts +21 -0
- package/dist/services/project-parser.js +192 -0
- package/dist/services/project-parser.js.map +1 -0
- package/dist/services/snapshot-service.d.ts +13 -0
- package/dist/services/snapshot-service.js +85 -0
- package/dist/services/snapshot-service.js.map +1 -0
- package/dist/services/socket-client.d.ts +4 -0
- package/dist/services/socket-client.js +88 -0
- package/dist/services/socket-client.js.map +1 -0
- package/dist/services/test-filters.d.ts +3 -0
- package/dist/services/test-filters.js +27 -0
- package/dist/services/test-filters.js.map +1 -0
- package/dist/services/test-runner.d.ts +24 -0
- package/dist/services/test-runner.js +91 -0
- package/dist/services/test-runner.js.map +1 -0
- package/dist/services/trigger-runner.d.ts +29 -0
- package/dist/services/trigger-runner.js +59 -0
- package/dist/services/trigger-runner.js.map +1 -0
- package/dist/services/util.d.ts +32 -0
- package/dist/services/util.js +244 -0
- package/dist/services/util.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/oclif.manifest.json +635 -0
- package/package.json +151 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { AxiosInstance } from 'axios';
|
|
2
|
+
export interface HeartbeatCheck {
|
|
3
|
+
pingUrl: string;
|
|
4
|
+
name: string;
|
|
5
|
+
}
|
|
6
|
+
declare class HeartbeatChecks {
|
|
7
|
+
api: AxiosInstance;
|
|
8
|
+
constructor(api: AxiosInstance);
|
|
9
|
+
get(id: string): Promise<import("axios").AxiosResponse<HeartbeatCheck, any>>;
|
|
10
|
+
}
|
|
11
|
+
export default HeartbeatChecks;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
class HeartbeatChecks {
|
|
4
|
+
constructor(api) {
|
|
5
|
+
this.api = api;
|
|
6
|
+
}
|
|
7
|
+
get(id) {
|
|
8
|
+
return this.api.get(`/v1/checks/${id}`, {
|
|
9
|
+
transformResponse: (data) => {
|
|
10
|
+
const { heartbeat: { pingUrl }, name } = JSON.parse(data);
|
|
11
|
+
return { pingUrl, name };
|
|
12
|
+
},
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.default = HeartbeatChecks;
|
|
17
|
+
//# sourceMappingURL=heartbeat-checks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"heartbeat-checks.js","sourceRoot":"","sources":["../../src/rest/heartbeat-checks.ts"],"names":[],"mappings":";;AAOA,MAAM,eAAe;IAEnB,YAAa,GAAkB;QAC7B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;IAChB,CAAC;IAED,GAAG,CAAE,EAAU;QACb,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAiB,cAAc,EAAE,EAAE,EAAE;YACtD,iBAAiB,EAAE,CAAC,IAAS,EAAE,EAAE;gBAC/B,MAAM,EAAE,SAAS,EAAE,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;gBACzD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAA;YAC1B,CAAC;SACF,CAAC,CAAA;IACJ,CAAC;CACF;AAED,kBAAe,eAAe,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { AxiosInstance } from 'axios';
|
|
2
|
+
export interface Location {
|
|
3
|
+
name: string;
|
|
4
|
+
region: string;
|
|
5
|
+
}
|
|
6
|
+
declare class Locations {
|
|
7
|
+
api: AxiosInstance;
|
|
8
|
+
constructor(api: AxiosInstance);
|
|
9
|
+
getAll(): Promise<import("axios").AxiosResponse<Location[], any>>;
|
|
10
|
+
}
|
|
11
|
+
export default Locations;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
class Locations {
|
|
4
|
+
constructor(api) {
|
|
5
|
+
this.api = api;
|
|
6
|
+
}
|
|
7
|
+
getAll() {
|
|
8
|
+
return this.api.get('/v1/locations');
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.default = Locations;
|
|
12
|
+
//# sourceMappingURL=locations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"locations.js","sourceRoot":"","sources":["../../src/rest/locations.ts"],"names":[],"mappings":";;AAOA,MAAM,SAAS;IAEb,YAAa,GAAkB;QAC7B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;IAChB,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAkB,eAAe,CAAC,CAAA;IACvD,CAAC;CACF;AAED,kBAAe,SAAS,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { AxiosInstance } from 'axios';
|
|
2
|
+
export interface PrivateLocationApi {
|
|
3
|
+
id: string;
|
|
4
|
+
slugName: string;
|
|
5
|
+
}
|
|
6
|
+
export default class PrivateLocations {
|
|
7
|
+
api: AxiosInstance;
|
|
8
|
+
constructor(api: AxiosInstance);
|
|
9
|
+
getAll(): Promise<import("axios").AxiosResponse<PrivateLocationApi[], any>>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
class PrivateLocations {
|
|
4
|
+
constructor(api) {
|
|
5
|
+
this.api = api;
|
|
6
|
+
}
|
|
7
|
+
getAll() {
|
|
8
|
+
return this.api.get('/v1/private-locations');
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.default = PrivateLocations;
|
|
12
|
+
//# sourceMappingURL=private-locations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"private-locations.js","sourceRoot":"","sources":["../../src/rest/private-locations.ts"],"names":[],"mappings":";;AAOA,MAAqB,gBAAgB;IAEnC,YAAa,GAAkB;QAC7B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;IAChB,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAA4B,uBAAuB,CAAC,CAAA;IACzE,CAAC;CACF;AATD,mCASC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import type { AxiosInstance } from 'axios';
|
|
2
|
+
import type { GitInformation } from '../services/util';
|
|
3
|
+
export interface Project {
|
|
4
|
+
name: string;
|
|
5
|
+
logicalId: string;
|
|
6
|
+
repoUrl?: string;
|
|
7
|
+
}
|
|
8
|
+
type ProjectResponse = Project & {
|
|
9
|
+
id: string;
|
|
10
|
+
created_at: string;
|
|
11
|
+
};
|
|
12
|
+
export interface Change {
|
|
13
|
+
logicalId: string;
|
|
14
|
+
physicalId?: string | number;
|
|
15
|
+
type: string;
|
|
16
|
+
action: string;
|
|
17
|
+
}
|
|
18
|
+
export interface ResourceSync {
|
|
19
|
+
logicalId: string;
|
|
20
|
+
physicalId?: string | number;
|
|
21
|
+
type: string;
|
|
22
|
+
member: boolean;
|
|
23
|
+
payload: any;
|
|
24
|
+
}
|
|
25
|
+
export interface ProjectSync {
|
|
26
|
+
project: Project;
|
|
27
|
+
resources: Array<ResourceSync>;
|
|
28
|
+
repoInfo: GitInformation | null;
|
|
29
|
+
}
|
|
30
|
+
export interface ProjectDeployResponse {
|
|
31
|
+
project: Project;
|
|
32
|
+
diff: Array<Change>;
|
|
33
|
+
}
|
|
34
|
+
declare class Projects {
|
|
35
|
+
api: AxiosInstance;
|
|
36
|
+
constructor(api: AxiosInstance);
|
|
37
|
+
getAll(): Promise<import("axios").AxiosResponse<ProjectResponse[], any>>;
|
|
38
|
+
get(id: string): Promise<import("axios").AxiosResponse<ProjectResponse, any>>;
|
|
39
|
+
create(project: Project): Promise<import("axios").AxiosResponse<any, any>>;
|
|
40
|
+
deleteProject(logicalId: string): Promise<import("axios").AxiosResponse<any, any>>;
|
|
41
|
+
deploy(resources: ProjectSync, { dryRun, scheduleOnDeploy }?: {
|
|
42
|
+
dryRun?: boolean | undefined;
|
|
43
|
+
scheduleOnDeploy?: boolean | undefined;
|
|
44
|
+
}): Promise<import("axios").AxiosResponse<ProjectDeployResponse, any>>;
|
|
45
|
+
}
|
|
46
|
+
export default Projects;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const util_1 = require("./util");
|
|
4
|
+
class Projects {
|
|
5
|
+
constructor(api) {
|
|
6
|
+
this.api = api;
|
|
7
|
+
}
|
|
8
|
+
getAll() {
|
|
9
|
+
return this.api.get('/next/projects');
|
|
10
|
+
}
|
|
11
|
+
get(id) {
|
|
12
|
+
return this.api.get(`/next/projects/${id}`);
|
|
13
|
+
}
|
|
14
|
+
create(project) {
|
|
15
|
+
return this.api.post('/next/projects', project);
|
|
16
|
+
}
|
|
17
|
+
deleteProject(logicalId) {
|
|
18
|
+
return this.api.delete(`/next/projects/${logicalId}`);
|
|
19
|
+
}
|
|
20
|
+
deploy(resources, { dryRun = false, scheduleOnDeploy = true } = {}) {
|
|
21
|
+
return this.api.post(`/next-v2/projects/deploy?dryRun=${dryRun}&scheduleOnDeploy=${scheduleOnDeploy}`, resources, { transformRequest: util_1.compressJSONPayload });
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.default = Projects;
|
|
25
|
+
//# sourceMappingURL=projects.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"projects.js","sourceRoot":"","sources":["../../src/rest/projects.ts"],"names":[],"mappings":";;AAEA,iCAA4C;AAmC5C,MAAM,QAAQ;IAEZ,YAAa,GAAkB;QAC7B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;IAChB,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAyB,gBAAgB,CAAC,CAAA;IAC/D,CAAC;IAED,GAAG,CAAE,EAAU;QACb,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAkB,kBAAkB,EAAE,EAAE,CAAC,CAAA;IAC9D,CAAC;IAED,MAAM,CAAE,OAAgB;QACtB,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAA;IACjD,CAAC;IAED,aAAa,CAAE,SAAiB;QAC9B,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,kBAAkB,SAAS,EAAE,CAAC,CAAA;IACvD,CAAC;IAED,MAAM,CAAE,SAAsB,EAAE,EAAE,MAAM,GAAG,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAAE,GAAG,EAAE;QAC9E,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAClB,mCAAmC,MAAM,qBAAqB,gBAAgB,EAAE,EAChF,SAAS,EACT,EAAE,gBAAgB,EAAE,0BAAmB,EAAE,CAC1C,CAAA;IACH,CAAC;CACF;AAED,kBAAe,QAAQ,CAAA"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { AxiosInstance } from 'axios';
|
|
2
|
+
export interface Runtime {
|
|
3
|
+
name: string;
|
|
4
|
+
stage?: string;
|
|
5
|
+
runtimeEndOfLife?: string;
|
|
6
|
+
description?: string;
|
|
7
|
+
dependencies: Record<string, string>;
|
|
8
|
+
multiStepSupport?: boolean;
|
|
9
|
+
}
|
|
10
|
+
declare class Runtimes {
|
|
11
|
+
api: AxiosInstance;
|
|
12
|
+
constructor(api: AxiosInstance);
|
|
13
|
+
getAll(): Promise<import("axios").AxiosResponse<Runtime[], any>>;
|
|
14
|
+
get(runtimeId: string): Promise<import("axios").AxiosResponse<Runtime, any>>;
|
|
15
|
+
}
|
|
16
|
+
export default Runtimes;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
class Runtimes {
|
|
4
|
+
constructor(api) {
|
|
5
|
+
this.api = api;
|
|
6
|
+
}
|
|
7
|
+
getAll() {
|
|
8
|
+
return this.api.get('/v1/runtimes');
|
|
9
|
+
}
|
|
10
|
+
get(runtimeId) {
|
|
11
|
+
return this.api.get(`/v1/runtimes/${runtimeId}`);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
exports.default = Runtimes;
|
|
15
|
+
//# sourceMappingURL=runtimes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtimes.js","sourceRoot":"","sources":["../../src/rest/runtimes.ts"],"names":[],"mappings":";;AAWA,MAAM,QAAQ;IAEZ,YAAa,GAAkB;QAC7B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;IAChB,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAiB,cAAc,CAAC,CAAA;IACrD,CAAC;IAED,GAAG,CAAE,SAAiB;QACpB,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAU,gBAAgB,SAAS,EAAE,CAAC,CAAA;IAC3D,CAAC;CACF;AAED,kBAAe,QAAQ,CAAA"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import type { AxiosInstance } from 'axios';
|
|
2
|
+
import { GitInformation } from '../services/util';
|
|
3
|
+
import { RetryStrategy } from '../constructs';
|
|
4
|
+
type RunTestSessionRequest = {
|
|
5
|
+
name: string;
|
|
6
|
+
checkRunJobs: any[];
|
|
7
|
+
project: {
|
|
8
|
+
logicalId: string;
|
|
9
|
+
};
|
|
10
|
+
runLocation: string | {
|
|
11
|
+
type: 'PUBLIC';
|
|
12
|
+
region: string;
|
|
13
|
+
} | {
|
|
14
|
+
type: 'PRIVATE';
|
|
15
|
+
slugName: string;
|
|
16
|
+
id: string;
|
|
17
|
+
};
|
|
18
|
+
repoInfo?: GitInformation | null;
|
|
19
|
+
environment?: string | null;
|
|
20
|
+
shouldRecord: boolean;
|
|
21
|
+
};
|
|
22
|
+
type TriggerTestSessionRequest = {
|
|
23
|
+
name: string;
|
|
24
|
+
runLocation: string | {
|
|
25
|
+
type: 'PUBLIC';
|
|
26
|
+
region: string;
|
|
27
|
+
} | {
|
|
28
|
+
type: 'PRIVATE';
|
|
29
|
+
slugName: string;
|
|
30
|
+
id: string;
|
|
31
|
+
};
|
|
32
|
+
shouldRecord: boolean;
|
|
33
|
+
targetTags: string[][];
|
|
34
|
+
checkRunSuiteId: string;
|
|
35
|
+
environmentVariables: Array<{
|
|
36
|
+
key: string;
|
|
37
|
+
value: string;
|
|
38
|
+
}>;
|
|
39
|
+
repoInfo: GitInformation | null;
|
|
40
|
+
environment: string | null;
|
|
41
|
+
testRetryStrategy: RetryStrategy | null;
|
|
42
|
+
};
|
|
43
|
+
export type TestResultsShortLinks = {
|
|
44
|
+
testResultLink: string;
|
|
45
|
+
testTraceLinks: string[];
|
|
46
|
+
videoLinks: string[];
|
|
47
|
+
screenshotLinks: string[];
|
|
48
|
+
};
|
|
49
|
+
declare class TestSessions {
|
|
50
|
+
api: AxiosInstance;
|
|
51
|
+
constructor(api: AxiosInstance);
|
|
52
|
+
run(payload: RunTestSessionRequest): Promise<import("axios").AxiosResponse<any, any>>;
|
|
53
|
+
trigger(payload: TriggerTestSessionRequest): Promise<import("axios").AxiosResponse<any, any>>;
|
|
54
|
+
getShortLink(id: string): Promise<import("axios").AxiosResponse<{
|
|
55
|
+
link: string;
|
|
56
|
+
}, any>>;
|
|
57
|
+
getResultShortLinks(testSessionId: string, testResultId: string): Promise<import("axios").AxiosResponse<TestResultsShortLinks, any>>;
|
|
58
|
+
}
|
|
59
|
+
export default TestSessions;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const util_1 = require("./util");
|
|
4
|
+
class TestSessions {
|
|
5
|
+
constructor(api) {
|
|
6
|
+
this.api = api;
|
|
7
|
+
}
|
|
8
|
+
run(payload) {
|
|
9
|
+
return this.api.post('/next/test-sessions/run', payload, {
|
|
10
|
+
transformRequest: util_1.compressJSONPayload,
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
trigger(payload) {
|
|
14
|
+
return this.api.post('/next/test-sessions/trigger', payload);
|
|
15
|
+
}
|
|
16
|
+
getShortLink(id) {
|
|
17
|
+
return this.api.get(`/next/test-sessions/${id}/link`);
|
|
18
|
+
}
|
|
19
|
+
getResultShortLinks(testSessionId, testResultId) {
|
|
20
|
+
return this.api.get(`/next/test-sessions/${testSessionId}/results/${testResultId}/links`);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.default = TestSessions;
|
|
24
|
+
//# sourceMappingURL=test-sessions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test-sessions.js","sourceRoot":"","sources":["../../src/rest/test-sessions.ts"],"names":[],"mappings":";;AAGA,iCAA4C;AA+B5C,MAAM,YAAY;IAEhB,YAAa,GAAkB;QAC7B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;IAChB,CAAC;IAED,GAAG,CAAE,OAA8B;QACjC,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,yBAAyB,EAAE,OAAO,EAAE;YACvD,gBAAgB,EAAE,0BAAmB;SACtC,CAAC,CAAA;IACJ,CAAC;IAED,OAAO,CAAE,OAAkC;QACzC,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,6BAA6B,EAAE,OAAO,CAAC,CAAA;IAC9D,CAAC;IAED,YAAY,CAAE,EAAU;QACtB,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAmB,uBAAuB,EAAE,OAAO,CAAC,CAAA;IACzE,CAAC;IAED,mBAAmB,CAAE,aAAqB,EAAE,YAAoB;QAC9D,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAwB,uBAAuB,aAAa,YAAY,YAAY,QAAQ,CAAC,CAAA;IAClH,CAAC;CACF;AAED,kBAAe,YAAY,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { AxiosInstance } from 'axios';
|
|
2
|
+
export interface User {
|
|
3
|
+
id: string;
|
|
4
|
+
name: string;
|
|
5
|
+
nickname?: string;
|
|
6
|
+
}
|
|
7
|
+
declare class Users {
|
|
8
|
+
api: AxiosInstance;
|
|
9
|
+
constructor(api: AxiosInstance);
|
|
10
|
+
get(): Promise<import("axios").AxiosResponse<User, any>>;
|
|
11
|
+
}
|
|
12
|
+
export default Users;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
class Users {
|
|
4
|
+
constructor(api) {
|
|
5
|
+
this.api = api;
|
|
6
|
+
}
|
|
7
|
+
get() {
|
|
8
|
+
return this.api.get('/next/users/me');
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.default = Users;
|
|
12
|
+
//# sourceMappingURL=users.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"users.js","sourceRoot":"","sources":["../../src/rest/users.ts"],"names":[],"mappings":";;AAQA,MAAM,KAAK;IAET,YAAa,GAAkB;QAC7B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;IAChB,CAAC;IAED,GAAG;QACD,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAO,gBAAgB,CAAC,CAAA;IAC7C,CAAC;CACF;AAED,kBAAe,KAAK,CAAA"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.compressJSONPayload = void 0;
|
|
7
|
+
const node_zlib_1 = __importDefault(require("node:zlib"));
|
|
8
|
+
const json_stream_stringify_1 = require("json-stream-stringify");
|
|
9
|
+
function compressJSONPayload(data, headers) {
|
|
10
|
+
headers['Content-Type'] = 'application/json';
|
|
11
|
+
headers['Content-Encoding'] = 'gzip';
|
|
12
|
+
const zipper = node_zlib_1.default.createGzip();
|
|
13
|
+
const streamer = new json_stream_stringify_1.JsonStreamStringify(data);
|
|
14
|
+
return streamer.pipe(zipper);
|
|
15
|
+
}
|
|
16
|
+
exports.compressJSONPayload = compressJSONPayload;
|
|
17
|
+
//# sourceMappingURL=util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/rest/util.ts"],"names":[],"mappings":";;;;;;AAAA,0DAA4B;AAG5B,iEAA2D;AAE3D,SAAgB,mBAAmB,CAAE,IAAS,EAAE,OAA4B;IAC1E,OAAO,CAAC,cAAc,CAAC,GAAG,kBAAkB,CAAA;IAC5C,OAAO,CAAC,kBAAkB,CAAC,GAAG,MAAM,CAAA;IAEpC,MAAM,MAAM,GAAG,mBAAI,CAAC,UAAU,EAAE,CAAA;IAChC,MAAM,QAAQ,GAAG,IAAI,2CAAmB,CAAC,IAAI,CAAC,CAAA;IAE9C,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;AAC9B,CAAC;AARD,kDAQC"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
import PQueue from 'p-queue';
|
|
4
|
+
import { EventEmitter } from 'node:events';
|
|
5
|
+
import type { Region } from '..';
|
|
6
|
+
export declare enum Events {
|
|
7
|
+
CHECK_REGISTERED = "CHECK_REGISTERED",
|
|
8
|
+
CHECK_INPROGRESS = "CHECK_INPROGRESS",
|
|
9
|
+
CHECK_ATTEMPT_RESULT = "CHECK_ATTEMPT_RESULT",
|
|
10
|
+
CHECK_FAILED = "CHECK_FAILED",
|
|
11
|
+
CHECK_SUCCESSFUL = "CHECK_SUCCESSFUL",
|
|
12
|
+
CHECK_FINISHED = "CHECK_FINISHED",
|
|
13
|
+
RUN_STARTED = "RUN_STARTED",
|
|
14
|
+
RUN_FINISHED = "RUN_FINISHED",
|
|
15
|
+
ERROR = "ERROR",
|
|
16
|
+
MAX_SCHEDULING_DELAY_EXCEEDED = "MAX_SCHEDULING_DELAY_EXCEEDED"
|
|
17
|
+
}
|
|
18
|
+
export type PrivateRunLocation = {
|
|
19
|
+
type: 'PRIVATE';
|
|
20
|
+
id: string;
|
|
21
|
+
slugName: string;
|
|
22
|
+
};
|
|
23
|
+
export type PublicRunLocation = {
|
|
24
|
+
type: 'PUBLIC';
|
|
25
|
+
region: keyof Region;
|
|
26
|
+
};
|
|
27
|
+
export type RunLocation = PublicRunLocation | PrivateRunLocation;
|
|
28
|
+
export type CheckRunId = string;
|
|
29
|
+
export type SequenceId = string;
|
|
30
|
+
export declare const DEFAULT_CHECK_RUN_TIMEOUT_SECONDS = 600;
|
|
31
|
+
export default abstract class AbstractCheckRunner extends EventEmitter {
|
|
32
|
+
checks: Map<SequenceId, {
|
|
33
|
+
check: any;
|
|
34
|
+
}>;
|
|
35
|
+
testSessionId?: string;
|
|
36
|
+
timeouts: Map<SequenceId, NodeJS.Timeout>;
|
|
37
|
+
schedulingDelayExceededTimeout?: NodeJS.Timeout;
|
|
38
|
+
accountId: string;
|
|
39
|
+
timeout: number;
|
|
40
|
+
verbose: boolean;
|
|
41
|
+
queue: PQueue;
|
|
42
|
+
constructor(accountId: string, timeout: number, verbose: boolean);
|
|
43
|
+
abstract scheduleChecks(checkRunSuiteId: string): Promise<{
|
|
44
|
+
testSessionId?: string;
|
|
45
|
+
checks: Array<{
|
|
46
|
+
check: any;
|
|
47
|
+
sequenceId: SequenceId;
|
|
48
|
+
}>;
|
|
49
|
+
}>;
|
|
50
|
+
run(): Promise<void>;
|
|
51
|
+
private configureResultListener;
|
|
52
|
+
private processMessage;
|
|
53
|
+
processCheckResult(result: any): Promise<void>;
|
|
54
|
+
private allChecksFinished;
|
|
55
|
+
private setAllTimeouts;
|
|
56
|
+
private disableAllTimeouts;
|
|
57
|
+
private startSchedulingDelayTimeout;
|
|
58
|
+
private disableTimeout;
|
|
59
|
+
private getShortLinks;
|
|
60
|
+
}
|
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.DEFAULT_CHECK_RUN_TIMEOUT_SECONDS = exports.Events = void 0;
|
|
30
|
+
const api_1 = require("../rest/api");
|
|
31
|
+
const socket_client_1 = require("./socket-client");
|
|
32
|
+
const p_queue_1 = __importDefault(require("p-queue"));
|
|
33
|
+
const uuid = __importStar(require("uuid"));
|
|
34
|
+
const node_events_1 = require("node:events");
|
|
35
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
36
|
+
var Events;
|
|
37
|
+
(function (Events) {
|
|
38
|
+
Events["CHECK_REGISTERED"] = "CHECK_REGISTERED";
|
|
39
|
+
Events["CHECK_INPROGRESS"] = "CHECK_INPROGRESS";
|
|
40
|
+
Events["CHECK_ATTEMPT_RESULT"] = "CHECK_ATTEMPT_RESULT";
|
|
41
|
+
Events["CHECK_FAILED"] = "CHECK_FAILED";
|
|
42
|
+
Events["CHECK_SUCCESSFUL"] = "CHECK_SUCCESSFUL";
|
|
43
|
+
Events["CHECK_FINISHED"] = "CHECK_FINISHED";
|
|
44
|
+
Events["RUN_STARTED"] = "RUN_STARTED";
|
|
45
|
+
Events["RUN_FINISHED"] = "RUN_FINISHED";
|
|
46
|
+
Events["ERROR"] = "ERROR";
|
|
47
|
+
Events["MAX_SCHEDULING_DELAY_EXCEEDED"] = "MAX_SCHEDULING_DELAY_EXCEEDED";
|
|
48
|
+
})(Events || (exports.Events = Events = {}));
|
|
49
|
+
exports.DEFAULT_CHECK_RUN_TIMEOUT_SECONDS = 600;
|
|
50
|
+
const DEFAULT_SCHEDULING_DELAY_EXCEEDED_MS = 20000;
|
|
51
|
+
class AbstractCheckRunner extends node_events_1.EventEmitter {
|
|
52
|
+
constructor(accountId, timeout, verbose) {
|
|
53
|
+
super();
|
|
54
|
+
this.checks = new Map();
|
|
55
|
+
this.timeouts = new Map();
|
|
56
|
+
this.queue = new p_queue_1.default({ autoStart: false, concurrency: 1 });
|
|
57
|
+
this.timeout = timeout;
|
|
58
|
+
this.verbose = verbose;
|
|
59
|
+
this.accountId = accountId;
|
|
60
|
+
}
|
|
61
|
+
async run() {
|
|
62
|
+
let socketClient = null;
|
|
63
|
+
try {
|
|
64
|
+
socketClient = await socket_client_1.SocketClient.connect();
|
|
65
|
+
const checkRunSuiteId = uuid.v4();
|
|
66
|
+
// Configure the socket listener and allChecksFinished listener before starting checks to avoid race conditions
|
|
67
|
+
await this.configureResultListener(checkRunSuiteId, socketClient);
|
|
68
|
+
const { testSessionId, checks } = await this.scheduleChecks(checkRunSuiteId);
|
|
69
|
+
this.testSessionId = testSessionId;
|
|
70
|
+
this.checks = new Map(checks.map(({ check, sequenceId }) => [sequenceId, { check }]));
|
|
71
|
+
// `processMessage()` assumes that `this.timeouts` always has an entry for non-timed-out checks.
|
|
72
|
+
// To ensure that this is the case, we call `setAllTimeouts()` before `queue.start()`.
|
|
73
|
+
// Otherwise, we risk a race condition where check results are received before the timeout is set.
|
|
74
|
+
// This would cause `processMessage()` to mistakenly skip check results and consider the checks timed-out.
|
|
75
|
+
this.setAllTimeouts();
|
|
76
|
+
// Add timeout to fire an event after DEFAULT_SCHEDULING_DELAY_EXCEEDED_MS to let reporters know it's time
|
|
77
|
+
// to display a hint messages if some checks are still being scheduled.
|
|
78
|
+
this.startSchedulingDelayTimeout();
|
|
79
|
+
// `allChecksFinished` should be started before processing check results in `queue.start()`.
|
|
80
|
+
// Otherwise, there could be a race condition causing check results to be missed by `allChecksFinished()`.
|
|
81
|
+
const allChecksFinished = this.allChecksFinished();
|
|
82
|
+
/// / Need to structure the checks depending on how it went
|
|
83
|
+
this.emit(Events.RUN_STARTED, checks, testSessionId);
|
|
84
|
+
// Start the queue after the test session run rest call is completed to avoid race conditions
|
|
85
|
+
this.queue.start();
|
|
86
|
+
await allChecksFinished;
|
|
87
|
+
this.emit(Events.RUN_FINISHED, testSessionId);
|
|
88
|
+
}
|
|
89
|
+
catch (err) {
|
|
90
|
+
this.disableAllTimeouts();
|
|
91
|
+
this.emit(Events.ERROR, err);
|
|
92
|
+
}
|
|
93
|
+
finally {
|
|
94
|
+
if (socketClient) {
|
|
95
|
+
await socketClient.endAsync();
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
async configureResultListener(checkRunSuiteId, socketClient) {
|
|
100
|
+
socketClient.on('message', (topic, rawMessage) => {
|
|
101
|
+
const message = JSON.parse(rawMessage.toString('utf8'));
|
|
102
|
+
const topicComponents = topic.split('/');
|
|
103
|
+
const sequenceId = topicComponents[4];
|
|
104
|
+
const checkRunId = topicComponents[5];
|
|
105
|
+
const subtopic = topicComponents[6];
|
|
106
|
+
this.queue.add(() => this.processMessage(sequenceId, subtopic, message));
|
|
107
|
+
});
|
|
108
|
+
await socketClient.subscribeAsync(`account/${this.accountId}/ad-hoc-check-results/${checkRunSuiteId}/+/+/+`);
|
|
109
|
+
}
|
|
110
|
+
async processMessage(sequenceId, subtopic, message) {
|
|
111
|
+
if (!sequenceId) {
|
|
112
|
+
// There should always be a sequenceId, but let's have an early return to make forwards-compatibility easier.
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
if (!this.timeouts.has(sequenceId)) {
|
|
116
|
+
// The check has already timed out. We return early to avoid reporting a duplicate result.
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
if (!this.checks.get(sequenceId)) {
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
const { check } = this.checks.get(sequenceId);
|
|
123
|
+
if (subtopic === 'run-start') {
|
|
124
|
+
this.emit(Events.CHECK_INPROGRESS, check, sequenceId);
|
|
125
|
+
}
|
|
126
|
+
else if (subtopic === 'result') {
|
|
127
|
+
const { result, testResultId, resultType } = message;
|
|
128
|
+
await this.processCheckResult(result);
|
|
129
|
+
const links = testResultId && result.hasFailures && await this.getShortLinks(testResultId);
|
|
130
|
+
if (resultType === 'FINAL') {
|
|
131
|
+
this.disableTimeout(sequenceId);
|
|
132
|
+
this.emit(Events.CHECK_SUCCESSFUL, sequenceId, check, result, testResultId, links);
|
|
133
|
+
this.emit(Events.CHECK_FINISHED, check);
|
|
134
|
+
}
|
|
135
|
+
else if (resultType === 'ATTEMPT') {
|
|
136
|
+
this.emit(Events.CHECK_ATTEMPT_RESULT, sequenceId, check, result, links);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
else if (subtopic === 'error') {
|
|
140
|
+
this.disableTimeout(sequenceId);
|
|
141
|
+
this.emit(Events.CHECK_FAILED, sequenceId, check, message);
|
|
142
|
+
this.emit(Events.CHECK_FINISHED, check);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
async processCheckResult(result) {
|
|
146
|
+
const { region, logPath, checkRunDataPath, } = result.assets;
|
|
147
|
+
if (logPath && (this.verbose || result.hasFailures)) {
|
|
148
|
+
result.logs = await api_1.assets.getLogs(region, logPath);
|
|
149
|
+
}
|
|
150
|
+
if (checkRunDataPath && (this.verbose || result.hasFailures)) {
|
|
151
|
+
result.checkRunData = await api_1.assets.getCheckRunData(region, checkRunDataPath);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
allChecksFinished() {
|
|
155
|
+
let finishedCheckCount = 0;
|
|
156
|
+
const numChecks = this.checks.size;
|
|
157
|
+
if (numChecks === 0) {
|
|
158
|
+
return Promise.resolve();
|
|
159
|
+
}
|
|
160
|
+
return new Promise((resolve) => {
|
|
161
|
+
this.on(Events.CHECK_FINISHED, () => {
|
|
162
|
+
finishedCheckCount++;
|
|
163
|
+
if (finishedCheckCount === numChecks)
|
|
164
|
+
resolve();
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
setAllTimeouts() {
|
|
169
|
+
Array.from(this.checks.entries()).forEach(([sequenceId, { check }]) => this.timeouts.set(sequenceId, setTimeout(() => {
|
|
170
|
+
this.timeouts.delete(sequenceId);
|
|
171
|
+
let errorMessage = `Reached timeout of ${this.timeout} seconds waiting for check result.`;
|
|
172
|
+
// Checkly should always report a result within 240s.
|
|
173
|
+
// If the default timeout was used, we should point the user to the status page and support email.
|
|
174
|
+
if (this.timeout === exports.DEFAULT_CHECK_RUN_TIMEOUT_SECONDS) {
|
|
175
|
+
errorMessage += ' Checkly may be experiencing problems. Please check https://is.checkly.online or reach out to support@checklyhq.com.';
|
|
176
|
+
}
|
|
177
|
+
this.emit(Events.CHECK_FAILED, sequenceId, check, errorMessage);
|
|
178
|
+
this.emit(Events.CHECK_FINISHED, check);
|
|
179
|
+
}, this.timeout * 1000)));
|
|
180
|
+
}
|
|
181
|
+
disableAllTimeouts() {
|
|
182
|
+
if (!this.checks) {
|
|
183
|
+
return;
|
|
184
|
+
}
|
|
185
|
+
Array.from(this.checks.entries()).forEach(([checkRunId]) => this.disableTimeout(checkRunId));
|
|
186
|
+
if (this.schedulingDelayExceededTimeout) {
|
|
187
|
+
clearTimeout(this.schedulingDelayExceededTimeout);
|
|
188
|
+
this.schedulingDelayExceededTimeout = undefined;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
startSchedulingDelayTimeout() {
|
|
192
|
+
let scheduledCheckCount = 0;
|
|
193
|
+
const numChecks = this.checks.size;
|
|
194
|
+
if (numChecks === 0) {
|
|
195
|
+
return;
|
|
196
|
+
}
|
|
197
|
+
this.schedulingDelayExceededTimeout = setTimeout(() => {
|
|
198
|
+
this.emit(Events.MAX_SCHEDULING_DELAY_EXCEEDED);
|
|
199
|
+
this.schedulingDelayExceededTimeout = undefined;
|
|
200
|
+
}, DEFAULT_SCHEDULING_DELAY_EXCEEDED_MS);
|
|
201
|
+
this.on(Events.CHECK_INPROGRESS, () => {
|
|
202
|
+
scheduledCheckCount++;
|
|
203
|
+
if (scheduledCheckCount === numChecks)
|
|
204
|
+
clearTimeout(this.schedulingDelayExceededTimeout);
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
disableTimeout(timeoutKey) {
|
|
208
|
+
const timeout = this.timeouts.get(timeoutKey);
|
|
209
|
+
clearTimeout(timeout);
|
|
210
|
+
this.timeouts.delete(timeoutKey);
|
|
211
|
+
}
|
|
212
|
+
async getShortLinks(testResultId) {
|
|
213
|
+
try {
|
|
214
|
+
if (!this.testSessionId) {
|
|
215
|
+
return;
|
|
216
|
+
}
|
|
217
|
+
const { data: links } = await api_1.testSessions.getResultShortLinks(this.testSessionId, testResultId);
|
|
218
|
+
return links;
|
|
219
|
+
}
|
|
220
|
+
catch {
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
exports.default = AbstractCheckRunner;
|
|
225
|
+
//# sourceMappingURL=abstract-check-runner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-check-runner.js","sourceRoot":"","sources":["../../src/services/abstract-check-runner.ts"],"names":[],"mappings":"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"}
|