@ixo/common 1.1.0 → 1.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +1 -1
- package/CHANGELOG.md +0 -6
- package/README.md +1 -6
- package/dist/ai/nodes/generic-chat/generic-chat.node.d.ts +4 -4
- package/dist/ai/nodes/generic-chat/generic-chat.node.d.ts.map +1 -1
- package/dist/ai/nodes/generic-chat/generic-chat.node.js +1 -1
- package/dist/ai/nodes/generic-chat/generic-chat.node.js.map +1 -1
- package/dist/ai/semantic-router-factory/create-semantic-router.d.ts +2 -2
- package/dist/ai/semantic-router-factory/create-semantic-router.d.ts.map +1 -1
- package/dist/ai/semantic-router-factory/create-semantic-router.js.map +1 -1
- package/dist/ai/tools/action-caller.d.ts +3 -3
- package/dist/ai/tools/action-caller.d.ts.map +1 -1
- package/dist/ai/tools/ask-ixo-guru/ask-ixo-guru.d.ts.map +1 -1
- package/dist/ai/tools/ask-ixo-guru/ask-ixo-guru.js.map +1 -1
- package/dist/ai/tools/browser-tool-caller.d.ts +3 -3
- package/dist/ai/tools/browser-tool-caller.d.ts.map +1 -1
- package/dist/ai/tools/frontend-tool-caller.d.ts +2 -2
- package/dist/ai/tools/frontend-tool-caller.d.ts.map +1 -1
- package/dist/ai/tools/frontend-tool-caller.js +2 -1
- package/dist/ai/tools/frontend-tool-caller.js.map +1 -1
- package/dist/ai/tools/log-action-to-matrix.d.ts +2 -2
- package/dist/ai/tools/log-action-to-matrix.d.ts.map +1 -1
- package/dist/ai/tools/log-action-to-matrix.js.map +1 -1
- package/dist/ai/tools/parser-action-tool.d.ts +2 -2
- package/dist/ai/tools/parser-action-tool.d.ts.map +1 -1
- package/dist/ai/tools/parser-action-tool.js +5 -5
- package/dist/ai/tools/parser-action-tool.js.map +1 -1
- package/dist/ai/tools/parser-browser-tool.d.ts +2 -2
- package/dist/ai/tools/parser-browser-tool.d.ts.map +1 -1
- package/dist/ai/tools/parser-browser-tool.js +1 -1
- package/dist/ai/tools/parser-browser-tool.js.map +1 -1
- package/dist/ai/tools/scrape-web-page.d.ts +1 -1
- package/dist/ai/tools/scrape-web-page.d.ts.map +1 -1
- package/dist/ai/utils/doc-splitter.js.map +1 -1
- package/dist/ai/utils/generate-questions-from-chunks.d.ts +1 -1
- package/dist/ai/utils/generate-questions-from-chunks.d.ts.map +1 -1
- package/dist/ai/utils/json-to-yaml.js.map +1 -1
- package/dist/ai/utils/load-file.js +1 -1
- package/dist/ai/utils/load-file.js.map +1 -1
- package/dist/ai/utils/transformGraphStateMessageToListMessageResponse.d.ts.map +1 -1
- package/dist/ai/utils/transformGraphStateMessageToListMessageResponse.js +5 -3
- package/dist/ai/utils/transformGraphStateMessageToListMessageResponse.js.map +1 -1
- package/dist/ai/utils/verify-matrix-openId-token.d.ts.map +1 -1
- package/dist/ai/utils/verify-matrix-openId-token.js +2 -2
- package/dist/ai/utils/verify-matrix-openId-token.js.map +1 -1
- package/dist/services/env/env.service.d.ts.map +1 -1
- package/dist/services/env/env.service.js.map +1 -1
- package/dist/services/session-manager/session-manager.service.d.ts +2 -2
- package/dist/services/session-manager/session-manager.service.d.ts.map +1 -1
- package/dist/services/session-manager/session-manager.service.js +3 -2
- package/dist/services/session-manager/session-manager.service.js.map +1 -1
- package/package.json +7 -11
- package/src/ai/index.ts +1 -1
- package/src/ai/models/openai.test.ts +7 -8
- package/src/ai/nodes/generic-chat/generic-chat.node.ts +7 -4
- package/src/ai/nodes/generic-chat/index.ts +1 -1
- package/src/ai/nodes/index.ts +1 -1
- package/src/ai/semantic-router-factory/create-semantic-router.test.ts +8 -5
- package/src/ai/semantic-router-factory/create-semantic-router.ts +8 -5
- package/src/ai/tools/action-caller.ts +3 -3
- package/src/ai/tools/ask-ixo-guru/ask-ixo-guru.ts +6 -4
- package/src/ai/tools/browser-tool-caller.ts +3 -3
- package/src/ai/tools/frontend-tool-caller.ts +11 -6
- package/src/ai/tools/log-action-to-matrix.ts +2 -3
- package/src/ai/tools/parser-action-tool.ts +8 -8
- package/src/ai/tools/parser-browser-tool.ts +4 -4
- package/src/ai/tools/retriever-tool/retriever-tool.test.ts +30 -23
- package/src/ai/tools/scrape-web-page.ts +1 -1
- package/src/ai/utils/__tests__/doc-relevance-checker.test.ts +5 -3
- package/src/ai/utils/__tests__/json-to-yaml.test.ts +1 -1
- package/src/ai/utils/doc-splitter.ts +1 -1
- package/src/ai/utils/generate-questions-from-chunks.ts +1 -1
- package/src/ai/utils/json-to-yaml.ts +1 -1
- package/src/ai/utils/load-file.ts +1 -1
- package/src/ai/utils/transformGraphStateMessageToListMessageResponse.ts +8 -4
- package/src/ai/utils/verify-matrix-openId-token.ts +9 -6
- package/src/services/env/env-service.test.ts +1 -1
- package/src/services/env/env.service.ts +0 -1
- package/src/services/session-manager/session-manager.service.ts +6 -4
- package/src/utils/index.ts +1 -1
- package/tsconfig.json +8 -2
- package/tsconfig.tsbuildinfo +1 -1
- package/vitest.config.ts +2 -0
- package/.eslintrc.js +0 -9
- package/.prettierignore +0 -3
- package/.prettierrc.cjs +0 -4
- package/dist/ai/models/openai.test.d.ts +0 -2
- package/dist/ai/models/openai.test.d.ts.map +0 -1
- package/dist/ai/models/openai.test.js +0 -58
- package/dist/ai/models/openai.test.js.map +0 -1
- package/dist/ai/semantic-router-factory/create-semantic-router.test.d.ts +0 -2
- package/dist/ai/semantic-router-factory/create-semantic-router.test.d.ts.map +0 -1
- package/dist/ai/semantic-router-factory/create-semantic-router.test.js +0 -68
- package/dist/ai/semantic-router-factory/create-semantic-router.test.js.map +0 -1
- package/dist/ai/tools/retriever-tool/retriever-tool.test.d.ts +0 -2
- package/dist/ai/tools/retriever-tool/retriever-tool.test.d.ts.map +0 -1
- package/dist/ai/tools/retriever-tool/retriever-tool.test.js +0 -119
- package/dist/ai/tools/retriever-tool/retriever-tool.test.js.map +0 -1
- package/dist/ai/utils/__tests__/chunk-arr.test.d.ts +0 -2
- package/dist/ai/utils/__tests__/chunk-arr.test.d.ts.map +0 -1
- package/dist/ai/utils/__tests__/chunk-arr.test.js +0 -37
- package/dist/ai/utils/__tests__/chunk-arr.test.js.map +0 -1
- package/dist/ai/utils/__tests__/doc-relevance-checker.test.d.ts +0 -2
- package/dist/ai/utils/__tests__/doc-relevance-checker.test.d.ts.map +0 -1
- package/dist/ai/utils/__tests__/doc-relevance-checker.test.js +0 -80
- package/dist/ai/utils/__tests__/doc-relevance-checker.test.js.map +0 -1
- package/dist/ai/utils/__tests__/doc-splitter.test.d.ts +0 -2
- package/dist/ai/utils/__tests__/doc-splitter.test.d.ts.map +0 -1
- package/dist/ai/utils/__tests__/doc-splitter.test.js +0 -35
- package/dist/ai/utils/__tests__/doc-splitter.test.js.map +0 -1
- package/dist/ai/utils/__tests__/filter-similarity-search-results.test.d.ts +0 -2
- package/dist/ai/utils/__tests__/filter-similarity-search-results.test.d.ts.map +0 -1
- package/dist/ai/utils/__tests__/filter-similarity-search-results.test.js +0 -47
- package/dist/ai/utils/__tests__/filter-similarity-search-results.test.js.map +0 -1
- package/dist/ai/utils/__tests__/json-to-yaml.test.d.ts +0 -2
- package/dist/ai/utils/__tests__/json-to-yaml.test.d.ts.map +0 -1
- package/dist/ai/utils/__tests__/json-to-yaml.test.js +0 -63
- package/dist/ai/utils/__tests__/json-to-yaml.test.js.map +0 -1
- package/dist/ai/utils/__tests__/stringify-docs.test.d.ts +0 -2
- package/dist/ai/utils/__tests__/stringify-docs.test.d.ts.map +0 -1
- package/dist/ai/utils/__tests__/stringify-docs.test.js +0 -54
- package/dist/ai/utils/__tests__/stringify-docs.test.js.map +0 -1
- package/dist/services/env/env-service.test.d.ts +0 -2
- package/dist/services/env/env-service.test.d.ts.map +0 -1
- package/dist/services/env/env-service.test.js +0 -99
- package/dist/services/env/env-service.test.js.map +0 -1
- package/jest.config.js +0 -6
package/vitest.config.ts
ADDED
package/.eslintrc.js
DELETED
package/.prettierignore
DELETED
package/.prettierrc.cjs
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"openai.test.d.ts","sourceRoot":"","sources":["../../../src/ai/models/openai.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
import { ChatOpenAI, OpenAIEmbeddings } from '@langchain/openai';
|
|
2
|
-
import { getChatOpenAiModel, getOpenAiEmbeddings } from './openai.js';
|
|
3
|
-
const originalEnv = process.env;
|
|
4
|
-
describe('OpenAI Models', () => {
|
|
5
|
-
beforeEach(() => {
|
|
6
|
-
jest.resetModules();
|
|
7
|
-
process.env = { ...originalEnv };
|
|
8
|
-
process.env.OPENAI_API_KEY = 'test-api-key';
|
|
9
|
-
});
|
|
10
|
-
afterEach(() => {
|
|
11
|
-
process.env = originalEnv;
|
|
12
|
-
});
|
|
13
|
-
describe('getChatOpenAiModel', () => {
|
|
14
|
-
it('should create a ChatOpenAI instance with default parameters', () => {
|
|
15
|
-
const model = getChatOpenAiModel();
|
|
16
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
17
|
-
expect(model).toHaveProperty('temperature', 0.2);
|
|
18
|
-
expect(model).toHaveProperty('modelName', 'gpt-4o-mini');
|
|
19
|
-
expect(model).toHaveProperty('apiKey', 'test-api-key');
|
|
20
|
-
});
|
|
21
|
-
it('should override default parameters when provided', () => {
|
|
22
|
-
const customParams = {
|
|
23
|
-
temperature: 0.8,
|
|
24
|
-
model: 'gpt-4',
|
|
25
|
-
apiKey: 'custom-api-key',
|
|
26
|
-
};
|
|
27
|
-
const model = getChatOpenAiModel(customParams);
|
|
28
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
29
|
-
expect(model).toHaveProperty('temperature', 0.8);
|
|
30
|
-
expect(model).toHaveProperty('modelName', 'gpt-4');
|
|
31
|
-
expect(model).toHaveProperty('apiKey', 'custom-api-key');
|
|
32
|
-
});
|
|
33
|
-
});
|
|
34
|
-
describe('getOpenAiEmbeddings', () => {
|
|
35
|
-
it('should create an OpenAIEmbeddings instance with default parameters', () => {
|
|
36
|
-
const embeddings = getOpenAiEmbeddings();
|
|
37
|
-
expect(embeddings).toBeInstanceOf(OpenAIEmbeddings);
|
|
38
|
-
expect(embeddings.model).toEqual('text-embedding-3-small');
|
|
39
|
-
});
|
|
40
|
-
it('should override default parameters when provided', () => {
|
|
41
|
-
const customParams = {
|
|
42
|
-
model: 'text-embedding-ada-002',
|
|
43
|
-
apiKey: 'custom-api-key',
|
|
44
|
-
};
|
|
45
|
-
const embeddings = getOpenAiEmbeddings(customParams);
|
|
46
|
-
expect(embeddings).toBeInstanceOf(OpenAIEmbeddings);
|
|
47
|
-
expect(embeddings.model).toEqual('text-embedding-ada-002');
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
describe('Error handling', () => {
|
|
51
|
-
it('should throw an error when OPENAI_API_KEY is not set', () => {
|
|
52
|
-
delete process.env.OPENAI_API_KEY;
|
|
53
|
-
expect(() => getChatOpenAiModel()).toThrow();
|
|
54
|
-
expect(() => getOpenAiEmbeddings()).toThrow();
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
|
-
});
|
|
58
|
-
//# sourceMappingURL=openai.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"openai.test.js","sourceRoot":"","sources":["../../../src/ai/models/openai.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-semantic-router.test.d.ts","sourceRoot":"","sources":["../../../src/ai/semantic-router-factory/create-semantic-router.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { createSemanticRouter } from './create-semantic-router.js';
|
|
2
|
-
const parse = jest.fn();
|
|
3
|
-
const create = jest.fn();
|
|
4
|
-
jest.mock('openai', () => ({
|
|
5
|
-
OpenAI: jest.fn().mockImplementation(() => {
|
|
6
|
-
function fn() {
|
|
7
|
-
return {};
|
|
8
|
-
}
|
|
9
|
-
fn.beta = {
|
|
10
|
-
chat: {
|
|
11
|
-
completions: { parse },
|
|
12
|
-
},
|
|
13
|
-
};
|
|
14
|
-
fn.chat = {
|
|
15
|
-
completions: { create },
|
|
16
|
-
};
|
|
17
|
-
return fn;
|
|
18
|
-
}),
|
|
19
|
-
}));
|
|
20
|
-
describe('createSemanticRouter', () => {
|
|
21
|
-
it('should create a semantic router with valid routes', () => {
|
|
22
|
-
expect(() => createSemanticRouter({
|
|
23
|
-
generateBlog: 'if the intent is blog',
|
|
24
|
-
generateSocialMediaPost: 'if the intent is post',
|
|
25
|
-
}, ['intent'])).not.toThrow();
|
|
26
|
-
});
|
|
27
|
-
it('should fail to create a semantic router with invalid routes', () => {
|
|
28
|
-
expect(() => createSemanticRouter({}, ['intent'])).toThrow();
|
|
29
|
-
});
|
|
30
|
-
it('should fail to get route with invalid state', async () => {
|
|
31
|
-
const router = createSemanticRouter({
|
|
32
|
-
generateBlog: 'if the intent is blog',
|
|
33
|
-
generateSocialMediaPost: 'if the intent is post',
|
|
34
|
-
}, ['intent']);
|
|
35
|
-
await expect(router({
|
|
36
|
-
foo: 'boo',
|
|
37
|
-
})).rejects.toThrow();
|
|
38
|
-
});
|
|
39
|
-
it('should get route with valid state', async () => {
|
|
40
|
-
const router = createSemanticRouter({
|
|
41
|
-
generateBlog: 'if the intent is blog',
|
|
42
|
-
generateSocialMediaPost: 'if the intent is post',
|
|
43
|
-
}, ['intent'], 'gpt-4o-mini', false);
|
|
44
|
-
parse.mockResolvedValue({
|
|
45
|
-
choices: [
|
|
46
|
-
{
|
|
47
|
-
message: {
|
|
48
|
-
parsed: {
|
|
49
|
-
nextRoute: 'generateBlog',
|
|
50
|
-
},
|
|
51
|
-
content: 'generateBlog',
|
|
52
|
-
role: 'assistant',
|
|
53
|
-
refusal: null,
|
|
54
|
-
tool_calls: [],
|
|
55
|
-
},
|
|
56
|
-
finish_reason: 'stop',
|
|
57
|
-
index: 0,
|
|
58
|
-
logprobs: null,
|
|
59
|
-
},
|
|
60
|
-
],
|
|
61
|
-
});
|
|
62
|
-
const route = await router({
|
|
63
|
-
intent: 'blog',
|
|
64
|
-
});
|
|
65
|
-
expect(route).toBe('generateBlog');
|
|
66
|
-
});
|
|
67
|
-
});
|
|
68
|
-
//# sourceMappingURL=create-semantic-router.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-semantic-router.test.js","sourceRoot":"","sources":["../../../src/ai/semantic-router-factory/create-semantic-router.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,MAAM,KAAK,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACxB,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACzB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC;IACzB,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,GAAG,EAAE;QACxC,SAAS,EAAE;YACT,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,EAAE,CAAC,IAAI,GAAG;YACR,IAAI,EAAE;gBACJ,WAAW,EAAE,EAAE,KAAK,EAAE;aACvB;SACF,CAAC;QAEF,EAAE,CAAC,IAAI,GAAG;YACR,WAAW,EAAE,EAAE,MAAM,EAAE;SACxB,CAAC;QACF,OAAO,EAAE,CAAC;IACZ,CAAC,CAAC;CACH,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAQ3D,MAAM,CAAC,GAAG,EAAE,CACV,oBAAoB,CAClB;YACE,YAAY,EAAE,uBAAuB;YACrC,uBAAuB,EAAE,uBAAuB;SACjD,EACD,CAAC,QAAQ,CAAC,CACX,CACF,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACrE,MAAM,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC3D,MAAM,MAAM,GAAG,oBAAoB,CACjC;YACE,YAAY,EAAE,uBAAuB;YACrC,uBAAuB,EAAE,uBAAuB;SACjD,EACD,CAAC,QAAQ,CAAC,CACX,CAAC;QACF,MAAM,MAAM,CACV,MAAM,CAAC;YACL,GAAG,EAAE,KAAK;SACX,CAAC,CACH,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IACtB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;QACjD,MAAM,MAAM,GAAG,oBAAoB,CACjC;YACE,YAAY,EAAE,uBAAuB;YACrC,uBAAuB,EAAE,uBAAuB;SACjD,EACD,CAAC,QAAQ,CAAC,EACV,aAAa,EACb,KAAK,CACN,CAAC;QAEF,KAAK,CAAC,iBAAiB,CAAC;YACtB,OAAO,EAAE;gBACP;oBACE,OAAO,EAAE;wBACP,MAAM,EAAE;4BACN,SAAS,EAAE,cAAc;yBAC1B;wBACD,OAAO,EAAE,cAAc;wBACvB,IAAI,EAAE,WAAW;wBACjB,OAAO,EAAE,IAAI;wBACb,UAAU,EAAE,EAAE;qBACf;oBACD,aAAa,EAAE,MAAM;oBACrB,KAAK,EAAE,CAAC;oBACR,QAAQ,EAAE,IAAI;iBACf;aACF;SACF,CAAC,CAAC;QAEH,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC;YACzB,MAAM,EAAE,MAAM;SACf,CAAC,CAAC;QACH,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retriever-tool.test.d.ts","sourceRoot":"","sources":["../../../../src/ai/tools/retriever-tool/retriever-tool.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
import { Document } from '@langchain/core/documents';
|
|
2
|
-
import { FakeChatModel } from '@langchain/core/utils/testing';
|
|
3
|
-
import { retrieverToolFactory } from './retriever-tool.js';
|
|
4
|
-
const fakeModel = new FakeChatModel({});
|
|
5
|
-
jest.mock('@ixo/logger', () => ({
|
|
6
|
-
Logger: {
|
|
7
|
-
error: jest.fn(),
|
|
8
|
-
},
|
|
9
|
-
}));
|
|
10
|
-
jest.mock('../../models/openai', () => ({
|
|
11
|
-
getChatOpenAiModel: () => fakeModel,
|
|
12
|
-
}));
|
|
13
|
-
jest.mock('../../utils/doc-relevance-checker', () => ({
|
|
14
|
-
__esModule: true,
|
|
15
|
-
default: jest.fn().mockResolvedValue(true),
|
|
16
|
-
}));
|
|
17
|
-
const fakeDocRelevanceChecker = jest.fn().mockResolvedValue(true);
|
|
18
|
-
jest
|
|
19
|
-
.spyOn(require('../../utils/doc-relevance-checker'), 'default')
|
|
20
|
-
.mockImplementation(fakeDocRelevanceChecker);
|
|
21
|
-
describe('RetrieverTool', () => {
|
|
22
|
-
let mockStore;
|
|
23
|
-
let mockModel = new FakeChatModel({});
|
|
24
|
-
beforeEach(() => {
|
|
25
|
-
mockStore = {
|
|
26
|
-
queryWithSimilarity: jest.fn(),
|
|
27
|
-
};
|
|
28
|
-
});
|
|
29
|
-
it('should retrieve documents with default settings', async () => {
|
|
30
|
-
const mockDocs = [
|
|
31
|
-
{ id: '1', content: 'test content 1', metadata: { source: 'test1' } },
|
|
32
|
-
{ id: '2', content: 'test content 2', metadata: { source: 'test2' } },
|
|
33
|
-
];
|
|
34
|
-
mockStore.queryWithSimilarity.mockResolvedValue(mockDocs);
|
|
35
|
-
const tool = retrieverToolFactory({ store: mockStore });
|
|
36
|
-
const result = (await tool.invoke({ query: 'test query' }));
|
|
37
|
-
expect(mockStore.queryWithSimilarity).toHaveBeenCalledWith('test query', {
|
|
38
|
-
similarityThreshold: 0.3,
|
|
39
|
-
filters: undefined,
|
|
40
|
-
});
|
|
41
|
-
expect(result).toHaveLength(2);
|
|
42
|
-
expect(result[0]).toBeInstanceOf(Document);
|
|
43
|
-
expect(result[0]?.pageContent).toBe('test content 1');
|
|
44
|
-
expect(result[0]?.metadata).toEqual({ source: 'test1' });
|
|
45
|
-
expect(fakeDocRelevanceChecker).toHaveBeenCalledWith({
|
|
46
|
-
doc: result[0],
|
|
47
|
-
query: 'test query',
|
|
48
|
-
model: fakeModel,
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
it('should store results in provided map', async () => {
|
|
52
|
-
const mockDocs = [
|
|
53
|
-
{ id: '1', content: 'test content', metadata: { source: 'test' } },
|
|
54
|
-
];
|
|
55
|
-
mockStore.queryWithSimilarity.mockResolvedValue(mockDocs);
|
|
56
|
-
const resultsMap = new Map();
|
|
57
|
-
const requestId = 'test-request-id';
|
|
58
|
-
const tool = retrieverToolFactory({
|
|
59
|
-
store: mockStore,
|
|
60
|
-
map: resultsMap,
|
|
61
|
-
requestId,
|
|
62
|
-
});
|
|
63
|
-
await tool.invoke({ query: 'test query' });
|
|
64
|
-
expect(resultsMap.get(requestId)).toEqual([{ source: 'test' }]);
|
|
65
|
-
});
|
|
66
|
-
it('should return undefined when no documents found', async () => {
|
|
67
|
-
mockStore.queryWithSimilarity.mockResolvedValue([]);
|
|
68
|
-
const tool = retrieverToolFactory({ store: mockStore });
|
|
69
|
-
const result = await tool.invoke({ query: 'test query' });
|
|
70
|
-
expect(result).toBeUndefined();
|
|
71
|
-
});
|
|
72
|
-
it('should check document relevance when similarity threshold is higher', async () => {
|
|
73
|
-
const mockDocs = [
|
|
74
|
-
{ id: '1', content: 'test content', metadata: { source: 'test' } },
|
|
75
|
-
];
|
|
76
|
-
mockStore.queryWithSimilarity.mockResolvedValue(mockDocs);
|
|
77
|
-
const tool = retrieverToolFactory({
|
|
78
|
-
store: mockStore,
|
|
79
|
-
similarThreshold: 0.5,
|
|
80
|
-
model: mockModel,
|
|
81
|
-
});
|
|
82
|
-
const result = await tool.invoke({ query: 'test query' });
|
|
83
|
-
expect(result).toHaveLength(1);
|
|
84
|
-
expect(result[0]).toBeInstanceOf(Document);
|
|
85
|
-
});
|
|
86
|
-
it('should handle errors during relevance checking', async () => {
|
|
87
|
-
const mockDocs = [
|
|
88
|
-
{ id: '1', content: 'test content', metadata: { source: 'test' } },
|
|
89
|
-
];
|
|
90
|
-
mockStore.queryWithSimilarity.mockResolvedValue(mockDocs);
|
|
91
|
-
jest
|
|
92
|
-
.requireMock('../../utils/doc-relevance-checker')
|
|
93
|
-
.default.mockRejectedValueOnce(new Error('Test error'));
|
|
94
|
-
const tool = retrieverToolFactory({
|
|
95
|
-
store: mockStore,
|
|
96
|
-
similarThreshold: 0.5,
|
|
97
|
-
model: mockModel,
|
|
98
|
-
});
|
|
99
|
-
const result = await tool.invoke({ query: 'test query' });
|
|
100
|
-
expect(result).toHaveLength(0);
|
|
101
|
-
});
|
|
102
|
-
it('should apply filters when provided', async () => {
|
|
103
|
-
const mockDocs = [
|
|
104
|
-
{ id: '1', content: 'test content', metadata: { source: 'test' } },
|
|
105
|
-
];
|
|
106
|
-
mockStore.queryWithSimilarity.mockResolvedValue(mockDocs);
|
|
107
|
-
const filters = { category: 'test' };
|
|
108
|
-
const tool = retrieverToolFactory({
|
|
109
|
-
store: mockStore,
|
|
110
|
-
filters,
|
|
111
|
-
});
|
|
112
|
-
await tool.invoke({ query: 'test query' });
|
|
113
|
-
expect(mockStore.queryWithSimilarity).toHaveBeenCalledWith('test query', {
|
|
114
|
-
similarityThreshold: 0.3,
|
|
115
|
-
filters,
|
|
116
|
-
});
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
//# sourceMappingURL=retriever-tool.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retriever-tool.test.js","sourceRoot":"","sources":["../../../../src/ai/tools/retriever-tool/retriever-tool.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-arr.test.d.ts","sourceRoot":"","sources":["../../../../src/ai/utils/__tests__/chunk-arr.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { chunkArr } from '../chunk-arr.js';
|
|
2
|
-
describe('chunkArr', () => {
|
|
3
|
-
it('should split array into chunks of specified size', () => {
|
|
4
|
-
const array = [1, 2, 3, 4, 5, 6, 7];
|
|
5
|
-
const result = chunkArr(array, 3);
|
|
6
|
-
expect(result).toEqual([[1, 2, 3], [4, 5, 6], [7]]);
|
|
7
|
-
});
|
|
8
|
-
it('should handle empty arrays', () => {
|
|
9
|
-
const array = [];
|
|
10
|
-
const result = chunkArr(array, 2);
|
|
11
|
-
expect(result).toEqual([]);
|
|
12
|
-
});
|
|
13
|
-
it('should handle chunk size equal to array length', () => {
|
|
14
|
-
const array = [1, 2, 3];
|
|
15
|
-
const result = chunkArr(array, 3);
|
|
16
|
-
expect(result).toEqual([[1, 2, 3]]);
|
|
17
|
-
});
|
|
18
|
-
it('should handle chunk size larger than array length', () => {
|
|
19
|
-
const array = [1, 2];
|
|
20
|
-
const result = chunkArr(array, 3);
|
|
21
|
-
expect(result).toEqual([[1, 2]]);
|
|
22
|
-
});
|
|
23
|
-
it('should throw error for chunk size less than or equal to 0', () => {
|
|
24
|
-
const array = [1, 2, 3];
|
|
25
|
-
expect(() => chunkArr(array, 0)).toThrow('Chunk size must be greater than 0');
|
|
26
|
-
expect(() => chunkArr(array, -1)).toThrow('Chunk size must be greater than 0');
|
|
27
|
-
});
|
|
28
|
-
it('should work with different types', () => {
|
|
29
|
-
const array = ['a', 'b', 'c', 'd'];
|
|
30
|
-
const result = chunkArr(array, 2);
|
|
31
|
-
expect(result).toEqual([
|
|
32
|
-
['a', 'b'],
|
|
33
|
-
['c', 'd'],
|
|
34
|
-
]);
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
//# sourceMappingURL=chunk-arr.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-arr.test.js","sourceRoot":"","sources":["../../../../src/ai/utils/__tests__/chunk-arr.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACxB,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACpC,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,KAAK,GAAa,EAAE,CAAC;QAC3B,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,MAAM,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACxB,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACrB,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACnE,MAAM,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CACtC,mCAAmC,CACpC,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CACvC,mCAAmC,CACpC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,KAAK,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QACnC,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,CAAC,GAAG,EAAE,GAAG,CAAC;YACV,CAAC,GAAG,EAAE,GAAG,CAAC;SACX,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"doc-relevance-checker.test.d.ts","sourceRoot":"","sources":["../../../../src/ai/utils/__tests__/doc-relevance-checker.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import { Document } from '@langchain/core/documents';
|
|
2
|
-
import { ChatPromptTemplate } from '@langchain/core/prompts';
|
|
3
|
-
import { FakeChatModel } from '@langchain/core/utils/testing';
|
|
4
|
-
import checkDocRelevance from '../doc-relevance-checker.js';
|
|
5
|
-
jest.spyOn(ChatPromptTemplate, 'fromTemplate');
|
|
6
|
-
describe('checkDocRelevance', () => {
|
|
7
|
-
const createMockModel = (returnValue) => {
|
|
8
|
-
const mockModel = new FakeChatModel({});
|
|
9
|
-
mockModel.withStructuredOutput = jest.fn().mockReturnValue({
|
|
10
|
-
pipe: () => ({
|
|
11
|
-
invoke: async () => ({ answer: returnValue }),
|
|
12
|
-
}),
|
|
13
|
-
});
|
|
14
|
-
ChatPromptTemplate.fromTemplate.mockReturnValue({
|
|
15
|
-
pipe: () => ({
|
|
16
|
-
invoke: async () => ({ answer: returnValue }),
|
|
17
|
-
}),
|
|
18
|
-
});
|
|
19
|
-
return mockModel;
|
|
20
|
-
};
|
|
21
|
-
it('should return true for relevant document using string input', async () => {
|
|
22
|
-
const mockModel = createMockModel(true);
|
|
23
|
-
const result = await checkDocRelevance({
|
|
24
|
-
doc: 'This is a document about JavaScript programming',
|
|
25
|
-
query: 'JavaScript development',
|
|
26
|
-
model: mockModel,
|
|
27
|
-
});
|
|
28
|
-
expect(result).toBe(true);
|
|
29
|
-
});
|
|
30
|
-
it('should return false for irrelevant document using string input', async () => {
|
|
31
|
-
const mockModel = createMockModel(false);
|
|
32
|
-
const result = await checkDocRelevance({
|
|
33
|
-
doc: 'This is a document about cooking recipes',
|
|
34
|
-
query: 'JavaScript development',
|
|
35
|
-
model: mockModel,
|
|
36
|
-
});
|
|
37
|
-
expect(result).toBe(false);
|
|
38
|
-
});
|
|
39
|
-
it('should handle Document object input', async () => {
|
|
40
|
-
const mockModel = createMockModel(true);
|
|
41
|
-
const doc = new Document({
|
|
42
|
-
pageContent: 'This is a document about TypeScript',
|
|
43
|
-
metadata: { id: '1' },
|
|
44
|
-
});
|
|
45
|
-
const result = await checkDocRelevance({
|
|
46
|
-
doc,
|
|
47
|
-
query: 'TypeScript features',
|
|
48
|
-
model: mockModel,
|
|
49
|
-
});
|
|
50
|
-
expect(result).toBe(true);
|
|
51
|
-
});
|
|
52
|
-
it('should work with empty document content', async () => {
|
|
53
|
-
const mockModel = createMockModel(false);
|
|
54
|
-
const result = await checkDocRelevance({
|
|
55
|
-
doc: '',
|
|
56
|
-
query: 'Any query',
|
|
57
|
-
model: mockModel,
|
|
58
|
-
});
|
|
59
|
-
expect(result).toBe(false);
|
|
60
|
-
});
|
|
61
|
-
it('should work with empty query', async () => {
|
|
62
|
-
const mockModel = createMockModel(false);
|
|
63
|
-
const result = await checkDocRelevance({
|
|
64
|
-
doc: 'Some content',
|
|
65
|
-
query: '',
|
|
66
|
-
model: mockModel,
|
|
67
|
-
});
|
|
68
|
-
expect(result).toBe(false);
|
|
69
|
-
});
|
|
70
|
-
it('should handle special characters in document and query', async () => {
|
|
71
|
-
const mockModel = createMockModel(true);
|
|
72
|
-
const result = await checkDocRelevance({
|
|
73
|
-
doc: 'Content with \n newlines and \t tabs',
|
|
74
|
-
query: 'Query with \n newlines',
|
|
75
|
-
model: mockModel,
|
|
76
|
-
});
|
|
77
|
-
expect(result).toBe(true);
|
|
78
|
-
});
|
|
79
|
-
});
|
|
80
|
-
//# sourceMappingURL=doc-relevance-checker.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"doc-relevance-checker.test.js","sourceRoot":"","sources":["../../../../src/ai/utils/__tests__/doc-relevance-checker.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"doc-splitter.test.d.ts","sourceRoot":"","sources":["../../../../src/ai/utils/__tests__/doc-splitter.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import { Document } from '@langchain/core/documents';
|
|
2
|
-
import { docSplitter } from '../doc-splitter.js';
|
|
3
|
-
describe('docSplitter', () => {
|
|
4
|
-
it('should split a single string into documents', async () => {
|
|
5
|
-
const text = 'This is a test document';
|
|
6
|
-
const result = await docSplitter(text);
|
|
7
|
-
expect(Array.isArray(result)).toBe(true);
|
|
8
|
-
expect(result.length).toBeGreaterThan(0);
|
|
9
|
-
expect(result[0]).toBeInstanceOf(Document);
|
|
10
|
-
});
|
|
11
|
-
it('should split an array of strings into documents', async () => {
|
|
12
|
-
const texts = ['First document', 'Second document'];
|
|
13
|
-
const result = await docSplitter(texts);
|
|
14
|
-
expect(Array.isArray(result)).toBe(true);
|
|
15
|
-
expect(result.length).toBeGreaterThan(0);
|
|
16
|
-
expect(result).toEqual(expect.arrayContaining([expect.any(Document)]));
|
|
17
|
-
});
|
|
18
|
-
it('should throw error for empty string', () => {
|
|
19
|
-
expect(() => docSplitter('')).toThrow('No text provided');
|
|
20
|
-
});
|
|
21
|
-
it('should throw error for empty array', () => {
|
|
22
|
-
expect(() => docSplitter([])).toThrow('Text array cannot be empty');
|
|
23
|
-
});
|
|
24
|
-
it('should throw error for null or undefined input', () => {
|
|
25
|
-
expect(() => docSplitter(null)).toThrow('No text provided');
|
|
26
|
-
expect(() => docSplitter(undefined)).toThrow('No text provided');
|
|
27
|
-
});
|
|
28
|
-
it('should handle long text correctly', async () => {
|
|
29
|
-
const longText = 'a'.repeat(2000);
|
|
30
|
-
const result = await docSplitter(longText);
|
|
31
|
-
expect(Array.isArray(result)).toBe(true);
|
|
32
|
-
expect(result.length).toBeGreaterThan(0);
|
|
33
|
-
});
|
|
34
|
-
});
|
|
35
|
-
//# sourceMappingURL=doc-splitter.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"doc-splitter.test.js","sourceRoot":"","sources":["../../../../src/ai/utils/__tests__/doc-splitter.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC3D,MAAM,IAAI,GAAG,yBAAyB,CAAC;QACvC,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,IAAI,CAAC,CAAC;QACvC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,KAAK,GAAG,CAAC,gBAAgB,EAAE,iBAAiB,CAAC,CAAC;QACpD,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,KAAK,CAAC,CAAC;QACxC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;IACzE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QAExD,MAAM,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC;QAE5D,MAAM,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;QACjD,MAAM,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAClC,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,QAAQ,CAAC,CAAC;QAC3C,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"filter-similarity-search-results.test.d.ts","sourceRoot":"","sources":["../../../../src/ai/utils/__tests__/filter-similarity-search-results.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { Document } from '@langchain/core/documents';
|
|
2
|
-
import { filterSimilaritySearchResults } from '../filter-similarity-search-results.js';
|
|
3
|
-
describe('filterSimilaritySearchResults', () => {
|
|
4
|
-
const createDoc = (content) => new Document({ pageContent: content });
|
|
5
|
-
it('should filter results above threshold', () => {
|
|
6
|
-
const results = [
|
|
7
|
-
[createDoc('doc1'), 0.9],
|
|
8
|
-
[createDoc('doc2'), 0.7],
|
|
9
|
-
[createDoc('doc3'), 0.3],
|
|
10
|
-
];
|
|
11
|
-
const filtered = filterSimilaritySearchResults(results, 0.5);
|
|
12
|
-
expect(filtered).toHaveLength(2);
|
|
13
|
-
expect(filtered[0]).toBeInstanceOf(Document);
|
|
14
|
-
expect(filtered[1]).toBeInstanceOf(Document);
|
|
15
|
-
});
|
|
16
|
-
it('should return empty array when no results meet threshold', () => {
|
|
17
|
-
const results = [
|
|
18
|
-
[createDoc('doc1'), 0.3],
|
|
19
|
-
[createDoc('doc2'), 0.2],
|
|
20
|
-
];
|
|
21
|
-
const filtered = filterSimilaritySearchResults(results, 0.5);
|
|
22
|
-
expect(filtered).toHaveLength(0);
|
|
23
|
-
});
|
|
24
|
-
it('should handle empty results array', () => {
|
|
25
|
-
const results = [];
|
|
26
|
-
const filtered = filterSimilaritySearchResults(results, 0.5);
|
|
27
|
-
expect(filtered).toHaveLength(0);
|
|
28
|
-
});
|
|
29
|
-
it('should handle threshold of 0', () => {
|
|
30
|
-
const results = [
|
|
31
|
-
[createDoc('doc1'), 0.1],
|
|
32
|
-
[createDoc('doc2'), 0.2],
|
|
33
|
-
];
|
|
34
|
-
const filtered = filterSimilaritySearchResults(results, 0);
|
|
35
|
-
expect(filtered).toHaveLength(2);
|
|
36
|
-
});
|
|
37
|
-
it('should handle threshold of 1', () => {
|
|
38
|
-
const results = [
|
|
39
|
-
[createDoc('doc1'), 0.9],
|
|
40
|
-
[createDoc('doc2'), 1.0],
|
|
41
|
-
];
|
|
42
|
-
const filtered = filterSimilaritySearchResults(results, 1);
|
|
43
|
-
expect(filtered).toHaveLength(1);
|
|
44
|
-
expect(filtered[0]).toBeInstanceOf(Document);
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
//# sourceMappingURL=filter-similarity-search-results.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"filter-similarity-search-results.test.js","sourceRoot":"","sources":["../../../../src/ai/utils/__tests__/filter-similarity-search-results.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AACrD,OAAO,EAAE,6BAA6B,EAAE,MAAM,wCAAwC,CAAC;AAEvF,QAAQ,CAAC,+BAA+B,EAAE,GAAG,EAAE;IAC7C,MAAM,SAAS,GAAG,CAAC,OAAe,EAAY,EAAE,CAC9C,IAAI,QAAQ,CAAC,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC,CAAC;IAEzC,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;QAC/C,MAAM,OAAO,GAAG;YACd,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC;YACxB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC;YACxB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC;SACD,CAAC;QAE1B,MAAM,QAAQ,GAAG,6BAA6B,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAC7D,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAC7C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0DAA0D,EAAE,GAAG,EAAE;QAClE,MAAM,OAAO,GAAG;YACd,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC;YACxB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC;SACD,CAAC;QAE1B,MAAM,QAAQ,GAAG,6BAA6B,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAC7D,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC3C,MAAM,OAAO,GAAyB,EAAE,CAAC;QACzC,MAAM,QAAQ,GAAG,6BAA6B,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAC7D,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,OAAO,GAAG;YACd,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC;YACxB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC;SACD,CAAC;QAE1B,MAAM,QAAQ,GAAG,6BAA6B,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC3D,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,OAAO,GAAG;YACd,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC;YACxB,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC;SACD,CAAC;QAE1B,MAAM,QAAQ,GAAG,6BAA6B,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC3D,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"json-to-yaml.test.d.ts","sourceRoot":"","sources":["../../../../src/ai/utils/__tests__/json-to-yaml.test.ts"],"names":[],"mappings":""}
|