From 7a8cb603b5478f12bfded9000922ad98cf226d55 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Santiago=20Due=C3=B1as?= Date: Mon, 10 Jun 2024 17:23:49 +0200 Subject: [PATCH] [git] Fix file stats for merged files on subdirs MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Stats about changes on a file were not reported correctly for files that where moved to a subdirectory. They were reported as an invalid entry and without action associated. For example, the file `dir/filename` was moved to `dir/subdir/filename`, but it was reported as `dir//filename`. Therefore, the entry of the file `dir/subdire/filename` didn't have the stats about added and deleted lines. This error has been fixed and stats are reported correctly. Signed-off-by: Santiago Dueñas --- perceval/backends/core/git.py | 9 +++- .../wrong-filepath-for-movedcopied-files.yml | 16 ++++++++ tests/data/git/git_log_moved.txt | 12 ++++++ tests/test_git.py | 41 +++++++++++++++++++ 4 files changed, 77 insertions(+), 1 deletion(-) create mode 100644 releases/unreleased/wrong-filepath-for-movedcopied-files.yml create mode 100644 tests/data/git/git_log_moved.txt diff --git a/perceval/backends/core/git.py b/perceval/backends/core/git.py index 71b379328..cac293cf6 100644 --- a/perceval/backends/core/git.py +++ b/perceval/backends/core/git.py @@ -804,7 +804,14 @@ def __get_old_filepath(self, f): prefix = f[0:i] inner = f[i + 1:f.find(' => ', i)] suffix = f[j + 1:] - return prefix + inner + suffix + old_filepath = prefix + inner + suffix + + # Remove double '/' for corner cases like + # 'dir/{ => subdir}/filename'. + # The resulting old path on these entries is 'dir//filename'. + old_filepath = old_filepath.replace('//', '/') + + return old_filepath elif ' => ' in f: return f.split(' => ')[0] else: diff --git a/releases/unreleased/wrong-filepath-for-movedcopied-files.yml b/releases/unreleased/wrong-filepath-for-movedcopied-files.yml new file mode 100644 index 000000000..70db8f6f1 --- /dev/null +++ b/releases/unreleased/wrong-filepath-for-movedcopied-files.yml @@ -0,0 +1,16 @@ +--- +title: Empty stats for moved/copied files in git +category: fixed +author: Santiago Dueñas +issue: null +notes: > + Stats about changes on a file were not reported correctly + for files that where moved to a subdirectory. They + were reported as an invalid entry and without + action associated. + For example, the file `dir/filename` was moved to `dir/subdir/filename`, + but it was reported as `dir//filename`. Therefore, + the entry of the file `dir/subdire/filename` didn't + have the stats about added and deleted lines. + This error has been fixed and stats are reported + correctly. diff --git a/tests/data/git/git_log_moved.txt b/tests/data/git/git_log_moved.txt new file mode 100644 index 000000000..885849a2e --- /dev/null +++ b/tests/data/git/git_log_moved.txt @@ -0,0 +1,12 @@ +commit 1e6250992e6cddebfaf4e6fdf241171091874523 ff93e98029e7b8356bf87456df0254332f4a6549 +Author: John Smith +AuthorDate: Tue Nov 22 14:00:06 2016 +0100 +Commit: John Smith +CommitDate: Tue Nov 22 14:00:06 2016 +0100 + + [backends] Move backends to core sub-package + +:000000 100644 0000000 e69de29 A perceval/backends/core/__init__.py +:100644 100644 232acb3 7923641 R098 perceval/backends/bugzilla.py perceval/backends/core/bugzilla.py +0 0 perceval/backends/core/__init__.py +4 4 perceval/backends/{ => core}/bugzilla.py diff --git a/tests/test_git.py b/tests/test_git.py index 264d56fee..f3b17f107 100644 --- a/tests/test_git.py +++ b/tests/test_git.py @@ -1129,6 +1129,47 @@ def test_parser(self): self.assertDictEqual(commits[9], expected) + def test_parser_renamed_files(self): + """Check it moved or copied files are correctly renamed""" + + with open(os.path.join(os.path.dirname(os.path.abspath(__file__)), "data/git/git_log_moved.txt"), 'r') as f: + parser = GitParser(f) + commits = [commit for commit in parser.parse()] + + self.assertEqual(len(commits), 1) + + expected = { + 'commit': '1e6250992e6cddebfaf4e6fdf241171091874523', + 'parents': ['ff93e98029e7b8356bf87456df0254332f4a6549'], + 'refs': [], + 'Author': 'John Smith ', + 'AuthorDate': 'Tue Nov 22 14:00:06 2016 +0100', + 'Commit': 'John Smith ', + 'CommitDate': 'Tue Nov 22 14:00:06 2016 +0100', + 'message': '[backends] Move backends to core sub-package', + 'files': [ + { + 'file': 'perceval/backends/bugzilla.py', + 'newfile': 'perceval/backends/core/bugzilla.py', + 'added': '4', + 'removed': '4', + 'modes': ['100644', '100644'], + 'indexes': ['232acb3', '7923641'], + 'action': 'R098' + }, + { + 'file': 'perceval/backends/core/__init__.py', + 'added': '0', + 'removed': '0', + 'modes': ['000000', '100644'], + 'indexes': ['0000000', 'e69de29'], + 'action': 'A' + } + ] + } + + self.assertDictEqual(commits[0], expected) + def test_parser_merge_commit(self): """Test if it parses all the available data on a merge commit"""