Skip to content

Commit

Permalink
Merge branch 'master' into feature/scrape-text-regression-test
Browse files Browse the repository at this point in the history
  • Loading branch information
collijk authored Apr 27, 2023
2 parents 05d6d6c + 7cd76b8 commit 171d783
Show file tree
Hide file tree
Showing 5 changed files with 31 additions and 21 deletions.
17 changes: 12 additions & 5 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -99,15 +99,22 @@ https://github.com/Significant-Gravitas/Auto-GPT/pulls?q=is%3Apr+is%3Aopen+-labe
## Testing your changes

If you add or change code, make sure the updated code is covered by tests.

To increase coverage if necessary, [write tests using `pytest`].
To increase coverage if necessary, [write tests using pytest].

For more info on running tests, please refer to ["Running tests"](https://significant-gravitas.github.io/Auto-GPT/testing/).

[write tests using `pytest`]: https://realpython.com/pytest-python-testing/
[write tests using pytest]: https://realpython.com/pytest-python-testing/

### API-dependent tests

To run tests that involve making calls to the OpenAI API, we use VCRpy. It caches known
requests and matching responses in so-called *cassettes*, allowing us to run the tests
in CI without needing actual API access.

When changes cause a test prompt to be generated differently, it will likely miss the
cache and make a request to the API, updating the cassette with the new request+response.
*Be sure to include the updated cassette in your PR!*


In Pytest, we use VCRpy. It's a package that allows us to save OpenAI and other API providers' responses.
When you run Pytest locally:

- If no prompt change: you will not consume API tokens because there are no new OpenAI calls required.
Expand Down
7 changes: 5 additions & 2 deletions autogpt/commands/file_operations.py
Original file line number Diff line number Diff line change
Expand Up @@ -142,8 +142,7 @@ def write_to_file(filename: str, text: str) -> str:
return "Error: File has already been updated."
try:
directory = os.path.dirname(filename)
if not os.path.exists(directory):
os.makedirs(directory)
os.makedirs(directory, exist_ok=True)
with open(filename, "w", encoding="utf-8") as f:
f.write(text)
log_operation("write", filename)
Expand All @@ -167,6 +166,8 @@ def append_to_file(filename: str, text: str, should_log: bool = True) -> str:
str: A message indicating success or failure
"""
try:
directory = os.path.dirname(filename)
os.makedirs(directory, exist_ok=True)
with open(filename, "a") as f:
f.write(text)

Expand Down Expand Up @@ -236,6 +237,8 @@ def download_file(url, filename):
filename (str): Filename to save the file as
"""
try:
directory = os.path.dirname(filename)
os.makedirs(directory, exist_ok=True)
message = f"{Fore.YELLOW}Downloading file from {Back.LIGHTBLUE_EX}{url}{Back.RESET}{Fore.RESET}"
with Spinner(message) as spinner:
session = requests.Session()
Expand Down
4 changes: 2 additions & 2 deletions docs/configuration/voice.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,8 @@ premade voices that Auto-GPT can use for speech.

1. Go to [ElevenLabs](https://beta.elevenlabs.io/) and make an account if you don't
already have one.
2. Choose and setup the `Starter` plan.
3. Click the top right icon and find "Profile" to locate your API Key.
2. Choose and setup the *Starter* plan.
3. Click the top right icon and find *Profile* to locate your API Key.

In the `.env` file set:

Expand Down
5 changes: 1 addition & 4 deletions docs/setup.md
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ Get your OpenAI API key from: [https://platform.openai.com/account/api-keys](htt
!!! important
Make sure you have [Git](https://git-scm.com/downloads) installed for your OS.

!!! info
!!! info "Executing commands"
To execute the given commands, open a CMD, Bash, or Powershell window.
On Windows: press ++win+x++ and pick *Terminal*, or ++win+r++ and enter `cmd`

Expand Down Expand Up @@ -115,9 +115,6 @@ Get your OpenAI API key from: [https://platform.openai.com/account/api-keys](htt

7. Save and close the `.env` file.

!!! info
Get your ElevenLabs API key from: [ElevenLabs](https://elevenlabs.io). You can view your xi-api-key using the "Profile" tab on the website.

!!! info "Using a GPT Azure-instance"
If you want to use GPT on an Azure instance, set `USE_AZURE` to `True` and
make an Azure configuration file:
Expand Down
19 changes: 11 additions & 8 deletions tests/unit/test_file_operations.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ def setUp(self):
self.test_file = str(self.workspace.get_path("test_file.txt"))
self.test_file2 = "test_file2.txt"
self.test_directory = str(self.workspace.get_path("test_directory"))
self.test_nested_file = str(self.workspace.get_path("nested/test_file.txt"))
self.file_content = "This is a test file.\n"
self.file_logger_logs = "file_logger.txt"

Expand Down Expand Up @@ -69,21 +70,23 @@ def test_read_file(self):

def test_write_to_file(self):
new_content = "This is new content.\n"
write_to_file(self.test_file, new_content)
with open(self.test_file, "r") as f:
write_to_file(self.test_nested_file, new_content)
with open(self.test_nested_file, "r") as f:
content = f.read()
self.assertEqual(content, new_content)

def test_append_to_file(self):
with open(self.test_file, "r") as f:
content_before = f.read()

append_text = "This is appended text.\n"
append_to_file(self.test_file, append_text)
with open(self.test_file, "r") as f:
append_to_file(self.test_nested_file, append_text)
with open(self.test_nested_file, "r") as f:
content = f.read()

self.assertEqual(content, content_before + append_text)
append_to_file(self.test_nested_file, append_text)

with open(self.test_nested_file, "r") as f:
content_after = f.read()

self.assertEqual(content_after, append_text + append_text)

def test_delete_file(self):
delete_file(self.test_file)
Expand Down

0 comments on commit 171d783

Please sign in to comment.