promptfoo 0.47.0 → 0.48.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/README.md +2 -0
- package/dist/drizzle/0000_lush_hellion.sql +36 -0
- package/dist/drizzle/0001_wide_calypso.sql +3 -0
- package/dist/drizzle/meta/0000_snapshot.json +244 -0
- package/dist/drizzle/meta/0001_snapshot.json +237 -0
- package/dist/drizzle/meta/_journal.json +20 -0
- package/dist/package.json +10 -3
- package/dist/src/__mocks__/database.d.ts +5 -0
- package/dist/src/__mocks__/database.d.ts.map +1 -0
- package/dist/src/__mocks__/database.js +27 -0
- package/dist/src/__mocks__/database.js.map +1 -0
- package/dist/src/commands/list.d.ts.map +1 -1
- package/dist/src/commands/list.js +4 -5
- package/dist/src/commands/list.js.map +1 -1
- package/dist/src/commands/show.d.ts +1 -1
- package/dist/src/commands/show.d.ts.map +1 -1
- package/dist/src/commands/show.js +7 -7
- package/dist/src/commands/show.js.map +1 -1
- package/dist/src/csv.d.ts +1 -1
- package/dist/src/csv.d.ts.map +1 -1
- package/dist/src/csv.js +5 -0
- package/dist/src/csv.js.map +1 -1
- package/dist/src/database.d.ts +238 -0
- package/dist/src/database.d.ts.map +1 -0
- package/dist/src/database.js +141 -0
- package/dist/src/database.js.map +1 -0
- package/dist/src/evaluator.d.ts.map +1 -1
- package/dist/src/evaluator.js +8 -6
- package/dist/src/evaluator.js.map +1 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +2 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/main.js +6 -4
- package/dist/src/main.js.map +1 -1
- package/dist/src/migrate.d.ts +5 -0
- package/dist/src/migrate.d.ts.map +1 -0
- package/dist/src/migrate.js +50 -0
- package/dist/src/migrate.js.map +1 -0
- package/dist/src/prompts.d.ts.map +1 -1
- package/dist/src/prompts.js +3 -0
- package/dist/src/prompts.js.map +1 -1
- package/dist/src/providers/azureopenai.d.ts +2 -0
- package/dist/src/providers/azureopenai.d.ts.map +1 -1
- package/dist/src/providers/azureopenai.js +4 -2
- package/dist/src/providers/azureopenai.js.map +1 -1
- package/dist/src/providers.d.ts.map +1 -1
- package/dist/src/providers.js +2 -1
- package/dist/src/providers.js.map +1 -1
- package/dist/src/types.d.ts +5 -6
- package/dist/src/types.d.ts.map +1 -1
- package/dist/src/util.d.ts +46 -19
- package/dist/src/util.d.ts.map +1 -1
- package/dist/src/util.js +363 -121
- package/dist/src/util.js.map +1 -1
- package/dist/src/web/nextui/404/index.html +1 -1
- package/dist/src/web/nextui/404.html +1 -1
- package/dist/src/web/nextui/_next/static/chunks/952-ede6b209625d42a2.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/app/datasets/page-ad55f89d622ef8e7.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/app/prompts/page-01ab4878803b7068.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/app/setup/page-9c163111247d8da5.js +1 -0
- package/dist/src/web/nextui/api/results +1 -1
- package/dist/src/web/nextui/auth/login/index.html +1 -1
- package/dist/src/web/nextui/auth/login/index.txt +1 -1
- package/dist/src/web/nextui/auth/signup/index.html +1 -1
- package/dist/src/web/nextui/auth/signup/index.txt +1 -1
- package/dist/src/web/nextui/datasets/index.html +1 -1
- package/dist/src/web/nextui/datasets/index.txt +2 -2
- package/dist/src/web/nextui/eval/index.html +1 -1
- package/dist/src/web/nextui/eval/index.txt +2 -2
- package/dist/src/web/nextui/index.html +1 -1
- package/dist/src/web/nextui/index.txt +1 -1
- package/dist/src/web/nextui/prompts/index.html +1 -1
- package/dist/src/web/nextui/prompts/index.txt +2 -2
- package/dist/src/web/nextui/setup/index.html +1 -1
- package/dist/src/web/nextui/setup/index.txt +2 -2
- package/dist/src/web/server.d.ts +1 -1
- package/dist/src/web/server.d.ts.map +1 -1
- package/dist/src/web/server.js +25 -43
- package/dist/src/web/server.js.map +1 -1
- package/package.json +10 -3
- package/dist/src/web/nextui/_next/static/chunks/952-1367984f076e3060.js +0 -1
- package/dist/src/web/nextui/_next/static/chunks/app/datasets/page-44ab188f3b846712.js +0 -1
- package/dist/src/web/nextui/_next/static/chunks/app/prompts/page-0bf3409d6a6bfa22.js +0 -1
- package/dist/src/web/nextui/_next/static/chunks/app/setup/page-83c7e62787113081.js +0 -1
- /package/dist/src/web/nextui/_next/static/{kWF8sUISiIgB0hKr0muJH → 8yxA5JzS0wXTxJptFRKTo}/_buildManifest.js +0 -0
- /package/dist/src/web/nextui/_next/static/{kWF8sUISiIgB0hKr0muJH → 8yxA5JzS0wXTxJptFRKTo}/_ssgManifest.js +0 -0
|
@@ -20,10 +20,9 @@ function listCommand(program) {
|
|
|
20
20
|
name: 'list evals',
|
|
21
21
|
});
|
|
22
22
|
await telemetry_1.default.send();
|
|
23
|
-
const evals = (0, util_1.getEvals)();
|
|
23
|
+
const evals = await (0, util_1.getEvals)();
|
|
24
24
|
const tableData = evals.map((evl) => ({
|
|
25
|
-
'Eval ID': evl.id
|
|
26
|
-
Filename: evl.filePath,
|
|
25
|
+
'Eval ID': evl.id,
|
|
27
26
|
Prompts: evl.results.table.head.prompts.map((p) => (0, util_1.sha256)(p.raw).slice(0, 6)).join(', '),
|
|
28
27
|
Vars: evl.results.table.head.vars.map((v) => v).join(', '),
|
|
29
28
|
}));
|
|
@@ -41,7 +40,7 @@ function listCommand(program) {
|
|
|
41
40
|
name: 'list prompts',
|
|
42
41
|
});
|
|
43
42
|
await telemetry_1.default.send();
|
|
44
|
-
const prompts = (0, util_1.getPrompts)().sort((a, b) => b.recentEvalId.localeCompare(a.recentEvalId));
|
|
43
|
+
const prompts = (await (0, util_1.getPrompts)()).sort((a, b) => b.recentEvalId.localeCompare(a.recentEvalId));
|
|
45
44
|
const tableData = prompts.map((prompt) => ({
|
|
46
45
|
'Prompt ID': prompt.id.slice(0, 6),
|
|
47
46
|
Raw: prompt.prompt.raw.slice(0, 100) + (prompt.prompt.raw.length > 100 ? '...' : ''),
|
|
@@ -62,7 +61,7 @@ function listCommand(program) {
|
|
|
62
61
|
name: 'list datasets',
|
|
63
62
|
});
|
|
64
63
|
await telemetry_1.default.send();
|
|
65
|
-
const datasets = (0, util_1.getTestCases)().sort((a, b) => b.recentEvalId.localeCompare(a.recentEvalId));
|
|
64
|
+
const datasets = (await (0, util_1.getTestCases)()).sort((a, b) => b.recentEvalId.localeCompare(a.recentEvalId));
|
|
66
65
|
const tableData = datasets.map((dataset) => ({
|
|
67
66
|
'Dataset ID': dataset.id.slice(0, 6),
|
|
68
67
|
'Highest scoring prompt': dataset.prompts
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/list.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAG1B,kCAAkF;AAClF,oCAAqC;AACrC,uDAA+B;AAC/B,6DAAqC;AAErC,SAAgB,WAAW,CAAC,OAAgB;IAC1C,MAAM,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,WAAW,CAAC,wBAAwB,CAAC,CAAC;IAElF,WAAW;SACR,OAAO,CAAC,OAAO,CAAC;SAChB,WAAW,CAAC,mBAAmB,CAAC;SAChC,MAAM,CAAC,KAAK,IAAI,EAAE;QACjB,mBAAS,CAAC,eAAe,EAAE,CAAC;QAC5B,mBAAS,CAAC,MAAM,CAAC,cAAc,EAAE;YAC/B,IAAI,EAAE,YAAY;SACnB,CAAC,CAAC;QACH,MAAM,mBAAS,CAAC,IAAI,EAAE,CAAC;QAEvB,MAAM,KAAK,GAAG,IAAA,eAAQ,GAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/list.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"show.d.ts","sourceRoot":"","sources":["../../../src/commands/show.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAOpC,
|
|
1
|
+
{"version":3,"file":"show.d.ts","sourceRoot":"","sources":["../../../src/commands/show.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAOpC,wBAAsB,WAAW,CAAC,OAAO,EAAE,OAAO,iBAqCjD"}
|
|
@@ -9,20 +9,20 @@ const util_1 = require("../util");
|
|
|
9
9
|
const table_1 = require("../table");
|
|
10
10
|
const logger_1 = __importDefault(require("../logger"));
|
|
11
11
|
const telemetry_1 = __importDefault(require("../telemetry"));
|
|
12
|
-
function showCommand(program) {
|
|
12
|
+
async function showCommand(program) {
|
|
13
13
|
const showCommand = program
|
|
14
14
|
.command('show <id>')
|
|
15
15
|
.description('Show details of a specific resource')
|
|
16
16
|
.action(async (id) => {
|
|
17
|
-
const evl = (0, util_1.getEvalFromHash)(id);
|
|
17
|
+
const evl = await (0, util_1.getEvalFromHash)(id);
|
|
18
18
|
if (evl) {
|
|
19
19
|
return handleEval(id);
|
|
20
20
|
}
|
|
21
|
-
const prompt = (0, util_1.getPromptFromHash)(id);
|
|
21
|
+
const prompt = await (0, util_1.getPromptFromHash)(id);
|
|
22
22
|
if (prompt) {
|
|
23
23
|
return handlePrompt(id);
|
|
24
24
|
}
|
|
25
|
-
const dataset = (0, util_1.getDatasetFromHash)(id);
|
|
25
|
+
const dataset = await (0, util_1.getDatasetFromHash)(id);
|
|
26
26
|
if (dataset) {
|
|
27
27
|
return handleDataset(id);
|
|
28
28
|
}
|
|
@@ -48,7 +48,7 @@ async function handleEval(id) {
|
|
|
48
48
|
name: 'show eval',
|
|
49
49
|
});
|
|
50
50
|
await telemetry_1.default.send();
|
|
51
|
-
const evl = (0, util_1.getEvalFromHash)(id);
|
|
51
|
+
const evl = await (0, util_1.getEvalFromHash)(id);
|
|
52
52
|
if (!evl) {
|
|
53
53
|
logger_1.default.error(`No evaluation found with ID ${id}`);
|
|
54
54
|
return;
|
|
@@ -72,7 +72,7 @@ async function handlePrompt(id) {
|
|
|
72
72
|
name: 'show prompt',
|
|
73
73
|
});
|
|
74
74
|
await telemetry_1.default.send();
|
|
75
|
-
const prompt = (0, util_1.getPromptFromHash)(id);
|
|
75
|
+
const prompt = await (0, util_1.getPromptFromHash)(id);
|
|
76
76
|
if (!prompt) {
|
|
77
77
|
logger_1.default.error(`Prompt with ID ${id} not found.`);
|
|
78
78
|
return;
|
|
@@ -109,7 +109,7 @@ async function handleDataset(id) {
|
|
|
109
109
|
name: 'show dataset',
|
|
110
110
|
});
|
|
111
111
|
await telemetry_1.default.send();
|
|
112
|
-
const dataset = (0, util_1.getDatasetFromHash)(id);
|
|
112
|
+
const dataset = await (0, util_1.getDatasetFromHash)(id);
|
|
113
113
|
if (!dataset) {
|
|
114
114
|
logger_1.default.error(`Dataset with ID ${id} not found.`);
|
|
115
115
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"show.js","sourceRoot":"","sources":["../../../src/commands/show.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAG1B,kCAA8F;AAC9F,oCAAoD;AACpD,uDAA+B;AAC/B,6DAAqC;
|
|
1
|
+
{"version":3,"file":"show.js","sourceRoot":"","sources":["../../../src/commands/show.ts"],"names":[],"mappings":"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"}
|
package/dist/src/csv.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { Assertion, CsvRow, TestCase } from
|
|
1
|
+
import type { Assertion, CsvRow, TestCase } from './types';
|
|
2
2
|
export declare function testCaseFromCsvRow(row: CsvRow): TestCase;
|
|
3
3
|
export declare function assertionFromString(expected: string): Assertion;
|
|
4
4
|
//# sourceMappingURL=csv.d.ts.map
|
package/dist/src/csv.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"csv.d.ts","sourceRoot":"","sources":["../../src/csv.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAiB,MAAM,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAI1E,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,
|
|
1
|
+
{"version":3,"file":"csv.d.ts","sourceRoot":"","sources":["../../src/csv.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAiB,MAAM,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAI1E,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,CA2BxD;AAED,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,SAAS,CAiG/D"}
|
package/dist/src/csv.js
CHANGED
|
@@ -7,6 +7,7 @@ function testCaseFromCsvRow(row) {
|
|
|
7
7
|
const vars = {};
|
|
8
8
|
const asserts = [];
|
|
9
9
|
const options = {};
|
|
10
|
+
let description;
|
|
10
11
|
for (const [key, value] of Object.entries(row)) {
|
|
11
12
|
if (key.startsWith('__expected')) {
|
|
12
13
|
if (value.trim() !== '') {
|
|
@@ -19,6 +20,9 @@ function testCaseFromCsvRow(row) {
|
|
|
19
20
|
else if (key === '__suffix') {
|
|
20
21
|
options.suffix = value;
|
|
21
22
|
}
|
|
23
|
+
else if (key === '__description') {
|
|
24
|
+
description = value;
|
|
25
|
+
}
|
|
22
26
|
else {
|
|
23
27
|
vars[key] = value;
|
|
24
28
|
}
|
|
@@ -27,6 +31,7 @@ function testCaseFromCsvRow(row) {
|
|
|
27
31
|
vars,
|
|
28
32
|
assert: asserts,
|
|
29
33
|
options,
|
|
34
|
+
...(description ? { description } : {}),
|
|
30
35
|
};
|
|
31
36
|
}
|
|
32
37
|
exports.testCaseFromCsvRow = testCaseFromCsvRow;
|
package/dist/src/csv.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"csv.js","sourceRoot":"","sources":["../../src/csv.ts"],"names":[],"mappings":";AAAA,sEAAsE;;;AAItE,MAAM,qCAAqC,GAAG,GAAG,CAAC;AAElD,SAAgB,kBAAkB,CAAC,GAAW;IAC5C,MAAM,IAAI,GAA2B,EAAE,CAAC;IACxC,MAAM,OAAO,GAAgB,EAAE,CAAC;IAChC,MAAM,OAAO,GAAwB,EAAE,CAAC;IACxC,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QAC9C,IAAI,GAAG,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE;YAChC,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBACvB,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;aAC1C;SACF;aAAM,IAAI,GAAG,KAAK,UAAU,EAAE;YAC7B,OAAO,CAAC,MAAM,GAAG,KAAK,CAAC;SACxB;aAAM,IAAI,GAAG,KAAK,UAAU,EAAE;YAC7B,OAAO,CAAC,MAAM,GAAG,KAAK,CAAC;SACxB;aAAM;YACL,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;SACnB;KACF;IAED,OAAO;QACL,IAAI;QACJ,MAAM,EAAE,OAAO;QACf,OAAO;
|
|
1
|
+
{"version":3,"file":"csv.js","sourceRoot":"","sources":["../../src/csv.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
import type { EvaluateSummary, UnifiedConfig } from './types';
|
|
2
|
+
export declare const prompts: import("drizzle-orm/sqlite-core").SQLiteTableWithColumns<{
|
|
3
|
+
name: "prompts";
|
|
4
|
+
schema: undefined;
|
|
5
|
+
columns: {
|
|
6
|
+
id: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
7
|
+
name: "id";
|
|
8
|
+
tableName: "prompts";
|
|
9
|
+
dataType: "string";
|
|
10
|
+
columnType: "SQLiteText";
|
|
11
|
+
data: string;
|
|
12
|
+
driverParam: string;
|
|
13
|
+
notNull: true;
|
|
14
|
+
hasDefault: false;
|
|
15
|
+
enumValues: [string, ...string[]];
|
|
16
|
+
baseColumn: never;
|
|
17
|
+
}, object>;
|
|
18
|
+
createdAt: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
19
|
+
name: "created_at";
|
|
20
|
+
tableName: "prompts";
|
|
21
|
+
dataType: "number";
|
|
22
|
+
columnType: "SQLiteInteger";
|
|
23
|
+
data: number;
|
|
24
|
+
driverParam: number;
|
|
25
|
+
notNull: true;
|
|
26
|
+
hasDefault: true;
|
|
27
|
+
enumValues: undefined;
|
|
28
|
+
baseColumn: never;
|
|
29
|
+
}, object>;
|
|
30
|
+
prompt: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
31
|
+
name: "prompt";
|
|
32
|
+
tableName: "prompts";
|
|
33
|
+
dataType: "string";
|
|
34
|
+
columnType: "SQLiteText";
|
|
35
|
+
data: string;
|
|
36
|
+
driverParam: string;
|
|
37
|
+
notNull: true;
|
|
38
|
+
hasDefault: false;
|
|
39
|
+
enumValues: [string, ...string[]];
|
|
40
|
+
baseColumn: never;
|
|
41
|
+
}, object>;
|
|
42
|
+
};
|
|
43
|
+
dialect: "sqlite";
|
|
44
|
+
}>;
|
|
45
|
+
export declare const promptsRelations: import("drizzle-orm").Relations<"prompts", {
|
|
46
|
+
evalsToPrompts: import("drizzle-orm").Many<"evals_to_prompts">;
|
|
47
|
+
}>;
|
|
48
|
+
export declare const datasets: import("drizzle-orm/sqlite-core").SQLiteTableWithColumns<{
|
|
49
|
+
name: "datasets";
|
|
50
|
+
schema: undefined;
|
|
51
|
+
columns: {
|
|
52
|
+
id: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
53
|
+
name: "id";
|
|
54
|
+
tableName: "datasets";
|
|
55
|
+
dataType: "string";
|
|
56
|
+
columnType: "SQLiteText";
|
|
57
|
+
data: string;
|
|
58
|
+
driverParam: string;
|
|
59
|
+
notNull: true;
|
|
60
|
+
hasDefault: false;
|
|
61
|
+
enumValues: [string, ...string[]];
|
|
62
|
+
baseColumn: never;
|
|
63
|
+
}, object>;
|
|
64
|
+
tests: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
65
|
+
name: "tests";
|
|
66
|
+
tableName: "datasets";
|
|
67
|
+
dataType: "json";
|
|
68
|
+
columnType: "SQLiteTextJson";
|
|
69
|
+
data: string | (string | import("./types").TestCase<Record<string, string | object | string[]>>)[];
|
|
70
|
+
driverParam: string;
|
|
71
|
+
notNull: false;
|
|
72
|
+
hasDefault: false;
|
|
73
|
+
enumValues: undefined;
|
|
74
|
+
baseColumn: never;
|
|
75
|
+
}, object>;
|
|
76
|
+
createdAt: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
77
|
+
name: "created_at";
|
|
78
|
+
tableName: "datasets";
|
|
79
|
+
dataType: "number";
|
|
80
|
+
columnType: "SQLiteInteger";
|
|
81
|
+
data: number;
|
|
82
|
+
driverParam: number;
|
|
83
|
+
notNull: true;
|
|
84
|
+
hasDefault: true;
|
|
85
|
+
enumValues: undefined;
|
|
86
|
+
baseColumn: never;
|
|
87
|
+
}, object>;
|
|
88
|
+
};
|
|
89
|
+
dialect: "sqlite";
|
|
90
|
+
}>;
|
|
91
|
+
export declare const datasetsRelations: import("drizzle-orm").Relations<"datasets", {
|
|
92
|
+
evalsToDatasets: import("drizzle-orm").Many<"evals_to_datasets">;
|
|
93
|
+
}>;
|
|
94
|
+
export declare const evals: import("drizzle-orm/sqlite-core").SQLiteTableWithColumns<{
|
|
95
|
+
name: "evals";
|
|
96
|
+
schema: undefined;
|
|
97
|
+
columns: {
|
|
98
|
+
id: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
99
|
+
name: "id";
|
|
100
|
+
tableName: "evals";
|
|
101
|
+
dataType: "string";
|
|
102
|
+
columnType: "SQLiteText";
|
|
103
|
+
data: string;
|
|
104
|
+
driverParam: string;
|
|
105
|
+
notNull: true;
|
|
106
|
+
hasDefault: false;
|
|
107
|
+
enumValues: [string, ...string[]];
|
|
108
|
+
baseColumn: never;
|
|
109
|
+
}, object>;
|
|
110
|
+
createdAt: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
111
|
+
name: "created_at";
|
|
112
|
+
tableName: "evals";
|
|
113
|
+
dataType: "number";
|
|
114
|
+
columnType: "SQLiteInteger";
|
|
115
|
+
data: number;
|
|
116
|
+
driverParam: number;
|
|
117
|
+
notNull: true;
|
|
118
|
+
hasDefault: true;
|
|
119
|
+
enumValues: undefined;
|
|
120
|
+
baseColumn: never;
|
|
121
|
+
}, object>;
|
|
122
|
+
description: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
123
|
+
name: "description";
|
|
124
|
+
tableName: "evals";
|
|
125
|
+
dataType: "string";
|
|
126
|
+
columnType: "SQLiteText";
|
|
127
|
+
data: string;
|
|
128
|
+
driverParam: string;
|
|
129
|
+
notNull: false;
|
|
130
|
+
hasDefault: false;
|
|
131
|
+
enumValues: [string, ...string[]];
|
|
132
|
+
baseColumn: never;
|
|
133
|
+
}, object>;
|
|
134
|
+
results: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
135
|
+
name: "results";
|
|
136
|
+
tableName: "evals";
|
|
137
|
+
dataType: "json";
|
|
138
|
+
columnType: "SQLiteTextJson";
|
|
139
|
+
data: EvaluateSummary;
|
|
140
|
+
driverParam: string;
|
|
141
|
+
notNull: true;
|
|
142
|
+
hasDefault: false;
|
|
143
|
+
enumValues: undefined;
|
|
144
|
+
baseColumn: never;
|
|
145
|
+
}, object>;
|
|
146
|
+
config: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
147
|
+
name: "config";
|
|
148
|
+
tableName: "evals";
|
|
149
|
+
dataType: "json";
|
|
150
|
+
columnType: "SQLiteTextJson";
|
|
151
|
+
data: Partial<UnifiedConfig>;
|
|
152
|
+
driverParam: string;
|
|
153
|
+
notNull: true;
|
|
154
|
+
hasDefault: false;
|
|
155
|
+
enumValues: undefined;
|
|
156
|
+
baseColumn: never;
|
|
157
|
+
}, object>;
|
|
158
|
+
};
|
|
159
|
+
dialect: "sqlite";
|
|
160
|
+
}>;
|
|
161
|
+
export declare const evalsRelations: import("drizzle-orm").Relations<"evals", {
|
|
162
|
+
evalsToPrompts: import("drizzle-orm").Many<"evals_to_prompts">;
|
|
163
|
+
evalsToDatasets: import("drizzle-orm").Many<"evals_to_datasets">;
|
|
164
|
+
}>;
|
|
165
|
+
export declare const evalsToPrompts: import("drizzle-orm/sqlite-core").SQLiteTableWithColumns<{
|
|
166
|
+
name: "evals_to_prompts";
|
|
167
|
+
schema: undefined;
|
|
168
|
+
columns: {
|
|
169
|
+
evalId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
170
|
+
name: "eval_id";
|
|
171
|
+
tableName: "evals_to_prompts";
|
|
172
|
+
dataType: "string";
|
|
173
|
+
columnType: "SQLiteText";
|
|
174
|
+
data: string;
|
|
175
|
+
driverParam: string;
|
|
176
|
+
notNull: true;
|
|
177
|
+
hasDefault: false;
|
|
178
|
+
enumValues: [string, ...string[]];
|
|
179
|
+
baseColumn: never;
|
|
180
|
+
}, object>;
|
|
181
|
+
promptId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
182
|
+
name: "prompt_id";
|
|
183
|
+
tableName: "evals_to_prompts";
|
|
184
|
+
dataType: "string";
|
|
185
|
+
columnType: "SQLiteText";
|
|
186
|
+
data: string;
|
|
187
|
+
driverParam: string;
|
|
188
|
+
notNull: true;
|
|
189
|
+
hasDefault: false;
|
|
190
|
+
enumValues: [string, ...string[]];
|
|
191
|
+
baseColumn: never;
|
|
192
|
+
}, object>;
|
|
193
|
+
};
|
|
194
|
+
dialect: "sqlite";
|
|
195
|
+
}>;
|
|
196
|
+
export declare const evalsToPromptsRelations: import("drizzle-orm").Relations<"evals_to_prompts", {
|
|
197
|
+
eval: import("drizzle-orm").One<"evals", true>;
|
|
198
|
+
prompt: import("drizzle-orm").One<"prompts", true>;
|
|
199
|
+
}>;
|
|
200
|
+
export declare const evalsToDatasets: import("drizzle-orm/sqlite-core").SQLiteTableWithColumns<{
|
|
201
|
+
name: "evals_to_datasets";
|
|
202
|
+
schema: undefined;
|
|
203
|
+
columns: {
|
|
204
|
+
evalId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
205
|
+
name: "eval_id";
|
|
206
|
+
tableName: "evals_to_datasets";
|
|
207
|
+
dataType: "string";
|
|
208
|
+
columnType: "SQLiteText";
|
|
209
|
+
data: string;
|
|
210
|
+
driverParam: string;
|
|
211
|
+
notNull: true;
|
|
212
|
+
hasDefault: false;
|
|
213
|
+
enumValues: [string, ...string[]];
|
|
214
|
+
baseColumn: never;
|
|
215
|
+
}, object>;
|
|
216
|
+
datasetId: import("drizzle-orm/sqlite-core").SQLiteColumn<{
|
|
217
|
+
name: "dataset_id";
|
|
218
|
+
tableName: "evals_to_datasets";
|
|
219
|
+
dataType: "string";
|
|
220
|
+
columnType: "SQLiteText";
|
|
221
|
+
data: string;
|
|
222
|
+
driverParam: string;
|
|
223
|
+
notNull: true;
|
|
224
|
+
hasDefault: false;
|
|
225
|
+
enumValues: [string, ...string[]];
|
|
226
|
+
baseColumn: never;
|
|
227
|
+
}, object>;
|
|
228
|
+
};
|
|
229
|
+
dialect: "sqlite";
|
|
230
|
+
}>;
|
|
231
|
+
export declare const evalsToDatasetsRelations: import("drizzle-orm").Relations<"evals_to_datasets", {
|
|
232
|
+
eval: import("drizzle-orm").One<"evals", true>;
|
|
233
|
+
dataset: import("drizzle-orm").One<"datasets", true>;
|
|
234
|
+
}>;
|
|
235
|
+
export declare function getDbPath(): string;
|
|
236
|
+
export declare function getDbSignalPath(): string;
|
|
237
|
+
export declare function getDb(): import("drizzle-orm/better-sqlite3").BetterSQLite3Database<Record<string, unknown>>;
|
|
238
|
+
//# sourceMappingURL=database.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database.d.ts","sourceRoot":"","sources":["../../src/database.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAI9D,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAIlB,CAAC;AAEH,eAAO,MAAM,gBAAgB;;EAE1B,CAAC;AAIJ,eAAO,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAInB,CAAC;AAEH,eAAO,MAAM,iBAAiB;;EAE3B,CAAC;AAIJ,eAAO,MAAM,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAMhB,CAAC;AAEH,eAAO,MAAM,cAAc;;;EAGxB,CAAC;AAEJ,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAa1B,CAAC;AAEF,eAAO,MAAM,uBAAuB;;;EASjC,CAAC;AAEJ,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAa3B,CAAC;AAEF,eAAO,MAAM,wBAAwB;;;EASlC,CAAC;AA+CJ,wBAAgB,SAAS,WAExB;AAED,wBAAgB,eAAe,WAE9B;AAED,wBAAgB,KAAK,wFAMpB"}
|
|
@@ -0,0 +1,141 @@
|
|
|
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.getDb = exports.getDbSignalPath = exports.getDbPath = exports.evalsToDatasetsRelations = exports.evalsToDatasets = exports.evalsToPromptsRelations = exports.evalsToPrompts = exports.evalsRelations = exports.evals = exports.datasetsRelations = exports.datasets = exports.promptsRelations = exports.prompts = void 0;
|
|
7
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
8
|
+
const drizzle_orm_1 = require("drizzle-orm");
|
|
9
|
+
const sqlite_core_1 = require("drizzle-orm/sqlite-core");
|
|
10
|
+
const better_sqlite3_1 = require("drizzle-orm/better-sqlite3");
|
|
11
|
+
const better_sqlite3_2 = __importDefault(require("better-sqlite3"));
|
|
12
|
+
const util_1 = require("./util");
|
|
13
|
+
// ------------ Prompts ------------
|
|
14
|
+
exports.prompts = (0, sqlite_core_1.sqliteTable)('prompts', {
|
|
15
|
+
id: (0, sqlite_core_1.text)('id').primaryKey(),
|
|
16
|
+
createdAt: (0, sqlite_core_1.integer)('created_at').notNull().default((0, drizzle_orm_1.sql) `CURRENT_TIMESTAMP`),
|
|
17
|
+
prompt: (0, sqlite_core_1.text)('prompt').notNull(),
|
|
18
|
+
});
|
|
19
|
+
exports.promptsRelations = (0, drizzle_orm_1.relations)(exports.prompts, ({ many }) => ({
|
|
20
|
+
evalsToPrompts: many(exports.evalsToPrompts),
|
|
21
|
+
}));
|
|
22
|
+
// ------------ Datasets ------------
|
|
23
|
+
exports.datasets = (0, sqlite_core_1.sqliteTable)('datasets', {
|
|
24
|
+
id: (0, sqlite_core_1.text)('id').primaryKey(),
|
|
25
|
+
tests: (0, sqlite_core_1.text)('tests', { mode: 'json' }).$type(),
|
|
26
|
+
createdAt: (0, sqlite_core_1.integer)('created_at').notNull().default((0, drizzle_orm_1.sql) `CURRENT_TIMESTAMP`),
|
|
27
|
+
});
|
|
28
|
+
exports.datasetsRelations = (0, drizzle_orm_1.relations)(exports.datasets, ({ many }) => ({
|
|
29
|
+
evalsToDatasets: many(exports.evalsToDatasets),
|
|
30
|
+
}));
|
|
31
|
+
// ------------ Evals ------------
|
|
32
|
+
exports.evals = (0, sqlite_core_1.sqliteTable)('evals', {
|
|
33
|
+
id: (0, sqlite_core_1.text)('id').primaryKey(),
|
|
34
|
+
createdAt: (0, sqlite_core_1.integer)('created_at').notNull().default((0, drizzle_orm_1.sql) `CURRENT_TIMESTAMP`),
|
|
35
|
+
description: (0, sqlite_core_1.text)('description'),
|
|
36
|
+
results: (0, sqlite_core_1.text)('results', { mode: 'json' }).$type().notNull(),
|
|
37
|
+
config: (0, sqlite_core_1.text)('config', { mode: 'json' }).$type().notNull(),
|
|
38
|
+
});
|
|
39
|
+
exports.evalsRelations = (0, drizzle_orm_1.relations)(exports.evals, ({ many }) => ({
|
|
40
|
+
evalsToPrompts: many(exports.evalsToPrompts),
|
|
41
|
+
evalsToDatasets: many(exports.evalsToDatasets),
|
|
42
|
+
}));
|
|
43
|
+
exports.evalsToPrompts = (0, sqlite_core_1.sqliteTable)('evals_to_prompts', {
|
|
44
|
+
evalId: (0, sqlite_core_1.text)('eval_id')
|
|
45
|
+
.notNull()
|
|
46
|
+
.references(() => exports.evals.id),
|
|
47
|
+
promptId: (0, sqlite_core_1.text)('prompt_id')
|
|
48
|
+
.notNull()
|
|
49
|
+
.references(() => exports.prompts.id),
|
|
50
|
+
}, (t) => ({
|
|
51
|
+
pk: (0, sqlite_core_1.primaryKey)({ columns: [t.evalId, t.promptId] }),
|
|
52
|
+
}));
|
|
53
|
+
exports.evalsToPromptsRelations = (0, drizzle_orm_1.relations)(exports.evalsToPrompts, ({ one }) => ({
|
|
54
|
+
eval: one(exports.evals, {
|
|
55
|
+
fields: [exports.evalsToPrompts.evalId],
|
|
56
|
+
references: [exports.evals.id],
|
|
57
|
+
}),
|
|
58
|
+
prompt: one(exports.prompts, {
|
|
59
|
+
fields: [exports.evalsToPrompts.promptId],
|
|
60
|
+
references: [exports.prompts.id],
|
|
61
|
+
}),
|
|
62
|
+
}));
|
|
63
|
+
exports.evalsToDatasets = (0, sqlite_core_1.sqliteTable)('evals_to_datasets', {
|
|
64
|
+
evalId: (0, sqlite_core_1.text)('eval_id')
|
|
65
|
+
.notNull()
|
|
66
|
+
.references(() => exports.evals.id),
|
|
67
|
+
datasetId: (0, sqlite_core_1.text)('dataset_id')
|
|
68
|
+
.notNull()
|
|
69
|
+
.references(() => exports.datasets.id),
|
|
70
|
+
}, (t) => ({
|
|
71
|
+
pk: (0, sqlite_core_1.primaryKey)({ columns: [t.evalId, t.datasetId] }),
|
|
72
|
+
}));
|
|
73
|
+
exports.evalsToDatasetsRelations = (0, drizzle_orm_1.relations)(exports.evalsToDatasets, ({ one }) => ({
|
|
74
|
+
eval: one(exports.evals, {
|
|
75
|
+
fields: [exports.evalsToDatasets.evalId],
|
|
76
|
+
references: [exports.evals.id],
|
|
77
|
+
}),
|
|
78
|
+
dataset: one(exports.datasets, {
|
|
79
|
+
fields: [exports.evalsToDatasets.datasetId],
|
|
80
|
+
references: [exports.datasets.id],
|
|
81
|
+
}),
|
|
82
|
+
}));
|
|
83
|
+
// ------------ Outputs ------------
|
|
84
|
+
// We're just recording these on eval.results for now...
|
|
85
|
+
/*
|
|
86
|
+
export const llmOutputs = sqliteTable(
|
|
87
|
+
'llm_outputs',
|
|
88
|
+
{
|
|
89
|
+
id: text('id')
|
|
90
|
+
.notNull()
|
|
91
|
+
.unique(),
|
|
92
|
+
createdAt: integer('created_at').notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
93
|
+
evalId: text('eval_id')
|
|
94
|
+
.notNull()
|
|
95
|
+
.references(() => evals.id),
|
|
96
|
+
promptId: text('prompt_id')
|
|
97
|
+
.notNull()
|
|
98
|
+
.references(() => prompts.id),
|
|
99
|
+
providerId: text('provider_id').notNull(),
|
|
100
|
+
vars: text('vars', {mode: 'json'}),
|
|
101
|
+
response: text('response', {mode: 'json'}),
|
|
102
|
+
error: text('error'),
|
|
103
|
+
latencyMs: integer('latency_ms'),
|
|
104
|
+
gradingResult: text('grading_result', {mode: 'json'}),
|
|
105
|
+
namedScores: text('named_scores', {mode: 'json'}),
|
|
106
|
+
cost: real('cost'),
|
|
107
|
+
},
|
|
108
|
+
(t) => ({
|
|
109
|
+
pk: primaryKey({ columns: [t.id] }),
|
|
110
|
+
}),
|
|
111
|
+
);
|
|
112
|
+
|
|
113
|
+
export const llmOutputsRelations = relations(llmOutputs, ({ one }) => ({
|
|
114
|
+
eval: one(evals, {
|
|
115
|
+
fields: [llmOutputs.evalId],
|
|
116
|
+
references: [evals.id],
|
|
117
|
+
}),
|
|
118
|
+
prompt: one(prompts, {
|
|
119
|
+
fields: [llmOutputs.promptId],
|
|
120
|
+
references: [prompts.id],
|
|
121
|
+
}),
|
|
122
|
+
}));
|
|
123
|
+
*/
|
|
124
|
+
let dbInstance = null;
|
|
125
|
+
function getDbPath() {
|
|
126
|
+
return node_path_1.default.resolve((0, util_1.getConfigDirectoryPath)(), 'promptfoo.db');
|
|
127
|
+
}
|
|
128
|
+
exports.getDbPath = getDbPath;
|
|
129
|
+
function getDbSignalPath() {
|
|
130
|
+
return node_path_1.default.resolve((0, util_1.getConfigDirectoryPath)(), 'evalLastWritten');
|
|
131
|
+
}
|
|
132
|
+
exports.getDbSignalPath = getDbSignalPath;
|
|
133
|
+
function getDb() {
|
|
134
|
+
if (!dbInstance) {
|
|
135
|
+
const sqlite = new better_sqlite3_2.default(getDbPath());
|
|
136
|
+
dbInstance = (0, better_sqlite3_1.drizzle)(sqlite);
|
|
137
|
+
}
|
|
138
|
+
return dbInstance;
|
|
139
|
+
}
|
|
140
|
+
exports.getDb = getDb;
|
|
141
|
+
//# sourceMappingURL=database.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database.js","sourceRoot":"","sources":["../../src/database.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"evaluator.d.ts","sourceRoot":"","sources":["../../src/evaluator.ts"],"names":[],"mappings":"AAiBA,OAAO,KAAK,EAIV,eAAe,EAGf,eAAe,EAEf,iBAAiB,EACjB,MAAM,EACN,SAAS,EACV,MAAM,SAAS,CAAC;AAiBjB,eAAO,MAAM,uBAAuB,IAAI,CAAC;AA+BzC,wBAAsB,YAAY,CAChC,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,EACrC,eAAe,EAAE,eAAe,EAChC,eAAe,CAAC,EAAE,iBAAiB,GAClC,OAAO,CAAC,MAAM,CAAC,CA2FjB;
|
|
1
|
+
{"version":3,"file":"evaluator.d.ts","sourceRoot":"","sources":["../../src/evaluator.ts"],"names":[],"mappings":"AAiBA,OAAO,KAAK,EAIV,eAAe,EAGf,eAAe,EAEf,iBAAiB,EACjB,MAAM,EACN,SAAS,EACV,MAAM,SAAS,CAAC;AAiBjB,eAAO,MAAM,uBAAuB,IAAI,CAAC;AA+BzC,wBAAsB,YAAY,CAChC,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,EACrC,eAAe,EAAE,eAAe,EAChC,eAAe,CAAC,EAAE,iBAAiB,GAClC,OAAO,CAAC,MAAM,CAAC,CA2FjB;AAuoBD,wBAAgB,QAAQ,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,eAAe,4BAGtE"}
|
package/dist/src/evaluator.js
CHANGED
|
@@ -171,7 +171,7 @@ class Evaluator {
|
|
|
171
171
|
let promptDisplay = prompt.display;
|
|
172
172
|
// Set up the special _conversation variable
|
|
173
173
|
const vars = test.vars || {};
|
|
174
|
-
const conversationKey = `${provider.id()}:${prompt.id}`;
|
|
174
|
+
const conversationKey = `${provider.label || provider.id()}:${prompt.id}`;
|
|
175
175
|
const usesConversation = prompt.raw.includes('_conversation');
|
|
176
176
|
if (!process.env.PROMPTFOO_DISABLE_CONVERSATION_VAR &&
|
|
177
177
|
!test.options?.disableConversationVar &&
|
|
@@ -188,6 +188,7 @@ class Evaluator {
|
|
|
188
188
|
const setup = {
|
|
189
189
|
provider: {
|
|
190
190
|
id: provider.id(),
|
|
191
|
+
label: provider.label,
|
|
191
192
|
},
|
|
192
193
|
prompt: {
|
|
193
194
|
raw: renderedPrompt,
|
|
@@ -356,10 +357,10 @@ class Evaluator {
|
|
|
356
357
|
continue;
|
|
357
358
|
}
|
|
358
359
|
}
|
|
359
|
-
|
|
360
|
+
const completedPrompt = {
|
|
360
361
|
...prompt,
|
|
361
362
|
id: (0, util_1.sha256)(typeof prompt.raw === 'object' ? JSON.stringify(prompt.raw) : prompt.raw),
|
|
362
|
-
provider: provider.id(),
|
|
363
|
+
provider: provider.label || provider.id(),
|
|
363
364
|
display: prompt.display,
|
|
364
365
|
metrics: {
|
|
365
366
|
score: 0,
|
|
@@ -377,7 +378,8 @@ class Evaluator {
|
|
|
377
378
|
namedScores: {},
|
|
378
379
|
cost: 0,
|
|
379
380
|
},
|
|
380
|
-
}
|
|
381
|
+
};
|
|
382
|
+
prompts.push(completedPrompt);
|
|
381
383
|
}
|
|
382
384
|
}
|
|
383
385
|
// Aggregate all vars across test cases
|
|
@@ -528,7 +530,7 @@ class Evaluator {
|
|
|
528
530
|
numComplete++;
|
|
529
531
|
if (progressbar) {
|
|
530
532
|
progressbar.increment({
|
|
531
|
-
provider: evalStep.provider.id(),
|
|
533
|
+
provider: evalStep.provider.label || evalStep.provider.id(),
|
|
532
534
|
prompt: evalStep.prompt.raw.slice(0, 10).replace(/\n/g, ' '),
|
|
533
535
|
vars: Object.entries(evalStep.test.vars || {})
|
|
534
536
|
.map(([k, v]) => `${k}=${v}`)
|
|
@@ -588,7 +590,7 @@ class Evaluator {
|
|
|
588
590
|
namedScores: row.namedScores,
|
|
589
591
|
text: resultText,
|
|
590
592
|
prompt: row.prompt.raw,
|
|
591
|
-
provider: row.provider.id,
|
|
593
|
+
provider: row.provider.label || row.provider.id,
|
|
592
594
|
latencyMs: row.latencyMs,
|
|
593
595
|
tokenUsage: row.response?.tokenUsage,
|
|
594
596
|
gradingResult: row.gradingResult,
|