diff --git a/packages/kbot/.vscode/launch.json b/packages/kbot/.vscode/launch.json index 86d989e1..ffa00c01 100644 --- a/packages/kbot/.vscode/launch.json +++ b/packages/kbot/.vscode/launch.json @@ -705,23 +705,24 @@ "!**/node_modules/**" ], "outputCapture": "std" - }, + }, { "type": "node", "request": "launch", - "name": "Debug Current Test File", - "autoAttachChildProcesses": true, - "skipFiles": [ - "/**", - "**/node_modules/**" + "name": "Debug Files Tests (Vitest)", + "skipFiles": ["/**"], + "cwd": "${workspaceFolder}", + "runtimeExecutable": "npm", + "runtimeArgs": ["run", "test:files", "--", "--inspect-brk"], + "outFiles": ["${workspaceFolder}/**/*.js", "${workspaceFolder}/**/*.ts"], + "console": "integratedTerminal", + "internalConsoleOptions": "neverOpen", + "sourceMaps": true, + "resolveSourceMapLocations": [ + "${workspaceFolder}/**", + "!**/node_modules/**" ], - "program": "${workspaceRoot}/node_modules/vitest/vitest.mjs", - "args": [ - "run", - "${relativeFile}" - ], - "smartStep": true, - "console": "integratedTerminal" + "outputCapture": "std" } ] } \ No newline at end of file diff --git a/packages/kbot/Preferences b/packages/kbot/Preferences new file mode 100644 index 00000000..d258bdab --- /dev/null +++ b/packages/kbot/Preferences @@ -0,0 +1,3 @@ +# Preferences + +You are a helpful AI assistant. When asked to perform calculations, you should return only the numerical result without any explanation or comments. \ No newline at end of file diff --git a/packages/kbot/dist-in/commands/run.js b/packages/kbot/dist-in/commands/run.js index 44a13f99..a91cd88e 100644 --- a/packages/kbot/dist-in/commands/run.js +++ b/packages/kbot/dist-in/commands/run.js @@ -107,11 +107,15 @@ export const processRun = async (opts) => { * */ function extractPaths(input) { + // If it's a direct path that exists, return it if (exists(path.resolve(resolve(input)))) { return [input]; } + // If it's a glob pattern, return it as is + if (hasMagic(input)) { + return [input]; + } // Matches either a Windows drive pattern like "C:\" or a forward slash "/". - // Parentheses group with `|` to match either part correctly. const pathStartRegex = /([A-Za-z]:\\)|\//g; const matchIndices = []; let match; @@ -142,17 +146,20 @@ function flattenArrays(arrays) { } export const run = async (opts) => { const ret = []; - const logger = new Logger({ - minLevel: opts.logLevel - }); + const logger = new Logger({ minLevel: opts.logLevel || 2 }); if (opts.include) { if (isString(opts.include)) { opts.include = [opts.include]; } if (isArray(opts.include)) { - opts.include = flattenArrays(opts.include.map(extractPaths)); + // First check for glob patterns + const globPatterns = opts.include.filter((path) => hasMagic(path)); + // Then process non-glob patterns + const nonGlobPaths = opts.include.filter((path) => !hasMagic(path)); + const processedPaths = flattenArrays(nonGlobPaths.map(extractPaths)); + // Combine glob patterns and processed paths + opts.include = [...globPatterns, ...processedPaths]; } - opts.include = Array.from(new Set(opts.include)); } else { opts.include = []; @@ -201,4 +208,4 @@ export const run = async (opts) => { } return ret; }; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbW1hbmRzL3J1bi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssSUFBSSxNQUFNLFdBQVcsQ0FBQTtBQUNqQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sTUFBTSxDQUFBO0FBQy9CLE9BQU8sRUFBRSxJQUFJLElBQUksR0FBRyxFQUFFLE1BQU0sa0JBQWtCLENBQUE7QUFDOUMsT0FBTyxFQUFFLElBQUksSUFBSSxNQUFNLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUNwRCxPQUFPLEVBQUUsSUFBSSxJQUFJLEtBQUssRUFBRSxNQUFNLG9CQUFvQixDQUFBO0FBQ2xELE9BQU8sRUFBRSxJQUFJLElBQUksSUFBSSxFQUFFLE1BQU0sbUJBQW1CLENBQUE7QUFDaEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQzlFLE9BQU8sRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sMkJBQTJCLENBQUE7QUFLN0QsT0FBTyxFQUFFLE1BQU0sRUFBVyxNQUFNLE9BQU8sQ0FBQTtBQUN2QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sY0FBYyxDQUFBO0FBQzNDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUNoRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sY0FBYyxDQUFBO0FBQ2xDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUMzQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDM0MsT0FBTyxFQUFFLElBQUksSUFBSSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDbkQsT0FBTyxFQUFFLElBQUksSUFBSSxTQUFTLEVBQUUsTUFBTSxhQUFhLENBQUE7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFB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 \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbW1hbmRzL3J1bi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssSUFBSSxNQUFNLFdBQVcsQ0FBQTtBQUNqQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sTUFBTSxDQUFBO0FBQy9CLE9BQU8sRUFBRSxJQUFJLElBQUksR0FBRyxFQUFFLE1BQU0sa0JBQWtCLENBQUE7QUFDOUMsT0FBTyxFQUFFLElBQUksSUFBSSxNQUFNLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUNwRCxPQUFPLEVBQUUsSUFBSSxJQUFJLEtBQUssRUFBRSxNQUFNLG9CQUFvQixDQUFBO0FBQ2xELE9BQU8sRUFBRSxJQUFJLElBQUksSUFBSSxFQUFFLE1BQU0sbUJBQW1CLENBQUE7QUFDaEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQzlFLE9BQU8sRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sMkJBQTJCLENBQUE7QUFLN0QsT0FBTyxFQUFFLE1BQU0sRUFBVyxNQUFNLE9BQU8sQ0FBQTtBQUN2QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sY0FBYyxDQUFBO0FBQzNDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUNoRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sY0FBYyxDQUFBO0FBQ2xDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUMzQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDM0MsT0FBTyxFQUFFLElBQUksSUFBSSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDbkQsT0FBTyxFQUFFLElBQUksSUFBSSxTQUFTLEVBQUUsTUFBTSxhQUFhLENBQUE7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFB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 \ No newline at end of file diff --git a/packages/kbot/logs/params.json b/packages/kbot/logs/params.json index 2d04628d..e95bf8b2 100644 --- a/packages/kbot/logs/params.json +++ b/packages/kbot/logs/params.json @@ -1,13 +1,24 @@ { - "model": "openrouter/quasar-alpha", + "model": "google/gemini-2.0-flash-exp:free", "messages": [ { "role": "user", - "content": "Generate a JavaScript function that implements bubble sort.\n The function should be named 'bubbleSort' and take one parameter 'arr' (an array of numbers).\n The function should return the sorted array.\n Return only the function code, no explanation." + "content": "What animals are shown in these images? Return as JSON array." }, { "role": "user", "content": "USER Preferences : # Preferences\r\n\r\nYou are a helpful AI assistant. When asked to perform calculations, you should return only the numerical result without any explanation or comments. " + }, + { + "role": "user", + "content": [ + { + "type": "image_url", + "image_url": { + "url": "" + } + } + ] } ], "tools": [] diff --git a/packages/kbot/package.json b/packages/kbot/package.json index 4a80883f..6aa52603 100644 --- a/packages/kbot/package.json +++ b/packages/kbot/package.json @@ -24,6 +24,7 @@ "test:language": "vitest run tests/unit/language.test.ts", "test:tools": "vitest run tests/unit/tools.test.ts", "test:coding": "vitest run tests/unit/coding.test.ts", + "test:files": "vitest run tests/unit/files.test.ts", "test2:watch": "vitest", "test2:coverage": "vitest run --coverage", "webpack": "webpack --config webpack.config.js --stats-error-details", diff --git a/packages/kbot/src/commands/run.ts b/packages/kbot/src/commands/run.ts index 7f04677c..9862a966 100644 --- a/packages/kbot/src/commands/run.ts +++ b/packages/kbot/src/commands/run.ts @@ -124,13 +124,17 @@ export const processRun = async (opts: IKBotTask) => { * */ function extractPaths(input: string): string[] { - + // If it's a direct path that exists, return it if(exists(path.resolve(resolve(input)))){ return [input] } + // If it's a glob pattern, return it as is + if(hasMagic(input)){ + return [input] + } + // Matches either a Windows drive pattern like "C:\" or a forward slash "/". - // Parentheses group with `|` to match either part correctly. const pathStartRegex = /([A-Za-z]:\\)|\//g; const matchIndices: number[] = []; @@ -168,18 +172,22 @@ function flattenArrays(arrays: T[][]): T[] { export const run = async (opts: IKBotTask) => { const ret = [] - const logger = new Logger({ - minLevel: opts.logLevel - }) + const logger = new Logger({ minLevel: opts.logLevel || 2 }) + if (opts.include) { if (isString(opts.include)) { opts.include = [opts.include] } if (isArray(opts.include)) { - opts.include = flattenArrays(opts.include.map(extractPaths)) + // First check for glob patterns + const globPatterns = opts.include.filter((path: string) => hasMagic(path)) + // Then process non-glob patterns + const nonGlobPaths = opts.include.filter((path: string) => !hasMagic(path)) + const processedPaths = flattenArrays(nonGlobPaths.map(extractPaths)) + // Combine glob patterns and processed paths + opts.include = [...globPatterns, ...processedPaths] } - opts.include = Array.from(new Set(opts.include)) - }else{ + } else { opts.include = [] } if (opts.each) { diff --git a/packages/kbot/tests/test-data/files/bubblesort.js b/packages/kbot/tests/test-data/files/bubblesort.js new file mode 100644 index 00000000..e72b4d35 --- /dev/null +++ b/packages/kbot/tests/test-data/files/bubblesort.js @@ -0,0 +1,20 @@ +/* Prompt: +Generate a JavaScript function that implements bubble sort. + The function should be named 'bubbleSort' and take one parameter 'arr' (an array of numbers). + The function should return the sorted array. + Return only the function code, no explanation. +*/ + +function bubbleSort(arr) { + let n = arr.length; + for (let i = 0; i < n - 1; i++) { + for (let j = 0; j < n - 1 - i; j++) { + if (arr[j] > arr[j + 1]) { + let temp = arr[j]; + arr[j] = arr[j + 1]; + arr[j + 1] = temp; + } + } + } + return arr; +} \ No newline at end of file diff --git a/packages/kbot/tests/test-data/files/factorial.js b/packages/kbot/tests/test-data/files/factorial.js new file mode 100644 index 00000000..5c58d586 --- /dev/null +++ b/packages/kbot/tests/test-data/files/factorial.js @@ -0,0 +1,12 @@ +/* Prompt: +Generate a JavaScript function that calculates the factorial of a number. + The function should be named 'factorial' and take one parameter 'n'. + Return only the function code, no explanation. +*/ + +function factorial(n) { + if (n === 0 || n === 1) { + return 1; + } + return n * factorial(n - 1); +} \ No newline at end of file diff --git a/packages/kbot/tests/test-data/files/glob/data.json b/packages/kbot/tests/test-data/files/glob/data.json new file mode 100644 index 00000000..9ecf2842 --- /dev/null +++ b/packages/kbot/tests/test-data/files/glob/data.json @@ -0,0 +1,19 @@ +{ + "title": "Injection Barrel", + "price": "90.00", + "storeName": "Vaughn", + "storeLink": "https://bazar.preciousplastic.com/vaughn/", + "mediaHTML": "\n\n \n \n\n \n \n \n \n
\n \n\n\n \n\n \n\n
\n\n \n \n\n\n\n\n\n\n\n ", + "description": "\n \n

Injection Barrel made to precious plastic design with a 3/4\" BSP thread on the end.

- Barrel diameter 34mm

\n

- Made from Steel

\n

-  Works perfectly with this heating system: https://bazar.preciousplastic....

\n

- Free shipping in Europe 

\n\n \n ", + "features": "\n \n \n
\n
Condition:
\n\n \n
New
\n
\n \n
\n
Country of Origin:
\n\n \n
Netherlands
\n
\n \n
\n
Made according to the Precious Plastic drawings? :
\n\n \n
Yes
\n
\n \n
\n
Weight (KG):
\n\n \n
1.5KG
\n
\n \n \n \n ", + "options": "\n\n\n\n\n\n \n

Injection Barrel

\n \n \n \n
\n \n\n\n
\n \n\n \n\n \n\n\n \n \n \n\n\n
\n
\n \n \n \n\n \n \n
\n \n \n \n \n €90.00\n \n\n \n\n
\n \n \n \n \n \n \n \n
\n
\n \n \n\n\n\n
\n
\n \n \n \n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n\n\n\n\n \n\n
\n \n
\n \n
\n
\n
\n \n \n Vaughn\n \n\n
\n\n \n \n\n
\n \n
\n\n
\n
\n \n \n \n
\n \n
\n\n
\n \n
\n \n
\n \n \n In stock\n \n
\n
\n\n\n\n\n \n
\n \n \n \n
\n
\n +\n \n −\n
\n
\n
\n \n\n\n\n \n \n\n\n
\n \n \n\n \n \n\n
\n \n
\n\n\n\n\n\n\n\n \n \n \n\n\n \n\n\n\n\n\n\n \n \n \n Contact Seller\n\n\n\n\n\n
\n\n\n \n\n \n
\n \n ", + "authorImage": "https://bazar.preciousplastic.com/images/thumbnails/180/80/logos/2/PP_Veldhoven.png", + "images": [ + "https://bazar.preciousplastic.com/images/thumbnails/700/490/detailed/17/Extruder_and_barrel.jpg", + "https://bazar.preciousplastic.com/images/thumbnails/700/604/detailed/17/Fixture.PNG", + "https://bazar.preciousplastic.com/images/thumbnails/700/482/detailed/17/3D_model.PNG" + ], + "content": null, + "url": "https://bazar.preciousplastic.com/machines/injection/injection-parts/injection-barrel/", + "prefix": "machines/injection/parts" +} \ No newline at end of file diff --git a/packages/kbot/tests/test-data/files/glob/data2.json b/packages/kbot/tests/test-data/files/glob/data2.json new file mode 100644 index 00000000..5f8041dc --- /dev/null +++ b/packages/kbot/tests/test-data/files/glob/data2.json @@ -0,0 +1,21 @@ +{ + "title": "HIGH-QUALITY INJECTION BY CPTEK LAB", + "price": "3,578.00", + "storeName": "CPTek", + "storeLink": "https://bazar.preciousplastic.com/conceptos-plasticos/", + "mediaHTML": "\n\n \n \n\n \n \n \n \n
\n \n\n\n \n\n \n\n \n\n \n\n
\n\n \n \n\n\n\n\n\n\n\n ", + "description": "\n \n

Our semi-automatic injection molding machine is ideal for manufacturing lightweight parts with precision and efficiency, perfect for entrepreneurs, small workshops and educational projects. Its compact vertical design offers innovative recycling solutions in small spaces.

\n\n \n ", + "features": "\n \n \n
\n
Condition:
\n\n \n
New
\n
\n \n
\n
Country of Origin:
\n\n \n
COLOMBIA
\n
\n \n
\n
Dimensions of the listing:
\n\n \n
200 X 45 X 62 CM
\n
\n \n
\n
Frequency (Hz):
\n\n \n
60 Hz
\n
\n \n
\n
Made according to the Precious Plastic drawings? :
\n\n \n
No
\n
\n \n
\n
Plug type:
\n\n \n
  • Type A: USA, Canada, Mexico and Japan
