-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun.ts
96 lines (81 loc) · 3.23 KB
/
run.ts
1
2
3
4
5
6
7
8
9
10
11
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
40
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/*
* Copyright (c) 2024, salesforce.com, inc.
* All rights reserved.
* Licensed under the BSD 3-Clause license.
* For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause
*/
import { SfCommand, Flags } from '@salesforce/sf-plugins-core';
import { Messages } from '@salesforce/core';
import { AgentTester } from '@salesforce/agents';
import { colorize } from '@oclif/core/ux';
import { resultFormatFlag, testOutputDirFlag } from '../../../flags.js';
import { AgentTestCache } from '../../../agentTestCache.js';
import { TestStages } from '../../../testStages.js';
import { handleTestResults } from '../../../handleTestResults.js';
Messages.importMessagesDirectoryFromMetaUrl(import.meta.url);
const messages = Messages.loadMessages('@salesforce/plugin-agent', 'agent.test.run');
// TODO: this should include details and status
export type AgentTestRunResult = {
aiEvaluationId: string;
status: string;
};
export default class AgentTestRun extends SfCommand<AgentTestRunResult> {
public static readonly summary = messages.getMessage('summary');
public static readonly description = messages.getMessage('description');
public static readonly examples = messages.getMessages('examples');
public static readonly state = 'beta';
public static readonly flags = {
'target-org': Flags.requiredOrg(),
'api-version': Flags.orgApiVersion(),
name: Flags.string({
char: 'n',
required: true,
summary: messages.getMessage('flags.name.summary'),
}),
// we want to pass `undefined` to the API
// eslint-disable-next-line sf-plugin/flag-min-max-default
wait: Flags.duration({
char: 'w',
unit: 'minutes',
min: 1,
summary: messages.getMessage('flags.wait.summary'),
}),
'result-format': resultFormatFlag(),
'output-dir': testOutputDirFlag(),
};
public async run(): Promise<AgentTestRunResult> {
const { flags } = await this.parse(AgentTestRun);
const mso = new TestStages({ title: `Agent Test Run: ${flags.name}`, jsonEnabled: this.jsonEnabled() });
mso.start();
const agentTester = new AgentTester(flags['target-org'].getConnection(flags['api-version']));
const response = await agentTester.start(flags.name);
mso.update({ id: response.aiEvaluationId });
const agentTestCache = await AgentTestCache.create();
await agentTestCache.createCacheEntry(response.aiEvaluationId, flags.name);
if (flags.wait?.minutes) {
const { completed, response: detailsResponse } = await mso.poll(agentTester, response.aiEvaluationId, flags.wait);
if (completed) await agentTestCache.removeCacheEntry(response.aiEvaluationId);
mso.stop();
await handleTestResults({
id: response.aiEvaluationId,
format: flags['result-format'],
results: detailsResponse,
jsonEnabled: this.jsonEnabled(),
outputDir: flags['output-dir'],
});
return {
status: 'COMPLETED',
aiEvaluationId: response.aiEvaluationId,
};
} else {
mso.stop();
this.log(
`Run ${colorize(
'dim',
`sf agent test resume --job-id ${response.aiEvaluationId}`
)} to resuming watching this test.`
);
}
return response;
}
}