From 16d47d3f1933c1822884e2d3770e9c463245fdb6 Mon Sep 17 00:00:00 2001 From: TY <42710806+CTY-git@users.noreply.github.com> Date: Fri, 13 Dec 2024 15:59:04 +0800 Subject: [PATCH] Fix tool records giving path relative to base path. (#1098) * Make modified files be always relative to current working directory instead of base path * Support push triggers in pr --- .github/workflows/test.yml | 4 ++-- patchwork/common/tools/code_edit_tools.py | 4 ++-- patchwork/steps/FixIssue/FixIssue.py | 4 +++- 3 files changed, 7 insertions(+), 5 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 40085b580..fa4364fe3 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -16,10 +16,10 @@ on: - resolveissue-* - demo* -# Credits to https://blog.maximeheckel.com/posts/building-perfect-github-action-frontend-teams/ +# Credits to https://blog.maximeheckel.com/posts/building-perfect-github-action-frontend-teams/#you-are-terminated concurrency: # Here the group is defined by the head_ref of the PR - group: ${{ github.head_ref }} + group: ${{ github.head_ref || github.ref_name }} # Here we specify that we'll cancel any "in progress" workflow of the same group. Thus if we push, ammend a commit and push # again the previous workflow will be cancelled, thus saving us github action build minutes and avoid any conflicts cancel-in-progress: true diff --git a/patchwork/common/tools/code_edit_tools.py b/patchwork/common/tools/code_edit_tools.py index 841137c10..158de4dc2 100644 --- a/patchwork/common/tools/code_edit_tools.py +++ b/patchwork/common/tools/code_edit_tools.py @@ -104,13 +104,13 @@ def execute( return f"Error: {str(e)}" if command in {"create", "str_replace", "insert"}: - self.modified_files.update({abs_path.relative_to(self.repo_path)}) + self.modified_files.update({abs_path}) return result @property def tool_records(self): - return dict(modified_files=[{"path": str(file)} for file in self.modified_files]) + return dict(modified_files=[file for file in self.modified_files]) def __get_abs_path(self, path: str): wanted_path = Path(path).resolve() diff --git a/patchwork/steps/FixIssue/FixIssue.py b/patchwork/steps/FixIssue/FixIssue.py index c7a1dc051..edf8f3a15 100644 --- a/patchwork/steps/FixIssue/FixIssue.py +++ b/patchwork/steps/FixIssue/FixIssue.py @@ -126,5 +126,7 @@ def run(self): self.multiturn_llm_call.execute(limit=100) for tool in self.multiturn_llm_call.tool_set.values(): if isinstance(tool, CodeEditTool): - return tool.tool_records + cwd = Path.cwd() + modified_files = [file_path.relative_to(cwd) for file_path in tool.tool_records["modified_files"]] + return dict(modified_files=[{"path": str(file)} for file in modified_files]) return dict()