\n
\n \n
\n
Voltage:
\n\n \n
110V
\n
\n \n
\n
Weight (KG):
\n\n \n
70KG
\n
\n \n \n \n ", + "options": "\n\n\n\n\n\n \n

HIGH-QUALITY INJECTION BY CPTEK LAB

\n \n \n \n
\n \n\n\n
\n \n\n \n\n \n\n\n \n \n \n\n\n
\n
\n \n \n \n\n \n \n
\n \n \n \n \n €3,578.00\n \n\n \n\n
\n \n \n \n \n \n \n \n
\n
\n \n \n\n\n\n
\n
\n \n \n \n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n\n\n\n\n \n\n
\n \n
\n \n
\n
\n
\n \n \n CPTek\n \n\n
\n\n \n \n\n
\n \n
\n\n
\n
\n \n \n \n
\n \n
\n\n
\n \n
\n \n
\n \n \n In stock\n \n
\n
\n\n\n\n\n \n
\n \n \n \n
\n
\n +\n \n −\n
\n
\n
\n \n\n\n\n \n \n\n\n
\n \n \n\n \n \n\n
\n \n
\n\n\n\n\n\n\n\n \n \n \n\n\n \n\n\n\n\n\n\n \n \n \n Contact Seller\n\n\n\n\n\n
\n\n\n \n\n \n
\n \n ", + "authorImage": "https://bazar.preciousplastic.com/images/thumbnails/180/80/logos/22/cart_msc1-3l_cbx4-ai.png", + "images": [ + "https://bazar.preciousplastic.com/images/thumbnails/700/982/detailed/23/_1_.jpg", + "https://bazar.preciousplastic.com/images/thumbnails/700/1050/detailed/23/_5_.png", + "https://bazar.preciousplastic.com/images/thumbnails/700/930/detailed/23/_4_.png", + "https://bazar.preciousplastic.com/images/thumbnails/700/2013/detailed/23/_2_.jpg", + "https://bazar.preciousplastic.com/images/thumbnails/700/829/detailed/23/_3_.jpg" + ], + "content": null, + "url": "https://bazar.preciousplastic.com/machines/injection/injection-kits/high-quality-injection-by-cptek-lab/", + "prefix": "machines/injection/kits" +} \ No newline at end of file diff --git a/packages/kbot/tests/test-data/files/lazyfox.jpg b/packages/kbot/tests/test-data/files/lazyfox.jpg new file mode 100644 index 00000000..3c5c9971 Binary files /dev/null and b/packages/kbot/tests/test-data/files/lazyfox.jpg differ diff --git a/packages/kbot/tests/unit/basic.test.ts b/packages/kbot/tests/unit/basic.test.ts index 81d607b7..f7841590 100644 --- a/packages/kbot/tests/unit/basic.test.ts +++ b/packages/kbot/tests/unit/basic.test.ts @@ -26,7 +26,7 @@ describe('Basic Operations', () => { it.each(models)('should add two numbers with model %s', async (modelName) => { const result = await runTest( 'add 5 and 3. Return only the number, no explanation.', - '8', + '8', 'addition', modelName, TEST_LOG_PATH diff --git a/packages/kbot/tests/unit/commons.ts b/packages/kbot/tests/unit/commons.ts index 51dab179..39c2a0cc 100644 --- a/packages/kbot/tests/unit/commons.ts +++ b/packages/kbot/tests/unit/commons.ts @@ -11,7 +11,8 @@ export enum ModelCategory { LANGUAGE = 'language', TOOL = 'tool', ALL = 'all', - CODING = 'coding' + CODING = 'coding', + FILES = 'file' } export const getFastModels = (): string[] => { @@ -29,6 +30,14 @@ export const getCodingModels = (): string[] => { ] } +export const getFileModels = (): string[] => { + return [ + E_OPENROUTER_MODEL.MODEL_OPENAI_GPT_4O_MINI, + E_OPENROUTER_MODEL.MODEL_OPENROUTER_QUASAR_ALPHA, + E_OPENROUTER_MODEL.MODEL_GOOGLE_GEMINI_2_0_FLASH_EXP_FREE + ] +} + export const getLanguageModels = (): string[] => { return [ E_OPENROUTER_MODEL.MODEL_ANTHROPIC_CLAUDE_3_5_SONNET, @@ -54,6 +63,8 @@ export const getDefaultModels = (category: ModelCategory = ModelCategory.FAST): return getToolModels() case ModelCategory.CODING: return getCodingModels() + case ModelCategory.FILES: + return getFileModels() case ModelCategory.ALL: default: return [ diff --git a/packages/kbot/tests/unit/files.test.ts b/packages/kbot/tests/unit/files.test.ts new file mode 100644 index 00000000..53cbb428 --- /dev/null +++ b/packages/kbot/tests/unit/files.test.ts @@ -0,0 +1,132 @@ +import { describe, it, expect } from 'vitest' +import * as path from 'node:path' +import { sync as exists } from "@polymech/fs/exists" +import { sync as read } from "@polymech/fs/read" + +import { + getDefaultModels, + TEST_BASE_PATH, + TEST_LOGS_PATH, + TEST_PREFERENCES_PATH, + TEST_TIMEOUT, + TestResult, + runTest, + generateTestReport, + getReportPaths, + ModelCategory +} from './commons' +import { IKBotOptions } from '@polymech/commons' + +// Optionally override models for this specific test file +const models = getDefaultModels(ModelCategory.FILES) + +describe('File Operations', () => { + let testResults: TestResult[] = [] + const TEST_LOG_PATH = getReportPaths('files', 'json') + const TEST_REPORT_PATH = getReportPaths('files', 'md') + + it.each(models)('should process single file with model %s', async (modelName) => { + const result = await runTest( + 'What is the name of the algorithm implemented in these files? Return only the name.', + 'bubble sort', + 'file-inclusion', + modelName, + TEST_LOG_PATH, + 'completion', + { include: ['tests/test-data/files/bubblesort.js'] } + ) + testResults.push(result) + expect(result.result[0]?.trim()?.toLowerCase()).toContain('bubble') + }, { timeout: TEST_TIMEOUT }) + + + it.each(models)('should process multiple files with model %s', async (modelName) => { + console.log('Starting test for model:', modelName) + console.log('About to run test with debugger') + + const result = await runTest( + 'List all algorithms implemented in these files, as JSON array.', + '["bubble sort","factorial"]', + 'file-inclusion', + modelName, + TEST_LOG_PATH, + 'completion', + { + include: ['./tests/test-data/files/*.js'], + logLevel: 2, + format: { + type: "object", + properties: { + algorithms: { + type: "array", + items: { + type: "string" + }, + minItems: 2, + maxItems: 2 + } + }, + required: ["algorithms"] + } + } as IKBotOptions + ) + testResults.push(result) + const parsedResult = JSON.parse(result.result[0]?.trim()) + expect(parsedResult.includes('bubble')) + expect(parsedResult.includes('factorial')) + expect(parsedResult).toHaveLength(2) + }, { timeout: TEST_TIMEOUT }) + + it.each(models)('should process files in glob subdirectory with model %s', async (modelName) => { + const result = await runTest( + 'What is the title of the product in data.json? Return only the title.', + 'Injection Barrel', + 'file-inclusion', + modelName, + TEST_LOG_PATH, + 'completion', + { include: ['tests/test-data/files/glob/data.json'] } + ) + testResults.push(result) + expect(result.result[0]?.trim()).toBe('Injection Barrel') + }, { timeout: TEST_TIMEOUT }) + + it.each(models)('should identify animals in image files with model %s', async (modelName) => { + const result = await runTest( + 'What animals are shown in these images? Return as JSON array.', + '["cat","fox"]', + 'file-inclusion', + modelName, + TEST_LOG_PATH, + 'completion', + { + include: ['tests/test-data/files/lazyfox.jpg'], + logLevel: 2, + format: { + type: "object", + properties: { + animals: { + type: "array", + items: { + type: "string" + }, + minItems: 2, + maxItems: 2 + } + }, + required: ["animals"] + } + } as IKBotOptions + ) + testResults.push(result) + const parsedResult = JSON.parse(result.result[0]?.trim()) + expect(parsedResult.includes('cat')) + expect(parsedResult.includes('fox')) + expect(parsedResult.length==2) + }, { timeout: TEST_TIMEOUT }) + + it('should generate markdown report', () => { + generateTestReport(testResults, 'File Operations Test Results', TEST_REPORT_PATH) + expect(exists(TEST_REPORT_PATH) === 'file').toBe(true) + }) +}) \ No newline at end of file diff --git a/packages/kbot/tests/unit/logs/completion.json b/packages/kbot/tests/unit/logs/completion.json deleted file mode 100644 index 3ecd90c6..00000000 --- a/packages/kbot/tests/unit/logs/completion.json +++ /dev/null @@ -1,694 +0,0 @@ -[ - { - "level": "debug", - "message": { - "id": "gen-1743630981-Ui1Cks6yDC82puC81x2r", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743630981, - "choices": [ - { - "logprobs": null, - "finish_reason": "stop", - "native_finish_reason": "stop", - "index": 0, - "message": { - "role": "assistant", - "content": "Let's solve each of these equations step by step:\n\n1. **Equation 1: \\(2x + 5 = 13\\)**\n\n \\[\n 2x + 5 = 13\n \\]\n\n First, subtract 5 from both sides to isolate the term with \\(x\\):\n\n \\[\n 2x = 13 - 5\n \\]\n\n \\[\n 2x = 8\n \\]\n\n Next, divide both sides by 2 to solve for \\(x\\):\n\n \\[\n x = \\frac{8}{2}\n \\]\n\n \\[\n x = 4\n \\]\n\n2. **Equation 2: \\(3y - 7 = 20\\)**\n\n \\[\n 3y - 7 = 20\n \\]\n\n First, add 7 to both sides to isolate the term with \\(y\\):\n\n \\[\n 3y = 20 + 7\n \\]\n\n \\[\n 3y = 27\n \\]\n\n Next, divide both sides by 3 to solve for \\(y\\):\n\n \\[\n y = \\frac{27}{3}\n \\]\n\n \\[\n y = 9\n \\]\n\n3. **Equation 3: \\(4z + 8 = 32\\)**\n\n \\[\n 4z + 8 = 32\n \\]\n\n First, subtract 8 from both sides to isolate the term with \\(z\\):\n\n \\[\n 4z = 32 - 8\n \\]\n\n \\[\n 4z = 24\n \\]\n\n Next, divide both sides by 4 to solve for \\(z\\):\n\n \\[\n z = \\frac{24}{4}\n \\]\n\n \\[\n z = 6\n \\]\n\nThe solutions to the equations are indeed \\(x = 4\\), \\(y = 9\\), and \\(z = 6\\), which match the results you provided.", - "refusal": null, - "parsed": null - } - } - ], - "system_fingerprint": "fp_6dd05565ef", - "usage": { - "prompt_tokens": 139, - "completion_tokens": 434, - "total_tokens": 573, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:56:24.861Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743630985-jop6l4mg8eqlwxxrtsU3", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743630985, - "choices": [ - { - "logprobs": null, - "finish_reason": "stop", - "native_finish_reason": "stop", - "index": 0, - "message": { - "role": "assistant", - "content": "To write the JSON data to the specified file and then read it back, you can perform the following steps in Python. The Python script uses local file I/O to write and read the JSON data:\n\n1. **Write the JSON data** to the file.\n2. **Read the JSON data** back from the file.\n\nHere is the Python code to achieve this:\n\n```python\nimport json\nimport os\n\n# JSON data\ndata = {\"test\": \"data\", \"timestamp\": \"2025-04-02t21:56:24.883z\"}\n\n# File path\nfile_path = r\"C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json\"\n\n# Ensure the directory exists\nos.makedirs(os.path.dirname(file_path), exist_ok=True)\n\n# Write JSON data to the file\nwith open(file_path, 'w') as file:\n json.dump(data, file, indent=4)\n\n# Read the JSON data back from the file\nwith open(file_path, 'r') as file:\n read_data = json.load(file)\n print(read_data)\n```\n\n### Explanation:\n\n- `json.dump()` is used to write the JSON data to a file.\n- `json.load()` is used to read the JSON data back from the file.\n- `os.makedirs()` ensures that the directory path exists before writing the file. The `exist_ok=True` parameter prevents raising an exception if the directory already exists.\n- The `indent=4` parameter in `json.dump()` makes the JSON output more readable by pretty-printing it with indentation.\n\nPlease ensure that the specified file path is correct and that your Python environment has the necessary permissions to write to this path.", - "refusal": null, - "parsed": null - } - } - ], - "system_fingerprint": "fp_de57b65c90", - "usage": { - "prompt_tokens": 78, - "completion_tokens": 362, - "total_tokens": 440, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:56:29.189Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743630989-BpECy5n3TbfFuNSbqegq", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743630989, - "choices": [ - { - "logprobs": null, - "finish_reason": "stop", - "native_finish_reason": "stop", - "index": 0, - "message": { - "role": "assistant", - "content": "I'm unable to access or browse files on your computer or any external systems. However, I can guide you on how to list all the files in a specific directory using the command line or a script.\n\n### Using Command Prompt on Windows:\n\n1. Open Command Prompt by typing `cmd` in the Start menu and pressing Enter.\n2. Navigate to the directory by typing:\n ```\n cd C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\n ```\n3. To list all files, type:\n ```\n dir\n ```\n\n### Using Windows PowerShell:\n\n1. Open PowerShell by searching for it in the Start menu.\n2. Navigate to the directory by typing:\n ```powershell\n Set-Location -Path 'C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data'\n ```\n3. To list all files, use:\n ```powershell\n Get-ChildItem\n ```\n\n### Using a Python Script:\n\nYou can also write a simple Python script to list the files:\n\n```python\nimport os\n\ndirectory = r'C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data'\n\nfor filename in os.listdir(directory):\n print(filename)\n```\n\nChoose the method that best suits your needs. If you have any questions or need further assistance, feel free to ask!", - "refusal": null, - "parsed": null - } - } - ], - "system_fingerprint": "fp_726d488742", - "usage": { - "prompt_tokens": 49, - "completion_tokens": 319, - "total_tokens": 368, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:56:32.923Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631031-TEPvmBQ8xnWyvb04vIQ1", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631031, - "choices": [ - { - "logprobs": null, - "finish_reason": "stop", - "native_finish_reason": "stop", - "index": 0, - "message": { - "role": "assistant", - "content": "It looks like there's an issue specific to your request that involves accessing files on your local machine, which I can't do. However, you can manually provide me with the equations, and I will solve them for you. Here are solutions to the sample equations you provided:\n\n1. \\(2x + 5 = 13\\)\n\n To solve for \\(x\\), subtract 5 from both sides:\n \\[\n 2x = 13 - 5\n \\]\n \\[\n 2x = 8\n \\]\n Now, divide by 2:\n \\[\n x = \\frac{8}{2} = 4\n \\]\n\n2. \\(3y - 7 = 20\\)\n\n To solve for \\(y\\), add 7 to both sides:\n \\[\n 3y = 20 + 7\n \\]\n \\[\n 3y = 27\n \\]\n Now, divide by 3:\n \\[\n y = \\frac{27}{3} = 9\n \\]\n\n3. \\(4z + 8 = 32\\)\n\n To solve for \\(z\\), subtract 8 from both sides:\n \\[\n 4z = 32 - 8\n \\]\n \\[\n 4z = 24\n \\]\n Now, divide by 4:\n \\[\n z = \\frac{24}{4} = 6\n \\]\n\nIf you have other equations, please provide them here, and I'd be happy to solve those as well.", - "refusal": null, - "parsed": null - } - } - ], - "system_fingerprint": "fp_6dd05565ef", - "usage": { - "prompt_tokens": 139, - "completion_tokens": 336, - "total_tokens": 475, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:57:14.989Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631035-irYWrkVOuFctO9yuFPSp", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631035, - "choices": [ - { - "logprobs": null, - "finish_reason": "stop", - "native_finish_reason": "stop", - "index": 0, - "message": { - "role": "assistant", - "content": "To write JSON data to a file and read it back in a Windows environment using Python, you can follow these steps. Below is a Python script that performs this task:\n\n```python\nimport json\nimport os\n\n# Define the file path\nfile_path = r'C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json'\n\n# JSON data to write\ndata_to_write = {\n \"test\": \"data\",\n \"timestamp\": \"2025-04-02t21:57:15.012z\"\n}\n\n# Write JSON data to the file\nwith open(file_path, 'w') as file:\n json.dump(data_to_write, file, indent=4)\n\n# Read JSON data back from the file\nwith open(file_path, 'r') as file:\n data_read = json.load(file)\n\n# Print the data read from the file\nprint(data_read)\n```\n\n### Explanation:\n\n1. **Import Necessary Modules**: We import the `json` module for handling JSON data and `os` module if needed for path operations.\n\n2. **Define the File Path**: The `file_path` variable holds the path where we want to save and read the JSON file. Make sure that all the directories in the path exist.\n\n3. **JSON Data Definition**: The `data_to_write` dictionary contains the JSON data you want to store.\n\n4. **Write JSON Data**: Using `json.dump()`, we write the JSON data to a file. The `indent=4` argument ensures the file is formatted nicely.\n\n5. **Read JSON Data**: We open the file in read mode and use `json.load()` to read the data back into a Python dictionary.\n\n6. **Print the Data**: Finally, we print the data to confirm that it was read correctly.\n\nMake sure you have the necessary file write permissions and the directory structure exists. If any directories are missing, you'll need to create them before running the script.", - "refusal": null, - "parsed": null - } - } - ], - "system_fingerprint": "fp_6dd05565ef", - "usage": { - "prompt_tokens": 78, - "completion_tokens": 421, - "total_tokens": 499, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:57:20.822Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631041-sxD3N0lo3vBaYvwpc4DN", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631041, - "choices": [ - { - "logprobs": null, - "finish_reason": "stop", - "native_finish_reason": "stop", - "index": 0, - "message": { - "role": "assistant", - "content": "I'm unable to browse or list files on your local machine or any external systems. However, you can view the files in the specified directory by following these steps:\n\n1. Open File Explorer on your Windows machine.\n2. Navigate to `C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data`.\n3. You will see the list of files present in that directory.\n\nIf you need assistance with any specific file or task related to these files, feel free to ask!", - "refusal": null, - "parsed": null - } - } - ], - "system_fingerprint": "fp_726d488742", - "usage": { - "prompt_tokens": 49, - "completion_tokens": 112, - "total_tokens": 161, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:57:22.998Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631057-dXPQgGzrR5LGaSS5OBTT", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631057, - "choices": [ - { - "logprobs": null, - "finish_reason": "tool_calls", - "native_finish_reason": "tool_calls", - "index": 0, - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_Nz1V2egRr4OCdgNP9hSuMqkI", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null - } - } - ], - "system_fingerprint": "fp_6dd05565ef", - "usage": { - "prompt_tokens": 773, - "completion_tokens": 49, - "total_tokens": 822, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:57:39.218Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631106-ozgqEgJqsntkf58bE1ON", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631106, - "choices": [ - { - "logprobs": null, - "finish_reason": "tool_calls", - "native_finish_reason": "tool_calls", - "index": 0, - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_ZcofgyYvRZycqe5i9v00OW1a", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null - } - } - ], - "system_fingerprint": "fp_898ac29719", - "usage": { - "prompt_tokens": 773, - "completion_tokens": 49, - "total_tokens": 822, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:58:27.885Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631108-Q7OlFgo1GXwsrz9ZjSeI", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631108, - "choices": [ - { - "logprobs": null, - "finish_reason": "tool_calls", - "native_finish_reason": "tool_calls", - "index": 0, - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_bR4C5jbZCSLJ2HXCF68kcH7k", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null - } - } - ], - "system_fingerprint": "fp_898ac29719", - "usage": { - "prompt_tokens": 868, - "completion_tokens": 49, - "total_tokens": 917, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:58:29.963Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631110-Uzpdnyxx46oCLkIAYh6a", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631110, - "choices": [ - { - "logprobs": null, - "finish_reason": "tool_calls", - "native_finish_reason": "tool_calls", - "index": 0, - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_bRWTWRqxjiVUFLZtAUo0ywn6", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null - } - } - ], - "system_fingerprint": "fp_898ac29719", - "usage": { - "prompt_tokens": 963, - "completion_tokens": 49, - "total_tokens": 1012, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:58:32.838Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631113-7ewJ4tlprslgS4ZsTOi8", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631113, - "choices": [ - { - "logprobs": null, - "finish_reason": "stop", - "native_finish_reason": "stop", - "index": 0, - "message": { - "role": "assistant", - "content": "It seems there's an issue reading the file. Let's solve the sample equations provided:\n\n1. Solve \\(2x + 5 = 13\\):\n \\[\n 2x + 5 = 13 \\\\\n 2x = 13 - 5 \\\\\n 2x = 8 \\\\\n x = \\frac{8}{2} \\\\\n x = 4\n \\]\n\n2. Solve \\(3y - 7 = 20\\):\n \\[\n 3y - 7 = 20 \\\\\n 3y = 20 + 7 \\\\\n 3y = 27 \\\\\n y = \\frac{27}{3} \\\\\n y = 9\n \\]\n\n3. Solve \\(4z + 8 = 32\\):\n \\[\n 4z + 8 = 32 \\\\\n 4z = 32 - 8 \\\\\n 4z = 24 \\\\\n z = \\frac{24}{4} \\\\\n z = 6\n \\]\n\nThe solutions for the equations are \\(x = 4\\), \\(y = 9\\), and \\(z = 6\\), which match the test preferences provided.", - "refusal": null, - "parsed": null - } - } - ], - "system_fingerprint": "fp_898ac29719", - "usage": { - "prompt_tokens": 1058, - "completion_tokens": 266, - "total_tokens": 1324, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:58:37.074Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631117-mzDobMKRdGgUwQk516dc", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631117, - "choices": [ - { - "logprobs": null, - "finish_reason": "tool_calls", - "native_finish_reason": "tool_calls", - "index": 0, - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_UBPjOY0FqjXD0jLHriQuPuMw", - "type": "function", - "function": { - "name": "write_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\test-data.json\",\"content\":\"eyJ0ZXN0IjoiZGF0YSIsInRpbWVzdGFtcCI6IjIwMjUtMDQtMDJUMjE6NTg6MzcuMDk1WiJ9\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null - } - } - ], - "system_fingerprint": "fp_898ac29719", - "usage": { - "prompt_tokens": 712, - "completion_tokens": 97, - "total_tokens": 809, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:58:39.839Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631120-LAcQkBwjTPY4Ho8kcFAF", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631120, - "choices": [ - { - "logprobs": null, - "finish_reason": "tool_calls", - "native_finish_reason": "tool_calls", - "index": 0, - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_pIwhdVPXqnTlfyQz7hZoALrw", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\test-data.json\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null - } - } - ], - "system_fingerprint": "fp_6dd05565ef", - "usage": { - "prompt_tokens": 903, - "completion_tokens": 49, - "total_tokens": 952, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:58:41.861Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631122-FWA3dqCLKmt8j8VZDLk1", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631122, - "choices": [ - { - "logprobs": null, - "finish_reason": "stop", - "native_finish_reason": "stop", - "index": 0, - "message": { - "role": "assistant", - "content": "The content of the file `test-data.json` has been successfully written and read back:\n\n```json\n{\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"}\n```", - "refusal": null, - "parsed": null - } - } - ], - "system_fingerprint": "fp_6dd05565ef", - "usage": { - "prompt_tokens": 998, - "completion_tokens": 47, - "total_tokens": 1045, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:58:43.202Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631123-uocGbvEEvH6vpHRoHByM", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631123, - "choices": [ - { - "logprobs": null, - "finish_reason": "tool_calls", - "native_finish_reason": "tool_calls", - "index": 0, - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_mmLKD2FDdNm1znzU1nVTK1ga", - "type": "function", - "function": { - "name": "list_files", - "arguments": "{\"directory\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\"}", - "parsed_arguments": null - } - } - ], - "parsed": null - } - } - ], - "system_fingerprint": "fp_898ac29719", - "usage": { - "prompt_tokens": 683, - "completion_tokens": 43, - "total_tokens": 726, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:58:45.106Z", - "service": "collector:onChatCompletion" - }, - { - "level": "debug", - "message": { - "id": "gen-1743631125-OGtG0QQwt7Azex9vNPBl", - "provider": "OpenAI", - "model": "openai/gpt-4o", - "object": "chat.completion", - "created": 1743631125, - "choices": [ - { - "logprobs": null, - "finish_reason": "stop", - "native_finish_reason": "stop", - "index": 0, - "message": { - "role": "assistant", - "content": "There are no files in the directory: `C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data`.", - "refusal": null, - "parsed": null - } - } - ], - "system_fingerprint": "fp_898ac29719", - "usage": { - "prompt_tokens": 766, - "completion_tokens": 41, - "total_tokens": 807, - "prompt_tokens_details": { - "cached_tokens": 0 - }, - "completion_tokens_details": { - "reasoning_tokens": 0 - } - } - }, - "timestamp": "2025-04-02T21:58:46.313Z", - "service": "collector:onChatCompletion" - } -] \ No newline at end of file diff --git a/packages/kbot/tests/unit/logs/content.json b/packages/kbot/tests/unit/logs/content.json deleted file mode 100644 index 808e41ce..00000000 --- a/packages/kbot/tests/unit/logs/content.json +++ /dev/null @@ -1,56 +0,0 @@ -[ - { - "level": "debug", - "message": "Let's solve each of these equations step by step:\n\n1. **Equation 1: \\(2x + 5 = 13\\)**\n\n \\[\n 2x + 5 = 13\n \\]\n\n First, subtract 5 from both sides to isolate the term with \\(x\\):\n\n \\[\n 2x = 13 - 5\n \\]\n\n \\[\n 2x = 8\n \\]\n\n Next, divide both sides by 2 to solve for \\(x\\):\n\n \\[\n x = \\frac{8}{2}\n \\]\n\n \\[\n x = 4\n \\]\n\n2. **Equation 2: \\(3y - 7 = 20\\)**\n\n \\[\n 3y - 7 = 20\n \\]\n\n First, add 7 to both sides to isolate the term with \\(y\\):\n\n \\[\n 3y = 20 + 7\n \\]\n\n \\[\n 3y = 27\n \\]\n\n Next, divide both sides by 3 to solve for \\(y\\):\n\n \\[\n y = \\frac{27}{3}\n \\]\n\n \\[\n y = 9\n \\]\n\n3. **Equation 3: \\(4z + 8 = 32\\)**\n\n \\[\n 4z + 8 = 32\n \\]\n\n First, subtract 8 from both sides to isolate the term with \\(z\\):\n\n \\[\n 4z = 32 - 8\n \\]\n\n \\[\n 4z = 24\n \\]\n\n Next, divide both sides by 4 to solve for \\(z\\):\n\n \\[\n z = \\frac{24}{4}\n \\]\n\n \\[\n z = 6\n \\]\n\nThe solutions to the equations are indeed \\(x = 4\\), \\(y = 9\\), and \\(z = 6\\), which match the results you provided.", - "timestamp": "2025-04-02T21:56:24.863Z", - "service": "collector:onContent" - }, - { - "level": "debug", - "message": "To write the JSON data to the specified file and then read it back, you can perform the following steps in Python. The Python script uses local file I/O to write and read the JSON data:\n\n1. **Write the JSON data** to the file.\n2. **Read the JSON data** back from the file.\n\nHere is the Python code to achieve this:\n\n```python\nimport json\nimport os\n\n# JSON data\ndata = {\"test\": \"data\", \"timestamp\": \"2025-04-02t21:56:24.883z\"}\n\n# File path\nfile_path = r\"C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json\"\n\n# Ensure the directory exists\nos.makedirs(os.path.dirname(file_path), exist_ok=True)\n\n# Write JSON data to the file\nwith open(file_path, 'w') as file:\n json.dump(data, file, indent=4)\n\n# Read the JSON data back from the file\nwith open(file_path, 'r') as file:\n read_data = json.load(file)\n print(read_data)\n```\n\n### Explanation:\n\n- `json.dump()` is used to write the JSON data to a file.\n- `json.load()` is used to read the JSON data back from the file.\n- `os.makedirs()` ensures that the directory path exists before writing the file. The `exist_ok=True` parameter prevents raising an exception if the directory already exists.\n- The `indent=4` parameter in `json.dump()` makes the JSON output more readable by pretty-printing it with indentation.\n\nPlease ensure that the specified file path is correct and that your Python environment has the necessary permissions to write to this path.", - "timestamp": "2025-04-02T21:56:29.191Z", - "service": "collector:onContent" - }, - { - "level": "debug", - "message": "I'm unable to access or browse files on your computer or any external systems. However, I can guide you on how to list all the files in a specific directory using the command line or a script.\n\n### Using Command Prompt on Windows:\n\n1. Open Command Prompt by typing `cmd` in the Start menu and pressing Enter.\n2. Navigate to the directory by typing:\n ```\n cd C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\n ```\n3. To list all files, type:\n ```\n dir\n ```\n\n### Using Windows PowerShell:\n\n1. Open PowerShell by searching for it in the Start menu.\n2. Navigate to the directory by typing:\n ```powershell\n Set-Location -Path 'C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data'\n ```\n3. To list all files, use:\n ```powershell\n Get-ChildItem\n ```\n\n### Using a Python Script:\n\nYou can also write a simple Python script to list the files:\n\n```python\nimport os\n\ndirectory = r'C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data'\n\nfor filename in os.listdir(directory):\n print(filename)\n```\n\nChoose the method that best suits your needs. If you have any questions or need further assistance, feel free to ask!", - "timestamp": "2025-04-02T21:56:32.925Z", - "service": "collector:onContent" - }, - { - "level": "debug", - "message": "It looks like there's an issue specific to your request that involves accessing files on your local machine, which I can't do. However, you can manually provide me with the equations, and I will solve them for you. Here are solutions to the sample equations you provided:\n\n1. \\(2x + 5 = 13\\)\n\n To solve for \\(x\\), subtract 5 from both sides:\n \\[\n 2x = 13 - 5\n \\]\n \\[\n 2x = 8\n \\]\n Now, divide by 2:\n \\[\n x = \\frac{8}{2} = 4\n \\]\n\n2. \\(3y - 7 = 20\\)\n\n To solve for \\(y\\), add 7 to both sides:\n \\[\n 3y = 20 + 7\n \\]\n \\[\n 3y = 27\n \\]\n Now, divide by 3:\n \\[\n y = \\frac{27}{3} = 9\n \\]\n\n3. \\(4z + 8 = 32\\)\n\n To solve for \\(z\\), subtract 8 from both sides:\n \\[\n 4z = 32 - 8\n \\]\n \\[\n 4z = 24\n \\]\n Now, divide by 4:\n \\[\n z = \\frac{24}{4} = 6\n \\]\n\nIf you have other equations, please provide them here, and I'd be happy to solve those as well.", - "timestamp": "2025-04-02T21:57:14.991Z", - "service": "collector:onContent" - }, - { - "level": "debug", - "message": "To write JSON data to a file and read it back in a Windows environment using Python, you can follow these steps. Below is a Python script that performs this task:\n\n```python\nimport json\nimport os\n\n# Define the file path\nfile_path = r'C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json'\n\n# JSON data to write\ndata_to_write = {\n \"test\": \"data\",\n \"timestamp\": \"2025-04-02t21:57:15.012z\"\n}\n\n# Write JSON data to the file\nwith open(file_path, 'w') as file:\n json.dump(data_to_write, file, indent=4)\n\n# Read JSON data back from the file\nwith open(file_path, 'r') as file:\n data_read = json.load(file)\n\n# Print the data read from the file\nprint(data_read)\n```\n\n### Explanation:\n\n1. **Import Necessary Modules**: We import the `json` module for handling JSON data and `os` module if needed for path operations.\n\n2. **Define the File Path**: The `file_path` variable holds the path where we want to save and read the JSON file. Make sure that all the directories in the path exist.\n\n3. **JSON Data Definition**: The `data_to_write` dictionary contains the JSON data you want to store.\n\n4. **Write JSON Data**: Using `json.dump()`, we write the JSON data to a file. The `indent=4` argument ensures the file is formatted nicely.\n\n5. **Read JSON Data**: We open the file in read mode and use `json.load()` to read the data back into a Python dictionary.\n\n6. **Print the Data**: Finally, we print the data to confirm that it was read correctly.\n\nMake sure you have the necessary file write permissions and the directory structure exists. If any directories are missing, you'll need to create them before running the script.", - "timestamp": "2025-04-02T21:57:20.824Z", - "service": "collector:onContent" - }, - { - "level": "debug", - "message": "I'm unable to browse or list files on your local machine or any external systems. However, you can view the files in the specified directory by following these steps:\n\n1. Open File Explorer on your Windows machine.\n2. Navigate to `C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data`.\n3. You will see the list of files present in that directory.\n\nIf you need assistance with any specific file or task related to these files, feel free to ask!", - "timestamp": "2025-04-02T21:57:23.000Z", - "service": "collector:onContent" - }, - { - "level": "debug", - "message": "It seems there's an issue reading the file. Let's solve the sample equations provided:\n\n1. Solve \\(2x + 5 = 13\\):\n \\[\n 2x + 5 = 13 \\\\\n 2x = 13 - 5 \\\\\n 2x = 8 \\\\\n x = \\frac{8}{2} \\\\\n x = 4\n \\]\n\n2. Solve \\(3y - 7 = 20\\):\n \\[\n 3y - 7 = 20 \\\\\n 3y = 20 + 7 \\\\\n 3y = 27 \\\\\n y = \\frac{27}{3} \\\\\n y = 9\n \\]\n\n3. Solve \\(4z + 8 = 32\\):\n \\[\n 4z + 8 = 32 \\\\\n 4z = 32 - 8 \\\\\n 4z = 24 \\\\\n z = \\frac{24}{4} \\\\\n z = 6\n \\]\n\nThe solutions for the equations are \\(x = 4\\), \\(y = 9\\), and \\(z = 6\\), which match the test preferences provided.", - "timestamp": "2025-04-02T21:58:37.076Z", - "service": "collector:onContent" - }, - { - "level": "debug", - "message": "The content of the file `test-data.json` has been successfully written and read back:\n\n```json\n{\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"}\n```", - "timestamp": "2025-04-02T21:58:43.204Z", - "service": "collector:onContent" - }, - { - "level": "debug", - "message": "There are no files in the directory: `C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data`.", - "timestamp": "2025-04-02T21:58:46.315Z", - "service": "collector:onContent" - } -] \ No newline at end of file diff --git a/packages/kbot/tests/unit/logs/openai-message.json b/packages/kbot/tests/unit/logs/openai-message.json deleted file mode 100644 index 93dd31e8..00000000 --- a/packages/kbot/tests/unit/logs/openai-message.json +++ /dev/null @@ -1,401 +0,0 @@ -[ - { - "level": "info", - "message": { - "role": "assistant", - "content": "Let's solve each of these equations step by step:\n\n1. **Equation 1: \\(2x + 5 = 13\\)**\n\n \\[\n 2x + 5 = 13\n \\]\n\n First, subtract 5 from both sides to isolate the term with \\(x\\):\n\n \\[\n 2x = 13 - 5\n \\]\n\n \\[\n 2x = 8\n \\]\n\n Next, divide both sides by 2 to solve for \\(x\\):\n\n \\[\n x = \\frac{8}{2}\n \\]\n\n \\[\n x = 4\n \\]\n\n2. **Equation 2: \\(3y - 7 = 20\\)**\n\n \\[\n 3y - 7 = 20\n \\]\n\n First, add 7 to both sides to isolate the term with \\(y\\):\n\n \\[\n 3y = 20 + 7\n \\]\n\n \\[\n 3y = 27\n \\]\n\n Next, divide both sides by 3 to solve for \\(y\\):\n\n \\[\n y = \\frac{27}{3}\n \\]\n\n \\[\n y = 9\n \\]\n\n3. **Equation 3: \\(4z + 8 = 32\\)**\n\n \\[\n 4z + 8 = 32\n \\]\n\n First, subtract 8 from both sides to isolate the term with \\(z\\):\n\n \\[\n 4z = 32 - 8\n \\]\n\n \\[\n 4z = 24\n \\]\n\n Next, divide both sides by 4 to solve for \\(z\\):\n\n \\[\n z = \\frac{24}{4}\n \\]\n\n \\[\n z = 6\n \\]\n\nThe solutions to the equations are indeed \\(x = 4\\), \\(y = 9\\), and \\(z = 6\\), which match the results you provided.", - "refusal": null, - "parsed": null, - "timestamp": "2025-04-02T21:56:24.862Z", - "sessionId": "1743630981203", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:56:24.862Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "To write the JSON data to the specified file and then read it back, you can perform the following steps in Python. The Python script uses local file I/O to write and read the JSON data:\n\n1. **Write the JSON data** to the file.\n2. **Read the JSON data** back from the file.\n\nHere is the Python code to achieve this:\n\n```python\nimport json\nimport os\n\n# JSON data\ndata = {\"test\": \"data\", \"timestamp\": \"2025-04-02t21:56:24.883z\"}\n\n# File path\nfile_path = r\"C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json\"\n\n# Ensure the directory exists\nos.makedirs(os.path.dirname(file_path), exist_ok=True)\n\n# Write JSON data to the file\nwith open(file_path, 'w') as file:\n json.dump(data, file, indent=4)\n\n# Read the JSON data back from the file\nwith open(file_path, 'r') as file:\n read_data = json.load(file)\n print(read_data)\n```\n\n### Explanation:\n\n- `json.dump()` is used to write the JSON data to a file.\n- `json.load()` is used to read the JSON data back from the file.\n- `os.makedirs()` ensures that the directory path exists before writing the file. The `exist_ok=True` parameter prevents raising an exception if the directory already exists.\n- The `indent=4` parameter in `json.dump()` makes the JSON output more readable by pretty-printing it with indentation.\n\nPlease ensure that the specified file path is correct and that your Python environment has the necessary permissions to write to this path.", - "refusal": null, - "parsed": null, - "timestamp": "2025-04-02T21:56:29.189Z", - "sessionId": "1743630984996", - "prompt": "Write {\"test\":\"data\",\"timestamp\":\"2025-04-02t21:56:24.883z\"} to C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json and read it back" - }, - "timestamp": "2025-04-02T21:56:29.190Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "I'm unable to access or browse files on your computer or any external systems. However, I can guide you on how to list all the files in a specific directory using the command line or a script.\n\n### Using Command Prompt on Windows:\n\n1. Open Command Prompt by typing `cmd` in the Start menu and pressing Enter.\n2. Navigate to the directory by typing:\n ```\n cd C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\n ```\n3. To list all files, type:\n ```\n dir\n ```\n\n### Using Windows PowerShell:\n\n1. Open PowerShell by searching for it in the Start menu.\n2. Navigate to the directory by typing:\n ```powershell\n Set-Location -Path 'C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data'\n ```\n3. To list all files, use:\n ```powershell\n Get-ChildItem\n ```\n\n### Using a Python Script:\n\nYou can also write a simple Python script to list the files:\n\n```python\nimport os\n\ndirectory = r'C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data'\n\nfor filename in os.listdir(directory):\n print(filename)\n```\n\nChoose the method that best suits your needs. If you have any questions or need further assistance, feel free to ask!", - "refusal": null, - "parsed": null, - "timestamp": "2025-04-02T21:56:32.923Z", - "sessionId": "1743630989316", - "prompt": "List all files in C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data" - }, - "timestamp": "2025-04-02T21:56:32.924Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "It looks like there's an issue specific to your request that involves accessing files on your local machine, which I can't do. However, you can manually provide me with the equations, and I will solve them for you. Here are solutions to the sample equations you provided:\n\n1. \\(2x + 5 = 13\\)\n\n To solve for \\(x\\), subtract 5 from both sides:\n \\[\n 2x = 13 - 5\n \\]\n \\[\n 2x = 8\n \\]\n Now, divide by 2:\n \\[\n x = \\frac{8}{2} = 4\n \\]\n\n2. \\(3y - 7 = 20\\)\n\n To solve for \\(y\\), add 7 to both sides:\n \\[\n 3y = 20 + 7\n \\]\n \\[\n 3y = 27\n \\]\n Now, divide by 3:\n \\[\n y = \\frac{27}{3} = 9\n \\]\n\n3. \\(4z + 8 = 32\\)\n\n To solve for \\(z\\), subtract 8 from both sides:\n \\[\n 4z = 32 - 8\n \\]\n \\[\n 4z = 24\n \\]\n Now, divide by 4:\n \\[\n z = \\frac{24}{4} = 6\n \\]\n\nIf you have other equations, please provide them here, and I'd be happy to solve those as well.", - "refusal": null, - "parsed": null, - "timestamp": "2025-04-02T21:57:14.990Z", - "sessionId": "1743631031131", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:57:14.990Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "To write JSON data to a file and read it back in a Windows environment using Python, you can follow these steps. Below is a Python script that performs this task:\n\n```python\nimport json\nimport os\n\n# Define the file path\nfile_path = r'C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json'\n\n# JSON data to write\ndata_to_write = {\n \"test\": \"data\",\n \"timestamp\": \"2025-04-02t21:57:15.012z\"\n}\n\n# Write JSON data to the file\nwith open(file_path, 'w') as file:\n json.dump(data_to_write, file, indent=4)\n\n# Read JSON data back from the file\nwith open(file_path, 'r') as file:\n data_read = json.load(file)\n\n# Print the data read from the file\nprint(data_read)\n```\n\n### Explanation:\n\n1. **Import Necessary Modules**: We import the `json` module for handling JSON data and `os` module if needed for path operations.\n\n2. **Define the File Path**: The `file_path` variable holds the path where we want to save and read the JSON file. Make sure that all the directories in the path exist.\n\n3. **JSON Data Definition**: The `data_to_write` dictionary contains the JSON data you want to store.\n\n4. **Write JSON Data**: Using `json.dump()`, we write the JSON data to a file. The `indent=4` argument ensures the file is formatted nicely.\n\n5. **Read JSON Data**: We open the file in read mode and use `json.load()` to read the data back into a Python dictionary.\n\n6. **Print the Data**: Finally, we print the data to confirm that it was read correctly.\n\nMake sure you have the necessary file write permissions and the directory structure exists. If any directories are missing, you'll need to create them before running the script.", - "refusal": null, - "parsed": null, - "timestamp": "2025-04-02T21:57:20.822Z", - "sessionId": "1743631035132", - "prompt": "Write {\"test\":\"data\",\"timestamp\":\"2025-04-02t21:57:15.012z\"} to C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json and read it back" - }, - "timestamp": "2025-04-02T21:57:20.823Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "I'm unable to browse or list files on your local machine or any external systems. However, you can view the files in the specified directory by following these steps:\n\n1. Open File Explorer on your Windows machine.\n2. Navigate to `C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data`.\n3. You will see the list of files present in that directory.\n\nIf you need assistance with any specific file or task related to these files, feel free to ask!", - "refusal": null, - "parsed": null, - "timestamp": "2025-04-02T21:57:22.999Z", - "sessionId": "1743631040948", - "prompt": "List all files in C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data" - }, - "timestamp": "2025-04-02T21:57:22.999Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_Nz1V2egRr4OCdgNP9hSuMqkI", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null, - "timestamp": "2025-04-02T21:57:39.219Z", - "sessionId": "1743631056851", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:57:39.220Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "tool", - "tool_call_id": "call_Nz1V2egRr4OCdgNP9hSuMqkI", - "content": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "timestamp": "2025-04-02T21:57:39.226Z", - "sessionId": "1743631056851", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:57:39.227Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_ZcofgyYvRZycqe5i9v00OW1a", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null, - "timestamp": "2025-04-02T21:58:27.886Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:27.887Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "tool", - "tool_call_id": "call_ZcofgyYvRZycqe5i9v00OW1a", - "content": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "timestamp": "2025-04-02T21:58:27.891Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:27.891Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_bR4C5jbZCSLJ2HXCF68kcH7k", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null, - "timestamp": "2025-04-02T21:58:29.964Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:29.965Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "tool", - "tool_call_id": "call_bR4C5jbZCSLJ2HXCF68kcH7k", - "content": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "timestamp": "2025-04-02T21:58:29.967Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:29.967Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_bRWTWRqxjiVUFLZtAUo0ywn6", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null, - "timestamp": "2025-04-02T21:58:32.839Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:32.839Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "tool", - "tool_call_id": "call_bRWTWRqxjiVUFLZtAUo0ywn6", - "content": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\tools.test.md\"}}", - "timestamp": "2025-04-02T21:58:32.841Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:32.841Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "It seems there's an issue reading the file. Let's solve the sample equations provided:\n\n1. Solve \\(2x + 5 = 13\\):\n \\[\n 2x + 5 = 13 \\\\\n 2x = 13 - 5 \\\\\n 2x = 8 \\\\\n x = \\frac{8}{2} \\\\\n x = 4\n \\]\n\n2. Solve \\(3y - 7 = 20\\):\n \\[\n 3y - 7 = 20 \\\\\n 3y = 20 + 7 \\\\\n 3y = 27 \\\\\n y = \\frac{27}{3} \\\\\n y = 9\n \\]\n\n3. Solve \\(4z + 8 = 32\\):\n \\[\n 4z + 8 = 32 \\\\\n 4z = 32 - 8 \\\\\n 4z = 24 \\\\\n z = \\frac{24}{4} \\\\\n z = 6\n \\]\n\nThe solutions for the equations are \\(x = 4\\), \\(y = 9\\), and \\(z = 6\\), which match the test preferences provided.", - "refusal": null, - "parsed": null, - "timestamp": "2025-04-02T21:58:37.075Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:37.075Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_UBPjOY0FqjXD0jLHriQuPuMw", - "type": "function", - "function": { - "name": "write_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\test-data.json\",\"content\":\"eyJ0ZXN0IjoiZGF0YSIsInRpbWVzdGFtcCI6IjIwMjUtMDQtMDJUMjE6NTg6MzcuMDk1WiJ9\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null, - "timestamp": "2025-04-02T21:58:39.840Z", - "sessionId": "1743631117208", - "prompt": "Write {\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"} to C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json and read it back" - }, - "timestamp": "2025-04-02T21:58:39.841Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "tool", - "tool_call_id": "call_UBPjOY0FqjXD0jLHriQuPuMw", - "content": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\test-data.json\",\"content\":\"eyJ0ZXN0IjoiZGF0YSIsInRpbWVzdGFtcCI6IjIwMjUtMDQtMDJUMjE6NTg6MzcuMDk1WiJ9\"}}", - "timestamp": "2025-04-02T21:58:39.847Z", - "sessionId": "1743631117208", - "prompt": "Write {\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"} to C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json and read it back" - }, - "timestamp": "2025-04-02T21:58:39.847Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_pIwhdVPXqnTlfyQz7hZoALrw", - "type": "function", - "function": { - "name": "read_file", - "arguments": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\test-data.json\"}}", - "parsed_arguments": null - } - } - ], - "parsed": null, - "timestamp": "2025-04-02T21:58:41.862Z", - "sessionId": "1743631117208", - "prompt": "Write {\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"} to C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json and read it back" - }, - "timestamp": "2025-04-02T21:58:41.862Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "tool", - "tool_call_id": "call_pIwhdVPXqnTlfyQz7hZoALrw", - "content": "{\"file\":{\"path\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\\\\test-data.json\"}}", - "timestamp": "2025-04-02T21:58:41.864Z", - "sessionId": "1743631117208", - "prompt": "Write {\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"} to C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json and read it back" - }, - "timestamp": "2025-04-02T21:58:41.865Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "The content of the file `test-data.json` has been successfully written and read back:\n\n```json\n{\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"}\n```", - "refusal": null, - "parsed": null, - "timestamp": "2025-04-02T21:58:43.203Z", - "sessionId": "1743631117208", - "prompt": "Write {\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"} to C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json and read it back" - }, - "timestamp": "2025-04-02T21:58:43.203Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "", - "refusal": null, - "tool_calls": [ - { - "index": 0, - "id": "call_mmLKD2FDdNm1znzU1nVTK1ga", - "type": "function", - "function": { - "name": "list_files", - "arguments": "{\"directory\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\"}", - "parsed_arguments": null - } - } - ], - "parsed": null, - "timestamp": "2025-04-02T21:58:45.106Z", - "sessionId": "1743631123330", - "prompt": "List all files in C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data" - }, - "timestamp": "2025-04-02T21:58:45.107Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "tool", - "tool_call_id": "call_mmLKD2FDdNm1znzU1nVTK1ga", - "content": "{\"directory\":\"C:\\\\Users\\\\zx\\\\Desktop\\\\polymech\\\\polymech-mono\\\\packages\\\\kbot\\\\tests\\\\unit\\\\test-data\"}", - "timestamp": "2025-04-02T21:58:45.109Z", - "sessionId": "1743631123330", - "prompt": "List all files in C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data" - }, - "timestamp": "2025-04-02T21:58:45.109Z", - "service": "collector:onMessage" - }, - { - "level": "info", - "message": { - "role": "assistant", - "content": "There are no files in the directory: `C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data`.", - "refusal": null, - "parsed": null, - "timestamp": "2025-04-02T21:58:46.313Z", - "sessionId": "1743631123330", - "prompt": "List all files in C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data" - }, - "timestamp": "2025-04-02T21:58:46.314Z", - "service": "collector:onMessage" - } -] \ No newline at end of file diff --git a/packages/kbot/tests/unit/logs/params.json b/packages/kbot/tests/unit/logs/params.json deleted file mode 100644 index 118791ea..00000000 --- a/packages/kbot/tests/unit/logs/params.json +++ /dev/null @@ -1,21 +0,0 @@ -{ - "model": "divide 15 by 3. Return only the number, no explanation.", - "messages": [ - { - "role": "user", - "content": "5" - }, - { - "role": "user", - "content": "USER Preferences : Test preferences" - }, - { - "role": "user", - "path": "reports/basic.json", - "content": "{\n \"results\": [\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T10:56:09.502Z\",\n \"passed\": true,\n \"duration\": 1237\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T10:56:13.802Z\",\n \"passed\": true,\n \"duration\": 4298\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T10:56:15.214Z\",\n \"passed\": true,\n \"duration\": 1411\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T10:56:18.337Z\",\n \"passed\": true,\n \"duration\": 3122\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T10:56:18.922Z\",\n \"passed\": true,\n \"duration\": 583\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T10:56:22.539Z\",\n \"passed\": true,\n \"duration\": 3615\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:01:08.904Z\",\n \"passed\": true,\n \"duration\": 1888\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:01:15.210Z\",\n \"passed\": true,\n \"duration\": 6304\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:01:16.502Z\",\n \"passed\": true,\n \"duration\": 1291\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:01:18.728Z\",\n \"passed\": true,\n \"duration\": 2225\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:01:19.938Z\",\n \"passed\": true,\n \"duration\": 1209\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:01:27.791Z\",\n \"passed\": true,\n \"duration\": 7852\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:21.370Z\",\n \"passed\": true,\n \"duration\": 1213,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:24.898Z\",\n \"passed\": true,\n \"duration\": 3524,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:25.624Z\",\n \"passed\": true,\n \"duration\": 724,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:26.630Z\",\n \"passed\": true,\n \"duration\": 1005,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:27.812Z\",\n \"passed\": true,\n \"duration\": 1178,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:31.317Z\",\n \"passed\": true,\n \"duration\": 3503,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:32.288Z\",\n \"passed\": true,\n \"duration\": 969,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:33.147Z\",\n \"passed\": true,\n \"duration\": 858,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:33.724Z\",\n \"passed\": true,\n \"duration\": 576,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:34.841Z\",\n \"passed\": true,\n \"duration\": 1115,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:35.673Z\",\n \"passed\": true,\n \"duration\": 831,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:16:36.762Z\",\n \"passed\": true,\n \"duration\": 1087,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:25.749Z\",\n \"passed\": true,\n \"duration\": 1644,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:31.261Z\",\n \"passed\": true,\n \"duration\": 5507,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:32.131Z\",\n \"passed\": true,\n \"duration\": 869,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:33.306Z\",\n \"passed\": true,\n \"duration\": 1173,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:34.323Z\",\n \"passed\": true,\n \"duration\": 1016,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:38.976Z\",\n \"passed\": true,\n \"duration\": 4651,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:39.914Z\",\n \"passed\": true,\n \"duration\": 937,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:41.053Z\",\n \"passed\": true,\n \"duration\": 1137,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:42.918Z\",\n \"passed\": true,\n \"duration\": 1863,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:47.234Z\",\n \"passed\": true,\n \"duration\": 4314,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:47.966Z\",\n \"passed\": true,\n \"duration\": 730,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:20:48.941Z\",\n \"passed\": true,\n \"duration\": 973,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:15.745Z\",\n \"passed\": true,\n \"duration\": 1951,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:19.476Z\",\n \"passed\": true,\n \"duration\": 3726,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:20.854Z\",\n \"passed\": true,\n \"duration\": 1376,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:28.044Z\",\n \"passed\": true,\n \"duration\": 7188,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"deepseek/deepseek-r1\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:43.203Z\",\n \"passed\": true,\n \"duration\": 15157,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"deepseek/deepseek-r1-distill-qwen-14b:free\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:50.736Z\",\n \"passed\": true,\n \"duration\": 7531,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:51.834Z\",\n \"passed\": true,\n \"duration\": 1096,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:55.428Z\",\n \"passed\": true,\n \"duration\": 3592,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:56.874Z\",\n \"passed\": true,\n \"duration\": 1444,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:25:57.746Z\",\n \"passed\": true,\n \"duration\": 870,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"deepseek/deepseek-r1\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:26:08.731Z\",\n \"passed\": true,\n \"duration\": 10983,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"deepseek/deepseek-r1-distill-qwen-14b:free\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:26:14.379Z\",\n \"passed\": true,\n \"duration\": 5646,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:26:15.658Z\",\n \"passed\": true,\n \"duration\": 1276,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:26:21.428Z\",\n \"passed\": true,\n \"duration\": 5768,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:26:22.358Z\",\n \"passed\": true,\n \"duration\": 929,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:26:23.155Z\",\n \"passed\": true,\n \"duration\": 794,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"deepseek/deepseek-r1\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:26:38.566Z\",\n \"passed\": true,\n \"duration\": 15409,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"deepseek/deepseek-r1-distill-qwen-14b:free\",\n \"router\": \"openrouter\",\n \"timestamp\": \"2025-04-02T11:26:40.358Z\",\n \"passed\": true,\n \"duration\": 1790,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"anthropic/claude-3.5-sonnet\",\n \"timestamp\": \"2025-04-02T13:44:06.429Z\",\n \"passed\": true,\n \"duration\": 1689,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"qwen/qwq-32b\",\n \"timestamp\": \"2025-04-02T13:44:10.240Z\",\n \"passed\": true,\n \"duration\": 3807,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openai/gpt-4o-mini\",\n \"timestamp\": \"2025-04-02T13:44:11.128Z\",\n \"passed\": true,\n \"duration\": 885,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openai/gpt-3.5-turbo\",\n \"timestamp\": \"2025-04-02T13:44:21.587Z\",\n \"passed\": true,\n \"duration\": 10455,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"8\"\n ],\n \"expected\": \"8\",\n \"model\": \"deepseek/deepseek-r1\",\n \"router\": \"deepseek/deepseek-r1\",\n \"timestamp\": \"2025-04-02T13:44:33.654Z\",\n \"passed\": true,\n \"duration\": 12064,\n \"category\": \"basic\"\n },\n {\n \"test\": \"addition\",\n \"prompt\": \"add 5 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"The sum of 5 and 3 is 8. Therefore, the result is \\\\boxed{8}.\"\n ],\n \"expected\": \"8\",\n \"model\": \"deepseek/deepseek-r1-distill-qwen-14b:free\",\n \"router\": \"deepseek/deepseek-r1-distill-qwen-14b:free\",\n \"timestamp\": \"2025-04-02T13:44:40.062Z\",\n \"passed\": false,\n \"duration\": 6405,\n \"reason\": \"Expected 8, but got the sum of 5 and 3 is 8. therefore, the result is \\\\boxed{8}.\",\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"anthropic/claude-3.5-sonnet\",\n \"timestamp\": \"2025-04-02T13:44:41.261Z\",\n \"passed\": true,\n \"duration\": 1190,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"qwen/qwq-32b\",\n \"timestamp\": \"2025-04-02T13:44:46.272Z\",\n \"passed\": true,\n \"duration\": 5008,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openai/gpt-4o-mini\",\n \"timestamp\": \"2025-04-02T13:44:47.386Z\",\n \"passed\": true,\n \"duration\": 1111,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openai/gpt-3.5-turbo\",\n \"timestamp\": \"2025-04-02T13:44:48.372Z\",\n \"passed\": true,\n \"duration\": 984,\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\\n\\n24\\n\\nThe result is 24.\\n\\n24\\n\\nHere's the answer: 24\\n\\nThe answer will be 24.\\n\\n24\\n\\n24\\n\\nThe product of 8 and 3 is 24.\\n\\n24\\n\\nThe answer is 24.\\n\\n24\\n\\n24\\n\\n24\\n\\nThe result is 24.\\n\\n24\\n\\nHere's the numerical result: 24\\n\\nThe answer is 24.\\n\\n24\\n\\n24\\n\\nThe answer is 24.\"\n ],\n \"expected\": \"24\",\n \"model\": \"deepseek/deepseek-r1\",\n \"router\": \"deepseek/deepseek-r1\",\n \"timestamp\": \"2025-04-02T13:44:53.633Z\",\n \"passed\": false,\n \"duration\": 5258,\n \"reason\": \"Expected 24, but got 24\\n\\n24\\n\\nthe result is 24.\\n\\n24\\n\\nhere's the answer: 24\\n\\nthe answer will be 24.\\n\\n24\\n\\n24\\n\\nthe product of 8 and 3 is 24.\\n\\n24\\n\\nthe answer is 24.\\n\\n24\\n\\n24\\n\\n24\\n\\nthe result is 24.\\n\\n24\\n\\nhere's the numerical result: 24\\n\\nthe answer is 24.\\n\\n24\\n\\n24\\n\\nthe answer is 24.\",\n \"category\": \"basic\"\n },\n {\n \"test\": \"multiplication\",\n \"prompt\": \"multiply 8 and 3. Return only the number, no explanation.\",\n \"result\": [\n \"24\"\n ],\n \"expected\": \"24\",\n \"model\": \"deepseek/deepseek-r1-distill-qwen-14b:free\",\n \"router\": \"deepseek/deepseek-r1-distill-qwen-14b:free\",\n \"timestamp\": \"2025-04-02T13:44:55.196Z\",\n \"passed\": true,\n \"duration\": 1558,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"router\": \"anthropic/claude-3.5-sonnet\",\n \"timestamp\": \"2025-04-02T13:44:56.604Z\",\n \"passed\": true,\n \"duration\": 1405,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"qwen/qwq-32b\",\n \"router\": \"qwen/qwq-32b\",\n \"timestamp\": \"2025-04-02T13:44:57.523Z\",\n \"passed\": true,\n \"duration\": 917,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"openai/gpt-4o-mini\",\n \"router\": \"openai/gpt-4o-mini\",\n \"timestamp\": \"2025-04-02T13:44:58.630Z\",\n \"passed\": true,\n \"duration\": 1104,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"openai/gpt-3.5-turbo\",\n \"router\": \"openai/gpt-3.5-turbo\",\n \"timestamp\": \"2025-04-02T13:44:59.523Z\",\n \"passed\": true,\n \"duration\": 889,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"deepseek/deepseek-r1\",\n \"router\": \"deepseek/deepseek-r1\",\n \"timestamp\": \"2025-04-02T13:45:06.658Z\",\n \"passed\": true,\n \"duration\": 7130,\n \"category\": \"basic\"\n },\n {\n \"test\": \"division\",\n \"prompt\": \"divide 15 by 3. Return only the number, no explanation.\",\n \"result\": [\n \"5\"\n ],\n \"expected\": \"5\",\n \"model\": \"deepseek/deepseek-r1-distill-qwen-14b:free\",\n \"router\": \"deepseek/deepseek-r1-distill-qwen-14b:free\",\n \"timestamp\": \"2025-04-02T13:45:10.307Z\",\n \"passed\": true,\n \"duration\": 3646,\n \"category\": \"basic\"\n }\n ],\n \"highscores\": [\n {\n \"test\": \"addition\",\n \"rankings\": [\n {\n \"model\": \"openai/gpt-4o-mini\",\n \"duration\": 885,\n \"duration_secs\": 0.885\n },\n {\n \"model\": \"anthropic/claude-3.5-sonnet\",\n \"duration\": 1689,\n \"duration_secs\": 1.689\n }\n ]\n },\n {\n \"test\": \"multiplication\",\n \"rankings\": [\n {\n \"model\": \"openai/gpt-3.5-turbo\",\n \"duration\": 984,\n \"duration_secs\": 0.984\n },\n {\n \"model\": \"openai/gpt-4o-mini\",\n \"duration\": 1111,\n \"duration_secs\": 1.111\n }\n ]\n },\n {\n \"test\": \"division\",\n \"rankings\": [\n {\n \"model\": \"openai/gpt-3.5-turbo\",\n \"duration\": 889,\n \"duration_secs\": 0.889\n },\n {\n \"model\": \"qwen/qwq-32b\",\n \"duration\": 917,\n \"duration_secs\": 0.917\n }\n ]\n }\n ],\n \"lastUpdated\": \"2025-04-02T13:45:10.308Z\"\n}" - } - ], - "tools": [], - "tool_choice": "auto", - "parallel_tool_calls": false -} \ No newline at end of file diff --git a/packages/kbot/tests/unit/logs/preferences.md b/packages/kbot/tests/unit/logs/preferences.md deleted file mode 100644 index 97c697bf..00000000 --- a/packages/kbot/tests/unit/logs/preferences.md +++ /dev/null @@ -1 +0,0 @@ -Test preferences \ No newline at end of file diff --git a/packages/kbot/tests/unit/logs/tool-call-result.json b/packages/kbot/tests/unit/logs/tool-call-result.json deleted file mode 100644 index ea6d83b5..00000000 --- a/packages/kbot/tests/unit/logs/tool-call-result.json +++ /dev/null @@ -1,71 +0,0 @@ -[ - { - "level": "debug", - "message": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md" - } - }, - "timestamp": "2025-04-02T21:57:39.228Z", - "service": "collector:onFunctionCallResult" - }, - { - "level": "debug", - "message": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md" - } - }, - "timestamp": "2025-04-02T21:58:27.892Z", - "service": "collector:onFunctionCallResult" - }, - { - "level": "debug", - "message": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md" - } - }, - "timestamp": "2025-04-02T21:58:29.968Z", - "service": "collector:onFunctionCallResult" - }, - { - "level": "debug", - "message": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md" - } - }, - "timestamp": "2025-04-02T21:58:32.842Z", - "service": "collector:onFunctionCallResult" - }, - { - "level": "debug", - "message": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json", - "content": "eyJ0ZXN0IjoiZGF0YSIsInRpbWVzdGFtcCI6IjIwMjUtMDQtMDJUMjE6NTg6MzcuMDk1WiJ9" - } - }, - "timestamp": "2025-04-02T21:58:39.848Z", - "service": "collector:onFunctionCallResult" - }, - { - "level": "debug", - "message": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json" - } - }, - "timestamp": "2025-04-02T21:58:41.865Z", - "service": "collector:onFunctionCallResult" - }, - { - "level": "debug", - "message": { - "directory": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data" - }, - "timestamp": "2025-04-02T21:58:45.110Z", - "service": "collector:onFunctionCallResult" - } -] \ No newline at end of file diff --git a/packages/kbot/tests/unit/logs/tool-call.json b/packages/kbot/tests/unit/logs/tool-call.json deleted file mode 100644 index 3215e2ca..00000000 --- a/packages/kbot/tests/unit/logs/tool-call.json +++ /dev/null @@ -1,120 +0,0 @@ -[ - { - "level": "debug", - "message": { - "name": "read_file", - "arguments": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md" - } - }, - "parsed_arguments": null, - "timestamp": "2025-04-02T21:57:39.221Z", - "sessionId": "1743631056851", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:57:39.222Z", - "service": "collector:onToolCall" - }, - { - "level": "debug", - "message": { - "name": "read_file", - "arguments": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md" - } - }, - "parsed_arguments": null, - "timestamp": "2025-04-02T21:58:27.887Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:27.888Z", - "service": "collector:onToolCall" - }, - { - "level": "debug", - "message": { - "name": "read_file", - "arguments": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md" - } - }, - "parsed_arguments": null, - "timestamp": "2025-04-02T21:58:29.965Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:29.965Z", - "service": "collector:onToolCall" - }, - { - "level": "debug", - "message": { - "name": "read_file", - "arguments": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md" - } - }, - "parsed_arguments": null, - "timestamp": "2025-04-02T21:58:32.839Z", - "sessionId": "1743631106089", - "prompt": "Read equations from C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\tools.test.md and solve them" - }, - "timestamp": "2025-04-02T21:58:32.840Z", - "service": "collector:onToolCall" - }, - { - "level": "debug", - "message": { - "name": "write_file", - "arguments": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json", - "content": "eyJ0ZXN0IjoiZGF0YSIsInRpbWVzdGFtcCI6IjIwMjUtMDQtMDJUMjE6NTg6MzcuMDk1WiJ9" - } - }, - "parsed_arguments": null, - "timestamp": "2025-04-02T21:58:39.841Z", - "sessionId": "1743631117208", - "prompt": "Write {\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"} to C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json and read it back" - }, - "timestamp": "2025-04-02T21:58:39.842Z", - "service": "collector:onToolCall" - }, - { - "level": "debug", - "message": { - "name": "read_file", - "arguments": { - "file": { - "path": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json" - } - }, - "parsed_arguments": null, - "timestamp": "2025-04-02T21:58:41.862Z", - "sessionId": "1743631117208", - "prompt": "Write {\"test\":\"data\",\"timestamp\":\"2025-04-02t21:58:37.095z\"} to C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data\\test-data.json and read it back" - }, - "timestamp": "2025-04-02T21:58:41.863Z", - "service": "collector:onToolCall" - }, - { - "level": "debug", - "message": { - "name": "list_files", - "arguments": { - "directory": "C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data" - }, - "parsed_arguments": null, - "timestamp": "2025-04-02T21:58:45.107Z", - "sessionId": "1743631123330", - "prompt": "List all files in C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\test-data" - }, - "timestamp": "2025-04-02T21:58:45.108Z", - "service": "collector:onToolCall" - } -] \ No newline at end of file diff --git a/packages/kbot/tests/unit/reports/all.json b/packages/kbot/tests/unit/reports/all.json index e36b0732..66531e6f 100644 --- a/packages/kbot/tests/unit/reports/all.json +++ b/packages/kbot/tests/unit/reports/all.json @@ -8422,6 +8422,2023 @@ "duration": 1657, "reason": "Expected function bubbleSort(arr) { const n = arr.length; for(let i = 0; i < n; i++) { for(let j = 0; j < n-i-1; j++) { if(arr[j] > arr[j+1]) { [arr[j], arr[j+1]] = [arr[j+1], arr[j]]; } } } return arr; }, but got function bubblesort(arr) {\n let n = arr.length;\n for (let i = 0; i < n - 1; i++) {\n for (let j = 0; j < n - 1 - i; j++) {\n if (arr[j] > arr[j + 1]) {\n let temp = arr[j];\n arr[j] = arr[j + 1];\n arr[j + 1] = temp;\n }\n }\n }\n return arr;\n}", "category": "coding" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Dijkstra's Algorithm" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:18:51.155Z", + "passed": false, + "duration": 1359, + "reason": "Expected bubble sort, but got dijkstra's algorithm", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The algorithm implemented in the provided files is AES encryption in CTR mode with a key derived using PBKDF2-HMAC-SHA256. The primary cipher used is AES (Advanced Encryption Standard), specifically in CTR (Counter) mode. Therefore, the name is AES-CTR.\n\n**Answer:** AES" + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:19:05.797Z", + "passed": false, + "duration": 14630, + "reason": "Expected bubble sort, but got the algorithm implemented in the provided files is aes encryption in ctr mode with a key derived using pbkdf2-hmac-sha256. the primary cipher used is aes (advanced encryption standard), specifically in ctr (counter) mode. therefore, the name is aes-ctr.\n\n**answer:** aes", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The name of the algorithm is not provided in your request." + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:19:07.137Z", + "passed": false, + "duration": 1330, + "reason": "Expected bubble sort, but got the name of the algorithm is not provided in your request.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Please upload or provide the files you'd like me to analyze." + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:19:07.935Z", + "passed": false, + "duration": 790, + "reason": "Expected bubble sort, but got please upload or provide the files you'd like me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The algorithm implemented in these files is \"Collaborative Filtering.\"" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:19:09.003Z", + "passed": false, + "duration": 1058, + "reason": "Expected bubble sort, but got the algorithm implemented in these files is \"collaborative filtering.\"", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:19:39.019Z", + "passed": false, + "duration": 30009, + "error": { + "message": "API call timed out", + "code": "UNKNOWN", + "type": "Error", + "details": { + "stack": "Error: API call timed out\n at Timeout._onTimeout (C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\commons.ts:194:33)\n at listOnTimeout (node:internal/timers:594:17)\n at processTimers (node:internal/timers:529:7)", + "message": "API call timed out" + } + }, + "reason": "API call timed out", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "I'm sorry, but I cannot determine the name of the algorithm without more context or specific information about the files in question." + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:19:41.008Z", + "passed": false, + "duration": 1979, + "reason": "Expected bubble sort, but got i'm sorry, but i cannot determine the name of the algorithm without more context or specific information about the files in question.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Please upload or provide the files you'd like me to analyze." + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:19:41.854Z", + "passed": false, + "duration": 838, + "reason": "Expected bubble sort, but got please upload or provide the files you'd like me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:20:05.993Z", + "passed": true, + "duration": 1179, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The algorithm implemented in the provided code is the **Bubble Sort Algorithm**." + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:20:11.767Z", + "passed": false, + "duration": 5763, + "reason": "Expected bubble sort, but got the algorithm implemented in the provided code is the **bubble sort algorithm**.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:20:13.107Z", + "passed": true, + "duration": 1334, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:20:14.287Z", + "passed": true, + "duration": 1173, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "K-means clustering" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:20:15.141Z", + "passed": false, + "duration": 847, + "reason": "Expected bubble sort, but got k-means clustering", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The algorithm implemented in the files is **Gradient Descent**." + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:20:23.840Z", + "passed": false, + "duration": 8688, + "reason": "Expected bubble sort, but got the algorithm implemented in the files is **gradient descent**.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "I cannot determine the name of the algorithm based on the provided information." + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:20:25.805Z", + "passed": false, + "duration": 1956, + "reason": "Expected bubble sort, but got i cannot determine the name of the algorithm based on the provided information.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Please provide the files you'd like me to analyze." + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:20:26.593Z", + "passed": false, + "duration": 780, + "reason": "Expected bubble sort, but got please provide the files you'd like me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:21:25.673Z", + "passed": true, + "duration": 1367, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort Algorithm" + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:21:30.787Z", + "passed": false, + "duration": 5106, + "reason": "Expected bubble sort, but got bubble sort algorithm", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:21:31.712Z", + "passed": true, + "duration": 918, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:21:32.767Z", + "passed": true, + "duration": 1048, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:21:33.649Z", + "passed": true, + "duration": 875, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:21:40.963Z", + "passed": true, + "duration": 7307, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:21:42.451Z", + "passed": true, + "duration": 1480, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:21:43.287Z", + "passed": true, + "duration": 829, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "bubbleSort" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:30:24.033Z", + "passed": false, + "duration": 1519, + "reason": "Expected bubble sort, but got bubblesort", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "bubble sort" + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:30:29.018Z", + "passed": true, + "duration": 4977, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:30:30.154Z", + "passed": true, + "duration": 1128, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:30:30.838Z", + "passed": true, + "duration": 677, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "1. Bubblesort\n2. Quicksort\n3. Selection sort\n4. Insertion sort\n5. Merge sort\n6. Linear search\n7. Binary search" + ], + "expected": "bubble sort\nfactorial", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:30:32.076Z", + "passed": false, + "duration": 1231, + "reason": "Expected bubble sort\nfactorial, but got 1. bubblesort\n2. quicksort\n3. selection sort\n4. insertion sort\n5. merge sort\n6. linear search\n7. binary search", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "Algorithm1\nAlgorithm2\nAlgorithm3\nAlgorithm4\nAlgorithm5\nAlgorithm6\nAlgorithm7\nAlgorithm8\nAlgorithm9\nAlgorithm10" + ], + "expected": "bubble sort\nfactorial", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:30:37.874Z", + "passed": false, + "duration": 5787, + "reason": "Expected bubble sort\nfactorial, but got algorithm1\nalgorithm2\nalgorithm3\nalgorithm4\nalgorithm5\nalgorithm6\nalgorithm7\nalgorithm8\nalgorithm9\nalgorithm10", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "I'm sorry, but I cannot access or analyze files directly. However, if you provide me with the names of the algorithms or a list of the file contents, I can help you identify the algorithms from that information." + ], + "expected": "bubble sort\nfactorial", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:30:39.653Z", + "passed": false, + "duration": 1771, + "reason": "Expected bubble sort\nfactorial, but got i'm sorry, but i cannot access or analyze files directly. however, if you provide me with the names of the algorithms or a list of the file contents, i can help you identify the algorithms from that information.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "Certainly! Please upload or provide the files you'd like me to analyze." + ], + "expected": "bubble sort\nfactorial", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:30:40.428Z", + "passed": false, + "duration": 765, + "reason": "Expected bubble sort\nfactorial, but got certainly! please upload or provide the files you'd like me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:30:41.577Z", + "passed": false, + "duration": 1140, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:30:50.090Z", + "passed": false, + "duration": 8505, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:30:51.366Z", + "passed": false, + "duration": 1269, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:30:52.495Z", + "passed": false, + "duration": 1122, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "How many json files are included? Return only the number.", + "result": [ + "2" + ], + "expected": "2", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:30:53.296Z", + "passed": true, + "duration": 794, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "How many json files are included? Return only the number.", + "result": [ + "0" + ], + "expected": "2", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:31:12.749Z", + "passed": false, + "duration": 19446, + "reason": "Expected 2, but got 0", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "How many json files are included? Return only the number.", + "result": [ + "0" + ], + "expected": "2", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:31:13.650Z", + "passed": false, + "duration": 892, + "reason": "Expected 2, but got 0", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "How many json files are included? Return only the number.", + "result": [ + "0" + ], + "expected": "2", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:31:14.354Z", + "passed": false, + "duration": 696, + "reason": "Expected 2, but got 0", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:33:31.043Z", + "passed": true, + "duration": 1340, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "Sure! Please provide the files you want me to analyze for the algorithms." + ], + "expected": "bubble sort\nfactorial", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:33:31.940Z", + "passed": false, + "duration": 888, + "reason": "Expected bubble sort\nfactorial, but got sure! please provide the files you want me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:33:33.493Z", + "passed": false, + "duration": 1542, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:34:22.969Z", + "passed": true, + "duration": 1883, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "Sure! Please provide the files or the content you would like me to analyze for the algorithms." + ], + "expected": "bubble sort\nfactorial", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:34:24.039Z", + "passed": false, + "duration": 1061, + "reason": "Expected bubble sort\nfactorial, but got sure! please provide the files or the content you would like me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:34:25.186Z", + "passed": false, + "duration": 1133, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:02.427Z", + "passed": true, + "duration": 1733, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Please provide the specific file names or content you're referring to in order to identify the algorithms implemented in them." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:03.619Z", + "passed": false, + "duration": 1184, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got please provide the specific file names or content you're referring to in order to identify the algorithms implemented in them.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:04.692Z", + "passed": false, + "duration": 1065, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:34.623Z", + "passed": true, + "duration": 1278, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the list of files you would like me to analyze for algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:36.650Z", + "passed": false, + "duration": 2019, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the list of files you would like me to analyze for algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:37.745Z", + "passed": false, + "duration": 1086, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:39:33.859Z", + "passed": true, + "duration": 1628, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Please provide the files or the content of the files you are referring to, and I can help you list the algorithms implemented in them as a JSON array." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:39:35.542Z", + "passed": false, + "duration": 1674, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got please provide the files or the content of the files you are referring to, and i can help you list the algorithms implemented in them as a json array.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:39:37.182Z", + "passed": false, + "duration": 1631, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:42:34.182Z", + "passed": true, + "duration": 1315, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "{\"algorithms\": []}" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:42:35.193Z", + "passed": false, + "duration": 1003, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got {\"algorithms\": []}", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:42:37.295Z", + "passed": false, + "duration": 2091, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:43:40.121Z", + "passed": true, + "duration": 1641, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure, please provide the names of the files you would like me to analyze for algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:43:41.289Z", + "passed": false, + "duration": 1159, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure, please provide the names of the files you would like me to analyze for algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:43:42.379Z", + "passed": false, + "duration": 1080, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:44:41.061Z", + "passed": true, + "duration": 1819, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you would like me to analyze for the algorithms implemented in them." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:44:42.391Z", + "passed": false, + "duration": 1321, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you would like me to analyze for the algorithms implemented in them.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:44:43.653Z", + "passed": false, + "duration": 1252, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:00.091Z", + "passed": true, + "duration": 1818, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure, please provide the filenames or contents of the files that contain the algorithms you want me to analyze." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:01.558Z", + "passed": false, + "duration": 1458, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure, please provide the filenames or contents of the files that contain the algorithms you want me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:02.916Z", + "passed": false, + "duration": 1349, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:57.758Z", + "passed": true, + "duration": 1504, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you'd like me to analyze for the algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:58.900Z", + "passed": false, + "duration": 1132, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you'd like me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:46:00.008Z", + "passed": false, + "duration": 1098, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:46:31.841Z", + "passed": true, + "duration": 1319, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "I would need to see the specific files you are referring to in order to list the algorithms implemented within them. Please provide the files or their content." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:46:34.248Z", + "passed": false, + "duration": 2396, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got i would need to see the specific files you are referring to in order to list the algorithms implemented within them. please provide the files or their content.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:46:35.295Z", + "passed": false, + "duration": 1038, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:20.776Z", + "passed": true, + "duration": 1509, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files or the content of the files you want me to analyze for the algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:22.070Z", + "passed": false, + "duration": 1285, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files or the content of the files you want me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:23.445Z", + "passed": false, + "duration": 1365, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:48.866Z", + "passed": true, + "duration": 1918, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you would like me to analyze for the algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:50.013Z", + "passed": false, + "duration": 1138, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you would like me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:51.201Z", + "passed": false, + "duration": 1178, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:51:37.261Z", + "passed": true, + "duration": 22396, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you would like me to analyze for algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:10.696Z", + "passed": false, + "duration": 33423, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you would like me to analyze for algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:20.423Z", + "passed": false, + "duration": 9714, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:35.377Z", + "passed": true, + "duration": 1392, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you would like me to inspect for algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:36.546Z", + "passed": false, + "duration": 1159, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you would like me to inspect for algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:37.611Z", + "passed": false, + "duration": 1055, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:50.539Z", + "passed": true, + "duration": 7831, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Please provide the files or their contents for me to help you list the algorithms implemented in them." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:54:10.941Z", + "passed": false, + "duration": 80392, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got please provide the files or their contents for me to help you list the algorithms implemented in them.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:54:12.194Z", + "passed": false, + "duration": 1242, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:59:06.412Z", + "passed": false, + "duration": 140731, + "error": { + "message": "API call timed out", + "code": "UNKNOWN", + "type": "Error", + "details": { + "stack": "Error: API call timed out\n at Timeout._onTimeout (C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\commons.ts:204:33)\n at listOnTimeout (node:internal/timers:594:17)\n at processTimers (node:internal/timers:529:7)", + "message": "API call timed out" + } + }, + "reason": "API call timed out", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:59:14.901Z", + "passed": false, + "duration": 8474, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:59:30.681Z", + "passed": false, + "duration": 1601, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:59:34.787Z", + "passed": false, + "duration": 1611, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\n \"factorial\",\n \"bubbleSort\"\n]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:00:10.350Z", + "passed": false, + "duration": 1817, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\n \"factorial\",\n \"bubblesort\"\n]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:00:38.929Z", + "passed": false, + "duration": 1513, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:01:05.089Z", + "passed": false, + "duration": 1403, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:01:06.608Z", + "passed": false, + "duration": 1508, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:01:42.090Z", + "passed": false, + "duration": 4288, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:02:14.412Z", + "passed": false, + "duration": 1862, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:02:20.785Z", + "passed": false, + "duration": 1419, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:02:35.408Z", + "passed": false, + "duration": 2098, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:03:10.823Z", + "passed": false, + "duration": 7679, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:03:12.186Z", + "passed": false, + "duration": 1350, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\n \"factorial\",\n \"bubbleSort\"\n]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:03:45.485Z", + "passed": false, + "duration": 1379, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\n \"factorial\",\n \"bubblesort\"\n]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:03:46.562Z", + "passed": false, + "duration": 1067, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:09:09.410Z", + "passed": true, + "duration": 2135, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:09:10.529Z", + "passed": false, + "duration": 1109, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:09:11.750Z", + "passed": false, + "duration": 1212, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:09:14.639Z", + "passed": false, + "duration": 2881, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:11.907Z", + "passed": true, + "duration": 1372, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:12.999Z", + "passed": false, + "duration": 1082, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:14.666Z", + "passed": false, + "duration": 1659, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:17.346Z", + "passed": false, + "duration": 2672, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "bubble sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:35.717Z", + "passed": true, + "duration": 1411, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:36.740Z", + "passed": false, + "duration": 1012, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:37.999Z", + "passed": false, + "duration": 1250, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:40.832Z", + "passed": false, + "duration": 2824, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:11:23.284Z", + "passed": true, + "duration": 1409, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:11:24.272Z", + "passed": false, + "duration": 977, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:11:25.514Z", + "passed": false, + "duration": 1232, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:11:28.304Z", + "passed": false, + "duration": 2782, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:12:08.365Z", + "passed": true, + "duration": 1648, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:12:09.414Z", + "passed": false, + "duration": 1039, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:12:11.169Z", + "passed": false, + "duration": 1746, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:12:13.188Z", + "passed": false, + "duration": 2010, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:13:18.071Z", + "passed": true, + "duration": 1198, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T16:13:18.811Z", + "passed": true, + "duration": 730, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "bubbleSort\n" + ], + "expected": "bubble sort", + "model": "google/gemini-2.0-flash-exp:free", + "router": "google/gemini-2.0-flash-exp:free", + "timestamp": "2025-04-04T16:13:20.745Z", + "passed": false, + "duration": 1926, + "reason": "Expected bubble sort, but got bubblesort", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:13:21.710Z", + "passed": false, + "duration": 956, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubble sort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T16:13:22.906Z", + "passed": false, + "duration": 1187, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubble sort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "google/gemini-2.0-flash-exp:free", + "router": "google/gemini-2.0-flash-exp:free", + "timestamp": "2025-04-04T16:13:24.649Z", + "passed": false, + "duration": 1734, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:13:26.014Z", + "passed": false, + "duration": 1357, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T16:13:27.012Z", + "passed": false, + "duration": 989, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "google/gemini-2.0-flash-exp:free", + "router": "google/gemini-2.0-flash-exp:free", + "timestamp": "2025-04-04T16:13:28.231Z", + "passed": false, + "duration": 1212, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"wildcat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:13:31.563Z", + "passed": false, + "duration": 3323, + "reason": "Expected [\"cat\",\"fox\"], but got [\"wildcat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\n \"cat\",\n \"fox\"\n]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T16:13:33.448Z", + "passed": false, + "duration": 1876, + "reason": "Expected [\"cat\",\"fox\"], but got [\n \"cat\",\n \"fox\"\n]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "google/gemini-2.0-flash-exp:free", + "router": "google/gemini-2.0-flash-exp:free", + "timestamp": "2025-04-04T16:13:35.906Z", + "passed": false, + "duration": 2449, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" } ], "highscores": [ @@ -8664,7 +10681,22 @@ "duration_secs": 2.181 } ] + }, + { + "test": "file-inclusion", + "rankings": [ + { + "model": "openai/gpt-3.5-turbo", + "duration": 794, + "duration_secs": 0.794 + }, + { + "model": "openrouter/quasar-alpha", + "duration": 1876, + "duration_secs": 1.876 + } + ] } ], - "lastUpdated": "2025-04-04T13:12:05.778Z" + "lastUpdated": "2025-04-04T16:13:35.912Z" } \ No newline at end of file diff --git a/packages/kbot/tests/unit/reports/files.json b/packages/kbot/tests/unit/reports/files.json new file mode 100644 index 00000000..eea6386f --- /dev/null +++ b/packages/kbot/tests/unit/reports/files.json @@ -0,0 +1,2039 @@ +{ + "results": [ + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Dijkstra's Algorithm" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:18:51.155Z", + "passed": false, + "duration": 1359, + "reason": "Expected bubble sort, but got dijkstra's algorithm", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The algorithm implemented in the provided files is AES encryption in CTR mode with a key derived using PBKDF2-HMAC-SHA256. The primary cipher used is AES (Advanced Encryption Standard), specifically in CTR (Counter) mode. Therefore, the name is AES-CTR.\n\n**Answer:** AES" + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:19:05.797Z", + "passed": false, + "duration": 14630, + "reason": "Expected bubble sort, but got the algorithm implemented in the provided files is aes encryption in ctr mode with a key derived using pbkdf2-hmac-sha256. the primary cipher used is aes (advanced encryption standard), specifically in ctr (counter) mode. therefore, the name is aes-ctr.\n\n**answer:** aes", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The name of the algorithm is not provided in your request." + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:19:07.137Z", + "passed": false, + "duration": 1330, + "reason": "Expected bubble sort, but got the name of the algorithm is not provided in your request.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Please upload or provide the files you'd like me to analyze." + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:19:07.935Z", + "passed": false, + "duration": 790, + "reason": "Expected bubble sort, but got please upload or provide the files you'd like me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The algorithm implemented in these files is \"Collaborative Filtering.\"" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:19:09.003Z", + "passed": false, + "duration": 1058, + "reason": "Expected bubble sort, but got the algorithm implemented in these files is \"collaborative filtering.\"", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:19:39.019Z", + "passed": false, + "duration": 30009, + "error": { + "message": "API call timed out", + "code": "UNKNOWN", + "type": "Error", + "details": { + "stack": "Error: API call timed out\n at Timeout._onTimeout (C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\commons.ts:194:33)\n at listOnTimeout (node:internal/timers:594:17)\n at processTimers (node:internal/timers:529:7)", + "message": "API call timed out" + } + }, + "reason": "API call timed out", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "I'm sorry, but I cannot determine the name of the algorithm without more context or specific information about the files in question." + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:19:41.008Z", + "passed": false, + "duration": 1979, + "reason": "Expected bubble sort, but got i'm sorry, but i cannot determine the name of the algorithm without more context or specific information about the files in question.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Please upload or provide the files you'd like me to analyze." + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:19:41.854Z", + "passed": false, + "duration": 838, + "reason": "Expected bubble sort, but got please upload or provide the files you'd like me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:20:05.993Z", + "passed": true, + "duration": 1179, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The algorithm implemented in the provided code is the **Bubble Sort Algorithm**." + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:20:11.767Z", + "passed": false, + "duration": 5763, + "reason": "Expected bubble sort, but got the algorithm implemented in the provided code is the **bubble sort algorithm**.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:20:13.107Z", + "passed": true, + "duration": 1334, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:20:14.287Z", + "passed": true, + "duration": 1173, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "K-means clustering" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:20:15.141Z", + "passed": false, + "duration": 847, + "reason": "Expected bubble sort, but got k-means clustering", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "The algorithm implemented in the files is **Gradient Descent**." + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:20:23.840Z", + "passed": false, + "duration": 8688, + "reason": "Expected bubble sort, but got the algorithm implemented in the files is **gradient descent**.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "I cannot determine the name of the algorithm based on the provided information." + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:20:25.805Z", + "passed": false, + "duration": 1956, + "reason": "Expected bubble sort, but got i cannot determine the name of the algorithm based on the provided information.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Please provide the files you'd like me to analyze." + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:20:26.593Z", + "passed": false, + "duration": 780, + "reason": "Expected bubble sort, but got please provide the files you'd like me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:21:25.673Z", + "passed": true, + "duration": 1367, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort Algorithm" + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:21:30.787Z", + "passed": false, + "duration": 5106, + "reason": "Expected bubble sort, but got bubble sort algorithm", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:21:31.712Z", + "passed": true, + "duration": 918, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:21:32.767Z", + "passed": true, + "duration": 1048, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:21:33.649Z", + "passed": true, + "duration": 875, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:21:40.963Z", + "passed": true, + "duration": 7307, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:21:42.451Z", + "passed": true, + "duration": 1480, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:21:43.287Z", + "passed": true, + "duration": 829, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "bubbleSort" + ], + "expected": "bubble sort", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:30:24.033Z", + "passed": false, + "duration": 1519, + "reason": "Expected bubble sort, but got bubblesort", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "bubble sort" + ], + "expected": "bubble sort", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:30:29.018Z", + "passed": true, + "duration": 4977, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:30:30.154Z", + "passed": true, + "duration": 1128, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:30:30.838Z", + "passed": true, + "duration": 677, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "1. Bubblesort\n2. Quicksort\n3. Selection sort\n4. Insertion sort\n5. Merge sort\n6. Linear search\n7. Binary search" + ], + "expected": "bubble sort\nfactorial", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:30:32.076Z", + "passed": false, + "duration": 1231, + "reason": "Expected bubble sort\nfactorial, but got 1. bubblesort\n2. quicksort\n3. selection sort\n4. insertion sort\n5. merge sort\n6. linear search\n7. binary search", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "Algorithm1\nAlgorithm2\nAlgorithm3\nAlgorithm4\nAlgorithm5\nAlgorithm6\nAlgorithm7\nAlgorithm8\nAlgorithm9\nAlgorithm10" + ], + "expected": "bubble sort\nfactorial", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:30:37.874Z", + "passed": false, + "duration": 5787, + "reason": "Expected bubble sort\nfactorial, but got algorithm1\nalgorithm2\nalgorithm3\nalgorithm4\nalgorithm5\nalgorithm6\nalgorithm7\nalgorithm8\nalgorithm9\nalgorithm10", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "I'm sorry, but I cannot access or analyze files directly. However, if you provide me with the names of the algorithms or a list of the file contents, I can help you identify the algorithms from that information." + ], + "expected": "bubble sort\nfactorial", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:30:39.653Z", + "passed": false, + "duration": 1771, + "reason": "Expected bubble sort\nfactorial, but got i'm sorry, but i cannot access or analyze files directly. however, if you provide me with the names of the algorithms or a list of the file contents, i can help you identify the algorithms from that information.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "Certainly! Please upload or provide the files you'd like me to analyze." + ], + "expected": "bubble sort\nfactorial", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:30:40.428Z", + "passed": false, + "duration": 765, + "reason": "Expected bubble sort\nfactorial, but got certainly! please upload or provide the files you'd like me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:30:41.577Z", + "passed": false, + "duration": 1140, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:30:50.090Z", + "passed": false, + "duration": 8505, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:30:51.366Z", + "passed": false, + "duration": 1269, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:30:52.495Z", + "passed": false, + "duration": 1122, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "How many json files are included? Return only the number.", + "result": [ + "2" + ], + "expected": "2", + "model": "openai/gpt-3.5-turbo", + "router": "openai/gpt-3.5-turbo", + "timestamp": "2025-04-04T15:30:53.296Z", + "passed": true, + "duration": 794, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "How many json files are included? Return only the number.", + "result": [ + "0" + ], + "expected": "2", + "model": "deepseek/deepseek-r1-distill-qwen-14b:free", + "router": "deepseek/deepseek-r1-distill-qwen-14b:free", + "timestamp": "2025-04-04T15:31:12.749Z", + "passed": false, + "duration": 19446, + "reason": "Expected 2, but got 0", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "How many json files are included? Return only the number.", + "result": [ + "0" + ], + "expected": "2", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:31:13.650Z", + "passed": false, + "duration": 892, + "reason": "Expected 2, but got 0", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "How many json files are included? Return only the number.", + "result": [ + "0" + ], + "expected": "2", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T15:31:14.354Z", + "passed": false, + "duration": 696, + "reason": "Expected 2, but got 0", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:33:31.043Z", + "passed": true, + "duration": 1340, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "Sure! Please provide the files you want me to analyze for the algorithms." + ], + "expected": "bubble sort\nfactorial", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:33:31.940Z", + "passed": false, + "duration": 888, + "reason": "Expected bubble sort\nfactorial, but got sure! please provide the files you want me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:33:33.493Z", + "passed": false, + "duration": 1542, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:34:22.969Z", + "passed": true, + "duration": 1883, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files. Return only the names, one per line.", + "result": [ + "Sure! Please provide the files or the content you would like me to analyze for the algorithms." + ], + "expected": "bubble sort\nfactorial", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:34:24.039Z", + "passed": false, + "duration": 1061, + "reason": "Expected bubble sort\nfactorial, but got sure! please provide the files or the content you would like me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:34:25.186Z", + "passed": false, + "duration": 1133, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:02.427Z", + "passed": true, + "duration": 1733, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Please provide the specific file names or content you're referring to in order to identify the algorithms implemented in them." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:03.619Z", + "passed": false, + "duration": 1184, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got please provide the specific file names or content you're referring to in order to identify the algorithms implemented in them.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:04.692Z", + "passed": false, + "duration": 1065, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:34.623Z", + "passed": true, + "duration": 1278, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the list of files you would like me to analyze for algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:36.650Z", + "passed": false, + "duration": 2019, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the list of files you would like me to analyze for algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:38:37.745Z", + "passed": false, + "duration": 1086, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:39:33.859Z", + "passed": true, + "duration": 1628, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Please provide the files or the content of the files you are referring to, and I can help you list the algorithms implemented in them as a JSON array." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:39:35.542Z", + "passed": false, + "duration": 1674, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got please provide the files or the content of the files you are referring to, and i can help you list the algorithms implemented in them as a json array.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:39:37.182Z", + "passed": false, + "duration": 1631, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:42:34.182Z", + "passed": true, + "duration": 1315, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "{\"algorithms\": []}" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:42:35.193Z", + "passed": false, + "duration": 1003, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got {\"algorithms\": []}", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:42:37.295Z", + "passed": false, + "duration": 2091, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:43:40.121Z", + "passed": true, + "duration": 1641, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure, please provide the names of the files you would like me to analyze for algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:43:41.289Z", + "passed": false, + "duration": 1159, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure, please provide the names of the files you would like me to analyze for algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:43:42.379Z", + "passed": false, + "duration": 1080, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:44:41.061Z", + "passed": true, + "duration": 1819, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you would like me to analyze for the algorithms implemented in them." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:44:42.391Z", + "passed": false, + "duration": 1321, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you would like me to analyze for the algorithms implemented in them.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:44:43.653Z", + "passed": false, + "duration": 1252, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:00.091Z", + "passed": true, + "duration": 1818, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure, please provide the filenames or contents of the files that contain the algorithms you want me to analyze." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:01.558Z", + "passed": false, + "duration": 1458, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure, please provide the filenames or contents of the files that contain the algorithms you want me to analyze.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:02.916Z", + "passed": false, + "duration": 1349, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:57.758Z", + "passed": true, + "duration": 1504, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you'd like me to analyze for the algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:45:58.900Z", + "passed": false, + "duration": 1132, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you'd like me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:46:00.008Z", + "passed": false, + "duration": 1098, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:46:31.841Z", + "passed": true, + "duration": 1319, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "I would need to see the specific files you are referring to in order to list the algorithms implemented within them. Please provide the files or their content." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:46:34.248Z", + "passed": false, + "duration": 2396, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got i would need to see the specific files you are referring to in order to list the algorithms implemented within them. please provide the files or their content.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:46:35.295Z", + "passed": false, + "duration": 1038, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:20.776Z", + "passed": true, + "duration": 1509, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files or the content of the files you want me to analyze for the algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:22.070Z", + "passed": false, + "duration": 1285, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files or the content of the files you want me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:23.445Z", + "passed": false, + "duration": 1365, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:48.866Z", + "passed": true, + "duration": 1918, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you would like me to analyze for the algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:50.013Z", + "passed": false, + "duration": 1138, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you would like me to analyze for the algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:49:51.201Z", + "passed": false, + "duration": 1178, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:51:37.261Z", + "passed": true, + "duration": 22396, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you would like me to analyze for algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:10.696Z", + "passed": false, + "duration": 33423, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you would like me to analyze for algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:20.423Z", + "passed": false, + "duration": 9714, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:35.377Z", + "passed": true, + "duration": 1392, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Sure! Please provide the files you would like me to inspect for algorithms." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:36.546Z", + "passed": false, + "duration": 1159, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got sure! please provide the files you would like me to inspect for algorithms.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:37.611Z", + "passed": false, + "duration": 1055, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:52:50.539Z", + "passed": true, + "duration": 7831, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "Please provide the files or their contents for me to help you list the algorithms implemented in them." + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:54:10.941Z", + "passed": false, + "duration": 80392, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got please provide the files or their contents for me to help you list the algorithms implemented in them.", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:54:12.194Z", + "passed": false, + "duration": 1242, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:59:06.412Z", + "passed": false, + "duration": 140731, + "error": { + "message": "API call timed out", + "code": "UNKNOWN", + "type": "Error", + "details": { + "stack": "Error: API call timed out\n at Timeout._onTimeout (C:\\Users\\zx\\Desktop\\polymech\\polymech-mono\\packages\\kbot\\tests\\unit\\commons.ts:204:33)\n at listOnTimeout (node:internal/timers:594:17)\n at processTimers (node:internal/timers:529:7)", + "message": "API call timed out" + } + }, + "reason": "API call timed out", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:59:14.901Z", + "passed": false, + "duration": 8474, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:59:30.681Z", + "passed": false, + "duration": 1601, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T15:59:34.787Z", + "passed": false, + "duration": 1611, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\n \"factorial\",\n \"bubbleSort\"\n]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:00:10.350Z", + "passed": false, + "duration": 1817, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\n \"factorial\",\n \"bubblesort\"\n]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:00:38.929Z", + "passed": false, + "duration": 1513, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:01:05.089Z", + "passed": false, + "duration": 1403, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:01:06.608Z", + "passed": false, + "duration": 1508, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:01:42.090Z", + "passed": false, + "duration": 4288, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:02:14.412Z", + "passed": false, + "duration": 1862, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:02:20.785Z", + "passed": false, + "duration": 1419, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:02:35.408Z", + "passed": false, + "duration": 2098, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:03:10.823Z", + "passed": false, + "duration": 7679, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:03:12.186Z", + "passed": false, + "duration": 1350, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\n \"factorial\",\n \"bubbleSort\"\n]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:03:45.485Z", + "passed": false, + "duration": 1379, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\n \"factorial\",\n \"bubblesort\"\n]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:03:46.562Z", + "passed": false, + "duration": 1067, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:09:09.410Z", + "passed": true, + "duration": 2135, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:09:10.529Z", + "passed": false, + "duration": 1109, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:09:11.750Z", + "passed": false, + "duration": 1212, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:09:14.639Z", + "passed": false, + "duration": 2881, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:11.907Z", + "passed": true, + "duration": 1372, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:12.999Z", + "passed": false, + "duration": 1082, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:14.666Z", + "passed": false, + "duration": 1659, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:17.346Z", + "passed": false, + "duration": 2672, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "bubble sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:35.717Z", + "passed": true, + "duration": 1411, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:36.740Z", + "passed": false, + "duration": 1012, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:37.999Z", + "passed": false, + "duration": 1250, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:10:40.832Z", + "passed": false, + "duration": 2824, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:11:23.284Z", + "passed": true, + "duration": 1409, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:11:24.272Z", + "passed": false, + "duration": 977, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:11:25.514Z", + "passed": false, + "duration": 1232, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:11:28.304Z", + "passed": false, + "duration": 2782, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:12:08.365Z", + "passed": true, + "duration": 1648, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:12:09.414Z", + "passed": false, + "duration": 1039, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:12:11.169Z", + "passed": false, + "duration": 1746, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:12:13.188Z", + "passed": false, + "duration": 2010, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:13:18.071Z", + "passed": true, + "duration": 1198, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "Bubble Sort" + ], + "expected": "bubble sort", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T16:13:18.811Z", + "passed": true, + "duration": 730, + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the name of the algorithm implemented in these files? Return only the name.", + "result": [ + "bubbleSort\n" + ], + "expected": "bubble sort", + "model": "google/gemini-2.0-flash-exp:free", + "router": "google/gemini-2.0-flash-exp:free", + "timestamp": "2025-04-04T16:13:20.745Z", + "passed": false, + "duration": 1926, + "reason": "Expected bubble sort, but got bubblesort", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:13:21.710Z", + "passed": false, + "duration": 956, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubble sort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T16:13:22.906Z", + "passed": false, + "duration": 1187, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubble sort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "List all algorithms implemented in these files, as JSON array.", + "result": [ + "[\"factorial\", \"bubbleSort\"]" + ], + "expected": "[\"bubble sort\",\"factorial\"]", + "model": "google/gemini-2.0-flash-exp:free", + "router": "google/gemini-2.0-flash-exp:free", + "timestamp": "2025-04-04T16:13:24.649Z", + "passed": false, + "duration": 1734, + "reason": "Expected [\"bubble sort\",\"factorial\"], but got [\"factorial\", \"bubblesort\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:13:26.014Z", + "passed": false, + "duration": 1357, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T16:13:27.012Z", + "passed": false, + "duration": 989, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What is the title of the product in data.json? Return only the title.", + "result": [ + "Injection Barrel" + ], + "expected": "Injection Barrel", + "model": "google/gemini-2.0-flash-exp:free", + "router": "google/gemini-2.0-flash-exp:free", + "timestamp": "2025-04-04T16:13:28.231Z", + "passed": false, + "duration": 1212, + "reason": "Expected Injection Barrel, but got injection barrel", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"wildcat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openai/gpt-4o-mini", + "router": "openai/gpt-4o-mini", + "timestamp": "2025-04-04T16:13:31.563Z", + "passed": false, + "duration": 3323, + "reason": "Expected [\"cat\",\"fox\"], but got [\"wildcat\", \"fox\"]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\n \"cat\",\n \"fox\"\n]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "openrouter/quasar-alpha", + "router": "openrouter/quasar-alpha", + "timestamp": "2025-04-04T16:13:33.448Z", + "passed": false, + "duration": 1876, + "reason": "Expected [\"cat\",\"fox\"], but got [\n \"cat\",\n \"fox\"\n]", + "category": "files" + }, + { + "test": "file-inclusion", + "prompt": "What animals are shown in these images? Return as JSON array.", + "result": [ + "[\"cat\", \"fox\"]" + ], + "expected": "[\"cat\",\"fox\"]", + "model": "google/gemini-2.0-flash-exp:free", + "router": "google/gemini-2.0-flash-exp:free", + "timestamp": "2025-04-04T16:13:35.906Z", + "passed": false, + "duration": 2449, + "reason": "Expected [\"cat\",\"fox\"], but got [\"cat\", \"fox\"]", + "category": "files" + } + ], + "highscores": [ + { + "test": "file-inclusion", + "rankings": [ + { + "model": "openai/gpt-3.5-turbo", + "duration": 794, + "duration_secs": 0.794 + }, + { + "model": "openrouter/quasar-alpha", + "duration": 1876, + "duration_secs": 1.876 + } + ] + } + ], + "lastUpdated": "2025-04-04T16:13:35.907Z" +} \ No newline at end of file diff --git a/packages/kbot/tests/unit/reports/files.md b/packages/kbot/tests/unit/reports/files.md new file mode 100644 index 00000000..0976918a --- /dev/null +++ b/packages/kbot/tests/unit/reports/files.md @@ -0,0 +1,59 @@ +# File Operations Test Results + +## Highscores + +### Performance Rankings (Duration) + +| Test | Model | Duration (ms) | Duration (s) | +|------|-------|--------------|--------------| +| file-inclusion | openrouter/quasar-alpha | 1876 | 1.88 | +| file-inclusion | google/gemini-2.0-flash-exp:free | 2449 | 2.45 | +| file-inclusion | openai/gpt-4o-mini | 3323 | 3.32 | + +## Summary + +- Total Tests: 12 +- Passed: 2 +- Failed: 10 +- Success Rate: 16.67% +- Average Duration: 1578ms (1.58s) + +## Failed Tests + +### file-inclusion - openai/gpt-4o-mini + +- Prompt: `What animals are shown in these images? Return as JSON array.` +- Expected: `["cat","fox"]` +- Actual: `["wildcat", "fox"]` +- Duration: 3323ms (3.32s) +- Reason: Expected ["cat","fox"], but got ["wildcat", "fox"] +- Timestamp: 4/4/2025, 6:13:31 PM + +### file-inclusion - openrouter/quasar-alpha + +- Prompt: `What animals are shown in these images? Return as JSON array.` +- Expected: `["cat","fox"]` +- Actual: `[ + "cat", + "fox" +]` +- Duration: 1876ms (1.88s) +- Reason: Expected ["cat","fox"], but got [ + "cat", + "fox" +] +- Timestamp: 4/4/2025, 6:13:33 PM + +### file-inclusion - google/gemini-2.0-flash-exp:free + +- Prompt: `What animals are shown in these images? Return as JSON array.` +- Expected: `["cat","fox"]` +- Actual: `["cat", "fox"]` +- Duration: 2449ms (2.45s) +- Reason: Expected ["cat","fox"], but got ["cat", "fox"] +- Timestamp: 4/4/2025, 6:13:35 PM + +## Passed Tests + +*No passed tests* + diff --git a/packages/kbot/tests/unit/test-data/test.md b/packages/kbot/tests/unit/test-data/test.md deleted file mode 100644 index e69de29b..00000000 diff --git a/packages/kbot/tests/unit/test-data/tools.test.md b/packages/kbot/tests/unit/test-data/tools.test.md deleted file mode 100644 index b52aa1a8..00000000 --- a/packages/kbot/tests/unit/test-data/tools.test.md +++ /dev/null @@ -1,14 +0,0 @@ -[ - { - "equation": "2x + 5 = 13", - "result": "4" - }, - { - "equation": "3y - 7 = 20", - "result": "9" - }, - { - "equation": "4z + 8 = 32", - "result": "6" - } -] \ No newline at end of file