1
0

Compare commits

...

3 Commits

Author SHA1 Message Date
253e594a60 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
2025-03-03 10:10:02 +01:00
eccd7099e7 Expose __version__ 2025-03-03 10:09:38 +01:00
77f0420af2 Parsing tests 2025-03-03 10:08:55 +01:00
3 changed files with 92 additions and 17 deletions

View File

@ -6,9 +6,14 @@ 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'
@ -16,8 +21,6 @@ class NamingScheme(enum.Enum):
FROM_DESC = 'desc'
PATTERN_JAVADOC = r'/\*\*(?P<javadoc>.*(\n\s*\*.*)*?)\s*\*/'
PATTERN_DISPLAY_NAME_EXPRESSION = r'\s*(?:"[^"]*?")(?:\s*\+\s*"[^"]*?")*\s*'
PATTERN_DISPLAY_NAME = (
@ -47,7 +50,6 @@ IGNORABLE_WORDS_IN_NAME = frozenset(
'the',
'is',
'are',
'test',
'tests',
},
@ -92,7 +94,7 @@ def to_camel_case(description: str) -> str:
.replace('+', ' ')
.replace('-', ' ')
.replace(':', ' ')
.replace('\'', '')
.replace("'", '')
.strip(' \t.')
)
words = description.split(' ')
@ -110,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()
@ -136,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'))
@ -174,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

46
test/test_parsing.py Normal file
View File

@ -0,0 +1,46 @@
import re
import pytest
from standardize_test_format import (
PATTERN_DISPLAY_NAME,
PATTERN_DISPLAY_NAME_EXPRESSION,
PATTERN_JAVADOC,
)
VALID_JAVADOCS = [
'/** Hello World */',
'/** Hello\n * World */',
'/**\n * Hello World\n */',
]
VALID_DISPLAY_NAME_EXPRESSIONS = [
'"Hello"',
' "Hello" ',
'"Hello " + " World!"',
]
VALID_DISPLAY_NAMES = [
'@DisplayName("test")',
'@DisplayName( "test" )',
'@DisplayName(\n"test"\n)',
'@DisplayName("Hello " + " World!")',
'@DisplayName("Hello "\n+\n" World!")',
]
@pytest.mark.parametrize('text', VALID_JAVADOCS)
def test_javadoc_parsing(text: str):
assert re.match(PATTERN_JAVADOC, text) is not None
@pytest.mark.parametrize('text', VALID_DISPLAY_NAMES)
def test_display_name_parsing(text: str):
assert re.match(PATTERN_DISPLAY_NAME, text) is not None
@pytest.mark.parametrize('text', VALID_DISPLAY_NAME_EXPRESSIONS)
def test_display_name_expressions(text: str):
assert re.match(PATTERN_DISPLAY_NAME_EXPRESSION, text) is not None