mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-16 16:30:15 +01:00
* 🖥️ feat: Add Proxy Support for Tavily API Tool
- Integrated ProxyAgent from undici to enable proxy support for API requests in TavilySearch and TavilySearchResults.
- Updated fetch options to conditionally include the proxy configuration based on the environment variable, enhancing flexibility for network requests.
* ci: TavilySearchResults with Proxy Support Tests
- Added tests to verify the integration of ProxyAgent for API requests in TavilySearchResults.
- Implemented conditional logic to check for the PROXY environment variable, ensuring correct usage of ProxyAgent based on its presence.
- Updated test setup to clear mocks before each test for improved isolation and reliability.
84 lines
2.3 KiB
JavaScript
84 lines
2.3 KiB
JavaScript
const { fetch, ProxyAgent } = require('undici');
|
|
const TavilySearchResults = require('../TavilySearchResults');
|
|
|
|
jest.mock('undici');
|
|
jest.mock('@langchain/core/utils/env');
|
|
|
|
describe('TavilySearchResults', () => {
|
|
let originalEnv;
|
|
const mockApiKey = 'mock_api_key';
|
|
|
|
beforeAll(() => {
|
|
originalEnv = { ...process.env };
|
|
});
|
|
|
|
beforeEach(() => {
|
|
jest.resetModules();
|
|
jest.clearAllMocks();
|
|
process.env = {
|
|
...originalEnv,
|
|
TAVILY_API_KEY: mockApiKey,
|
|
};
|
|
});
|
|
|
|
afterEach(() => {
|
|
process.env = originalEnv;
|
|
});
|
|
|
|
it('should throw an error if TAVILY_API_KEY is missing', () => {
|
|
delete process.env.TAVILY_API_KEY;
|
|
expect(() => new TavilySearchResults()).toThrow('Missing TAVILY_API_KEY environment variable.');
|
|
});
|
|
|
|
it('should use mockApiKey when TAVILY_API_KEY is not set in the environment', () => {
|
|
const instance = new TavilySearchResults({
|
|
TAVILY_API_KEY: mockApiKey,
|
|
});
|
|
expect(instance.apiKey).toBe(mockApiKey);
|
|
});
|
|
|
|
describe('proxy support', () => {
|
|
const mockResponse = {
|
|
ok: true,
|
|
json: jest.fn().mockResolvedValue({ results: [] }),
|
|
};
|
|
|
|
beforeEach(() => {
|
|
fetch.mockResolvedValue(mockResponse);
|
|
});
|
|
|
|
it('should use ProxyAgent when PROXY env var is set', async () => {
|
|
const proxyUrl = 'http://proxy.example.com:8080';
|
|
process.env.PROXY = proxyUrl;
|
|
|
|
const mockProxyAgent = { type: 'proxy-agent' };
|
|
ProxyAgent.mockImplementation(() => mockProxyAgent);
|
|
|
|
const instance = new TavilySearchResults({ TAVILY_API_KEY: mockApiKey });
|
|
await instance._call({ query: 'test query' });
|
|
|
|
expect(ProxyAgent).toHaveBeenCalledWith(proxyUrl);
|
|
expect(fetch).toHaveBeenCalledWith(
|
|
'https://api.tavily.com/search',
|
|
expect.objectContaining({
|
|
dispatcher: mockProxyAgent,
|
|
}),
|
|
);
|
|
});
|
|
|
|
it('should not use ProxyAgent when PROXY env var is not set', async () => {
|
|
delete process.env.PROXY;
|
|
|
|
const instance = new TavilySearchResults({ TAVILY_API_KEY: mockApiKey });
|
|
await instance._call({ query: 'test query' });
|
|
|
|
expect(ProxyAgent).not.toHaveBeenCalled();
|
|
expect(fetch).toHaveBeenCalledWith(
|
|
'https://api.tavily.com/search',
|
|
expect.not.objectContaining({
|
|
dispatcher: expect.anything(),
|
|
}),
|
|
);
|
|
});
|
|
});
|
|
});
|