@appland/appmap 3.35.0 → 3.36.0
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/CHANGELOG.md +7 -0
- package/built/appmap.html +1 -1
- package/built/cli.js +2 -2
- package/built/cli.js.map +1 -1
- package/built/cmds/agentInstaller/install-agent.js +2 -2
- package/built/cmds/agentInstaller/install-agent.js.map +1 -1
- package/built/cmds/record/action/cancelRecording.js +2 -3
- package/built/cmds/record/action/cancelRecording.js.map +1 -1
- package/built/cmds/record/action/configureHostAndPort.js +6 -6
- package/built/cmds/record/action/configureHostAndPort.js.map +1 -1
- package/built/cmds/record/action/configureRemainingRequestOptions.js +7 -7
- package/built/cmds/record/action/configureRemainingRequestOptions.js.map +1 -1
- package/built/cmds/record/action/detectProcessCharacteristics.js +2 -3
- package/built/cmds/record/action/detectProcessCharacteristics.js.map +1 -1
- package/built/cmds/record/action/saveAppMap.js +2 -3
- package/built/cmds/record/action/saveAppMap.js.map +1 -1
- package/built/cmds/record/action/saveRecording.js +2 -3
- package/built/cmds/record/action/saveRecording.js.map +1 -1
- package/built/cmds/record/action/startRecording.js +2 -3
- package/built/cmds/record/action/startRecording.js.map +1 -1
- package/built/cmds/record/action/startTestCases.js +6 -5
- package/built/cmds/record/action/startTestCases.js.map +1 -1
- package/built/cmds/record/configuration.js +66 -84
- package/built/cmds/record/configuration.js.map +1 -1
- package/built/cmds/record/makeRequest.js +50 -0
- package/built/cmds/record/makeRequest.js.map +1 -0
- package/built/cmds/record/prompt/continueWithRequestOptionConfiguration.js +2 -3
- package/built/cmds/record/prompt/continueWithRequestOptionConfiguration.js.map +1 -1
- package/built/cmds/record/prompt/obtainTestCommands.js +7 -3
- package/built/cmds/record/prompt/obtainTestCommands.js.map +1 -1
- package/built/cmds/record/record.js +110 -83
- package/built/cmds/record/record.js.map +1 -1
- package/built/cmds/record/recordContext.js +11 -7
- package/built/cmds/record/recordContext.js.map +1 -1
- package/built/cmds/record/remoteRecording.js +7 -35
- package/built/cmds/record/remoteRecording.js.map +1 -1
- package/built/cmds/record/state/agentAvailableAndReady.js +2 -2
- package/built/cmds/record/state/agentAvailableAndReady.js.map +1 -1
- package/built/cmds/record/state/agentIsRecording.js +1 -1
- package/built/cmds/record/state/agentIsRecording.js.map +1 -1
- package/built/cmds/record/state/agentNotAvailable.js +37 -10
- package/built/cmds/record/state/agentNotAvailable.js.map +1 -1
- package/built/cmds/record/state/agentProcessNotRunning.js +2 -2
- package/built/cmds/record/state/agentProcessNotRunning.js.map +1 -1
- package/built/cmds/record/state/initial.js +6 -1
- package/built/cmds/record/state/initial.js.map +1 -1
- package/built/cmds/record/state/record_remote.js +3 -3
- package/built/cmds/record/state/record_remote.js.map +1 -1
- package/built/cmds/record/state/record_test.js +2 -2
- package/built/cmds/record/state/record_test.js.map +1 -1
- package/built/cmds/record/state/testCasesComplete.js +9 -6
- package/built/cmds/record/state/testCasesComplete.js.map +1 -1
- package/built/cmds/record/state/testCommandsAvailable.js +1 -1
- package/built/cmds/record/state/testCommandsAvailable.js.map +1 -1
- package/built/cmds/record/state/testCommandsNeeded.js +2 -2
- package/built/cmds/record/state/testCommandsNeeded.js.map +1 -1
- package/built/cmds/record/test/areTestCommandsConfigured.js +4 -4
- package/built/cmds/record/test/areTestCommandsConfigured.js.map +1 -1
- package/built/cmds/record/test/isAgentAvailable.js +12 -5
- package/built/cmds/record/test/isAgentAvailable.js.map +1 -1
- package/built/cmds/record/test/isRecordingInProgress.js +2 -3
- package/built/cmds/record/test/isRecordingInProgress.js.map +1 -1
- package/built/cmds/record/testCaseRecording.js +3 -4
- package/built/cmds/record/testCaseRecording.js.map +1 -1
- package/built/cmds/runCommand.js +3 -1
- package/built/cmds/runCommand.js.map +1 -1
- package/built/lib/ticket/openTicket.js +30 -36
- package/built/lib/ticket/openTicket.js.map +1 -1
- package/built/lib/ticket/zendesk.js +3 -2
- package/built/lib/ticket/zendesk.js.map +1 -1
- package/built/main.js.map +1 -1
- package/package.json +4 -4
|
@@ -22,38 +22,65 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
22
22
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
23
|
};
|
|
24
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
+
exports.NextStepChoices = void 0;
|
|
26
|
+
const openTicket_1 = __importDefault(require("../../../lib/ticket/openTicket"));
|
|
25
27
|
const userInteraction_1 = __importDefault(require("../../userInteraction"));
|
|
26
28
|
const configureRemainingRequestOptions_1 = __importDefault(require("../action/configureRemainingRequestOptions"));
|
|
27
29
|
const detectProcessCharacteristics_1 = __importDefault(require("../action/detectProcessCharacteristics"));
|
|
28
30
|
const continueWithRequestOptionConfiguration_1 = __importStar(require("../prompt/continueWithRequestOptionConfiguration"));
|
|
31
|
+
const abort_1 = __importDefault(require("./abort"));
|
|
29
32
|
const agentProcessNotRunning_1 = __importDefault(require("./agentProcessNotRunning"));
|
|
30
33
|
const record_remote_1 = __importDefault(require("./record_remote"));
|
|
34
|
+
exports.NextStepChoices = {
|
|
35
|
+
CONFIGURE: { name: 'Configure the path and protocol', value: 'configure' },
|
|
36
|
+
RELAUNCH: { name: 'Re-launch the server', value: 'relaunch' },
|
|
37
|
+
SUPPORT: { name: 'Contact support', value: 'support' },
|
|
38
|
+
};
|
|
31
39
|
// The agent was not reachable using the configured settings. This may be because:
|
|
32
40
|
// * The agent process isn't running.
|
|
33
41
|
// * The agent process is running, but the agent isn't reachable (e.g. security filter?).
|
|
34
42
|
// * The host/port parameters are wrong.
|
|
35
43
|
// * The host/port parameters are right, but the agent URL is different than the default.
|
|
36
44
|
async function agentNotAvailable(recordContext) {
|
|
37
|
-
|
|
38
|
-
|
|
45
|
+
var _a;
|
|
46
|
+
if (!(await (0, detectProcessCharacteristics_1.default)(recordContext))) {
|
|
47
|
+
if ((await (0, continueWithRequestOptionConfiguration_1.default)(recordContext)) ===
|
|
39
48
|
continueWithRequestOptionConfiguration_1.ConfigurationAction.HostAndPort)
|
|
40
49
|
return agentProcessNotRunning_1.default;
|
|
41
50
|
}
|
|
42
51
|
userInteraction_1.default.progress(`
|
|
43
52
|
You've confirmed that your application process is running, but I'm unable to connect to the AppMap agent over HTTP. There are three common reasons for this:
|
|
44
53
|
|
|
45
|
-
1) The agent
|
|
46
|
-
2) The agent
|
|
47
|
-
3) The agent is enabled
|
|
54
|
+
1) The agent is enabled and reachable, but it's mounted to a non-root URL path (e.g. /myapp), or the application server is only requesting HTTPS connections.
|
|
55
|
+
2) The agent isn't configured to accept connections in this process. For example, the app isn't running with APPMAP=true (Ruby, Python), or the app isn't running with the AppMap agent enabled (Java).
|
|
56
|
+
3) The agent is enabled, but HTTP requests to the agent are being blocked by some application or framework code; for example, a security filter.
|
|
48
57
|
|
|
49
|
-
For case (1), you
|
|
58
|
+
For case (1), you can configure the application URL path and protocol.
|
|
50
59
|
|
|
51
|
-
For case (2), you
|
|
60
|
+
For case (2), you'll need to re-launch the server with the agent enabled.
|
|
52
61
|
|
|
53
|
-
For case (3), you
|
|
62
|
+
For case (3), you should contact AppMap support for help with troubleshooting.
|
|
54
63
|
`);
|
|
55
|
-
await
|
|
56
|
-
|
|
64
|
+
const { option } = await userInteraction_1.default.prompt({
|
|
65
|
+
type: 'list',
|
|
66
|
+
name: 'option',
|
|
67
|
+
message: 'Which would you like to do?',
|
|
68
|
+
choices: Object.values(exports.NextStepChoices),
|
|
69
|
+
});
|
|
70
|
+
switch (option) {
|
|
71
|
+
case exports.NextStepChoices.CONFIGURE.value:
|
|
72
|
+
await (0, configureRemainingRequestOptions_1.default)(recordContext);
|
|
73
|
+
recordContext.populateURL();
|
|
74
|
+
break;
|
|
75
|
+
case exports.NextStepChoices.RELAUNCH.value:
|
|
76
|
+
await userInteraction_1.default.continue('Press enter when the server has been restarted');
|
|
77
|
+
break;
|
|
78
|
+
case exports.NextStepChoices.SUPPORT.value:
|
|
79
|
+
const details = ((_a = recordContext.remoteError) === null || _a === void 0 ? void 0 : _a.toString()) || '';
|
|
80
|
+
await (0, openTicket_1.default)(details);
|
|
81
|
+
return abort_1.default; // We're done
|
|
82
|
+
break;
|
|
83
|
+
}
|
|
57
84
|
return record_remote_1.default;
|
|
58
85
|
}
|
|
59
86
|
exports.default = agentNotAvailable;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agentNotAvailable.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/agentNotAvailable.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"agentNotAvailable.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/agentNotAvailable.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,gFAAwD;AACxD,4EAAuC;AACvC,kHAA0F;AAC1F,0GAAkF;AAClF,2HAE0D;AAG1D,oDAA4B;AAC5B,sFAA8D;AAC9D,oEAAsC;AAEzB,QAAA,eAAe,GAAG;IAC7B,SAAS,EAAE,EAAE,IAAI,EAAE,iCAAiC,EAAE,KAAK,EAAE,WAAW,EAAE;IAC1E,QAAQ,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE,KAAK,EAAE,UAAU,EAAE;IAC7D,OAAO,EAAE,EAAE,IAAI,EAAE,iBAAiB,EAAE,KAAK,EAAE,SAAS,EAAE;CACvD,CAAC;AAEF,kFAAkF;AAClF,qCAAqC;AACrC,yFAAyF;AACzF,wCAAwC;AACxC,yFAAyF;AAC1E,KAAK,UAAU,iBAAiB,CAC7C,aAA4B;;IAE5B,IAAI,CAAC,CAAC,MAAM,IAAA,sCAA4B,EAAC,aAAa,CAAC,CAAC,EAAE;QACxD,IACE,CAAC,MAAM,IAAA,gDAAsC,EAAC,aAAa,CAAC,CAAC;YAC7D,4DAAmB,CAAC,WAAW;YAE/B,OAAO,gCAAsB,CAAC;KACjC;IAED,yBAAE,CAAC,QAAQ,CACT;;;;;;;;;;;;CAYH,CACE,CAAC;IAEF,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,yBAAE,CAAC,MAAM,CAAC;QACjC,IAAI,EAAE,MAAM;QACZ,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,6BAA6B;QACtC,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,uBAAe,CAAC;KACxC,CAAC,CAAC;IAEH,QAAQ,MAAM,EAAE;QACd,KAAK,uBAAe,CAAC,SAAS,CAAC,KAAK;YAClC,MAAM,IAAA,0CAAgC,EAAC,aAAa,CAAC,CAAC;YACtD,aAAa,CAAC,WAAW,EAAE,CAAC;YAC5B,MAAM;QACR,KAAK,uBAAe,CAAC,QAAQ,CAAC,KAAK;YACjC,MAAM,yBAAE,CAAC,QAAQ,CAAC,gDAAgD,CAAC,CAAC;YACpE,MAAM;QACR,KAAK,uBAAe,CAAC,OAAO,CAAC,KAAK;YAChC,MAAM,OAAO,GAAG,CAAA,MAAA,aAAa,CAAC,WAAW,0CAAE,QAAQ,EAAE,KAAI,EAAE,CAAC;YAE5D,MAAM,IAAA,oBAAU,EAAC,OAAO,CAAC,CAAC;YAC1B,OAAO,eAAK,CAAC,CAAC,aAAa;YAC3B,MAAM;KACT;IAED,OAAO,uBAAO,CAAC;AACjB,CAAC;AAnDD,oCAmDC"}
|
|
@@ -8,7 +8,7 @@ const configureHostAndPort_1 = __importDefault(require("../action/configureHostA
|
|
|
8
8
|
const record_remote_1 = __importDefault(require("./record_remote"));
|
|
9
9
|
// No process could be contact on the configured host and port.
|
|
10
10
|
// Prompt the user to start the agent process, and then start over.
|
|
11
|
-
async function agentProcessNotRunning() {
|
|
11
|
+
async function agentProcessNotRunning(context) {
|
|
12
12
|
userInteraction_1.default.progress(`It looks like you need to start your app (make sure you have the AppMap agent enabled).`);
|
|
13
13
|
userInteraction_1.default.progress(`Or maybe your app is running, but it's on a different host and/or port.`);
|
|
14
14
|
userInteraction_1.default.progress(``);
|
|
@@ -23,7 +23,7 @@ async function agentProcessNotRunning() {
|
|
|
23
23
|
Java: https://appland.com/docs/reference/appmap-java.html#remote-recording
|
|
24
24
|
JavaScript: https://appland.com/docs/reference/appmap-agent-js.html#remote-recording
|
|
25
25
|
`);
|
|
26
|
-
await (0, configureHostAndPort_1.default)();
|
|
26
|
+
await (0, configureHostAndPort_1.default)(context);
|
|
27
27
|
return record_remote_1.default;
|
|
28
28
|
}
|
|
29
29
|
exports.default = agentProcessNotRunning;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"agentProcessNotRunning.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/agentProcessNotRunning.ts"],"names":[],"mappings":";;;;;AAAA,4EAAuC;AACvC,0FAAkE;
|
|
1
|
+
{"version":3,"file":"agentProcessNotRunning.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/agentProcessNotRunning.ts"],"names":[],"mappings":";;;;;AAAA,4EAAuC;AACvC,0FAAkE;AAGlE,oEAAsC;AAEtC,+DAA+D;AAC/D,mEAAmE;AACpD,KAAK,UAAU,sBAAsB,CAClD,OAAsB;IAEtB,yBAAE,CAAC,QAAQ,CACT,yFAAyF,CAC1F,CAAC;IACF,yBAAE,CAAC,QAAQ,CACT,yEAAyE,CAC1E,CAAC;IACF,yBAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAEhB,yBAAE,CAAC,QAAQ,CACT,wDAAwD;QACtD,oFAAoF;QACpF,gGAAgG;QAChG,wBAAwB,CAC3B,CAAC;IACF,yBAAE,CAAC,QAAQ,CAAC;;;;;;GAMX,CAAC,CAAC;IAEH,MAAM,IAAA,8BAAoB,EAAC,OAAO,CAAC,CAAC;IAEpC,OAAO,uBAAO,CAAC;AACjB,CAAC;AA5BD,yCA4BC"}
|
|
@@ -22,7 +22,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
22
22
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
23
|
};
|
|
24
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
+
exports.createState = void 0;
|
|
25
26
|
const userInteraction_1 = __importDefault(require("../../userInteraction"));
|
|
27
|
+
async function createState(method) {
|
|
28
|
+
return (await Promise.resolve().then(() => __importStar(require(`./record_${method}`)))).default;
|
|
29
|
+
}
|
|
30
|
+
exports.createState = createState;
|
|
26
31
|
async function initial(recordContext) {
|
|
27
32
|
const choices = {
|
|
28
33
|
'test cases': 'test',
|
|
@@ -36,7 +41,7 @@ async function initial(recordContext) {
|
|
|
36
41
|
});
|
|
37
42
|
const method = choices[methodName];
|
|
38
43
|
recordContext.recordMethod = method;
|
|
39
|
-
return
|
|
44
|
+
return createState.bind(null, method);
|
|
40
45
|
}
|
|
41
46
|
exports.default = initial;
|
|
42
47
|
//# sourceMappingURL=initial.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"initial.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/initial.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"initial.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/initial.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4EAAuC;AAIhC,KAAK,UAAU,WAAW,CAAC,MAAc;IAC9C,OAAO,CAAC,wDAAa,YAAY,MAAM,EAAE,GAAC,CAAC,CAAC,OAAO,CAAC;AACtD,CAAC;AAFD,kCAEC;AAEc,KAAK,UAAU,OAAO,CACnC,aAA4B;IAE5B,MAAM,OAAO,GAAG;QACd,YAAY,EAAE,MAAM;QACpB,kBAAkB,EAAE,QAAQ;KAC7B,CAAC;IAEF,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,yBAAE,CAAC,MAAM,CAAC;QAC7C,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,0BAA0B;QACnC,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;KAC9B,CAAC,CAAC;IACH,MAAM,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAEnC,aAAa,CAAC,YAAY,GAAG,MAAM,CAAC;IACpC,OAAO,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;AACxC,CAAC;AAlBD,0BAkBC"}
|
|
@@ -11,9 +11,9 @@ const agentNotAvailable_1 = __importDefault(require("./agentNotAvailable"));
|
|
|
11
11
|
// This is the initial state of remote recording. From here, the connection to the AppMap
|
|
12
12
|
// agent must be configured and verified, and then the recording will be run.
|
|
13
13
|
async function remote(recordContext) {
|
|
14
|
-
|
|
15
|
-
if (await (0, isAgentAvailable_1.default)()) {
|
|
16
|
-
if (!(await (0, isRecordingInProgress_1.default)())) {
|
|
14
|
+
recordContext.populateURL();
|
|
15
|
+
if (await (0, isAgentAvailable_1.default)(recordContext)) {
|
|
16
|
+
if (!(await (0, isRecordingInProgress_1.default)(recordContext))) {
|
|
17
17
|
return agentAvailableAndReady_1.default;
|
|
18
18
|
}
|
|
19
19
|
else {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"record_remote.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/record_remote.ts"],"names":[],"mappings":";;;;;AAAA,gFAAwD;AACxD,0FAAkE;AAClE,sFAA8D;AAC9D,0EAAkD;AAClD,4EAAoD;AAIpD,yFAAyF;AACzF,6EAA6E;AAC9D,KAAK,UAAU,MAAM,CAClC,aAA4B;IAE5B,
|
|
1
|
+
{"version":3,"file":"record_remote.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/record_remote.ts"],"names":[],"mappings":";;;;;AAAA,gFAAwD;AACxD,0FAAkE;AAClE,sFAA8D;AAC9D,0EAAkD;AAClD,4EAAoD;AAIpD,yFAAyF;AACzF,6EAA6E;AAC9D,KAAK,UAAU,MAAM,CAClC,aAA4B;IAE5B,aAAa,CAAC,WAAW,EAAE,CAAC;IAC5B,IAAI,MAAM,IAAA,0BAAgB,EAAC,aAAa,CAAC,EAAE;QACzC,IAAI,CAAC,CAAC,MAAM,IAAA,+BAAqB,EAAC,aAAa,CAAC,CAAC,EAAE;YACjD,OAAO,gCAAsB,CAAC;SAC/B;aAAM;YACL,OAAO,0BAAgB,CAAC;SACzB;KACF;SAAM;QACL,OAAO,2BAAiB,CAAC;KAC1B;AACH,CAAC;AAbD,yBAaC"}
|
|
@@ -9,8 +9,8 @@ const testCommandsAvailable_1 = __importDefault(require("./testCommandsAvailable
|
|
|
9
9
|
// This is the initial state of test case recording. From here, the record command is
|
|
10
10
|
// configured by the user and executed.
|
|
11
11
|
async function test(recordContext) {
|
|
12
|
-
if (await (0, areTestCommandsConfigured_1.default)()) {
|
|
13
|
-
|
|
12
|
+
if (await (0, areTestCommandsConfigured_1.default)(recordContext)) {
|
|
13
|
+
recordContext.populateTestCommands();
|
|
14
14
|
return testCommandsAvailable_1.default;
|
|
15
15
|
}
|
|
16
16
|
else {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"record_test.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/record_test.ts"],"names":[],"mappings":";;;;;AAAA,kGAA0E;AAE1E,8EAAsD;AACtD,oFAA4D;AAG5D,qFAAqF;AACrF,uCAAuC;AACxB,KAAK,UAAU,IAAI,CAChC,aAA4B;IAE5B,IAAI,MAAM,IAAA,mCAAyB,
|
|
1
|
+
{"version":3,"file":"record_test.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/record_test.ts"],"names":[],"mappings":";;;;;AAAA,kGAA0E;AAE1E,8EAAsD;AACtD,oFAA4D;AAG5D,qFAAqF;AACrF,uCAAuC;AACxB,KAAK,UAAU,IAAI,CAChC,aAA4B;IAE5B,IAAI,MAAM,IAAA,mCAAyB,EAAC,aAAa,CAAC,EAAE;QAClD,aAAa,CAAC,oBAAoB,EAAE,CAAC;QAErC,OAAO,+BAAqB,CAAC;KAC9B;SAAM;QACL,OAAO,4BAAkB,CAAC;KAC3B;AACH,CAAC;AAVD,uBAUC"}
|
|
@@ -3,22 +3,25 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const assert_1 = __importDefault(require("assert"));
|
|
6
7
|
const chalk_1 = __importDefault(require("chalk"));
|
|
7
|
-
const openTicket_1 = require("../../../lib/ticket/openTicket");
|
|
8
|
+
const openTicket_1 = __importDefault(require("../../../lib/ticket/openTicket"));
|
|
8
9
|
const userInteraction_1 = __importDefault(require("../../userInteraction"));
|
|
9
10
|
const printAppMapCount_1 = __importDefault(require("../action/printAppMapCount"));
|
|
10
11
|
async function testCasesComplete(recordContext) {
|
|
12
|
+
var _a;
|
|
11
13
|
// Handle command failures here, rather than in a separate state, so we maintain compatibility
|
|
12
14
|
// with the Azure Function that processes telemetry events.
|
|
13
15
|
if (recordContext.failures > 0 || recordContext.appMapsCreated === 0) {
|
|
14
16
|
userInteraction_1.default.warn(`\n${chalk_1.default.yellow('!')} The test commands failed to create AppMaps\n`);
|
|
15
|
-
const errors = recordContext.output ||
|
|
16
|
-
|
|
17
|
-
Test command failed with no output
|
|
18
|
-
|
|
19
|
-
await (0, openTicket_1.
|
|
17
|
+
const errors = ((_a = recordContext.output) === null || _a === void 0 ? void 0 : _a.join('\n').length) > 0
|
|
18
|
+
? recordContext.output
|
|
19
|
+
: `[Test command failed with no output]`;
|
|
20
|
+
const helpMsg = ` If you want assistance, the test command, error message, exit code, and APPMAP environment variables can be uploaded securely to the AppMap ZenDesk support portal.`;
|
|
21
|
+
await (0, openTicket_1.default)(errors, helpMsg);
|
|
20
22
|
return;
|
|
21
23
|
}
|
|
24
|
+
(0, assert_1.default)(recordContext.appMapDir);
|
|
22
25
|
await (0, printAppMapCount_1.default)(recordContext.appMapDir);
|
|
23
26
|
return;
|
|
24
27
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"testCasesComplete.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/testCasesComplete.ts"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAC1B
|
|
1
|
+
{"version":3,"file":"testCasesComplete.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/testCasesComplete.ts"],"names":[],"mappings":";;;;;AAAA,oDAA4B;AAC5B,kDAA0B;AAC1B,gFAAwD;AACxD,4EAAuC;AACvC,kFAA0D;AAG3C,KAAK,UAAU,iBAAiB,CAC7C,aAA4B;;IAE5B,8FAA8F;IAC9F,2DAA2D;IAC3D,IAAI,aAAa,CAAC,QAAQ,GAAG,CAAC,IAAI,aAAa,CAAC,cAAc,KAAK,CAAC,EAAE;QACpE,yBAAE,CAAC,IAAI,CACL,KAAK,eAAK,CAAC,MAAM,CAAC,GAAG,CAAC,+CAA+C,CACtE,CAAC;QAEF,MAAM,MAAM,GACV,CAAA,MAAA,aAAa,CAAC,MAAM,0CAAE,IAAI,CAAC,IAAI,EAAE,MAAM,IAAG,CAAC;YACzC,CAAC,CAAC,aAAa,CAAC,MAAM;YACtB,CAAC,CAAC,sCAAsC,CAAC;QAC7C,MAAM,OAAO,GAAG,sKAAsK,CAAC;QACvL,MAAM,IAAA,oBAAU,EAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAElC,OAAO;KACR;IAED,IAAA,gBAAM,EAAC,aAAa,CAAC,SAAS,CAAC,CAAC;IAChC,MAAM,IAAA,0BAAgB,EAAC,aAAa,CAAC,SAAS,CAAC,CAAC;IAEhD,OAAO;AACT,CAAC;AAxBD,oCAwBC"}
|
|
@@ -7,7 +7,7 @@ const startTestCases_1 = __importDefault(require("../action/startTestCases"));
|
|
|
7
7
|
const testCasesRunning_1 = __importDefault(require("./testCasesRunning"));
|
|
8
8
|
// Test cases are available and configured.
|
|
9
9
|
async function testCommandsAvailable(recordContext) {
|
|
10
|
-
await (0, startTestCases_1.default)();
|
|
10
|
+
await (0, startTestCases_1.default)(recordContext);
|
|
11
11
|
await recordContext.populateMaxTime();
|
|
12
12
|
return testCasesRunning_1.default;
|
|
13
13
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"testCommandsAvailable.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/testCommandsAvailable.ts"],"names":[],"mappings":";;;;;AAAA,8EAAsD;AACtD,0EAAkD;AAIlD,2CAA2C;AAC5B,KAAK,UAAU,qBAAqB,CACjD,aAA4B;IAE5B,MAAM,IAAA,wBAAc,
|
|
1
|
+
{"version":3,"file":"testCommandsAvailable.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/testCommandsAvailable.ts"],"names":[],"mappings":";;;;;AAAA,8EAAsD;AACtD,0EAAkD;AAIlD,2CAA2C;AAC5B,KAAK,UAAU,qBAAqB,CACjD,aAA4B;IAE5B,MAAM,IAAA,wBAAc,EAAC,aAAa,CAAC,CAAC;IAEpC,MAAM,aAAa,CAAC,eAAe,EAAE,CAAC;IAEtC,OAAO,0BAAgB,CAAC;AAC1B,CAAC;AARD,wCAQC"}
|
|
@@ -6,8 +6,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
const obtainTestCommands_1 = __importDefault(require("../prompt/obtainTestCommands"));
|
|
7
7
|
const testCommandsAvailable_1 = __importDefault(require("./testCommandsAvailable"));
|
|
8
8
|
async function testCommandsNeeded(recordContext) {
|
|
9
|
-
await (0, obtainTestCommands_1.default)();
|
|
10
|
-
|
|
9
|
+
await (0, obtainTestCommands_1.default)(recordContext);
|
|
10
|
+
recordContext.populateTestCommands();
|
|
11
11
|
return testCommandsAvailable_1.default;
|
|
12
12
|
}
|
|
13
13
|
exports.default = testCommandsNeeded;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"testCommandsNeeded.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/testCommandsNeeded.ts"],"names":[],"mappings":";;;;;AAAA,sFAA8D;AAG9D,oFAA4D;AAE7C,KAAK,UAAU,kBAAkB,CAC9C,aAA4B;IAE5B,MAAM,IAAA,4BAAkB,
|
|
1
|
+
{"version":3,"file":"testCommandsNeeded.js","sourceRoot":"","sources":["../../../../src/cmds/record/state/testCommandsNeeded.ts"],"names":[],"mappings":";;;;;AAAA,sFAA8D;AAG9D,oFAA4D;AAE7C,KAAK,UAAU,kBAAkB,CAC9C,aAA4B;IAE5B,MAAM,IAAA,4BAAkB,EAAC,aAAa,CAAC,CAAC;IAExC,aAAa,CAAC,oBAAoB,EAAE,CAAC;IAErC,OAAO,+BAAqB,CAAC;AAC/B,CAAC;AARD,qCAQC"}
|
|
@@ -4,10 +4,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
const userInteraction_1 = __importDefault(require("../../userInteraction"));
|
|
7
|
-
const configuration_1 = require("../configuration");
|
|
8
7
|
const testCaseRecording_1 = __importDefault(require("../testCaseRecording"));
|
|
9
|
-
async function areTestCasesConfigured() {
|
|
10
|
-
let testCommands =
|
|
8
|
+
async function areTestCasesConfigured({ configuration, }) {
|
|
9
|
+
let testCommands = configuration.configOption('test_recording.test_commands', []);
|
|
11
10
|
if (testCommands && testCommands.length > 0) {
|
|
12
11
|
userInteraction_1.default.progress(`The following test commands were provided by your AppMap configuration (appmap.yml):`);
|
|
13
12
|
userInteraction_1.default.progress(``);
|
|
@@ -22,7 +21,8 @@ async function areTestCasesConfigured() {
|
|
|
22
21
|
message: 'Use these test commands?',
|
|
23
22
|
});
|
|
24
23
|
if (!useTestCommands) {
|
|
25
|
-
|
|
24
|
+
configuration.setConfigOption('test_recording.test_commands', []);
|
|
25
|
+
await configuration.write();
|
|
26
26
|
}
|
|
27
27
|
return useTestCommands;
|
|
28
28
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"areTestCommandsConfigured.js","sourceRoot":"","sources":["../../../../src/cmds/record/test/areTestCommandsConfigured.ts"],"names":[],"mappings":";;;;;AAAA,4EAAuC;
|
|
1
|
+
{"version":3,"file":"areTestCommandsConfigured.js","sourceRoot":"","sources":["../../../../src/cmds/record/test/areTestCommandsConfigured.ts"],"names":[],"mappings":";;;;;AAAA,4EAAuC;AAGvC,6EAAqD;AAEtC,KAAK,UAAU,sBAAsB,CAAC,EACnD,aAAa,GACC;IACd,IAAI,YAAY,GAA8B,aAAa,CAAC,YAAY,CACtE,8BAA8B,EAC9B,EAAE,CACc,CAAC;IAEnB,IAAI,YAAY,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE;QAC3C,yBAAE,CAAC,QAAQ,CACT,sFAAsF,CACvF,CAAC;QACF,yBAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAChB,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE;YACtC,WAAW,CAAC,GAAG,KAAf,WAAW,CAAC,GAAG,GAAK,EAAE,EAAC;YACvB,yBAAE,CAAC,QAAQ,CACT,GAAG,2BAAiB,CAAC,SAAS,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,OAAO,EAAE,CACxE,CAAC;SACH;QACD,yBAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAEhB,MAAM,EAAE,eAAe,EAAE,GAAG,MAAM,yBAAE,CAAC,MAAM,CAAC;YAC1C,IAAI,EAAE,iBAAiB;YACvB,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,0BAA0B;SACpC,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,EAAE;YACpB,aAAa,CAAC,eAAe,CAAC,8BAA8B,EAAE,EAAE,CAAC,CAAC;YAClE,MAAM,aAAa,CAAC,KAAK,EAAE,CAAC;SAC7B;QAED,OAAO,eAAe,CAAC;KACxB;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AApCD,yCAoCC"}
|
|
@@ -4,11 +4,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
const userInteraction_1 = __importDefault(require("../../userInteraction"));
|
|
7
|
-
const
|
|
7
|
+
const makeRequest_1 = require("../makeRequest");
|
|
8
8
|
const remoteRecording_1 = __importDefault(require("../remoteRecording"));
|
|
9
|
-
async function isAgentAvailable() {
|
|
10
|
-
const
|
|
11
|
-
const
|
|
9
|
+
async function isAgentAvailable(recordContext) {
|
|
10
|
+
const { configuration } = recordContext;
|
|
11
|
+
const ro = configuration.requestOptions();
|
|
12
|
+
const location = configuration.locationString();
|
|
12
13
|
userInteraction_1.default.status = `Checking if the AppMap agent is available at ${location}`;
|
|
13
14
|
try {
|
|
14
15
|
await new remoteRecording_1.default(ro).status();
|
|
@@ -16,7 +17,13 @@ async function isAgentAvailable() {
|
|
|
16
17
|
return true;
|
|
17
18
|
}
|
|
18
19
|
catch (e) {
|
|
19
|
-
|
|
20
|
+
if (e instanceof makeRequest_1.RemoteRecordingError) {
|
|
21
|
+
recordContext.remoteError = e;
|
|
22
|
+
}
|
|
23
|
+
userInteraction_1.default.error(`AppMap agent is not available at ${location}.`);
|
|
24
|
+
if (await userInteraction_1.default.confirm(`Would you like to see the server's response?`)) {
|
|
25
|
+
userInteraction_1.default.error(e.toString());
|
|
26
|
+
}
|
|
20
27
|
return false;
|
|
21
28
|
}
|
|
22
29
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isAgentAvailable.js","sourceRoot":"","sources":["../../../../src/cmds/record/test/isAgentAvailable.ts"],"names":[],"mappings":";;;;;AAAA,4EAAuC;AACvC,
|
|
1
|
+
{"version":3,"file":"isAgentAvailable.js","sourceRoot":"","sources":["../../../../src/cmds/record/test/isAgentAvailable.ts"],"names":[],"mappings":";;;;;AAAA,4EAAuC;AACvC,gDAAsD;AAEtD,yEAAiD;AAElC,KAAK,UAAU,gBAAgB,CAC5C,aAA4B;IAE5B,MAAM,EAAE,aAAa,EAAE,GAAG,aAAa,CAAC;IACxC,MAAM,EAAE,GAAG,aAAa,CAAC,cAAc,EAAE,CAAC;IAC1C,MAAM,QAAQ,GAAG,aAAa,CAAC,cAAc,EAAE,CAAC;IAChD,yBAAE,CAAC,MAAM,GAAG,gDAAgD,QAAQ,EAAE,CAAC;IACvE,IAAI;QACF,MAAM,IAAI,yBAAe,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;QACvC,yBAAE,CAAC,OAAO,CAAC,gCAAgC,QAAQ,EAAE,CAAC,CAAC;QACvD,OAAO,IAAI,CAAC;KACb;IAAC,OAAO,CAAM,EAAE;QACf,IAAI,CAAC,YAAY,kCAAoB,EAAE;YACrC,aAAa,CAAC,WAAW,GAAG,CAAC,CAAC;SAC/B;QACD,yBAAE,CAAC,KAAK,CAAC,oCAAoC,QAAQ,GAAG,CAAC,CAAC;QAC1D,IAAI,MAAM,yBAAE,CAAC,OAAO,CAAC,8CAA8C,CAAC,EAAE;YACpE,yBAAE,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;SACxB;QACD,OAAO,KAAK,CAAC;KACd;AACH,CAAC;AArBD,mCAqBC"}
|
|
@@ -3,10 +3,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const configuration_1 = require("../configuration");
|
|
7
6
|
const remoteRecording_1 = __importDefault(require("../remoteRecording"));
|
|
8
|
-
async function isRecordingInProgress() {
|
|
9
|
-
const status = await new remoteRecording_1.default(
|
|
7
|
+
async function isRecordingInProgress({ configuration, }) {
|
|
8
|
+
const status = await new remoteRecording_1.default(configuration.requestOptions()).status();
|
|
10
9
|
return status.enabled === true;
|
|
11
10
|
}
|
|
12
11
|
exports.default = isRecordingInProgress;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isRecordingInProgress.js","sourceRoot":"","sources":["../../../../src/cmds/record/test/isRecordingInProgress.ts"],"names":[],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"isRecordingInProgress.js","sourceRoot":"","sources":["../../../../src/cmds/record/test/isRecordingInProgress.ts"],"names":[],"mappings":";;;;;AACA,yEAAiD;AAElC,KAAK,UAAU,qBAAqB,CAAC,EAClD,aAAa,GACC;IACd,MAAM,MAAM,GAAG,MAAM,IAAI,yBAAe,CACtC,aAAa,CAAC,cAAc,EAAE,CAC/B,CAAC,MAAM,EAAE,CAAC;IACX,OAAO,MAAM,CAAC,OAAO,KAAK,IAAI,CAAC;AACjC,CAAC;AAPD,wCAOC"}
|
|
@@ -7,7 +7,6 @@ const child_process_1 = require("child_process");
|
|
|
7
7
|
const process_1 = require("process");
|
|
8
8
|
const utils_1 = require("../../utils");
|
|
9
9
|
const userInteraction_1 = __importDefault(require("../userInteraction"));
|
|
10
|
-
const configuration_1 = require("./configuration");
|
|
11
10
|
const recordContext_1 = require("./recordContext");
|
|
12
11
|
let TestCommands = [];
|
|
13
12
|
let TestCaseProcesses = [];
|
|
@@ -15,14 +14,14 @@ const DiagnosticCommands = {
|
|
|
15
14
|
Gemfile: ['ruby -v', 'bundle info rails', 'bundle info actionpack'],
|
|
16
15
|
};
|
|
17
16
|
class TestCaseRecording {
|
|
18
|
-
static async start() {
|
|
17
|
+
static async start({ configuration }) {
|
|
19
18
|
TestCaseProcesses.forEach((process) => {
|
|
20
19
|
if (process.pid)
|
|
21
20
|
(0, process_1.kill)(process.pid);
|
|
22
21
|
});
|
|
23
22
|
TestCommands = [];
|
|
24
23
|
TestCaseProcesses = [];
|
|
25
|
-
let testCommands =
|
|
24
|
+
let testCommands = configuration.configOption('test_recording.test_commands', []);
|
|
26
25
|
if (testCommands.length === 0)
|
|
27
26
|
throw new Error(`No test commands are configured`);
|
|
28
27
|
if ((0, utils_1.verbose)()) {
|
|
@@ -46,7 +45,7 @@ class TestCaseRecording {
|
|
|
46
45
|
TestCommands = testCommands;
|
|
47
46
|
}
|
|
48
47
|
static async waitFor(ctx) {
|
|
49
|
-
let maxTime =
|
|
48
|
+
let maxTime = ctx.configuration.setting('test_recording.max_time', -1);
|
|
50
49
|
if (maxTime === -1)
|
|
51
50
|
maxTime = undefined;
|
|
52
51
|
if (maxTime)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"testCaseRecording.js","sourceRoot":"","sources":["../../../src/cmds/record/testCaseRecording.ts"],"names":[],"mappings":";;;;;AAAA,iDAA0D;AAC1D,qCAAyC;AACzC,uCAA8C;AAC9C,yEAAoC;
|
|
1
|
+
{"version":3,"file":"testCaseRecording.js","sourceRoot":"","sources":["../../../src/cmds/record/testCaseRecording.ts"],"names":[],"mappings":"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"}
|
package/built/cmds/runCommand.js
CHANGED
|
@@ -65,7 +65,9 @@ async function runCommand(commandPrefix, fn) {
|
|
|
65
65
|
flushTelemetry(exitCode_1.ExitCode.Error, err);
|
|
66
66
|
}
|
|
67
67
|
else {
|
|
68
|
-
//
|
|
68
|
+
// You'll wind up here if the object thrown wasn't an instance of Error. An obvious way this
|
|
69
|
+
// can happen is `throw 'Fail'`. A less obvious way is rejecting a Promise with something
|
|
70
|
+
// other than an error, e.g. `reject('Fail')`.
|
|
69
71
|
throw err;
|
|
70
72
|
}
|
|
71
73
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runCommand.js","sourceRoot":"","sources":["../../src/cmds/runCommand.ts"],"names":[],"mappings":";;;;;AAAA,qCAAuD;AACvD,oCAAmC;AACnC,wEAAmC;AACnC,kDAA0B;AAC1B,kDAAuC;AACvC,sDAAmD;AACnD,6DAAqC;AAErC,KAAK,UAAU,aAAa,KAAI,CAAC;AAEjC,SAAS,cAAc,CAAC,QAAkB,EAAE,GAAW;IACrD,mBAAS,CAAC,KAAK,CAAC,GAAG,EAAE;QACnB,wBAAwB;QACxB,0CAA0C;QAC1C,yDAAyD;QACzD,eAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAU,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;AACL,CAAC;AAEc,KAAK,UAAU,UAAU,CACtC,aAAqB,EACrB,EAAsB;IAEtB,IAAI;QACF,MAAM,EAAE,EAAE,CAAC;QAEX,mBAAS,CAAC,SAAS,CAAC;YAClB,IAAI,EAAE,GAAG,aAAa,UAAU;SACjC,CAAC,CAAC;QAEH,cAAc,CAAC,CAAC,CAAC,CAAC;KACnB;IAAC,OAAO,GAAG,EAAE;QACZ,IAAI,GAAG,YAAY,wBAAe,EAAE;YAClC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YAE1B,mBAAS,CAAC,SAAS,CAAC;gBAClB,IAAI,EAAE,GAAG,aAAa,mBAAmB;gBACzC,UAAU,EAAE;oBACV,KAAK,EAAE,GAAG,CAAC,OAAO;iBACnB;aACF,CAAC,CAAC;YAEH,OAAO,cAAc,CAAC,mBAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SAC5C;aAAM,IAAI,GAAG,YAAY,mBAAU,EAAE;YACpC,mBAAS,CAAC,SAAS,CAAC;gBAClB,IAAI,EAAE,GAAG,aAAa,QAAQ;gBAC9B,UAAU,EAAE;oBACV,KAAK,EAAE,GAAG,CAAC,OAAO;iBACnB;aACF,CAAC,CAAC;YAEH,OAAO,cAAc,CAAC,mBAAQ,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SAC3C;aAAM,IAAI,GAAG,YAAY,KAAK,EAAE;YAC/B,mBAAS,CAAC,SAAS,CAAC;gBAClB,IAAI,EAAE,GAAG,aAAa,QAAQ;gBAC9B,UAAU,EAAE;oBACV,YAAY,EAAE,GAAG,CAAC,OAAO;oBACzB,UAAU,EAAE,GAAG,CAAC,KAAK;iBACtB;aACF,CAAC,CAAC;YAEH,IAAI,IAAA,eAAO,GAAE,EAAE;gBACb,yBAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;aACf;iBAAM;gBACL,yBAAE,CAAC,KAAK,CAAC,sBAAsB,GAAG,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBAChE,yBAAE,CAAC,KAAK,CACN,uCAAuC,eAAK,CAAC,GAAG,CAC9C,SAAS,CACV,UAAU,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAC/B,CAAC;aACH;YACD,cAAc,CAAC,mBAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SACrC;aAAM;YACL,
|
|
1
|
+
{"version":3,"file":"runCommand.js","sourceRoot":"","sources":["../../src/cmds/runCommand.ts"],"names":[],"mappings":";;;;;AAAA,qCAAuD;AACvD,oCAAmC;AACnC,wEAAmC;AACnC,kDAA0B;AAC1B,kDAAuC;AACvC,sDAAmD;AACnD,6DAAqC;AAErC,KAAK,UAAU,aAAa,KAAI,CAAC;AAEjC,SAAS,cAAc,CAAC,QAAkB,EAAE,GAAW;IACrD,mBAAS,CAAC,KAAK,CAAC,GAAG,EAAE;QACnB,wBAAwB;QACxB,0CAA0C;QAC1C,yDAAyD;QACzD,eAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAU,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;AACL,CAAC;AAEc,KAAK,UAAU,UAAU,CACtC,aAAqB,EACrB,EAAsB;IAEtB,IAAI;QACF,MAAM,EAAE,EAAE,CAAC;QAEX,mBAAS,CAAC,SAAS,CAAC;YAClB,IAAI,EAAE,GAAG,aAAa,UAAU;SACjC,CAAC,CAAC;QAEH,cAAc,CAAC,CAAC,CAAC,CAAC;KACnB;IAAC,OAAO,GAAG,EAAE;QACZ,IAAI,GAAG,YAAY,wBAAe,EAAE;YAClC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YAE1B,mBAAS,CAAC,SAAS,CAAC;gBAClB,IAAI,EAAE,GAAG,aAAa,mBAAmB;gBACzC,UAAU,EAAE;oBACV,KAAK,EAAE,GAAG,CAAC,OAAO;iBACnB;aACF,CAAC,CAAC;YAEH,OAAO,cAAc,CAAC,mBAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SAC5C;aAAM,IAAI,GAAG,YAAY,mBAAU,EAAE;YACpC,mBAAS,CAAC,SAAS,CAAC;gBAClB,IAAI,EAAE,GAAG,aAAa,QAAQ;gBAC9B,UAAU,EAAE;oBACV,KAAK,EAAE,GAAG,CAAC,OAAO;iBACnB;aACF,CAAC,CAAC;YAEH,OAAO,cAAc,CAAC,mBAAQ,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SAC3C;aAAM,IAAI,GAAG,YAAY,KAAK,EAAE;YAC/B,mBAAS,CAAC,SAAS,CAAC;gBAClB,IAAI,EAAE,GAAG,aAAa,QAAQ;gBAC9B,UAAU,EAAE;oBACV,YAAY,EAAE,GAAG,CAAC,OAAO;oBACzB,UAAU,EAAE,GAAG,CAAC,KAAK;iBACtB;aACF,CAAC,CAAC;YAEH,IAAI,IAAA,eAAO,GAAE,EAAE;gBACb,yBAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;aACf;iBAAM;gBACL,yBAAE,CAAC,KAAK,CAAC,sBAAsB,GAAG,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBAChE,yBAAE,CAAC,KAAK,CACN,uCAAuC,eAAK,CAAC,GAAG,CAC9C,SAAS,CACV,UAAU,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAC/B,CAAC;aACH;YACD,cAAc,CAAC,mBAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SACrC;aAAM;YACL,4FAA4F;YAC5F,yFAAyF;YACzF,8CAA8C;YAC9C,MAAM,GAAG,CAAC;SACX;KACF;AACH,CAAC;AA5DD,6BA4DC"}
|
|
@@ -3,29 +3,29 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.openTicket = void 0;
|
|
7
6
|
const chalk_1 = __importDefault(require("chalk"));
|
|
8
7
|
const userInteraction_1 = __importDefault(require("../../cmds/userInteraction"));
|
|
9
8
|
const telemetry_1 = __importDefault(require("../../telemetry"));
|
|
10
|
-
const zendesk_1 = require("./zendesk");
|
|
11
|
-
async function openTicket(errors) {
|
|
9
|
+
const zendesk_1 = __importDefault(require("./zendesk"));
|
|
10
|
+
async function openTicket(errors, helpMsg = ' ', prompt = true) {
|
|
12
11
|
var _a;
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
12
|
+
errors = !Array.isArray(errors) ? [errors] : errors;
|
|
13
|
+
userInteraction_1.default.progress(`
|
|
14
|
+
Help is available from the AppMap support team!${helpMsg}
|
|
15
|
+
`);
|
|
16
|
+
if (await userInteraction_1.default.confirm(`Details of the error will be provided to the support team.
|
|
17
|
+
Would you like to see them?`)) {
|
|
18
|
+
userInteraction_1.default.error(errors.join('\n'));
|
|
19
|
+
}
|
|
20
|
+
if (prompt) {
|
|
21
|
+
const message = `Would you like to open a support request?`;
|
|
22
|
+
const { openTicket } = await userInteraction_1.default.prompt({
|
|
23
|
+
type: 'confirm',
|
|
24
|
+
name: 'openTicket',
|
|
25
|
+
default: true,
|
|
26
|
+
message,
|
|
27
|
+
});
|
|
28
|
+
if (!openTicket) {
|
|
29
29
|
userInteraction_1.default.progress([
|
|
30
30
|
`
|
|
31
31
|
You've elected not to open a support request for this problem.
|
|
@@ -36,25 +36,19 @@ If you change your mind, you can always reach us by email: support@appmap.io
|
|
|
36
36
|
telemetry_1.default.sendEvent({
|
|
37
37
|
name: 'open-ticket:declined',
|
|
38
38
|
});
|
|
39
|
-
return
|
|
39
|
+
return;
|
|
40
40
|
}
|
|
41
|
-
const { email } = await userInteraction_1.default.prompt([
|
|
42
|
-
{
|
|
43
|
-
name: 'email',
|
|
44
|
-
message: 'Please provide your email address, so that we can contact you with a response:',
|
|
45
|
-
validate: (v) => v.trim().length > 0 || 'Please enter your email address',
|
|
46
|
-
},
|
|
47
|
-
]);
|
|
48
|
-
return {
|
|
49
|
-
email,
|
|
50
|
-
openTicket: true,
|
|
51
|
-
};
|
|
52
|
-
});
|
|
53
|
-
if (!openTicket) {
|
|
54
|
-
return;
|
|
55
41
|
}
|
|
42
|
+
const { email } = await userInteraction_1.default.prompt([
|
|
43
|
+
{
|
|
44
|
+
name: 'email',
|
|
45
|
+
message: `The AppMap team will respond to you by email.
|
|
46
|
+
Please provide your email address to open the support request:`,
|
|
47
|
+
validate: (v) => v.trim().length > 0 || 'Please enter your email address',
|
|
48
|
+
},
|
|
49
|
+
]);
|
|
56
50
|
try {
|
|
57
|
-
const id = await (0, zendesk_1.
|
|
51
|
+
const id = await (0, zendesk_1.default)(errors, email);
|
|
58
52
|
telemetry_1.default.sendEvent({
|
|
59
53
|
name: 'open-ticket:success',
|
|
60
54
|
});
|
|
@@ -87,5 +81,5 @@ Please monitor your email for updates. Thank you for using AppMap!`, 'left');
|
|
|
87
81
|
${chalk_1.default.red('!')} This problem has been reported to the AppMap team.`);
|
|
88
82
|
}
|
|
89
83
|
}
|
|
90
|
-
exports.
|
|
84
|
+
exports.default = openTicket;
|
|
91
85
|
//# sourceMappingURL=openTicket.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"openTicket.js","sourceRoot":"","sources":["../../../src/lib/ticket/openTicket.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"openTicket.js","sourceRoot":"","sources":["../../../src/lib/ticket/openTicket.ts"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,iFAA4C;AAC5C,gEAAwC;AACxC,wDAA6C;AAE9B,KAAK,UAAU,UAAU,CACtC,MAAyB,EACzB,UAAkB,GAAG,EACrB,SAAkB,IAAI;;IAEtB,MAAM,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IAEpD,yBAAE,CAAC,QAAQ,CAAC;iDACmC,OAAO;CACvD,CAAC,CAAC;IAED,IACE,MAAM,yBAAE,CAAC,OAAO,CAAC;8BACS,CAAC,EAC3B;QACA,yBAAE,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;KAC7B;IAED,IAAI,MAAM,EAAE;QACV,MAAM,OAAO,GAAG,2CAA2C,CAAC;QAC5D,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,yBAAE,CAAC,MAAM,CAAC;YACrC,IAAI,EAAE,SAAS;YACf,IAAI,EAAE,YAAY;YAClB,OAAO,EAAE,IAAI;YACb,OAAO;SACR,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,EAAE;YACf,yBAAE,CAAC,QAAQ,CACT;gBACE;;;;CAIT;aACQ,CAAC,IAAI,CAAC,IAAI,CAAC,CACb,CAAC;YAEF,mBAAS,CAAC,SAAS,CAAC;gBAClB,IAAI,EAAE,sBAAsB;aAC7B,CAAC,CAAC;YAEH,OAAO;SACR;KACF;IAED,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,yBAAE,CAAC,MAAM,CAAC;QAChC;YACE,IAAI,EAAE,OAAO;YACb,OAAO,EAAE;+DACgD;YACzD,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,IAAI,iCAAiC;SAC1E;KACF,CAAC,CAAC;IAEH,IAAI;QACF,MAAM,EAAE,GAAG,MAAM,IAAA,iBAAoB,EAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACrD,mBAAS,CAAC,SAAS,CAAC;YAClB,IAAI,EAAE,qBAAqB;SAC5B,CAAC,CAAC;QACH,yBAAE,CAAC,OAAO,CACR;;SAEG,EAAE;;mEAEwD,EAC7D,MAAM,CACP,CAAC;KACH;IAAC,OAAO,CAAC,EAAE;QACV,MAAM,EAAE,GAAG,CAAc,CAAC;QAC1B,MAAM,QAAQ,GAAG,EAAE,CAAC,QAAQ,CAAC;QAC7B,IAAI,SAAiB,CAAC;QACtB,IAAI,KAAK,GAAuB,SAAS,CAAC;QAC1C,IAAI,QAAQ,EAAE;YACZ,SAAS,GAAG,eACV,CAAA,MAAA,EAAE,CAAC,QAAQ,0CAAE,MAAM,MAAK,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,OAC/C,EAAE,CAAC;YACH,KAAK,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;SAC7B;aAAM;YACL,SAAS,GAAG,yBAAyB,CAAC;SACvC;QACD,mBAAS,CAAC,SAAS,CAAC;YAClB,IAAI,EAAE,SAAS;YACf,UAAU,EAAE;gBACV,KAAK;aACN;SACF,CAAC,CAAC;QACH,yBAAE,CAAC,KAAK,CACN,GAAG,eAAK,CAAC,GAAG,CAAC,GAAG,CAAC;;EAErB,eAAK,CAAC,GAAG,CAAC,GAAG,CAAC,qDAAqD,CAChE,CAAC;KACH;AACH,CAAC;AA7FD,6BA6FC"}
|
|
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.
|
|
6
|
+
exports.APPMAP_SUPPORT_URL = void 0;
|
|
7
7
|
// There is a Zendesk API client: https://github.com/blakmatrix/node-zendesk . It appears to have
|
|
8
8
|
// some issues, notably incomplete typing (https://github.com/blakmatrix/node-zendesk/issues/251).
|
|
9
9
|
// We're only making a single API call here, so just use Axios instead.
|
|
@@ -31,6 +31,7 @@ const debugAdapter = async (config) => {
|
|
|
31
31
|
});
|
|
32
32
|
};
|
|
33
33
|
async function createRequest(errors, email) {
|
|
34
|
+
errors = !Array.isArray(errors) ? [errors] : errors;
|
|
34
35
|
const body = JSON.stringify({
|
|
35
36
|
request: {
|
|
36
37
|
comment: {
|
|
@@ -81,5 +82,5 @@ ${errors.map((e) => `===\n${(0, strip_ansi_1.default)(e)}\n===`).join('\n')}`,
|
|
|
81
82
|
});
|
|
82
83
|
}
|
|
83
84
|
}
|
|
84
|
-
exports.
|
|
85
|
+
exports.default = createRequest;
|
|
85
86
|
//# sourceMappingURL=zendesk.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"zendesk.js","sourceRoot":"","sources":["../../../src/lib/ticket/zendesk.ts"],"names":[],"mappings":";;;;;;AAAA,iGAAiG;AACjG,kGAAkG;AAClG,uEAAuE;AACvE,kDAA8D;AAE9D,4DAAmC;AACnC,8CAA8C;AAEjC,QAAA,kBAAkB,GAC7B,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,6BAA6B,CAAC;AAElE,iGAAiG;AACjG,iEAAiE;AACjE,MAAM,YAAY,GAAG,KAAK,EAAE,MAA0B,EAAgB,EAAE;IACtE,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC5B,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC3B,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QAErC,MAAM,QAAQ,GAAG;YACf,IAAI,EAAE,6CAA6C;YACnD,MAAM,EAAE,GAAG;YACX,UAAU,EAAE,IAAI;YAChB,OAAO,EAAE,EAAE;YACX,MAAM;YACN,OAAO,EAAE,EAAE;SACZ,CAAC;QACF,OAAO,CAAC,QAAQ,CAAC,CAAC;IACpB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"zendesk.js","sourceRoot":"","sources":["../../../src/lib/ticket/zendesk.ts"],"names":[],"mappings":"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"}
|