mirror of
https://github.com/aljazceru/Auto-GPT.git
synced 2026-01-04 06:44:31 +01:00
Co-authored-by: Reinier van der Leer <github@pwuts.nl> Co-authored-by: Nicholas Tindle <nick@ntindle.com> Co-authored-by: Nicholas Tindle <nicktindle@outlook.com> Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> Co-authored-by: merwanehamadi <merwanehamadi@gmail.com> Co-authored-by: Merwane Hamadi <merwanehamadi@gmail.com> Co-authored-by: Richard Beales <rich@richbeales.net> Co-authored-by: Luke K <2609441+lc0rp@users.noreply.github.com> Co-authored-by: Luke K (pr-0f3t) <2609441+lc0rp@users.noreply.github.com> Co-authored-by: Erik Peterson <e@eriklp.com> Co-authored-by: Auto-GPT-Bot <github-bot@agpt.co> Co-authored-by: Benny van der Lans <49377421+bfalans@users.noreply.github.com> Co-authored-by: Jan <jan-github@phobia.de> Co-authored-by: Robin Richtsfeld <robin.richtsfeld@gmail.com> Co-authored-by: Marc Bornträger <marc.borntraeger@gmail.com> Co-authored-by: Stefan Ayala <stefanayala3266@gmail.com> Co-authored-by: javableu <45064273+javableu@users.noreply.github.com> Co-authored-by: DGdev91 <DGdev91@users.noreply.github.com> Co-authored-by: Kinance <kinance@gmail.com> Co-authored-by: digger yu <digger-yu@outlook.com> Co-authored-by: David <scenaristeur@gmail.com> Co-authored-by: gravelBridge <john.tian31@gmail.com> Fix Python CI "update cassettes" step (#4591) fix CI (#4596) Fix inverted logic for deny_command (#4563) fix current_score.json generation (#4601) Fix duckduckgo rate limiting (#4592) Fix debug code challenge (#4632) Fix issues with information retrieval challenge a (#4622) fix issues with env configuration and .env.template (#4630) Fix prompt issue causing 'No Command' issues and challenge to fail (#4623) Fix benchmark logs (#4653) Fix typo in docs/setup.md (#4613) Fix run.sh shebang (#4561) Fix autogpt docker image not working because missing prompt_settings (#4680) Fix execute_command coming from plugins (#4730)
141 lines
3.9 KiB
Python
141 lines
3.9 KiB
Python
import json
|
|
|
|
import pytest
|
|
from googleapiclient.errors import HttpError
|
|
|
|
from autogpt.agent.agent import Agent
|
|
from autogpt.commands.google_search import (
|
|
google_official_search,
|
|
google_search,
|
|
safe_google_results,
|
|
)
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"query, expected_output",
|
|
[("test", "test"), (["test1", "test2"], '["test1", "test2"]')],
|
|
)
|
|
def test_safe_google_results(query, expected_output):
|
|
result = safe_google_results(query)
|
|
assert isinstance(result, str)
|
|
assert result == expected_output
|
|
|
|
|
|
def test_safe_google_results_invalid_input():
|
|
with pytest.raises(AttributeError):
|
|
safe_google_results(123)
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"query, num_results, expected_output, return_value",
|
|
[
|
|
(
|
|
"test",
|
|
1,
|
|
'[\n {\n "title": "Result 1",\n "link": "https://example.com/result1"\n }\n]',
|
|
[{"title": "Result 1", "link": "https://example.com/result1"}],
|
|
),
|
|
("", 1, "[]", []),
|
|
("no results", 1, "[]", []),
|
|
],
|
|
)
|
|
def test_google_search(
|
|
query, num_results, expected_output, return_value, mocker, agent: Agent
|
|
):
|
|
mock_ddg = mocker.Mock()
|
|
mock_ddg.return_value = return_value
|
|
|
|
mocker.patch("autogpt.commands.google_search.DDGS.text", mock_ddg)
|
|
actual_output = google_search(query, agent=agent, num_results=num_results)
|
|
expected_output = safe_google_results(expected_output)
|
|
assert actual_output == expected_output
|
|
|
|
|
|
@pytest.fixture
|
|
def mock_googleapiclient(mocker):
|
|
mock_build = mocker.patch("googleapiclient.discovery.build")
|
|
mock_service = mocker.Mock()
|
|
mock_build.return_value = mock_service
|
|
return mock_service.cse().list().execute().get
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"query, num_results, search_results, expected_output",
|
|
[
|
|
(
|
|
"test",
|
|
3,
|
|
[
|
|
{"link": "http://example.com/result1"},
|
|
{"link": "http://example.com/result2"},
|
|
{"link": "http://example.com/result3"},
|
|
],
|
|
[
|
|
"http://example.com/result1",
|
|
"http://example.com/result2",
|
|
"http://example.com/result3",
|
|
],
|
|
),
|
|
("", 3, [], []),
|
|
],
|
|
)
|
|
def test_google_official_search(
|
|
query,
|
|
num_results,
|
|
expected_output,
|
|
search_results,
|
|
mock_googleapiclient,
|
|
agent: Agent,
|
|
):
|
|
mock_googleapiclient.return_value = search_results
|
|
actual_output = google_official_search(query, agent=agent, num_results=num_results)
|
|
assert actual_output == safe_google_results(expected_output)
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"query, num_results, expected_output, http_code, error_msg",
|
|
[
|
|
(
|
|
"invalid query",
|
|
3,
|
|
"Error: <HttpError 400 when requesting https://www.googleapis.com/customsearch/v1?q=invalid+query&cx "
|
|
'returned "Invalid Value". Details: "Invalid Value">',
|
|
400,
|
|
"Invalid Value",
|
|
),
|
|
(
|
|
"invalid API key",
|
|
3,
|
|
"Error: The provided Google API key is invalid or missing.",
|
|
403,
|
|
"invalid API key",
|
|
),
|
|
],
|
|
)
|
|
def test_google_official_search_errors(
|
|
query,
|
|
num_results,
|
|
expected_output,
|
|
mock_googleapiclient,
|
|
http_code,
|
|
error_msg,
|
|
agent: Agent,
|
|
):
|
|
class resp:
|
|
def __init__(self, _status, _reason):
|
|
self.status = _status
|
|
self.reason = _reason
|
|
|
|
response_content = {
|
|
"error": {"code": http_code, "message": error_msg, "reason": "backendError"}
|
|
}
|
|
error = HttpError(
|
|
resp=resp(http_code, error_msg),
|
|
content=str.encode(json.dumps(response_content)),
|
|
uri="https://www.googleapis.com/customsearch/v1?q=invalid+query&cx",
|
|
)
|
|
|
|
mock_googleapiclient.side_effect = error
|
|
actual_output = google_official_search(query, agent=agent, num_results=num_results)
|
|
assert actual_output == safe_google_results(expected_output)
|