Tests utils suite (#2961)
* Update Python version and benchmark file in benchmark.yml * Refactor main function and imports in cli.py * Update import statement in ai_config.py * Add set_temperature and set_memory_backend methods in config.py * Remove unused import in prompt.py * Add goal oriented tasks workflow * Added agent_utils to create agent * added pytest and vcrpy * added write file cassette * created goal oriented task write file with cassettes to not pay openai tokens * solve conflicts * add ability set azure because github workflow needs it off * solve conflicts in cli.py * black because linter fails * solve conflict * setup github action to v3 Signed-off-by: Merwane Hamadi <merwanehamadi@gmail.com> * fix conflicts Signed-off-by: Merwane Hamadi <merwanehamadi@gmail.com> * Plugins: debug line always printed in plugin load * add decorator to tests Signed-off-by: Merwane Hamadi <merwanehamadi@gmail.com> * move decorator higher up Signed-off-by: Merwane Hamadi <merwanehamadi@gmail.com> * init * more tests * passing tests * skip gitbranch decorator on ci * decorator skiponci * black * Update tests/utils.py decorator of skipping ci Co-authored-by: Nicholas Tindle <nicktindle@outlook.com> * black * I oopsed the name * black * finally * black * wrong file --------- Signed-off-by: Merwane Hamadi <merwanehamadi@gmail.com> Co-authored-by: Merwane Hamadi <merwanehamadi@gmail.com> Co-authored-by: Merwane Hamadi <merwane.hamadi@redica.com> Co-authored-by: Richard Beales <rich@richbeales.net> Co-authored-by: Nicholas Tindle <nick@ntindle.com> Co-authored-by: BillSchumacher <34168009+BillSchumacher@users.noreply.github.com> Co-authored-by: Nicholas Tindle <nicktindle@outlook.com>pull/2955/head^2
parent
986bdaab36
commit
2b5852f7da
|
@ -49,15 +49,17 @@ def readable_file_size(size, decimal_places=2):
|
||||||
return f"{size:.{decimal_places}f} {unit}"
|
return f"{size:.{decimal_places}f} {unit}"
|
||||||
|
|
||||||
|
|
||||||
def get_bulletin_from_web() -> str:
|
def get_bulletin_from_web():
|
||||||
try:
|
try:
|
||||||
response = requests.get(
|
response = requests.get(
|
||||||
"https://raw.githubusercontent.com/Significant-Gravitas/Auto-GPT/master/BULLETIN.md"
|
"https://raw.githubusercontent.com/Significant-Gravitas/Auto-GPT/master/BULLETIN.md"
|
||||||
)
|
)
|
||||||
if response.status_code == 200:
|
if response.status_code == 200:
|
||||||
return response.text
|
return response.text
|
||||||
except:
|
except requests.exceptions.RequestException:
|
||||||
return ""
|
pass
|
||||||
|
|
||||||
|
return ""
|
||||||
|
|
||||||
|
|
||||||
def get_current_git_branch() -> str:
|
def get_current_git_branch() -> str:
|
||||||
|
|
|
@ -0,0 +1,200 @@
|
||||||
|
import os
|
||||||
|
from unittest.mock import Mock, patch
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
import requests
|
||||||
|
from colorama import Fore
|
||||||
|
from git import Repo
|
||||||
|
|
||||||
|
from autogpt.utils import (
|
||||||
|
clean_input,
|
||||||
|
get_bulletin_from_web,
|
||||||
|
get_current_git_branch,
|
||||||
|
get_latest_bulletin,
|
||||||
|
readable_file_size,
|
||||||
|
validate_yaml_file,
|
||||||
|
)
|
||||||
|
from tests.utils import skip_in_ci
|
||||||
|
|
||||||
|
|
||||||
|
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):
|
||||||
|
mock_get.return_value.status_code = 200
|
||||||
|
mock_get.return_value.text = "Test bulletin"
|
||||||
|
bulletin = get_bulletin_from_web()
|
||||||
|
|
||||||
|
assert bulletin == "Test bulletin"
|
||||||
|
|
||||||
|
|
||||||
|
@patch("requests.get")
|
||||||
|
def test_get_bulletin_from_web_failure(mock_get):
|
||||||
|
mock_get.return_value.status_code = 404
|
||||||
|
bulletin = get_bulletin_from_web()
|
||||||
|
print(bulletin)
|
||||||
|
assert bulletin == ""
|
||||||
|
|
||||||
|
|
||||||
|
@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 != ""
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_latest_bulletin_no_file():
|
||||||
|
if os.path.exists("CURRENT_BULLETIN.md"):
|
||||||
|
os.remove("CURRENT_BULLETIN.md")
|
||||||
|
|
||||||
|
with patch("autogpt.utils.get_bulletin_from_web", return_value=""):
|
||||||
|
bulletin = get_latest_bulletin()
|
||||||
|
assert bulletin == ""
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_latest_bulletin_with_file():
|
||||||
|
with open("CURRENT_BULLETIN.md", "w", encoding="utf-8") as f:
|
||||||
|
f.write("Test bulletin")
|
||||||
|
|
||||||
|
with patch("autogpt.utils.get_bulletin_from_web", return_value=""):
|
||||||
|
bulletin = get_latest_bulletin()
|
||||||
|
assert bulletin == "Test bulletin"
|
||||||
|
|
||||||
|
os.remove("CURRENT_BULLETIN.md")
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_latest_bulletin_with_new_bulletin():
|
||||||
|
with open("CURRENT_BULLETIN.md", "w", encoding="utf-8") as f:
|
||||||
|
f.write("Old bulletin")
|
||||||
|
|
||||||
|
with patch("autogpt.utils.get_bulletin_from_web", return_value="New bulletin"):
|
||||||
|
bulletin = get_latest_bulletin()
|
||||||
|
assert "New bulletin" in bulletin
|
||||||
|
|
||||||
|
os.remove("CURRENT_BULLETIN.md")
|
||||||
|
|
||||||
|
|
||||||
|
@patch("requests.get")
|
||||||
|
def test_get_bulletin_from_web_success(mock_get):
|
||||||
|
mock_get.return_value.status_code = 200
|
||||||
|
mock_get.return_value.text = "Test bulletin"
|
||||||
|
bulletin = get_bulletin_from_web()
|
||||||
|
|
||||||
|
assert bulletin == "Test 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 == ""
|
||||||
|
|
||||||
|
|
||||||
|
@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_get_latest_bulletin_no_file():
|
||||||
|
if os.path.exists("CURRENT_BULLETIN.md"):
|
||||||
|
os.remove("CURRENT_BULLETIN.md")
|
||||||
|
|
||||||
|
with patch("autogpt.utils.get_bulletin_from_web", return_value=""):
|
||||||
|
bulletin = get_latest_bulletin()
|
||||||
|
assert bulletin == ""
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_latest_bulletin_with_file():
|
||||||
|
with open("CURRENT_BULLETIN.md", "w", encoding="utf-8") as f:
|
||||||
|
f.write("Test bulletin")
|
||||||
|
|
||||||
|
with patch("autogpt.utils.get_bulletin_from_web", return_value=""):
|
||||||
|
bulletin = get_latest_bulletin()
|
||||||
|
assert bulletin == "Test bulletin"
|
||||||
|
|
||||||
|
os.remove("CURRENT_BULLETIN.md")
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_latest_bulletin_with_new_bulletin():
|
||||||
|
with open("CURRENT_BULLETIN.md", "w", encoding="utf-8") as f:
|
||||||
|
f.write("Old bulletin")
|
||||||
|
|
||||||
|
with patch("autogpt.utils.get_bulletin_from_web", return_value="New bulletin"):
|
||||||
|
bulletin = get_latest_bulletin()
|
||||||
|
assert f" {Fore.RED}::UPDATED:: {Fore.CYAN}New bulletin{Fore.RESET}" in bulletin
|
||||||
|
|
||||||
|
os.remove("CURRENT_BULLETIN.md")
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_latest_bulletin_new_bulletin_same_as_old_bulletin():
|
||||||
|
with open("CURRENT_BULLETIN.md", "w", encoding="utf-8") as f:
|
||||||
|
f.write("Test bulletin")
|
||||||
|
|
||||||
|
with patch("autogpt.utils.get_bulletin_from_web", return_value="Test bulletin"):
|
||||||
|
bulletin = get_latest_bulletin()
|
||||||
|
assert bulletin == "Test bulletin"
|
||||||
|
|
||||||
|
os.remove("CURRENT_BULLETIN.md")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
pytest.main()
|
|
@ -16,3 +16,10 @@ def requires_api_key(env_var):
|
||||||
return wrapper
|
return wrapper
|
||||||
|
|
||||||
return decorator
|
return decorator
|
||||||
|
|
||||||
|
|
||||||
|
def skip_in_ci(test_function):
|
||||||
|
return pytest.mark.skipif(
|
||||||
|
os.environ.get("CI") == "true",
|
||||||
|
reason="This test doesn't work on GitHub Actions.",
|
||||||
|
)(test_function)
|
||||||
|
|
Loading…
Reference in New Issue