From 409ce7aa518fae30b0e366fe324a75d569e8f29a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Santiago=20Due=C3=B1as?= Date: Wed, 20 Nov 2024 17:48:43 +0100 Subject: [PATCH] [git] Assign stats for files with whitespaces MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Git commit stats weren't assigned to the action for those files with whitespaces in ther filenames. Actions didn't have stats and empty stats entries were created, like in a merge commit. The problem was that the regular expression used to parse the stats considered whitespaces as separators. Signed-off-by: Santiago Dueñas --- perceval/backends/core/git.py | 4 ++-- ...ile-stats-with-whitespaces-were-not-assigned.yml | 11 +++++++++++ tests/data/git/git_log_merge.txt | 6 +++--- tests/test_git.py | 13 +++++++++++++ 4 files changed, 29 insertions(+), 5 deletions(-) create mode 100644 releases/unreleased/git-file-stats-with-whitespaces-were-not-assigned.yml diff --git a/perceval/backends/core/git.py b/perceval/backends/core/git.py index 2d00f7f0c..3b962353a 100644 --- a/perceval/backends/core/git.py +++ b/perceval/backends/core/git.py @@ -71,7 +71,7 @@ class Git(Backend): :raises RepositoryError: raised when there was an error cloning or updating the repository. """ - version = '1.0.0' + version = '1.0.1' CATEGORIES = [CATEGORY_COMMIT] @@ -567,7 +567,7 @@ class GitParser: (?P[^\t]+) (?:\t+(?P.+))?$""" - STATS_PATTERN = r"^(?P\d+|-)[ \t]+(?P\d+|-)[ \t]+(?P.+)$" + STATS_PATTERN = r"^(?P\d+|-)\t+(?P\d+|-)\t+(?P.+)$" EMPTY_LINE_PATTERN = r"^$" diff --git a/releases/unreleased/git-file-stats-with-whitespaces-were-not-assigned.yml b/releases/unreleased/git-file-stats-with-whitespaces-were-not-assigned.yml new file mode 100644 index 000000000..b0ef2ee39 --- /dev/null +++ b/releases/unreleased/git-file-stats-with-whitespaces-were-not-assigned.yml @@ -0,0 +1,11 @@ +--- +title: Git stats not assigned with their actions +category: fixed +author: Santiago Dueñas +issue: null +notes: > + Git stats were not assigned to their actions in + a commit for filenames that contain whitespaces. + Instead, an empty stat was created like in a + merge commit, where actions normally don't take + place. diff --git a/tests/data/git/git_log_merge.txt b/tests/data/git/git_log_merge.txt index 308414885..4419c5944 100644 --- a/tests/data/git/git_log_merge.txt +++ b/tests/data/git/git_log_merge.txt @@ -7,9 +7,9 @@ CommitDate: Tue Aug 2 19:47:06 2016 -0400 Merge tag 'for-linus-v4.8' of git://github.com/martinbrandenburg/linux -46 4 Documentation/filesystems/orangefs.txt -4 0 fs/orangefs/dcache.c -3 3 fs/orangefs/inode.c +46 4 Documentation/filesystems/orangefs.txt +4 0 fs/orangefs/dcache.c +3 3 fs/orangefs/inode.c commit 456a68ee1407a77f3e804a30dff245bb6c6b872f ce8e0b86a1e9877f42fe9453ede418519115f367 51a3b654f252210572297f47597b31527c475fb8 (HEAD -> refs/heads/master) Merge: ce8e0b8 51a3b65 diff --git a/tests/test_git.py b/tests/test_git.py index 83c5d94d3..1f2324661 100644 --- a/tests/test_git.py +++ b/tests/test_git.py @@ -1395,6 +1395,19 @@ def test_stats_pattern(self): self.assertEqual(m.group('removed'), "0") self.assertEqual(m.group('file'), "bbb/{something => something.renamed}") + # Test with files that have whitespaces + s = "5\t0\t afile.txt" + m = pattern.match(s) + self.assertEqual(m.group('added'), "5") + self.assertEqual(m.group('removed'), "0") + self.assertEqual(m.group('file'), " afile.txt") + + s = "5\t0\ta fi le.txt" + m = pattern.match(s) + self.assertEqual(m.group('added'), "5") + self.assertEqual(m.group('removed'), "0") + self.assertEqual(m.group('file'), "a fi le.txt") + def test_empty_line(self): """Test empty line pattern"""