1
0

Ruff
Some checks failed
Run Python tests (through Pytest) / Test (push) Failing after 23s
Verify Python project can be installed, loaded and have version checked / Test (push) Successful in 21s

This commit is contained in:
Jon Michael Aanes 2025-03-03 10:10:02 +01:00
parent eccd7099e7
commit 253e594a60
2 changed files with 42 additions and 17 deletions

View File

@ -6,22 +6,21 @@ Is capable of migrating from Javadoc based property specification to the
`@DisplayName` specification and back.
"""
import re
import enum
import hashlib
import re
from ._version import __version__
__all__ = ['__version__', 'standardize_java_text', 'NamingScheme']
class NamingScheme(enum.Enum):
PRESERVE = 'preserve'
HASH_OF_DESC = 'hash'
FROM_DESC = 'desc'
PATTERN_JAVADOC = r'/\*\*(?P<javadoc>.*(\n\s*\*.*)*?)\s*\*/'
PATTERN_DISPLAY_NAME_EXPRESSION = r'\s*(?:"[^"]*?")(?:\s*\+\s*"[^"]*?")*\s*'
PATTERN_DISPLAY_NAME = (
@ -51,7 +50,6 @@ IGNORABLE_WORDS_IN_NAME = frozenset(
'the',
'is',
'are',
'test',
'tests',
},
@ -96,7 +94,7 @@ def to_camel_case(description: str) -> str:
.replace('+', ' ')
.replace('-', ' ')
.replace(':', ' ')
.replace('\'', '')
.replace("'", '')
.strip(' \t.')
)
words = description.split(' ')
@ -114,7 +112,9 @@ def to_camel_case(description: str) -> str:
def from_camel_case(name: str) -> str:
return re.sub(
r'(^|[A-Z])[a-z]*', lambda x: ' ' + x.group(0).capitalize(), name,
r'(^|[A-Z])[a-z]*',
lambda x: ' ' + x.group(0).capitalize(),
name,
).strip()
@ -140,9 +140,10 @@ def parse_display_name_to_description(text: str | None):
return text
def replace_test_pattern(
match: re.Match, with_javadoc: bool, with_display_name: bool,
match: re.Match,
with_javadoc: bool,
with_display_name: bool,
naming_scheme: NamingScheme,
) -> str:
javadoc = parse_javadoc_to_description(match.group('javadoc'))
@ -162,7 +163,7 @@ def replace_test_pattern(
elif naming_scheme == NamingScheme.HASH_OF_DESC:
h = hashlib.sha256()
h.update(description.encode('utf8'))
name = 'test'+h.hexdigest()
name = 'test' + h.hexdigest()
del h
return format_test_prefix(
@ -178,9 +179,20 @@ def replace_test_pattern(
IMPORT_DISPLAY_NAME = 'import org.junit.jupiter.api.DisplayName;'
def standardize_java_text(text: str, with_javadoc: bool, with_display_name: bool, naming_scheme: NamingScheme):
def standardize_java_text(
text: str,
with_javadoc: bool,
with_display_name: bool,
naming_scheme: NamingScheme,
):
text = TEST_PATTERN.sub(
lambda m: replace_test_pattern(m, with_javadoc, with_display_name, naming_scheme), text,
lambda m: replace_test_pattern(
m,
with_javadoc,
with_display_name,
naming_scheme,
),
text,
)
if '@DisplayName' in text and IMPORT_DISPLAY_NAME not in text:
lines = text.split('\n')

View File

@ -1,7 +1,7 @@
import argparse
import pathlib
from . import standardize_java_text, NamingScheme
from . import NamingScheme, standardize_java_text
def test_files(repo: pathlib.Path) -> list[pathlib.Path]:
@ -9,13 +9,21 @@ def test_files(repo: pathlib.Path) -> list[pathlib.Path]:
def standardize_in_file(
path: pathlib.Path, inline: bool, with_javadoc: bool, with_display_name:
bool, naming_scheme: NamingScheme,
path: pathlib.Path,
inline: bool,
with_javadoc: bool,
with_display_name: bool,
naming_scheme: NamingScheme,
):
with open(path) as f:
text = f.read()
text_updated = standardize_java_text(text, with_javadoc, with_display_name, naming_scheme=naming_scheme)
text_updated = standardize_java_text(
text,
with_javadoc,
with_display_name,
naming_scheme=naming_scheme,
)
if text_updated == text:
return
@ -32,7 +40,12 @@ def argument_parser():
argparser.add_argument('-i', action='store_true')
argparser.add_argument('--javadoc', action='store_true')
argparser.add_argument('--displayname', action='store_true')
argparser.add_argument('--naming', type=NamingScheme, choices=list(NamingScheme), default=NamingScheme.FROM_DESC)
argparser.add_argument(
'--naming',
type=NamingScheme,
choices=list(NamingScheme),
default=NamingScheme.FROM_DESC,
)
return argparser