Skip to content

Commit

Permalink
feat(format): improve verbose commit message stripping (#105)
Browse files Browse the repository at this point in the history
  • Loading branch information
thekaveman authored Aug 2, 2024
2 parents 23e7888 + 800b147 commit 406f0d1
Show file tree
Hide file tree
Showing 3 changed files with 261 additions and 56 deletions.
13 changes: 7 additions & 6 deletions conventional_pre_commit/format.py
Original file line number Diff line number Diff line change
Expand Up @@ -67,13 +67,14 @@ def r_autosquash_prefixes():
return "|".join(AUTOSQUASH_PREFIXES)


def r_verbose_diff():
"""Regex str for verbose diff"""
return r"(?P<diff>(^# -* >8 -*$\r?\n)(^# .*$\r?\n)+(diff ){1}(.*\r?\n)*)"
def r_verbose_commit_ignored():
"""Regex str for the ignored part of verbose commit message templates"""
return r"^# -{24} >8 -{24}\r?\n.*\Z"


def strip_verbose_diff(input):
return re.sub(r_verbose_diff(), "", input, flags=re.MULTILINE)
def strip_verbose_commit_ignored(input):
"""Strip the ignored part of verbose commit message templates."""
return re.sub(r_verbose_commit_ignored(), "", input, flags=re.DOTALL | re.MULTILINE)


def r_comment():
Expand All @@ -99,7 +100,7 @@ def is_conventional(input, types=DEFAULT_TYPES, optional_scope=True, scopes: Opt
Optionally provide a list of additional custom types.
"""
input = strip_verbose_diff(input)
input = strip_verbose_commit_ignored(input)
input = strip_comments(input)
types = conventional_types(types)
pattern = f"^({r_types(types)}){r_scope(optional_scope, scopes=scopes)}{r_delim()}{r_subject()}{r_body()}"
Expand Down
2 changes: 1 addition & 1 deletion tests/run.sh
Original file line number Diff line number Diff line change
Expand Up @@ -7,5 +7,5 @@ coverage run -m pytest
# clean out old coverage results
rm -rf ./tests/coverage

# regenerate coverate report
# regenerate coverage report
coverage html --directory ./tests/coverage
302 changes: 253 additions & 49 deletions tests/test_format.py
Original file line number Diff line number Diff line change
Expand Up @@ -165,71 +165,275 @@ def test_strip_comments__spaced():
assert result.strip() == "feat(scope): message"


def test_r_verbose_diff__has_diff():
regex = re.compile(format.r_verbose_diff(), re.MULTILINE)
input = """# ----------- >8 -----------
# Some comment
# Some comment
diff --git a/file b/file
def test_r_verbose_commit_ignored__does_not_match_no_verbose():
regex = re.compile(format.r_verbose_commit_ignored(), re.DOTALL | re.MULTILINE)
input = """feat: some commit message
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# On branch main
# Your branch is up to date with 'origin/main'.
#
# Changes to be committed:
# modified: README.md
#
# Changes not staged for commit:
# modified: README.md
#
"""

assert regex.match(input)


def test_r_verbose_diff__no_diff():
regex = re.compile(format.r_verbose_diff(), re.MULTILINE)
input = """# ----------- >8 -----------
# Some comment
# Some comment
assert not regex.search(input)


def test_r_verbose_commit_ignored__matches_single_verbose_ignored():
regex = re.compile(format.r_verbose_commit_ignored(), re.DOTALL | re.MULTILINE)
input = (
"""feat: some commit message
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# On branch main
# Your branch is up to date with 'origin/main'.
#
# Changes to be committed:
# modified: README.md
#
# Changes not staged for commit:
# modified: README.md
#
# ------------------------ >8 ------------------------
# Do not modify or remove the line above.
# Everything below it will be ignored.
diff --git c/README.md i/README.md
index ea80a93..fe8a527 100644
--- c/README.md
+++ i/README.md
@@ -20,3 +20,4 @@ Some hunk header
Context 1
"""

assert not regex.match(input)


def test_r_verbose_diff__no_extra_comments():
regex = re.compile(format.r_verbose_diff(), re.MULTILINE)
input = """# ----------- >8 -----------
diff --git a/file b/file
+ " " # This is on purpose to preserve the space from overly eager stripping.
+ """
Context 2
+Added line
"""
)

assert not regex.match(input)


def test_strip_verbose_diff__has_diff():
input = """feat(scope): message
# Please enter the commit message for your changes.
assert regex.search(input)


def test_r_verbose_commit_ignored__matches_double_verbose_ignored():
regex = re.compile(format.r_verbose_commit_ignored(), re.DOTALL | re.MULTILINE)
input = (
"""feat: some commit message
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# On branch main
# Your branch is up to date with 'origin/main'.
#
# Changes to be committed:
# modified: README.md
#
# Changes not staged for commit:
# modified: README.md
#
# ------------------------ >8 ------------------------
# Do not modify or remove the line above.
# Everything below it will be ignored.
#
# Changes to be committed:
diff --git c/README.md i/README.md
index ea80a93..fe8a527 100644
--- c/README.md
+++ i/README.md
@@ -20,3 +20,4 @@ Some staged hunk header
Staged Context 1
"""
+ " " # This is on purpose to preserve the space from overly eager stripping.
+ """
Staged Context 2
+Staged added line
# --------------------------------------------------
# Changes not staged for commit:
diff --git i/README.md w/README.md
index fe8a527..1c00c14 100644
--- i/README.md
+++ w/README.md
@@ -10,6 +10,7 @@ Some unstaged hunk header
Context 1
Context 2
Context 3
-Removed line
+Added line
"""
+ " " # This is on purpose to preserve the space from overly eager stripping.
+ """
Context 4
"""
+ " " # This is on purpose to preserve the space from overly eager stripping.
+ """
"""
)

# These are comments usually added by editors, f.ex. with export EDITOR=vim
# ----------- >8 -----------
# Some comment
# Some comment
diff --git a/file b/file
assert regex.search(input)


def test_strip_verbose_commit_ignored__does_not_strip_no_verbose():
input = """feat: some commit message
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# On branch main
# Your branch is up to date with 'origin/main'.
#
# Changes to be committed:
# modified: README.md
#
# Changes not staged for commit:
# modified: README.md
#
"""

result = format.strip_verbose_diff(input)
assert result.count("\n") == 4
assert (
result
== """feat(scope): message
# Please enter the commit message for your changes.
expected = """feat: some commit message
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# On branch main
# Your branch is up to date with 'origin/main'.
#
# Changes to be committed:
# modified: README.md
#
# Changes not staged for commit:
# modified: README.md
#
"""

# These are comments usually added by editors, f.ex. with export EDITOR=vim
result = format.strip_verbose_commit_ignored(input)
assert result == expected


def test_strip_verbose_commit_ignored__strips_single_verbose_ignored():
input = (
"""feat: some commit message
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# On branch main
# Your branch is up to date with 'origin/main'.
#
# Changes to be committed:
# modified: README.md
#
# Changes not staged for commit:
# modified: README.md
#
# ------------------------ >8 ------------------------
# Do not modify or remove the line above.
# Everything below it will be ignored.
diff --git c/README.md i/README.md
index ea80a93..fe8a527 100644
--- c/README.md
+++ i/README.md
@@ -20,3 +20,4 @@ Some hunk header
Context 1
"""
+ " " # This is on purpose to preserve the space from overly eager stripping.
+ """
Context 2
+Added line
"""
)

expected = """feat: some commit message
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# On branch main
# Your branch is up to date with 'origin/main'.
#
# Changes to be committed:
# modified: README.md
#
# Changes not staged for commit:
# modified: README.md
#
"""

def test_strip_verbose_diff__no_diff():
input = """feat(scope): message
# Please enter the commit message for your changes.
result = format.strip_verbose_commit_ignored(input)
assert result == expected


def test_strip_verbose_commit_ignored__strips_double_verbose_ignored():
input = (
"""feat: some commit message
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# On branch main
# Your branch is up to date with 'origin/main'.
#
# Changes to be committed:
# modified: README.md
#
# Changes not staged for commit:
# modified: README.md
#
# ------------------------ >8 ------------------------
# Do not modify or remove the line above.
# Everything below it will be ignored.
#
# Changes to be committed:
diff --git c/README.md i/README.md
index ea80a93..fe8a527 100644
--- c/README.md
+++ i/README.md
@@ -20,3 +20,4 @@ Some staged hunk header
Staged Context 1
"""
+ " " # This is on purpose to preserve the space from overly eager stripping.
+ """
Staged Context 2
+Staged added line
# --------------------------------------------------
# Changes not staged for commit:
diff --git i/README.md w/README.md
index fe8a527..1c00c14 100644
--- i/README.md
+++ w/README.md
@@ -10,6 +10,7 @@ Some unstaged hunk header
Context 1
Context 2
Context 3
-Removed line
+Added line
"""
+ " " # This is on purpose to preserve the space from overly eager stripping.
+ """
Context 4
"""
+ " " # This is on purpose to preserve the space from overly eager stripping.
+ """
"""
)

# These are comments usually added by editors, f.ex. with export EDITOR=vim
# ----------- >8 -----------
# Some comment
# Some comment
expected = """feat: some commit message
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# On branch main
# Your branch is up to date with 'origin/main'.
#
# Changes to be committed:
# modified: README.md
#
# Changes not staged for commit:
# modified: README.md
#
"""

result = format.strip_verbose_diff(input)
assert result == input
result = format.strip_verbose_commit_ignored(input)
assert result == expected


@pytest.mark.parametrize("type", format.DEFAULT_TYPES)
Expand Down

0 comments on commit 406f0d1

Please # to comment.