mirror of
https://github.com/Aider-AI/aider.git
synced 2025-05-25 06:44:59 +00:00
Added GitTemporaryDirectory
This commit is contained in:
parent
86cea01434
commit
a9cca05680
2 changed files with 59 additions and 30 deletions
|
@ -12,6 +12,7 @@ from aider import models
|
||||||
from aider.coders import Coder
|
from aider.coders import Coder
|
||||||
from aider.dump import dump # noqa: F401
|
from aider.dump import dump # noqa: F401
|
||||||
from aider.io import InputOutput
|
from aider.io import InputOutput
|
||||||
|
from tests.utils import GitTemporaryDirectory
|
||||||
|
|
||||||
|
|
||||||
class TestCoder(unittest.TestCase):
|
class TestCoder(unittest.TestCase):
|
||||||
|
@ -95,47 +96,44 @@ class TestCoder(unittest.TestCase):
|
||||||
self.assertEqual(coder.abs_fnames, expected_files)
|
self.assertEqual(coder.abs_fnames, expected_files)
|
||||||
|
|
||||||
def test_check_for_ambiguous_filename_mentions_of_longer_paths(self):
|
def test_check_for_ambiguous_filename_mentions_of_longer_paths(self):
|
||||||
# Mock the IO object
|
with GitTemporaryDirectory():
|
||||||
mock_io = MagicMock()
|
io = InputOutput(pretty=False, yes=True)
|
||||||
|
coder = Coder.create(models.GPT4, None, io)
|
||||||
|
|
||||||
# Initialize the Coder object with the mocked IO and mocked repo
|
fname = Path("file1.txt")
|
||||||
coder = Coder.create(models.GPT4, None, mock_io)
|
fname.touch()
|
||||||
|
|
||||||
fname = Path("file1.txt")
|
other_fname = Path("other") / "file1.txt"
|
||||||
fname.touch()
|
other_fname.parent.mkdir(parents=True, exist_ok=True)
|
||||||
|
other_fname.touch()
|
||||||
|
|
||||||
other_fname = Path("other") / "file1.txt"
|
mock = MagicMock()
|
||||||
other_fname.parent.mkdir(parents=True, exist_ok=True)
|
mock.return_value = set([str(fname), str(other_fname)])
|
||||||
other_fname.touch()
|
coder.get_tracked_files = mock
|
||||||
|
|
||||||
mock = MagicMock()
|
# Call the check_for_file_mentions method
|
||||||
mock.return_value = set([str(fname), str(other_fname)])
|
coder.check_for_file_mentions(f"Please check {fname}!")
|
||||||
coder.get_tracked_files = mock
|
|
||||||
|
|
||||||
# Call the check_for_file_mentions method
|
self.assertEqual(coder.abs_fnames, set([str(fname.resolve())]))
|
||||||
coder.check_for_file_mentions(f"Please check {fname}!")
|
|
||||||
|
|
||||||
self.assertEqual(coder.abs_fnames, set([str(fname.resolve())]))
|
|
||||||
|
|
||||||
def test_check_for_subdir_mention(self):
|
def test_check_for_subdir_mention(self):
|
||||||
# Mock the IO object
|
with GitTemporaryDirectory():
|
||||||
mock_io = MagicMock()
|
io = InputOutput(pretty=False, yes=True)
|
||||||
|
coder = Coder.create(models.GPT4, None, io)
|
||||||
|
|
||||||
# Initialize the Coder object with the mocked IO and mocked repo
|
fname = Path("other") / "file1.txt"
|
||||||
coder = Coder.create(models.GPT4, None, mock_io)
|
fname.parent.mkdir(parents=True, exist_ok=True)
|
||||||
|
fname.touch()
|
||||||
|
|
||||||
fname = Path("other") / "file1.txt"
|
mock = MagicMock()
|
||||||
fname.parent.mkdir(parents=True, exist_ok=True)
|
mock.return_value = set([str(fname)])
|
||||||
fname.touch()
|
coder.get_tracked_files = mock
|
||||||
|
|
||||||
mock = MagicMock()
|
dump(fname)
|
||||||
mock.return_value = set([str(fname)])
|
# Call the check_for_file_mentions method
|
||||||
coder.get_tracked_files = mock
|
coder.check_for_file_mentions(f"Please check `{fname}`")
|
||||||
|
|
||||||
# Call the check_for_file_mentions method
|
self.assertEqual(coder.abs_fnames, set([str(fname.resolve())]))
|
||||||
coder.check_for_file_mentions(f"Please check `{fname}`")
|
|
||||||
|
|
||||||
self.assertEqual(coder.abs_fnames, set([str(fname.resolve())]))
|
|
||||||
|
|
||||||
def test_get_commit_message(self):
|
def test_get_commit_message(self):
|
||||||
# Mock the IO object
|
# Mock the IO object
|
||||||
|
|
|
@ -1,5 +1,10 @@
|
||||||
|
import os
|
||||||
import tempfile
|
import tempfile
|
||||||
|
|
||||||
|
import git
|
||||||
|
|
||||||
|
from aider.dump import dump # noqa: F401
|
||||||
|
|
||||||
|
|
||||||
class IgnorantTemporaryDirectory:
|
class IgnorantTemporaryDirectory:
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
|
@ -13,3 +18,29 @@ class IgnorantTemporaryDirectory:
|
||||||
self.temp_dir.__exit__(exc_type, exc_val, exc_tb)
|
self.temp_dir.__exit__(exc_type, exc_val, exc_tb)
|
||||||
except OSError:
|
except OSError:
|
||||||
pass # Ignore errors (Windows)
|
pass # Ignore errors (Windows)
|
||||||
|
|
||||||
|
|
||||||
|
class ChdirTemporaryDirectory(IgnorantTemporaryDirectory):
|
||||||
|
def __init__(self):
|
||||||
|
self.cwd = os.getcwd()
|
||||||
|
super().__init__()
|
||||||
|
|
||||||
|
def __enter__(self):
|
||||||
|
res = super().__enter__()
|
||||||
|
os.chdir(self.temp_dir.name)
|
||||||
|
return res
|
||||||
|
|
||||||
|
def __exit__(self, exc_type, exc_val, exc_tb):
|
||||||
|
os.chdir(self.cwd)
|
||||||
|
super().__exit__(exc_type, exc_val, exc_tb)
|
||||||
|
|
||||||
|
|
||||||
|
class GitTemporaryDirectory(ChdirTemporaryDirectory):
|
||||||
|
def __enter__(self):
|
||||||
|
res = super().__enter__()
|
||||||
|
|
||||||
|
repo = git.Repo.init()
|
||||||
|
repo.config_writer().set_value("user", "name", "Test User").release()
|
||||||
|
repo.config_writer().set_value("user", "email", "testuser@example.com").release()
|
||||||
|
|
||||||
|
return res
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue