mirror of
https://github.com/aljazceru/Auto-GPT.git
synced 2026-01-02 22:04:30 +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)
85 lines
2.6 KiB
Python
85 lines
2.6 KiB
Python
import pytest
|
|
from pytest_mock import MockerFixture
|
|
|
|
from autogpt.agent import Agent
|
|
from autogpt.commands.file_operations import read_file, write_to_file
|
|
from tests.challenges.challenge_decorator.challenge_decorator import challenge
|
|
from tests.challenges.utils import get_workspace_path, run_interaction_loop
|
|
|
|
OUTPUT_LOCATION = "output.txt"
|
|
|
|
|
|
@challenge()
|
|
def test_memory_challenge_a(
|
|
memory_management_agent: Agent,
|
|
patched_api_requestor: MockerFixture,
|
|
monkeypatch: pytest.MonkeyPatch,
|
|
level_to_run: int,
|
|
challenge_name: str,
|
|
) -> None:
|
|
"""
|
|
The agent reads a file containing a task_id. Then, it reads a series of other files.
|
|
After reading 'n' files, the agent must write the task_id into a new file.
|
|
Args:
|
|
memory_management_agent (Agent)
|
|
patched_api_requestor (MockerFixture)
|
|
monkeypatch (pytest.MonkeyPatch)
|
|
level_to_run (int)
|
|
"""
|
|
task_id = "2314"
|
|
create_instructions_files(memory_management_agent, level_to_run, task_id)
|
|
|
|
run_interaction_loop(
|
|
monkeypatch,
|
|
memory_management_agent,
|
|
level_to_run + 2,
|
|
challenge_name,
|
|
level_to_run,
|
|
)
|
|
|
|
file_path = get_workspace_path(memory_management_agent, OUTPUT_LOCATION)
|
|
content = read_file(file_path, memory_management_agent)
|
|
assert task_id in content, f"Expected the file to contain {task_id}"
|
|
|
|
|
|
def create_instructions_files(
|
|
memory_management_agent: Agent,
|
|
num_files: int,
|
|
task_id: str,
|
|
base_filename: str = "instructions_",
|
|
) -> None:
|
|
"""
|
|
Creates a series of instructions files for the memory challenge.
|
|
Args:
|
|
memory_management_agent (Agent)
|
|
num_files (int)
|
|
task_id (str)
|
|
base_filename (str, optional)
|
|
"""
|
|
for i in range(1, num_files + 1):
|
|
content = generate_content(i, task_id, base_filename, num_files)
|
|
file_name = f"{base_filename}{i}.txt"
|
|
file_path = get_workspace_path(memory_management_agent, file_name)
|
|
write_to_file(file_path, content, memory_management_agent)
|
|
|
|
|
|
def generate_content(
|
|
index: int, task_id: str, base_filename: str, num_files: int
|
|
) -> str:
|
|
"""
|
|
Args:
|
|
index: int
|
|
task_id: str
|
|
base_filename: str
|
|
num_files: int
|
|
|
|
Returns: str
|
|
"""
|
|
if index == 1:
|
|
return (
|
|
f"This task_id is {task_id}\nRead the file {base_filename}{index + 1}.txt"
|
|
)
|
|
if index != num_files:
|
|
return f"Read the file {base_filename}{index + 1}.txt"
|
|
return "Write the task_id into the file output.txt\nShutdown"
|