@fairspec/agent 0.9.3 → 0.11.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/build/package.json +1 -1
- package/build/server.js +3 -3
- package/build/tools/data/validate.d.ts +29 -28
- package/build/tools/dataSchema/infer.d.ts +29 -28
- package/build/tools/dataSchema/infer.js +4 -4
- package/build/tools/dataSchema/infer.spec.js +10 -10
- package/build/tools/dataSchema/validate.d.ts +4 -4
- package/build/tools/dataset/infer.d.ts +56 -54
- package/build/tools/dataset/infer.spec.js +7 -7
- package/build/tools/dataset/validate.d.ts +29 -28
- package/build/tools/{dialect → fileDialect}/infer.d.ts +31 -30
- package/build/tools/fileDialect/infer.js +19 -0
- package/build/tools/fileDialect/infer.spec.js +140 -0
- package/build/tools/table/query.d.ts +28 -27
- package/build/tools/table/query.spec.js +7 -7
- package/build/tools/table/validate.d.ts +29 -28
- package/build/tools/tableSchema/infer.d.ts +52 -50
- package/build/tools/tableSchema/infer.js +5 -5
- package/build/tools/tableSchema/infer.spec.js +34 -34
- package/build/tools/tableSchema/validate.d.ts +4 -4
- package/package.json +2 -2
- package/build/tools/dialect/infer.js +0 -19
- package/build/tools/dialect/infer.spec.js +0 -140
- /package/build/tools/{dialect → fileDialect}/infer.spec.d.ts +0 -0
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { writeTempFile } from "@fairspec/library";
|
|
2
|
+
import { describe, expect, it } from "vitest";
|
|
3
|
+
import { inferFileDialectTool } from "./infer.js";
|
|
4
|
+
describe("inferFileDialectTool", () => {
|
|
5
|
+
it("validates tool structure", () => {
|
|
6
|
+
expect(inferFileDialectTool.id).toBe("infer-file-dialect");
|
|
7
|
+
expect(inferFileDialectTool.description).toBeTruthy();
|
|
8
|
+
expect(inferFileDialectTool.inputSchema).toBeTruthy();
|
|
9
|
+
expect(inferFileDialectTool.outputSchema).toBeTruthy();
|
|
10
|
+
expect(inferFileDialectTool.execute).toBeTypeOf("function");
|
|
11
|
+
});
|
|
12
|
+
it("infers CSV format", async () => {
|
|
13
|
+
const path = await writeTempFile("id,name,age\n1,alice,25\n2,bob,30");
|
|
14
|
+
const resource = { data: path, fileDialect: { format: "csv" } };
|
|
15
|
+
const result = await inferFileDialectTool.execute?.({
|
|
16
|
+
resource,
|
|
17
|
+
}, {});
|
|
18
|
+
expect.assert(result);
|
|
19
|
+
expect.assert(!("error" in result));
|
|
20
|
+
expect(result.fileDialect).toEqual({
|
|
21
|
+
format: "csv",
|
|
22
|
+
delimiter: ",",
|
|
23
|
+
headerRows: [1],
|
|
24
|
+
lineTerminator: "\n",
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
it("infers TSV format", async () => {
|
|
28
|
+
const path = await writeTempFile("id\tname\tage\n1\talice\t25\n2\tbob\t30");
|
|
29
|
+
const resource = { data: path, fileDialect: { format: "csv" } };
|
|
30
|
+
const result = await inferFileDialectTool.execute?.({
|
|
31
|
+
resource,
|
|
32
|
+
}, {});
|
|
33
|
+
expect.assert(result);
|
|
34
|
+
expect.assert(!("error" in result));
|
|
35
|
+
expect(result.fileDialect).toEqual({
|
|
36
|
+
format: "tsv",
|
|
37
|
+
headerRows: [1],
|
|
38
|
+
lineTerminator: "\n",
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
it("infers JSON format with array of objects", async () => {
|
|
42
|
+
const path = await writeTempFile(JSON.stringify([{ id: 1, name: "alice" }]));
|
|
43
|
+
const resource = { data: path, fileDialect: { format: "json" } };
|
|
44
|
+
const result = await inferFileDialectTool.execute?.({
|
|
45
|
+
resource,
|
|
46
|
+
}, {});
|
|
47
|
+
expect.assert(result);
|
|
48
|
+
expect.assert(!("error" in result));
|
|
49
|
+
expect(result.fileDialect).toEqual({
|
|
50
|
+
format: "json",
|
|
51
|
+
rowType: "object",
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
it("infers JSON format with array of arrays", async () => {
|
|
55
|
+
const path = await writeTempFile(JSON.stringify([
|
|
56
|
+
[1, "alice"],
|
|
57
|
+
[2, "bob"],
|
|
58
|
+
]));
|
|
59
|
+
const resource = { data: path, fileDialect: { format: "json" } };
|
|
60
|
+
const result = await inferFileDialectTool.execute?.({
|
|
61
|
+
resource,
|
|
62
|
+
}, {});
|
|
63
|
+
expect.assert(result);
|
|
64
|
+
expect.assert(!("error" in result));
|
|
65
|
+
expect(result.fileDialect?.format).toBe("json");
|
|
66
|
+
expect(result.fileDialect).toHaveProperty("rowType");
|
|
67
|
+
});
|
|
68
|
+
it("infers JSONL format", async () => {
|
|
69
|
+
const path = await writeTempFile('{"id":1,"name":"alice"}\n{"id":2,"name":"bob"}');
|
|
70
|
+
const resource = { data: path, fileDialect: { format: "jsonl" } };
|
|
71
|
+
const result = await inferFileDialectTool.execute?.({
|
|
72
|
+
resource,
|
|
73
|
+
}, {});
|
|
74
|
+
expect.assert(result);
|
|
75
|
+
expect.assert(!("error" in result));
|
|
76
|
+
expect(result.fileDialect?.format).toBe("jsonl");
|
|
77
|
+
});
|
|
78
|
+
it("infers CSV with different delimiter", async () => {
|
|
79
|
+
const path = await writeTempFile("id;name;age\n1;alice;25\n2;bob;30");
|
|
80
|
+
const resource = { data: path, fileDialect: { format: "csv" } };
|
|
81
|
+
const result = await inferFileDialectTool.execute?.({
|
|
82
|
+
resource,
|
|
83
|
+
}, {});
|
|
84
|
+
expect.assert(result);
|
|
85
|
+
expect.assert(!("error" in result));
|
|
86
|
+
expect(result.fileDialect).toMatchObject({
|
|
87
|
+
format: "csv",
|
|
88
|
+
delimiter: ";",
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
it("infers CSV without headers", async () => {
|
|
92
|
+
const path = await writeTempFile("1,alice,25\n2,bob,30");
|
|
93
|
+
const resource = { data: path, fileDialect: { format: "csv" } };
|
|
94
|
+
const result = await inferFileDialectTool.execute?.({
|
|
95
|
+
resource,
|
|
96
|
+
}, {});
|
|
97
|
+
expect.assert(result);
|
|
98
|
+
expect.assert(!("error" in result));
|
|
99
|
+
expect(result.fileDialect?.format).toBe("csv");
|
|
100
|
+
expect(result.fileDialect).toHaveProperty("delimiter");
|
|
101
|
+
});
|
|
102
|
+
it("returns undefined for inline data", async () => {
|
|
103
|
+
const resource = {
|
|
104
|
+
data: [{ id: 1 }],
|
|
105
|
+
};
|
|
106
|
+
const result = await inferFileDialectTool.execute?.({
|
|
107
|
+
resource,
|
|
108
|
+
}, {});
|
|
109
|
+
expect.assert(result);
|
|
110
|
+
expect.assert(!("error" in result));
|
|
111
|
+
expect(result.fileDialect).toBeUndefined();
|
|
112
|
+
});
|
|
113
|
+
it("respects sampleBytes option", async () => {
|
|
114
|
+
const largeData = Array.from({ length: 1000 }, (_, i) => `${i},row${i}`).join("\n");
|
|
115
|
+
const path = await writeTempFile(`id,name\n${largeData}`);
|
|
116
|
+
const resource = { data: path, fileDialect: { format: "csv" } };
|
|
117
|
+
const result = await inferFileDialectTool.execute?.({
|
|
118
|
+
resource,
|
|
119
|
+
options: { sampleBytes: 1000 },
|
|
120
|
+
}, {});
|
|
121
|
+
expect.assert(result);
|
|
122
|
+
expect.assert(!("error" in result));
|
|
123
|
+
expect(result.fileDialect?.format).toBe("csv");
|
|
124
|
+
});
|
|
125
|
+
it("infers dialect with provided format hint", async () => {
|
|
126
|
+
const path = await writeTempFile("id,name\n1,alice\n2,bob");
|
|
127
|
+
const resource = {
|
|
128
|
+
data: path,
|
|
129
|
+
fileDialect: { format: "csv" },
|
|
130
|
+
};
|
|
131
|
+
const result = await inferFileDialectTool.execute?.({
|
|
132
|
+
resource,
|
|
133
|
+
}, {});
|
|
134
|
+
expect.assert(result);
|
|
135
|
+
expect.assert(!("error" in result));
|
|
136
|
+
expect(result.fileDialect?.format).toBe("csv");
|
|
137
|
+
expect(result.fileDialect).toHaveProperty("delimiter");
|
|
138
|
+
});
|
|
139
|
+
});
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infer.spec.js","sourceRoot":"","sources":["../../../tools/fileDialect/infer.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CsvFileDialect, Resource } from \"@fairspec/library\"\nimport { writeTempFile } from \"@fairspec/library\"\nimport { describe, expect, it } from \"vitest\"\nimport { inferFileDialectTool } from \"./infer.ts\"\n\ndescribe(\"inferFileDialectTool\", () => {\n  it(\"validates tool structure\", () => {\n    expect(inferFileDialectTool.id).toBe(\"infer-file-dialect\")\n    expect(inferFileDialectTool.description).toBeTruthy()\n    expect(inferFileDialectTool.inputSchema).toBeTruthy()\n    expect(inferFileDialectTool.outputSchema).toBeTruthy()\n    expect(inferFileDialectTool.execute).toBeTypeOf(\"function\")\n  })\n\n  it(\"infers CSV format\", async () => {\n    const path = await writeTempFile(\"id,name,age\\n1,alice,25\\n2,bob,30\")\n    const resource: Resource = { data: path, fileDialect: { format: \"csv\" } }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect).toEqual<CsvFileDialect>({\n      format: \"csv\",\n      delimiter: \",\",\n      headerRows: [1],\n      lineTerminator: \"\\n\",\n    })\n  })\n\n  it(\"infers TSV format\", async () => {\n    const path = await writeTempFile(\"id\\tname\\tage\\n1\\talice\\t25\\n2\\tbob\\t30\")\n    const resource: Resource = { data: path, fileDialect: { format: \"csv\" } }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect).toEqual({\n      format: \"tsv\",\n      headerRows: [1],\n      lineTerminator: \"\\n\",\n    })\n  })\n\n  it(\"infers JSON format with array of objects\", async () => {\n    const path = await writeTempFile(JSON.stringify([{ id: 1, name: \"alice\" }]))\n    const resource: Resource = { data: path, fileDialect: { format: \"json\" } }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect).toEqual({\n      format: \"json\",\n      rowType: \"object\",\n    })\n  })\n\n  it(\"infers JSON format with array of arrays\", async () => {\n    const path = await writeTempFile(\n      JSON.stringify([\n        [1, \"alice\"],\n        [2, \"bob\"],\n      ]),\n    )\n    const resource: Resource = { data: path, fileDialect: { format: \"json\" } }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect?.format).toBe(\"json\")\n    expect(result.fileDialect).toHaveProperty(\"rowType\")\n  })\n\n  it(\"infers JSONL format\", async () => {\n    const path = await writeTempFile(\n      '{\"id\":1,\"name\":\"alice\"}\\n{\"id\":2,\"name\":\"bob\"}',\n    )\n    const resource: Resource = { data: path, fileDialect: { format: \"jsonl\" } }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect?.format).toBe(\"jsonl\")\n  })\n\n  it(\"infers CSV with different delimiter\", async () => {\n    const path = await writeTempFile(\"id;name;age\\n1;alice;25\\n2;bob;30\")\n    const resource: Resource = { data: path, fileDialect: { format: \"csv\" } }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect).toMatchObject({\n      format: \"csv\",\n      delimiter: \";\",\n    })\n  })\n\n  it(\"infers CSV without headers\", async () => {\n    const path = await writeTempFile(\"1,alice,25\\n2,bob,30\")\n    const resource: Resource = { data: path, fileDialect: { format: \"csv\" } }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect?.format).toBe(\"csv\")\n    expect(result.fileDialect).toHaveProperty(\"delimiter\")\n  })\n\n  it(\"returns undefined for inline data\", async () => {\n    const resource: Resource = {\n      data: [{ id: 1 }],\n    }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect).toBeUndefined()\n  })\n\n  it(\"respects sampleBytes option\", async () => {\n    const largeData = Array.from(\n      { length: 1000 },\n      (_, i) => `${i},row${i}`,\n    ).join(\"\\n\")\n    const path = await writeTempFile(`id,name\\n${largeData}`)\n    const resource: Resource = { data: path, fileDialect: { format: \"csv\" } }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n        options: { sampleBytes: 1000 },\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect?.format).toBe(\"csv\")\n  })\n\n  it(\"infers dialect with provided format hint\", async () => {\n    const path = await writeTempFile(\"id,name\\n1,alice\\n2,bob\")\n    const resource: Resource = {\n      data: path,\n      fileDialect: { format: \"csv\" },\n    }\n\n    const result = await inferFileDialectTool.execute?.(\n      {\n        resource,\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(result.fileDialect?.format).toBe(\"csv\")\n    expect(result.fileDialect).toHaveProperty(\"delimiter\")\n  })\n})\n"]}
|
|
@@ -197,7 +197,11 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
197
197
|
data?: unknown;
|
|
198
198
|
name?: string | undefined;
|
|
199
199
|
textual?: boolean | undefined;
|
|
200
|
-
|
|
200
|
+
integrity?: {
|
|
201
|
+
type: "md5" | "sha1" | "sha256" | "sha512";
|
|
202
|
+
hash: string;
|
|
203
|
+
} | undefined;
|
|
204
|
+
fileDialect?: string | {
|
|
201
205
|
format: "csv";
|
|
202
206
|
$schema?: string | undefined;
|
|
203
207
|
title?: string | undefined;
|
|
@@ -287,18 +291,15 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
287
291
|
title?: string | undefined;
|
|
288
292
|
description?: string | undefined;
|
|
289
293
|
} | undefined;
|
|
290
|
-
integrity?: {
|
|
291
|
-
type: "md5" | "sha1" | "sha256" | "sha512";
|
|
292
|
-
hash: string;
|
|
293
|
-
} | undefined;
|
|
294
294
|
dataSchema?: string | Record<string, unknown> | undefined;
|
|
295
295
|
tableSchema?: string | {
|
|
296
296
|
$schema?: string | undefined;
|
|
297
297
|
title?: string | undefined;
|
|
298
298
|
description?: string | undefined;
|
|
299
299
|
required?: string[] | undefined;
|
|
300
|
+
allRequired?: boolean | undefined;
|
|
300
301
|
properties?: Record<string, {
|
|
301
|
-
type: "boolean";
|
|
302
|
+
type: "boolean" | ["boolean", "null"] | ["null", "boolean"];
|
|
302
303
|
title?: string | undefined;
|
|
303
304
|
description?: string | undefined;
|
|
304
305
|
rdfType?: string | undefined;
|
|
@@ -314,7 +315,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
314
315
|
trueValues?: string[] | undefined;
|
|
315
316
|
falseValues?: string[] | undefined;
|
|
316
317
|
} | {
|
|
317
|
-
type: "integer";
|
|
318
|
+
type: "integer" | ["integer", "null"] | ["null", "integer"];
|
|
318
319
|
title?: string | undefined;
|
|
319
320
|
description?: string | undefined;
|
|
320
321
|
rdfType?: string | undefined;
|
|
@@ -335,7 +336,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
335
336
|
withText?: boolean | undefined;
|
|
336
337
|
format?: "" | undefined;
|
|
337
338
|
} | {
|
|
338
|
-
type: "integer";
|
|
339
|
+
type: "integer" | ["integer", "null"] | ["null", "integer"];
|
|
339
340
|
format: "categorical";
|
|
340
341
|
title?: string | undefined;
|
|
341
342
|
description?: string | undefined;
|
|
@@ -361,7 +362,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
361
362
|
})[] | undefined;
|
|
362
363
|
withOrder?: boolean | undefined;
|
|
363
364
|
} | {
|
|
364
|
-
type: "number";
|
|
365
|
+
type: "number" | ["number", "null"] | ["null", "number"];
|
|
365
366
|
title?: string | undefined;
|
|
366
367
|
description?: string | undefined;
|
|
367
368
|
rdfType?: string | undefined;
|
|
@@ -383,7 +384,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
383
384
|
withText?: boolean | undefined;
|
|
384
385
|
format?: "" | undefined;
|
|
385
386
|
} | {
|
|
386
|
-
type: "string";
|
|
387
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
387
388
|
format: "list";
|
|
388
389
|
title?: string | undefined;
|
|
389
390
|
description?: string | undefined;
|
|
@@ -404,7 +405,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
404
405
|
minItems?: number | undefined;
|
|
405
406
|
maxItems?: number | undefined;
|
|
406
407
|
} | {
|
|
407
|
-
type: "string";
|
|
408
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
408
409
|
format: "base64";
|
|
409
410
|
title?: string | undefined;
|
|
410
411
|
description?: string | undefined;
|
|
@@ -421,7 +422,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
421
422
|
maxLength?: number | undefined;
|
|
422
423
|
pattern?: string | undefined;
|
|
423
424
|
} | {
|
|
424
|
-
type: "string";
|
|
425
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
425
426
|
format: "hex";
|
|
426
427
|
title?: string | undefined;
|
|
427
428
|
description?: string | undefined;
|
|
@@ -438,7 +439,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
438
439
|
maxLength?: number | undefined;
|
|
439
440
|
pattern?: string | undefined;
|
|
440
441
|
} | {
|
|
441
|
-
type: "string";
|
|
442
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
442
443
|
format: "email";
|
|
443
444
|
title?: string | undefined;
|
|
444
445
|
description?: string | undefined;
|
|
@@ -455,7 +456,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
455
456
|
maxLength?: number | undefined;
|
|
456
457
|
pattern?: string | undefined;
|
|
457
458
|
} | {
|
|
458
|
-
type: "string";
|
|
459
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
459
460
|
format: "url";
|
|
460
461
|
title?: string | undefined;
|
|
461
462
|
description?: string | undefined;
|
|
@@ -472,7 +473,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
472
473
|
maxLength?: number | undefined;
|
|
473
474
|
pattern?: string | undefined;
|
|
474
475
|
} | {
|
|
475
|
-
type: "string";
|
|
476
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
476
477
|
format: "date-time";
|
|
477
478
|
title?: string | undefined;
|
|
478
479
|
description?: string | undefined;
|
|
@@ -490,7 +491,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
490
491
|
pattern?: string | undefined;
|
|
491
492
|
temporalFormat?: string | undefined;
|
|
492
493
|
} | {
|
|
493
|
-
type: "string";
|
|
494
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
494
495
|
format: "date";
|
|
495
496
|
title?: string | undefined;
|
|
496
497
|
description?: string | undefined;
|
|
@@ -508,7 +509,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
508
509
|
pattern?: string | undefined;
|
|
509
510
|
temporalFormat?: string | undefined;
|
|
510
511
|
} | {
|
|
511
|
-
type: "string";
|
|
512
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
512
513
|
format: "time";
|
|
513
514
|
title?: string | undefined;
|
|
514
515
|
description?: string | undefined;
|
|
@@ -526,7 +527,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
526
527
|
pattern?: string | undefined;
|
|
527
528
|
temporalFormat?: string | undefined;
|
|
528
529
|
} | {
|
|
529
|
-
type: "string";
|
|
530
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
530
531
|
format: "duration";
|
|
531
532
|
title?: string | undefined;
|
|
532
533
|
description?: string | undefined;
|
|
@@ -543,7 +544,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
543
544
|
maxLength?: number | undefined;
|
|
544
545
|
pattern?: string | undefined;
|
|
545
546
|
} | {
|
|
546
|
-
type: "string";
|
|
547
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
547
548
|
format: "wkt";
|
|
548
549
|
title?: string | undefined;
|
|
549
550
|
description?: string | undefined;
|
|
@@ -560,7 +561,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
560
561
|
maxLength?: number | undefined;
|
|
561
562
|
pattern?: string | undefined;
|
|
562
563
|
} | {
|
|
563
|
-
type: "string";
|
|
564
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
564
565
|
format: "wkb";
|
|
565
566
|
title?: string | undefined;
|
|
566
567
|
description?: string | undefined;
|
|
@@ -577,7 +578,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
577
578
|
maxLength?: number | undefined;
|
|
578
579
|
pattern?: string | undefined;
|
|
579
580
|
} | {
|
|
580
|
-
type: "string";
|
|
581
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
581
582
|
title?: string | undefined;
|
|
582
583
|
description?: string | undefined;
|
|
583
584
|
rdfType?: string | undefined;
|
|
@@ -594,7 +595,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
594
595
|
pattern?: string | undefined;
|
|
595
596
|
format?: "" | undefined;
|
|
596
597
|
} | {
|
|
597
|
-
type: "string";
|
|
598
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
598
599
|
format: "categorical";
|
|
599
600
|
title?: string | undefined;
|
|
600
601
|
description?: string | undefined;
|
|
@@ -616,7 +617,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
616
617
|
})[] | undefined;
|
|
617
618
|
withOrder?: boolean | undefined;
|
|
618
619
|
} | {
|
|
619
|
-
type: "string";
|
|
620
|
+
type: "string" | ["string", "null"] | ["null", "string"];
|
|
620
621
|
format: "decimal";
|
|
621
622
|
title?: string | undefined;
|
|
622
623
|
description?: string | undefined;
|
|
@@ -641,7 +642,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
641
642
|
groupChar?: string | undefined;
|
|
642
643
|
withText?: boolean | undefined;
|
|
643
644
|
} | {
|
|
644
|
-
type: "array";
|
|
645
|
+
type: "array" | ["array", "null"] | ["null", "array"];
|
|
645
646
|
title?: string | undefined;
|
|
646
647
|
description?: string | undefined;
|
|
647
648
|
rdfType?: string | undefined;
|
|
@@ -671,7 +672,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
671
672
|
minItems?: number | undefined;
|
|
672
673
|
uniqueItems?: boolean | undefined;
|
|
673
674
|
} | {
|
|
674
|
-
type: "object";
|
|
675
|
+
type: "object" | ["object", "null"] | ["null", "object"];
|
|
675
676
|
format: "geojson";
|
|
676
677
|
title?: string | undefined;
|
|
677
678
|
description?: string | undefined;
|
|
@@ -702,7 +703,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
702
703
|
dependentSchemas?: unknown;
|
|
703
704
|
required?: unknown;
|
|
704
705
|
} | {
|
|
705
|
-
type: "object";
|
|
706
|
+
type: "object" | ["object", "null"] | ["null", "object"];
|
|
706
707
|
format: "topojson";
|
|
707
708
|
title?: string | undefined;
|
|
708
709
|
description?: string | undefined;
|
|
@@ -733,7 +734,7 @@ export declare const queryTableTool: import("@mastra/core/tools").Tool<{
|
|
|
733
734
|
dependentSchemas?: unknown;
|
|
734
735
|
required?: unknown;
|
|
735
736
|
} | {
|
|
736
|
-
type: "object";
|
|
737
|
+
type: "object" | ["object", "null"] | ["null", "object"];
|
|
737
738
|
title?: string | undefined;
|
|
738
739
|
description?: string | undefined;
|
|
739
740
|
rdfType?: string | undefined;
|
|
@@ -12,7 +12,7 @@ describe("queryTableTool", () => {
|
|
|
12
12
|
it("queries table with SELECT statement", async () => {
|
|
13
13
|
const csvContent = "id,name,age\n1,alice,25\n2,bob,30\n3,carol,28";
|
|
14
14
|
const csvPath = await writeTempFile(csvContent, { format: "csv" });
|
|
15
|
-
const resource = { data: csvPath,
|
|
15
|
+
const resource = { data: csvPath, fileDialect: { format: "csv" } };
|
|
16
16
|
const result = await queryTableTool.execute?.({
|
|
17
17
|
resource,
|
|
18
18
|
query: "SELECT * FROM self WHERE age > 25",
|
|
@@ -27,7 +27,7 @@ describe("queryTableTool", () => {
|
|
|
27
27
|
it("queries table with column selection", async () => {
|
|
28
28
|
const csvContent = "id,name,age,city\n1,alice,25,NYC\n2,bob,30,LA\n3,carol,28,SF";
|
|
29
29
|
const csvPath = await writeTempFile(csvContent, { format: "csv" });
|
|
30
|
-
const resource = { data: csvPath,
|
|
30
|
+
const resource = { data: csvPath, fileDialect: { format: "csv" } };
|
|
31
31
|
const result = await queryTableTool.execute?.({
|
|
32
32
|
resource,
|
|
33
33
|
query: "SELECT name, city FROM self",
|
|
@@ -44,7 +44,7 @@ describe("queryTableTool", () => {
|
|
|
44
44
|
it("queries table with ORDER BY clause", async () => {
|
|
45
45
|
const csvContent = "id,name,score\n1,alice,85\n2,bob,90\n3,carol,88";
|
|
46
46
|
const csvPath = await writeTempFile(csvContent, { format: "csv" });
|
|
47
|
-
const resource = { data: csvPath,
|
|
47
|
+
const resource = { data: csvPath, fileDialect: { format: "csv" } };
|
|
48
48
|
const result = await queryTableTool.execute?.({
|
|
49
49
|
resource,
|
|
50
50
|
query: "SELECT * FROM self ORDER BY score DESC",
|
|
@@ -60,7 +60,7 @@ describe("queryTableTool", () => {
|
|
|
60
60
|
it("queries table with aggregation", async () => {
|
|
61
61
|
const csvContent = "id,name,score\n1,alice,85\n2,bob,90\n3,carol,88";
|
|
62
62
|
const csvPath = await writeTempFile(csvContent, { format: "csv" });
|
|
63
|
-
const resource = { data: csvPath,
|
|
63
|
+
const resource = { data: csvPath, fileDialect: { format: "csv" } };
|
|
64
64
|
const result = await queryTableTool.execute?.({
|
|
65
65
|
resource,
|
|
66
66
|
query: "SELECT COUNT(*) as count, AVG(score) as avg_score FROM self",
|
|
@@ -75,7 +75,7 @@ describe("queryTableTool", () => {
|
|
|
75
75
|
it("queries table with WHERE and LIMIT", async () => {
|
|
76
76
|
const csvContent = "id,name,age\n1,alice,25\n2,bob,30\n3,carol,28\n4,dave,35\n5,eve,22";
|
|
77
77
|
const csvPath = await writeTempFile(csvContent, { format: "csv" });
|
|
78
|
-
const resource = { data: csvPath,
|
|
78
|
+
const resource = { data: csvPath, fileDialect: { format: "csv" } };
|
|
79
79
|
const result = await queryTableTool.execute?.({
|
|
80
80
|
resource,
|
|
81
81
|
query: "SELECT * FROM self WHERE age >= 25 ORDER BY age LIMIT 2",
|
|
@@ -124,7 +124,7 @@ describe("queryTableTool", () => {
|
|
|
124
124
|
it("returns all records when querying without filters", async () => {
|
|
125
125
|
const csvContent = "id,name\n1,alice\n2,bob\n3,carol";
|
|
126
126
|
const csvPath = await writeTempFile(csvContent, { format: "csv" });
|
|
127
|
-
const resource = { data: csvPath,
|
|
127
|
+
const resource = { data: csvPath, fileDialect: { format: "csv" } };
|
|
128
128
|
const result = await queryTableTool.execute?.({
|
|
129
129
|
resource,
|
|
130
130
|
query: "SELECT * FROM self",
|
|
@@ -135,4 +135,4 @@ describe("queryTableTool", () => {
|
|
|
135
135
|
expect(result.records.length).toBe(3);
|
|
136
136
|
});
|
|
137
137
|
});
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query.spec.js","sourceRoot":"","sources":["../../../tools/table/query.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Resource } from \"@fairspec/library\"\nimport { writeTempFile } from \"@fairspec/library\"\nimport { describe, expect, it } from \"vitest\"\nimport { queryTableTool } from \"./query.ts\"\n\ndescribe(\"queryTableTool\", () => {\n  it(\"validates tool structure\", () => {\n    expect(queryTableTool.id).toBe(\"query-table\")\n    expect(queryTableTool.description).toBeTruthy()\n    expect(queryTableTool.inputSchema).toBeTruthy()\n    expect(queryTableTool.outputSchema).toBeTruthy()\n    expect(queryTableTool.execute).toBeTypeOf(\"function\")\n  })\n\n  it(\"queries table with SELECT statement\", async () => {\n    const csvContent = \"id,name,age\\n1,alice,25\\n2,bob,30\\n3,carol,28\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, dialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self WHERE age > 25\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(2)\n    expect(result.records).toContainEqual({ id: 2, name: \"bob\", age: 30 })\n    expect(result.records).toContainEqual({ id: 3, name: \"carol\", age: 28 })\n  })\n\n  it(\"queries table with column selection\", async () => {\n    const csvContent =\n      \"id,name,age,city\\n1,alice,25,NYC\\n2,bob,30,LA\\n3,carol,28,SF\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, dialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT name, city FROM self\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(3)\n    expect(result.records[0]).toHaveProperty(\"name\")\n    expect(result.records[0]).toHaveProperty(\"city\")\n    expect(result.records[0]).not.toHaveProperty(\"id\")\n    expect(result.records[0]).not.toHaveProperty(\"age\")\n  })\n\n  it(\"queries table with ORDER BY clause\", async () => {\n    const csvContent = \"id,name,score\\n1,alice,85\\n2,bob,90\\n3,carol,88\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, dialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self ORDER BY score DESC\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(3)\n    expect(result.records[0]).toMatchObject({ name: \"bob\", score: 90 })\n    expect(result.records[1]).toMatchObject({ name: \"carol\", score: 88 })\n    expect(result.records[2]).toMatchObject({ name: \"alice\", score: 85 })\n  })\n\n  it(\"queries table with aggregation\", async () => {\n    const csvContent = \"id,name,score\\n1,alice,85\\n2,bob,90\\n3,carol,88\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, dialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT COUNT(*) as count, AVG(score) as avg_score FROM self\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(1)\n    expect(result.records[0]).toHaveProperty(\"count\")\n    expect(result.records[0]).toHaveProperty(\"avg_score\")\n  })\n\n  it(\"queries table with WHERE and LIMIT\", async () => {\n    const csvContent =\n      \"id,name,age\\n1,alice,25\\n2,bob,30\\n3,carol,28\\n4,dave,35\\n5,eve,22\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, dialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self WHERE age >= 25 ORDER BY age LIMIT 2\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(2)\n  })\n\n  it(\"queries inline data\", async () => {\n    const resource: Resource = {\n      data: [\n        { id: 1, name: \"alice\", score: 85 },\n        { id: 2, name: \"bob\", score: 90 },\n        { id: 3, name: \"carol\", score: 88 },\n      ],\n    }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT name, score FROM self WHERE score > 85\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(2)\n    expect(result.records).toContainEqual({ name: \"bob\", score: 90 })\n    expect(result.records).toContainEqual({ name: \"carol\", score: 88 })\n  })\n\n  it(\"queries with JOIN operations\", async () => {\n    const resource: Resource = {\n      data: [\n        { id: 1, name: \"alice\", dept_id: 10 },\n        { id: 2, name: \"bob\", dept_id: 20 },\n      ],\n    }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self WHERE dept_id = 10\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(1)\n    expect(result.records[0]).toMatchObject({ name: \"alice\", dept_id: 10 })\n  })\n\n  it(\"returns all records when querying without filters\", async () => {\n    const csvContent = \"id,name\\n1,alice\\n2,bob\\n3,carol\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, dialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(3)\n  })\n})\n"]}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query.spec.js","sourceRoot":"","sources":["../../../tools/table/query.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Resource } from \"@fairspec/library\"\nimport { writeTempFile } from \"@fairspec/library\"\nimport { describe, expect, it } from \"vitest\"\nimport { queryTableTool } from \"./query.ts\"\n\ndescribe(\"queryTableTool\", () => {\n  it(\"validates tool structure\", () => {\n    expect(queryTableTool.id).toBe(\"query-table\")\n    expect(queryTableTool.description).toBeTruthy()\n    expect(queryTableTool.inputSchema).toBeTruthy()\n    expect(queryTableTool.outputSchema).toBeTruthy()\n    expect(queryTableTool.execute).toBeTypeOf(\"function\")\n  })\n\n  it(\"queries table with SELECT statement\", async () => {\n    const csvContent = \"id,name,age\\n1,alice,25\\n2,bob,30\\n3,carol,28\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, fileDialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self WHERE age > 25\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(2)\n    expect(result.records).toContainEqual({ id: 2, name: \"bob\", age: 30 })\n    expect(result.records).toContainEqual({ id: 3, name: \"carol\", age: 28 })\n  })\n\n  it(\"queries table with column selection\", async () => {\n    const csvContent =\n      \"id,name,age,city\\n1,alice,25,NYC\\n2,bob,30,LA\\n3,carol,28,SF\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, fileDialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT name, city FROM self\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(3)\n    expect(result.records[0]).toHaveProperty(\"name\")\n    expect(result.records[0]).toHaveProperty(\"city\")\n    expect(result.records[0]).not.toHaveProperty(\"id\")\n    expect(result.records[0]).not.toHaveProperty(\"age\")\n  })\n\n  it(\"queries table with ORDER BY clause\", async () => {\n    const csvContent = \"id,name,score\\n1,alice,85\\n2,bob,90\\n3,carol,88\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, fileDialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self ORDER BY score DESC\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(3)\n    expect(result.records[0]).toMatchObject({ name: \"bob\", score: 90 })\n    expect(result.records[1]).toMatchObject({ name: \"carol\", score: 88 })\n    expect(result.records[2]).toMatchObject({ name: \"alice\", score: 85 })\n  })\n\n  it(\"queries table with aggregation\", async () => {\n    const csvContent = \"id,name,score\\n1,alice,85\\n2,bob,90\\n3,carol,88\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, fileDialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT COUNT(*) as count, AVG(score) as avg_score FROM self\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(1)\n    expect(result.records[0]).toHaveProperty(\"count\")\n    expect(result.records[0]).toHaveProperty(\"avg_score\")\n  })\n\n  it(\"queries table with WHERE and LIMIT\", async () => {\n    const csvContent =\n      \"id,name,age\\n1,alice,25\\n2,bob,30\\n3,carol,28\\n4,dave,35\\n5,eve,22\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, fileDialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self WHERE age >= 25 ORDER BY age LIMIT 2\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(2)\n  })\n\n  it(\"queries inline data\", async () => {\n    const resource: Resource = {\n      data: [\n        { id: 1, name: \"alice\", score: 85 },\n        { id: 2, name: \"bob\", score: 90 },\n        { id: 3, name: \"carol\", score: 88 },\n      ],\n    }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT name, score FROM self WHERE score > 85\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(2)\n    expect(result.records).toContainEqual({ name: \"bob\", score: 90 })\n    expect(result.records).toContainEqual({ name: \"carol\", score: 88 })\n  })\n\n  it(\"queries with JOIN operations\", async () => {\n    const resource: Resource = {\n      data: [\n        { id: 1, name: \"alice\", dept_id: 10 },\n        { id: 2, name: \"bob\", dept_id: 20 },\n      ],\n    }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self WHERE dept_id = 10\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(1)\n    expect(result.records[0]).toMatchObject({ name: \"alice\", dept_id: 10 })\n  })\n\n  it(\"returns all records when querying without filters\", async () => {\n    const csvContent = \"id,name\\n1,alice\\n2,bob\\n3,carol\"\n    const csvPath = await writeTempFile(csvContent, { format: \"csv\" })\n    const resource: Resource = { data: csvPath, fileDialect: { format: \"csv\" } }\n\n    const result = await queryTableTool.execute?.(\n      {\n        resource,\n        query: \"SELECT * FROM self\",\n      },\n      {},\n    )\n\n    expect.assert(result)\n    expect.assert(!(\"error\" in result))\n\n    expect(Array.isArray(result.records)).toBe(true)\n    expect(result.records.length).toBe(3)\n  })\n})\n"]}
|