Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Issue #15503: Added support for violation of p tag if it precedes a block tag #15710

Merged

Conversation

Zopsss
Copy link
Member

@Zopsss Zopsss commented Sep 26, 2024

fixes #15503

added support to check and violate block-tag if they're followed by p tag.

created a new violation message for it.

wrote new test cases.

took the HTML tags list from: https://checkstyle.sourceforge.io/checks/javadoc/javadocstyle.html#JavadocStyle

Check for allowed HTML tags. The list of allowed HTML tags is "a", "abbr", "acronym", "address", "area", "b", "bdo", "big", "blockquote", "br", "caption", "cite", "code", "colgroup", "dd", "del", "dfn", "div", "dl", "dt", "em", "fieldset", "font", "h1", "h2", "h3", "h4", "h5", "h6", "hr", "i", "img", "ins", "kbd", "li", "ol", "p", "pre", "q", "samp", "small", "span", "strong", "sub", "sup", "table", "tbody", "td", "tfoot", "th", "thead", "tr", "tt", "u", "ul", "var".

and filtered out block-level tags.


Diff Regression config: https://gist.githubusercontent.com/Zopsss/013f379d4c821f2d624be56212a64575/raw/5f17ec9186d4421396429ab38cbac3e4663bf4eb/javadocparagraph_config.xml
Diff Regression projects: https://raw.githubusercontent.com/checkstyle/contribution/master/checkstyle-tester/projects-to-test-on-for-github-action.properties

@Zopsss
Copy link
Member Author

Zopsss commented Sep 26, 2024

Github, generate report

Copy link
Contributor

Report generation failed on phase "make_report",
step "Generate report".
Link: https://github.com/checkstyle/checkstyle/actions/runs/11058159106

@Zopsss
Copy link
Member Author

Zopsss commented Sep 26, 2024

Github, generate report

@Zopsss Zopsss force-pushed the 15503-violate-for-extra-preceding-paragraph branch 3 times, most recently from b9d2992 to 3aa7ee5 Compare September 27, 2024 06:41
@Zopsss
Copy link
Member Author

Zopsss commented Sep 27, 2024

Github, generate report

Comment on lines 131 to 127
/* 4 lines below, no violation until #15503 */
/* 4 lines below, no violation until #15685 */
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

had to change issue number to #15685 because CI was complaining. These false-negatives will be covered as part of newly linked issue as they have their corresponding closing tag

@Zopsss Zopsss force-pushed the 15503-violate-for-extra-preceding-paragraph branch from 3aa7ee5 to a9cec53 Compare September 27, 2024 09:37
@Zopsss
Copy link
Member Author

Zopsss commented Sep 27, 2024

Github, generate report

@Zopsss Zopsss force-pushed the 15503-violate-for-extra-preceding-paragraph branch from a9cec53 to 3eb627a Compare September 27, 2024 09:53
Copy link
Contributor

Report generation failed on phase "make_report",
step "Generate report".
Link: https://github.com/checkstyle/checkstyle/actions/runs/11068301809

@Zopsss Zopsss force-pushed the 15503-violate-for-extra-preceding-paragraph branch from 3eb627a to 19ad95a Compare September 27, 2024 15:33
@Zopsss
Copy link
Member Author

Zopsss commented Sep 28, 2024

Github, generate report

Copy link
Contributor

Report generation failed on phase "make_report",
step "Generate report".
Link: https://github.com/checkstyle/checkstyle/actions/runs/11082649268

@Zopsss
Copy link
Member Author

Zopsss commented Sep 28, 2024

Github, generate report

Copy link
Member

@romani romani left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

items:

@romani romani self-assigned this Sep 28, 2024
Copy link
Member

@romani romani left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

items:

@Zopsss Zopsss force-pushed the 15503-violate-for-extra-preceding-paragraph branch from 19ad95a to 4315c39 Compare September 28, 2024 19:25
@romani
Copy link
Member

romani commented Sep 29, 2024

Pitest should be fixed, we can not merge in red CI

Copy link
Member

@romani romani left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Items

@romani
Copy link
Member

romani commented Sep 30, 2024

@Zopsss , please rebase

Copy link
Member

@romani romani left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

item:

@Zopsss Zopsss force-pushed the 15503-violate-for-extra-preceding-paragraph branch from 4315c39 to 70980bf Compare October 1, 2024 13:45
Copy link
Member

