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 #12817: fix switch-expression Indentation when appears on the start of the … #16418

Merged
merged 1 commit into from
Mar 21, 2025

Conversation

@mohitsatr
Copy link
Contributor Author

Github, generate report for indentation/all-examples-in-one

Copy link
Contributor

Failed to download or process the specified configuration(s).
Error details:

Please ensure you've used one of the following commands correctly:

@mohitsatr
Copy link
Contributor Author

Github, generate report

@mohitsatr mohitsatr changed the title Issue #12817: fix switch-expression when appears on the start of the … Issue #12817: fix switch-expression Indentation when appears on the start of the … Feb 27, 2025
@romani
Copy link
Member

romani commented Mar 2, 2025

I like fact that no changes except for one project.

camunda ( ±1196, -479, +717 )

this very scary difference.
lets handle it a bit differently. please try to guess what indentation is used in this project and make config that suites it, so we will use single config diff report run, so we should have less violations.
But main point will be even violation become different, or stay, we will see if it is correct or not.

@mohitsatr
Copy link
Contributor Author

mohitsatr commented Mar 3, 2025

I tested examples locally with same config and it passes without any problem.

@mohitsatr
Copy link
Contributor Author

Github, generate report for Indentation/Example1

@mohitsatr
Copy link
Contributor Author

Github, generate report

Copy link
Contributor

github-actions bot commented Mar 3, 2025

@mohitsatr
Copy link
Contributor Author

Github, generate report

@mohitsatr
Copy link
Contributor Author

@romani report is ready.

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.

Last minor:

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.

Itet

@romani
Copy link
Member

romani commented Mar 8, 2025

Just curious, how much violations are on camunda , if just run Indentation validation of config that you have in PR description.
I think we can use New module config: {{URI to new_module_config.xml}} to get this. But we need list of projects to be only camunda.

@mohitsatr
Copy link
Contributor Author

mohitsatr commented Mar 10, 2025

I'm having some difficulties specifying violations in google test suit.

Screenshot from 2025-03-10 08-06-39

Screenshot from 2025-03-10 08-07-30

image

every other test-case function has not specified any expected violation in them, so i was just following them.
could it be due to the asteriks(*) in the input file ?
I couldn't use full violation messages here, it violates 100 line length rule.

@Zopsss
Copy link
Member

Zopsss commented Mar 11, 2025

Can you try to debug to see what are the unexpected violations? If they're about line length limit then try to trim violation messages to:

// violation 'case' child * level 12, expected * 10

@mohitsatr
Copy link
Contributor Author

mohitsatr commented Mar 11, 2025

@Zopsss I figured it out. regexp was not catching it because ("") were missing.
// violation "'case' child * level 8, expected * 10"

But now

Screenshot from 2025-03-11 09-34-00

Screenshot from 2025-03-11 09-34-19

as you can see, full message causes line-length issue, but it is not accepting shortened message either.

@Zopsss
Copy link
Member

Zopsss commented Mar 11, 2025

Add . at the end of your message and please always push changes to let us see the whole code

@mohitsatr mohitsatr force-pushed the switch-newline-indentation branch from 49517b4 to 0748b8b Compare March 12, 2025 03:34
@mohitsatr
Copy link
Contributor Author

@Zopsss . at the end does not help either. please check the code

@mohitsatr
Copy link
Contributor Author

okay figured it out.

@mohitsatr mohitsatr force-pushed the switch-newline-indentation branch from 0748b8b to 2ad2e4c Compare March 12, 2025 04:12
@mohitsatr
Copy link
Contributor Author

mohitsatr commented Mar 12, 2025

i feel like there should be a page on the website about how to specify violations in input files, with different formats. we could also add how to write test functions. It'd make really easy for newcomers and time-saving as well. and we could avoid many repetitive questions . @romani what do you think, should i open an issue ?

@mohitsatr mohitsatr force-pushed the switch-newline-indentation branch from 2ad2e4c to 4aaed8d Compare March 12, 2025 08:17
@mohitsatr
Copy link
Contributor Author

Just curious, how much violations are on camunda , if just run Indentation validation of config that you have in PR description. I think we can use New module config: {{URI to new_module_config.xml}} to get this. But we need list of projects to be only camunda.

let's try

@mohitsatr
Copy link
Contributor Author

Github, generate report

Copy link
Contributor

Report generation failed on phase "make_report",
step "Prepare environment".
Link: https://github.com/checkstyle/checkstyle/actions/runs/13806697335

@mohitsatr
Copy link
Contributor Author

did I do something wrong in the configs/project file ?

@mohitsatr
Copy link
Contributor Author

Github, generate report

Copy link
Contributor

Report generation failed on phase "make_report",
step "Prepare environment".
Link: https://github.com/checkstyle/checkstyle/actions/runs/13832852114

@mohitsatr
Copy link
Contributor Author

Github, generate report

@romani
Copy link
Member

romani commented Mar 14, 2025

should i open an issue ?

Please create issue and feel free to send PR to resolve it, as look like know all pain points

@mohitsatr
Copy link
Contributor Author

@romani is this #16418 (comment) what we wanted ?

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.

is this #16418 (comment) what we wanted ?

unfortunately too much violation to take use from it, but yes conceptually it is.
I just tried to find config that will produce minimal amount of violations, to let it reviewable by humans.


very good.

last request:

String testMethod1(int i) {
String s =
switch (i) {
case 1 -> "one";
Copy link
Member

Choose a reason for hiding this comment

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

please make copy of correct to
...Correct.java files

see examples: https://github.com/checkstyle/checkstyle/tree/main/src/it/resources/com/google/checkstyle/test/chapter4formatting/rule4841indentation

in this case formatter will confirm that no violation from Checkstyle means no violation from java google formatter

Copy link
Contributor Author

@mohitsatr mohitsatr Mar 16, 2025

Choose a reason for hiding this comment

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

the file is already in the right location in resources-noncompilable section. trying to put it in https://github.com/checkstyle/checkstyle/tree/main/src/it/resources/com/google/checkstyle/test/chapter4formatting/rule4841indentation trigger IDEA errors about switch expression not being compartiable with java11.

Copy link
Member

@romani romani Mar 16, 2025

Choose a reason for hiding this comment

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

Keep same top folder noncopileable , but name file ..... Correct.java, to let CI run formatting on it.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

done

@mohitsatr mohitsatr force-pushed the switch-newline-indentation branch from 4aaed8d to eef0e7c Compare March 16, 2025 06:49
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.

thanks a lot for hard work on most complicated module in Checkstyle.

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

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.

Incorrect Indentation errors for expression switches with google_checks.xml
4 participants