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

Preparing for v2.9.0 PR review feature release #182

Closed
4 tasks done
shenxianpeng opened this issue Jan 16, 2024 · 8 comments
Closed
4 tasks done

Preparing for v2.9.0 PR review feature release #182

shenxianpeng opened this issue Jan 16, 2024 · 8 comments
Labels
documentation Improvements or additions to documentation minor A minor version bump release To track release notes and update

Comments

@shenxianpeng
Copy link
Collaborator

shenxianpeng commented Jan 16, 2024

To release v2.9.0 PR review and other improvements need to complete the following tasks

@shenxianpeng shenxianpeng added the documentation Improvements or additions to documentation label Jan 16, 2024
@2bndy5
Copy link
Collaborator

2bndy5 commented Jan 16, 2024

from test PR 1

image
image

from test PR 2

image


There are other caveats to note about this feature

  1. The "GitHub Actions" bot may need to be allowed to approve PRs. This can be done in the repo settings (or in org settings if applicable). By default, the bot cannot approve PR changes, only request more changes. This will show as a logged warning if the given token isn't configured with the proper permissions.
  2. The feature is auto-disabled for
    • closed PRs
    • PRs marked as "draft"
    • push events
  3. Clang-tidy and clang-format suggestions are shown in 1 PR review.
    • Users are encouraged to choose either tidy-review or format-review. Enabling both will likely show duplicate or similar suggestions. Remember, clang-tidy can be configured to use the same style that clang-format accepts. There is no current implementation to combine suggestions from both tools (clang-tidy kind of does that anyway).
    • Each generated review is specific to the commit that triggered the CI.
    • Outdated reviews are dismissed but not marked as resolved. Also, the outdated review's summary comment is not automatically hidden. To reduce PR thread noise, users interaction is required. GitHub REST API does not provide a way to hide comments or mark review suggestions as resolved.
  4. If any suggestions did not fit within the PR diff, then the review's summary comment will indicate how many suggestions were left out. The full patch of suggestions is always included as a collapsed code block in the review summary comment. This isn't a problem we can fix. GitHub won't allow review comments/suggestions to target lines that are not shown in the PR diff.
    • Users are encouraged to set lines-changed-only to true. This will help us keep the suggestions limited to lines that are shown within the PR diff. However, there are still some cases where clang-format or clang-tidy will apply fixes to lines that are not within the diff. This can't be avoided because the --line-filter passed to the clang-tidy (and --lines passed to clang-format) only applies to analysis, not fixes.
    • Not every diagnostic from clang-tidy can be automatically fixed. Some diagnostics require user interaction/decision to properly address.
    • Some fixes provided might depend on what compiler is used. I have made it so clang-tidy takes advantage of any fixes provided by the compiler. Compilation errors may still prevent clang-tidy from reporting all concerns.

@shenxianpeng
Copy link
Collaborator Author

I created this ticket only to remember to do it. I'm sorry to let you spend time on this. I would not publish this feature very soon until I completed my other todos and then learn this feature.

I also apologize for bothering you this past weekend as I hadn't noticed your email before. All the best.

@2bndy5
Copy link
Collaborator

2bndy5 commented Jan 16, 2024

Its no problem. These short comments are a welcome escape from reality, for now.

@2bndy5
Copy link
Collaborator

2bndy5 commented Jan 16, 2024

As I typed that list of caveats, I thought that it might be desirable to have only the PR review's summary comment (with no suggestions shown in the diff). To do that, I would probably support a env var named CPP_LINTER_PR_REVIEW_NO_SUGGESTION. That should help reduce PR thread pollution.

@shenxianpeng shenxianpeng changed the title Add screenshot of new feature PR review to README Preparing for v2.9.0 PR review feature release Jan 29, 2024
@shenxianpeng

This comment was marked as duplicate.

@2bndy5
Copy link
Collaborator

2bndy5 commented Feb 11, 2024

picture of clang-tidy review comment(s):
image

@2bndy5
Copy link
Collaborator

2bndy5 commented Feb 11, 2024

picture of clang-format review summary comment:
image

I didn't include any suggested changes here because they are a bit misleading (although accurate and expected). A more accurate preview of the PR review feature using clang-format would be something like:
image

Not this (from same review)

image
image

@2bndy5
Copy link
Collaborator

2bndy5 commented Feb 11, 2024

Picture of approved review from both tools:
image

2bndy5 added a commit to cpp-linter/cpp-linter that referenced this issue Feb 12, 2024
This is mostly taken from a comment I posted in cpp-linter/cpp-linter-action#182 with some updates.

Also reviewed other changes about the generated cli_args.rst document.
2bndy5 added a commit to cpp-linter/cpp-linter that referenced this issue Feb 12, 2024
This is mostly taken from a comment I posted in cpp-linter/cpp-linter-action#182 with some updates.
Also reviewed other changes about the generated cli_args.rst document.
@2bndy5 2bndy5 closed this as completed Feb 14, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Improvements or additions to documentation minor A minor version bump release To track release notes and update
Projects
None yet
Development

No branches or pull requests

2 participants