@romani romani left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Items

@Zopsss Zopsss force-pushed the 15503-violate-for-extra-preceding-paragraph branch 2 times, most recently from 03f5d5e to 5a5b1b4 Compare October 2, 2024 04:30
@romani romani assigned rdiachenko and unassigned romani Oct 2, 2024
@Zopsss
Copy link
Member Author

Zopsss commented Oct 2, 2024

github, generate report

@Zopsss
Copy link
Member Author

Zopsss commented Oct 2, 2024

ci passed 🎉

@Zopsss
Copy link
Member Author

Zopsss commented Oct 2, 2024

the check isn't aware of comments, found a case like that at:

https://checkstyle-diff-reports.s3.us-east-2.amazonaws.com/63facba_2024175613/reports/diff/apache-struts/index.html#A5

* <p>
* <!-- START SNIPPET: params -->
*
* <ul>

this is good. This should still be considered as a violation

@Zopsss
Copy link
Member Author

Zopsss commented Oct 2, 2024

report looks good, no false-positives.

@romani
Copy link
Member

romani commented Oct 2, 2024

https://checkstyle-diff-reports.s3.us-east-2.amazonaws.com/63facba_2024175613/reports/diff/pmd/index.html#A1

123     /**
124      * Parses a qualified name given in the format defined for this implementation. The format
125      * is specified by a regex pattern (see {@link #FORMAT}). Examples:
126      *
127      * <p>{@code com.company.MyClass$Nested#myMethod(String, int)}
128      * <ul>
129      * <li> Packages are separated by full stops;
130      * <li> Nested classes are separated by a dollar symbol;
131      * <li> The optional method suffix is separated from the class with a hashtag;
132      * <li> Method arguments are separated by a comma and a single space.
133      * </ul>
134      *
135      * <p>

There is content between P tag and UL tag, so it false-positive, no violation should be there.

@romani
Copy link
Member

romani commented Oct 3, 2024

https://checkstyle-diff-reports.s3.us-east-2.amazonaws.com/63facba_2024175613/reports/diff/apache-struts/index.html#A1

* <p>
55   * <!-- START SNIPPET: params -->
56   * <ul>
57   *      <li>id (String) - the id (if specified) to put the action under stack's context.
58   *      <li>name* (String) - name of the action to be executed (without the extension suffix eg. .action)</li>
59   *      <li>namespace (String) - default to the namespace where this action tag is invoked</li>
60   *      <li>executeResult (Boolean) -  default is false. Decides whether the result of this action is to be executed or not</li>
61   *      <li>ignoreContextParams (Boolean) - default to false. Decides whether the request parameters are to be included when the action is invoked</li>
62   * </ul>
63  

Ideally this should continue to be violation , there are some content that is comment tag. We should skip it. Please add this case to Inputs , it should be violated

@romani
Copy link
Member

romani commented Oct 3, 2024

False positive
https://checkstyle-diff-reports.s3.us-east-2.amazonaws.com/63facba_2024175613/reports/diff/openjdk21/index.html#A50

156  * See {@link ZoneInfo#transitions ZoneInfo.transitions} about the value.
157  *
158  * <p><strong>1.2 <code>offset_table</code> structure</strong><p>
159  * <blockquote>
160  * <pre>
161  *    offset_table {
162  *      u1      tag;              // 0x05 : constant
163  *      u2      length;           // byte length of whole values
164  *      s4      value[length/4];  // offset values in `int'
165  *    }
166  * </pre>
167  * </blockquote>

@Zopsss
Copy link
Member Author

Zopsss commented Oct 3, 2024

False positive
https://checkstyle-diff-reports.s3.us-east-2.amazonaws.com/63facba_2024175613/reports/diff/spring-framework/index.html#A8

*
88   * <p><b>Render Request:</b><p>
89   * <ol>

This isn't false-positive. There's a second opening <p> after </b> and in next line there's a block tag <ol>, so this should be a violation. If there was a closing paragraph tag instead of second opening paragraph tag then it wouldn't cause violation.

@Zopsss
Copy link
Member Author

Zopsss commented Oct 3, 2024

https://checkstyle-diff-reports.s3.us-east-2.amazonaws.com/63facba_2024175613/reports/diff/pmd/index.html#A1

123     /**
124      * Parses a qualified name given in the format defined for this implementation. The format
125      * is specified by a regex pattern (see {@link #FORMAT}). Examples:
126      *
127      * <p>{@code com.company.MyClass$Nested#myMethod(String, int)}
128      * <ul>
129      * <li> Packages are separated by full stops;
130      * <li> Nested classes are separated by a dollar symbol;
131      * <li> The optional method suffix is separated from the class with a hashtag;
132      * <li> Method arguments are separated by a comma and a single space.
133      * </ul>
134      *
135      * <p>

There is content between P tag and UL tag, so it false-positive, no violation should be there.

Ummm <p>{@code com.company.MyClass$Nested#myMethod(String, int)} does not have its corresponding closing tag, instead there's a block tag after it. If closing paragraph tag was present before <ul> then it would be fine, there would be no violation.

But I'll still look into this. Thanks for pointing this out

@Zopsss
Copy link
Member Author

Zopsss commented Oct 3, 2024

False positive
https://checkstyle-diff-reports.s3.us-east-2.amazonaws.com/63facba_2024175613/reports/diff/openjdk21/index.html#A50

156  * See {@link ZoneInfo#transitions ZoneInfo.transitions} about the value.
157  *
158  * <p><strong>1.2 <code>offset_table</code> structure</strong><p>
159  * <blockquote>
160  * <pre>
161  *    offset_table {
162  *      u1      tag;              // 0x05 : constant
163  *      u2      length;           // byte length of whole values
164  *      s4      value[length/4];  // offset values in `int'
165  *    }
166  * </pre>
167  * </blockquote>

The violation is for

<p>
> 159  * <blockquote>

Not for

> 158  * <p><strong>1.2 <code>offset_table</code> structure</strong>

The blockquote tag is a block-tag and it is preceded by an opening tag so there should be violation for it.

@Zopsss
Copy link
Member Author

Zopsss commented Oct 3, 2024

I guess this check needs to have column number in its violation. Otherwise it can confuse users.

You can see in the above comments, javadocs have multiple opening paragraph tags on same line and on next line they have block-tag. So check gives violation for it but the violation message only contains line number not the column number so it can confuse users about which paragraph tag is causing the violation.

Copy link
Contributor

@rdiachenko rdiachenko left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lgtm

@Zopsss Zopsss force-pushed the 15503-violate-for-extra-preceding-paragraph branch 2 times, most recently from cef359b to 730221a Compare October 3, 2024 10:10
Comment on lines +80 to +86
* <p>
* <!-- THIS COMMENT WILL GET IGNORED -->
* <ul>
* <li>Item 1</li>
* <li>Item 2</li>
* <li>Item 3</li>
* </ul>
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

test case added #15710 (comment)

Comment on lines +247 to +253
while (htmlElement != null && htmlElement.getType() != JavadocTokenTypes.HTML_ELEMENT) {
if ((htmlElement.getType() == JavadocTokenTypes.TEXT
|| htmlElement.getType() == JavadocTokenTypes.JAVADOC_INLINE_TAG)
&& !CommonUtil.isBlank(htmlElement.getText())) {
htmlElement = null;
break;
}
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

added new line: || htmlElement.getType() == JavadocTokenTypes.JAVADOC_INLINE_TAG) to fix the false-positive found at:

#15710 (comment)

@Zopsss Zopsss force-pushed the 15503-violate-for-extra-preceding-paragraph branch from 730221a to 6c9265f Compare October 3, 2024 10:15
Comment on lines +90 to +100
/**
* Some Summary.
*
* <p>{@code com.company.MyClass$Nested#myMethod(String, int)}
* <ul>
* <li>Item 1</li>
* <li>Item 2</li>
* <li>Item 3</li>
* </ul>
*/
private static final String NAME2 = "Jesse Pinkman";
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

test case added #15710 (comment)

@romani
Copy link
Member

romani commented Oct 3, 2024

GitHub, generate report for configs in PR description

@romani romani merged commit aeaf4b0 into checkstyle:master Oct 3, 2024
112 checks passed
@Zopsss Zopsss deleted the 15503-violate-for-extra-preceding-paragraph branch October 3, 2024 14:04
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

JavadocParagraph: violate preceding P tag before block-level HTML tags
4 participants