summaryrefslogtreecommitdiff
path: root/integration-tests/google_web_search.test.js
diff options
context:
space:
mode:
Diffstat (limited to 'integration-tests/google_web_search.test.js')
-rw-r--r--integration-tests/google_web_search.test.js67
1 files changed, 61 insertions, 6 deletions
diff --git a/integration-tests/google_web_search.test.js b/integration-tests/google_web_search.test.js
index a8968117..31747421 100644
--- a/integration-tests/google_web_search.test.js
+++ b/integration-tests/google_web_search.test.js
@@ -6,14 +6,69 @@
import { test } from 'node:test';
import { strict as assert } from 'assert';
-import { TestRig } from './test-helper.js';
+import { TestRig, printDebugInfo, validateModelOutput } from './test-helper.js';
-test('should be able to search the web', async (t) => {
+test('should be able to search the web', async () => {
const rig = new TestRig();
- rig.setup(t.name);
+ await rig.setup('should be able to search the web');
- const prompt = `what planet do we live on`;
- const result = await rig.run(prompt);
+ let result;
+ try {
+ result = await rig.run(`what is the weather in London`);
+ } catch (error) {
+ // Network errors can occur in CI environments
+ if (
+ error.message.includes('network') ||
+ error.message.includes('timeout')
+ ) {
+ console.warn('Skipping test due to network error:', error.message);
+ return; // Skip the test
+ }
+ throw error; // Re-throw if not a network error
+ }
- assert.ok(result.toLowerCase().includes('earth'));
+ const foundToolCall = await rig.waitForToolCall('google_web_search');
+
+ // Add debugging information
+ if (!foundToolCall) {
+ const allTools = printDebugInfo(rig, result);
+
+ // Check if the tool call failed due to network issues
+ const failedSearchCalls = allTools.filter(
+ (t) =>
+ t.toolRequest.name === 'google_web_search' && !t.toolRequest.success,
+ );
+ if (failedSearchCalls.length > 0) {
+ console.warn(
+ 'google_web_search tool was called but failed, possibly due to network issues',
+ );
+ console.warn(
+ 'Failed calls:',
+ failedSearchCalls.map((t) => t.toolRequest.args),
+ );
+ return; // Skip the test if network issues
+ }
+ }
+
+ assert.ok(foundToolCall, 'Expected to find a call to google_web_search');
+
+ // Validate model output - will throw if no output, warn if missing expected content
+ const hasExpectedContent = validateModelOutput(
+ result,
+ ['weather', 'london'],
+ 'Google web search test',
+ );
+
+ // If content was missing, log the search queries used
+ if (!hasExpectedContent) {
+ const searchCalls = rig
+ .readToolLogs()
+ .filter((t) => t.toolRequest.name === 'google_web_search');
+ if (searchCalls.length > 0) {
+ console.warn(
+ 'Search queries used:',
+ searchCalls.map((t) => t.toolRequest.args),
+ );
+ }
+ }
});