Class GoogleMethodNameCheck
java.lang.Object
com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
com.puppycrawl.tools.checkstyle.api.AbstractViolationReporter
com.puppycrawl.tools.checkstyle.api.AbstractCheck
com.puppycrawl.tools.checkstyle.checks.naming.GoogleMethodNameCheck
- All Implemented Interfaces:
Configurable,Contextualizable
Checks that method names conform to the
Google Java Style Guide for method naming.
This check enforces Google's specific method naming requirements:
- Method names must start with a lowercase letter and use uppercase letters for word boundaries.
- Underscores may appear in JUnit test method names to separate logical components.
- Underscores may be used to separate adjacent numbers (e.g., version
numbers like
guava33_4_5), but NOT between letters and digits.
- Since:
- 13.1.0
-
Nested Class Summary
Nested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
AbstractAutomaticBean.OutputStreamOptions -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final PatternMatches invalid underscore usage for regular methods: leading, trailing, double, or between any characters (letter-letter, letter-digit, digit-letter).private static final PatternMatches invalid underscore usage for test methods: leading, trailing, double, or between letter-digit/digit-letter.static final StringA key is pointing to the violation message text in "messages.properties" file.static final StringA key is pointing to the violation message text in "messages.properties" file.static final StringA key is pointing to the violation message text in "messages.properties" file.static final StringA key is pointing to the violation message text in "messages.properties" file.private static final PatternPattern to strip trailing numbering suffix (underscore followed by digits).private static final PatternPattern for valid regular method names in Google style.Set of JUnit 5 test annotation names that indicate a test method.private static final PatternPattern for valid test method names in Google style. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionint[]The configurable token set.int[]Returns the default token a check is interested in.int[]The tokens that this check must be registered for.private static booleanhasTestAnnotation(DetailAST methodDef) Checks if the method has any test annotation.private voidvalidateRegularMethodName(DetailAST nameAst, String methodName) Validates a regular (non-test) method name according to Google style.private voidvalidateTestMethodName(DetailAST nameAst, String methodName) Validates a test method name according to Google style.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheck
beginTree, clearViolations, destroy, finishTree, getFileContents, getFilePath, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, init, isCommentNodesRequired, leaveToken, log, log, log, setFileContents, setTabWidth, setTokensMethods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractViolationReporter
finishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityMethods inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
configure, contextualize, getConfiguration, setupChild
-
Field Details
-
MSG_KEY_FORMAT_REGULAR
A key is pointing to the violation message text in "messages.properties" file.- See Also:
-
MSG_KEY_FORMAT_TEST
A key is pointing to the violation message text in "messages.properties" file.- See Also:
-
MSG_KEY_UNDERSCORE_REGULAR
A key is pointing to the violation message text in "messages.properties" file.- See Also:
-
MSG_KEY_UNDERSCORE_TEST
A key is pointing to the violation message text in "messages.properties" file.- See Also:
-
REGULAR_METHOD_NAME_PATTERN
Pattern for valid regular method names in Google style. Format: start with lowercase, have at least 2 chars, optionally followed by numbering suffix.Explanation:
^(?![a-z]$)- Negative lookahead: cannot be single lowercase char(?![a-z][A-Z])- Negative lookahead: cannot be like "fO"[a-z]- Must start with lowercase[a-z0-9]*+- Followed by lowercase or digits(?:[A-Z][a-z0-9]*+)*+- CamelCase humps (uppercase followed by lowercase/digits)$- End of string (numbering suffix validated separately)
-
TEST_METHOD_NAME_PATTERN
Pattern for valid test method names in Google style. Each segment between underscores must:- Start with lowercase
- Be at least 2 characters long
- Not start with single lowercase followed by uppercase (e.g., "fO")
-
NUMBERING_SUFFIX_PATTERN
Pattern to strip trailing numbering suffix (underscore followed by digits). -
INVALID_UNDERSCORE_PATTERN_REGULAR
Matches invalid underscore usage for regular methods: leading, trailing, double, or between any characters (letter-letter, letter-digit, digit-letter). -
INVALID_UNDERSCORE_PATTERN_TEST
Matches invalid underscore usage for test methods: leading, trailing, double, or between letter-digit/digit-letter. -
TEST_ANNOTATIONS
Set of JUnit 5 test annotation names that indicate a test method.
-
-
Constructor Details
-
GoogleMethodNameCheck
public GoogleMethodNameCheck()
-
-
Method Details
-
getDefaultTokens
Description copied from class:AbstractCheckReturns the default token a check is interested in. Only used if the configuration for a check does not define the tokens.- Specified by:
getDefaultTokensin classAbstractCheck- Returns:
- the default tokens
- See Also:
-
getAcceptableTokens
Description copied from class:AbstractCheckThe configurable token set. Used to protect Checks against malicious users who specify an unacceptable token set in the configuration file. The default implementation returns the check's default tokens.- Specified by:
getAcceptableTokensin classAbstractCheck- Returns:
- the token set this check is designed for.
- See Also:
-
getRequiredTokens
Description copied from class:AbstractCheckThe tokens that this check must be registered for.- Specified by:
getRequiredTokensin classAbstractCheck- Returns:
- the token set this must be registered for.
- See Also:
-
visitToken
Description copied from class:AbstractCheckCalled to process a token.- Overrides:
visitTokenin classAbstractCheck- Parameters:
ast- the token to process
-
hasTestAnnotation
Checks if the method has any test annotation.- Parameters:
methodDef- the METHOD_DEF AST node- Returns:
- true if the method has @Test, @ParameterizedTest, or @RepeatedTest annotation.
-
validateRegularMethodName
Validates a regular (non-test) method name according to Google style.- Parameters:
nameAst- the IDENT AST node containing the method namemethodName- the method name string
-
validateTestMethodName
Validates a test method name according to Google style.- Parameters:
nameAst- the IDENT AST node containing the method namemethodName- the method name string
-