mirror of
https://github.com/aljazceru/Auto-GPT.git
synced 2025-12-23 00:44:22 +01:00
* feat: pass config to call_ai_functions in coimmands * feat: config for read_audio_from_file * feat: file operations cfg NOTE: we replaced the CFG in the command enable with TRUE b/c not sure how to handle this yet * feat: git command conversion * feat: google search * feat: image generation * feat: extract cfg from browser commands * feat: remove cfg from execute code commands * fix: file operation related tests * fix: linting * fix: tests for read_audio * fix: test error * feat: update cassettes * fix: linting * fix: test typechecking * fix: google_search errors if unexpected kw arg is passed * fix: pass config param to google search test * fix: agent commands were broken + cassettes * fix: agent test * feat: cassettes * feat: enable/disable logic for commands * fix: some commands threw errors * feat: fix tests * Add new cassettes * Add new cassettes * ci: trigger ci * Update autogpt/commands/execute_code.py Co-authored-by: Reinier van der Leer <github@pwuts.nl> * fix prompt * fix prompt + rebase * add config remove useless imports * put back CFG just for download file * lint * The signature should be mandatory in the decorator * black isort * fix: remove the CFG * fix: non typed arg * lint: type some args * lint: add types for libraries * Add new cassettes * fix: windows compatibility * fix: add config access to decorator * fix: remove twitter mention * DDGS search works at 3.0.2 version * ci: linting --------- Co-authored-by: Auto-GPT-Bot <github-bot@agpt.co> Co-authored-by: merwanehamadi <merwanehamadi@gmail.com> Co-authored-by: Reinier van der Leer <github@pwuts.nl> Co-authored-by: kinance <kinance@gmail.com>
135 lines
3.8 KiB
Python
135 lines
3.8 KiB
Python
import json
|
|
|
|
import pytest
|
|
from googleapiclient.errors import HttpError
|
|
|
|
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, config
|
|
):
|
|
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, config, 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, config
|
|
):
|
|
mock_googleapiclient.return_value = search_results
|
|
actual_output = google_official_search(query, config, 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,
|
|
config,
|
|
):
|
|
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, config, num_results=num_results)
|
|
assert actual_output == safe_google_results(expected_output)
|