mirror of
https://github.com/aljazceru/Auto-GPT.git
synced 2025-12-25 18:04:28 +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)
208 lines
6.6 KiB
Python
208 lines
6.6 KiB
Python
import os
|
|
from unittest.mock import patch
|
|
|
|
import pytest
|
|
import requests
|
|
|
|
from autogpt.json_utils.utilities import extract_json_from_response, validate_json
|
|
from autogpt.utils import (
|
|
get_bulletin_from_web,
|
|
get_current_git_branch,
|
|
get_latest_bulletin,
|
|
readable_file_size,
|
|
validate_yaml_file,
|
|
)
|
|
from tests.utils import skip_in_ci
|
|
|
|
|
|
@pytest.fixture
|
|
def valid_json_response() -> dict:
|
|
return {
|
|
"thoughts": {
|
|
"text": "My task is complete. I will use the 'task_complete' command to shut down.",
|
|
"reasoning": "I will use the 'task_complete' command because it allows me to shut down and signal that my task is complete.",
|
|
"plan": "I will use the 'task_complete' command with the reason 'Task complete: retrieved Tesla's revenue in 2022.' to shut down.",
|
|
"criticism": "I need to ensure that I have completed all necessary tasks before shutting down.",
|
|
"speak": "",
|
|
},
|
|
"command": {
|
|
"name": "task_complete",
|
|
"args": {"reason": "Task complete: retrieved Tesla's revenue in 2022."},
|
|
},
|
|
}
|
|
|
|
|
|
@pytest.fixture
|
|
def invalid_json_response() -> dict:
|
|
return {
|
|
"thoughts": {
|
|
"text": "My task is complete. I will use the 'task_complete' command to shut down.",
|
|
"reasoning": "I will use the 'task_complete' command because it allows me to shut down and signal that my task is complete.",
|
|
"plan": "I will use the 'task_complete' command with the reason 'Task complete: retrieved Tesla's revenue in 2022.' to shut down.",
|
|
"criticism": "I need to ensure that I have completed all necessary tasks before shutting down.",
|
|
"speak": "",
|
|
},
|
|
"command": {"name": "", "args": {}},
|
|
}
|
|
|
|
|
|
def test_validate_yaml_file_valid():
|
|
with open("valid_test_file.yaml", "w") as f:
|
|
f.write("setting: value")
|
|
result, message = validate_yaml_file("valid_test_file.yaml")
|
|
os.remove("valid_test_file.yaml")
|
|
|
|
assert result == True
|
|
assert "Successfully validated" in message
|
|
|
|
|
|
def test_validate_yaml_file_not_found():
|
|
result, message = validate_yaml_file("non_existent_file.yaml")
|
|
|
|
assert result == False
|
|
assert "wasn't found" in message
|
|
|
|
|
|
def test_validate_yaml_file_invalid():
|
|
with open("invalid_test_file.yaml", "w") as f:
|
|
f.write(
|
|
"settings:\n first_setting: value\n second_setting: value\n nested_setting: value\n third_setting: value\nunindented_setting: value"
|
|
)
|
|
result, message = validate_yaml_file("invalid_test_file.yaml")
|
|
os.remove("invalid_test_file.yaml")
|
|
print(result)
|
|
print(message)
|
|
assert result == False
|
|
assert "There was an issue while trying to read" in message
|
|
|
|
|
|
def test_readable_file_size():
|
|
size_in_bytes = 1024 * 1024 * 3.5 # 3.5 MB
|
|
readable_size = readable_file_size(size_in_bytes)
|
|
|
|
assert readable_size == "3.50 MB"
|
|
|
|
|
|
@patch("requests.get")
|
|
def test_get_bulletin_from_web_success(mock_get):
|
|
expected_content = "Test bulletin from web"
|
|
|
|
mock_get.return_value.status_code = 200
|
|
mock_get.return_value.text = expected_content
|
|
bulletin = get_bulletin_from_web()
|
|
|
|
assert expected_content in bulletin
|
|
mock_get.assert_called_with(
|
|
"https://raw.githubusercontent.com/Significant-Gravitas/Auto-GPT/master/BULLETIN.md"
|
|
)
|
|
|
|
|
|
@patch("requests.get")
|
|
def test_get_bulletin_from_web_failure(mock_get):
|
|
mock_get.return_value.status_code = 404
|
|
bulletin = get_bulletin_from_web()
|
|
|
|
assert bulletin == ""
|
|
|
|
|
|
@patch("requests.get")
|
|
def test_get_bulletin_from_web_exception(mock_get):
|
|
mock_get.side_effect = requests.exceptions.RequestException()
|
|
bulletin = get_bulletin_from_web()
|
|
|
|
assert bulletin == ""
|
|
|
|
|
|
def test_get_latest_bulletin_no_file():
|
|
if os.path.exists("data/CURRENT_BULLETIN.md"):
|
|
os.remove("data/CURRENT_BULLETIN.md")
|
|
|
|
bulletin, is_new = get_latest_bulletin()
|
|
assert is_new
|
|
|
|
|
|
def test_get_latest_bulletin_with_file():
|
|
expected_content = "Test bulletin"
|
|
with open("data/CURRENT_BULLETIN.md", "w", encoding="utf-8") as f:
|
|
f.write(expected_content)
|
|
|
|
with patch("autogpt.utils.get_bulletin_from_web", return_value=""):
|
|
bulletin, is_new = get_latest_bulletin()
|
|
assert expected_content in bulletin
|
|
assert is_new == False
|
|
|
|
os.remove("data/CURRENT_BULLETIN.md")
|
|
|
|
|
|
def test_get_latest_bulletin_with_new_bulletin():
|
|
with open("data/CURRENT_BULLETIN.md", "w", encoding="utf-8") as f:
|
|
f.write("Old bulletin")
|
|
|
|
expected_content = "New bulletin from web"
|
|
with patch("autogpt.utils.get_bulletin_from_web", return_value=expected_content):
|
|
bulletin, is_new = get_latest_bulletin()
|
|
assert "::NEW BULLETIN::" in bulletin
|
|
assert expected_content in bulletin
|
|
assert is_new
|
|
|
|
os.remove("data/CURRENT_BULLETIN.md")
|
|
|
|
|
|
def test_get_latest_bulletin_new_bulletin_same_as_old_bulletin():
|
|
expected_content = "Current bulletin"
|
|
with open("data/CURRENT_BULLETIN.md", "w", encoding="utf-8") as f:
|
|
f.write(expected_content)
|
|
|
|
with patch("autogpt.utils.get_bulletin_from_web", return_value=expected_content):
|
|
bulletin, is_new = get_latest_bulletin()
|
|
assert expected_content in bulletin
|
|
assert is_new == False
|
|
|
|
os.remove("data/CURRENT_BULLETIN.md")
|
|
|
|
|
|
@skip_in_ci
|
|
def test_get_current_git_branch():
|
|
branch_name = get_current_git_branch()
|
|
|
|
# Assuming that the branch name will be non-empty if the function is working correctly.
|
|
assert branch_name != ""
|
|
|
|
|
|
@patch("autogpt.utils.Repo")
|
|
def test_get_current_git_branch_success(mock_repo):
|
|
mock_repo.return_value.active_branch.name = "test-branch"
|
|
branch_name = get_current_git_branch()
|
|
|
|
assert branch_name == "test-branch"
|
|
|
|
|
|
@patch("autogpt.utils.Repo")
|
|
def test_get_current_git_branch_failure(mock_repo):
|
|
mock_repo.side_effect = Exception()
|
|
branch_name = get_current_git_branch()
|
|
|
|
assert branch_name == ""
|
|
|
|
|
|
def test_validate_json_valid(valid_json_response):
|
|
assert validate_json(valid_json_response)
|
|
|
|
|
|
def test_validate_json_invalid(invalid_json_response):
|
|
assert not validate_json(valid_json_response)
|
|
|
|
|
|
def test_extract_json_from_response(valid_json_response: dict):
|
|
emulated_response_from_openai = str(valid_json_response)
|
|
assert (
|
|
extract_json_from_response(emulated_response_from_openai) == valid_json_response
|
|
)
|
|
|
|
|
|
def test_extract_json_from_response_wrapped_in_code_block(valid_json_response: dict):
|
|
emulated_response_from_openai = "```" + str(valid_json_response) + "```"
|
|
assert (
|
|
extract_json_from_response(emulated_response_from_openai) == valid_json_response
|
|
)
|