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

🌱 Bump golangci-lint to v1.47.1 #6943

Closed

Conversation

sbueringer
Copy link
Member

@sbueringer sbueringer commented Jul 18, 2022

What this PR does / why we need it:

Which issue(s) this PR fixes (optional, in fixes #<issue number>(, fixes #<issue_number>, ...) format, will close the issue(s) when PR gets merged):
Fixes #6350

@k8s-ci-robot k8s-ci-robot added the cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. label Jul 18, 2022
@sbueringer
Copy link
Member Author

cc @killianmuldoon Finally :)

@k8s-ci-robot k8s-ci-robot added the size/S Denotes a PR that changes 10-29 lines, ignoring generated files. label Jul 18, 2022
@killianmuldoon
Copy link
Contributor

😆 you beat me to it - was just running it locally to make sure the gci fix is working.

@sbueringer sbueringer changed the title Bump golangci-lint to v1.47.0 🌱 Bump golangci-lint to v1.47.0 Jul 18, 2022
@sbueringer
Copy link
Member Author

sbueringer commented Jul 18, 2022

laughing you beat me to it - was just running it locally to make sure the gci fix is working.

I didn't find a better way around the gci findings in condition_types.go. If you have a good idea.. :)

@stmcginnis
Copy link
Contributor

/lgtm

@k8s-ci-robot k8s-ci-robot added the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Jul 18, 2022
@chrischdi
Copy link
Member

/lgtm

🎉

Copy link
Contributor

@killianmuldoon killianmuldoon left a comment

Choose a reason for hiding this comment

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

/lgtm

I can't figure out why gci is dropping those comments, but I'm happy with the version for now until we get to the root cause. This change has been a long time coming 🙂

@sbueringer
Copy link
Member Author

I dropped the 1.24 issue from "Fixes". There's another PR to bump to go 1.18

@sbueringer sbueringer force-pushed the pr-bump-golangci-lint branch from 20613de to ab0e616 Compare July 19, 2022 05:17
@k8s-ci-robot k8s-ci-robot removed the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Jul 19, 2022
@sbueringer
Copy link
Member Author

Looks like we're running into: golangci/golangci-lint-action#519

@sbueringer sbueringer force-pushed the pr-bump-golangci-lint branch from ab0e616 to 8373d59 Compare July 19, 2022 05:31
@oscr
Copy link
Contributor

oscr commented Jul 19, 2022

@sbueringer @killianmuldoon This issue is solved in gci v0.4.3. I just tried it. So I think this is a good solution until the next golangci-lint version is released daixiang0/gci#82

@sbueringer sbueringer force-pushed the pr-bump-golangci-lint branch from 8373d59 to 5d60581 Compare July 19, 2022 07:18
@sbueringer
Copy link
Member Author

@sbueringer @killianmuldoon This issue is solved in gci v0.4.3. I just tried it. So I think this is a good solution until the next golangci-lint version is released daixiang0/gci#82

Thank you very much. I added a corresponding TODO.

@oscr
Copy link
Contributor

oscr commented Jul 19, 2022

gci v0.4.3 is now merged into golangci-lint. So next release of golangci-lint should fix this.

golangci/golangci-lint#2992

@killianmuldoon
Copy link
Contributor

1.47.1 is out - it bumps the gci version and should have the fix: https://github.com/golangci/golangci-lint/releases/tag/v1.47.1

@oscr
Copy link
Contributor

oscr commented Jul 19, 2022

There is a new release of golangci-lint now with gci 0.4.3

https://github.com/golangci/golangci-lint/releases/tag/v1.47.1

@sbueringer sbueringer force-pushed the pr-bump-golangci-lint branch 2 times, most recently from 8a524c8 to 5eaec8a Compare July 19, 2022 13:20
@chrischdi
Copy link
Member

/retitle 🌱 Bump golangci-lint to v1.47.1

@k8s-ci-robot k8s-ci-robot changed the title 🌱 Bump golangci-lint to v1.47.0 🌱 Bump golangci-lint to v1.47.1 Jul 19, 2022
@killianmuldoon
Copy link
Contributor

/lgtm

@k8s-ci-robot k8s-ci-robot added the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Jul 19, 2022
@killianmuldoon
Copy link
Contributor

/hold

We need to investigate why the linter is taking much longer to run with this version.

@k8s-ci-robot k8s-ci-robot added the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Jul 19, 2022
@sbueringer
Copy link
Member Author

I'm on PTO starting tomorrow. Thx @killianmuldoon for taking over this PR!

@sbueringer sbueringer force-pushed the pr-bump-golangci-lint branch from 5eaec8a to 21ea504 Compare July 19, 2022 13:46
@k8s-ci-robot k8s-ci-robot removed the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Jul 19, 2022
@k8s-ci-robot
Copy link
Contributor

New changes are detected. LGTM label has been removed.

@killianmuldoon
Copy link
Contributor

Issue for the long runtime is open at the golangci-lint repo golangci/golangci-lint#2997

I'm trying to pinpoint which linter is responsible.

@Prajyot-Parab
Copy link
Contributor

Possible way to fix - golangci/golangci-lint#2997 (comment)

@killianmuldoon killianmuldoon force-pushed the pr-bump-golangci-lint branch from 21ea504 to 4e0e3e2 Compare July 20, 2022 10:38
@k8s-ci-robot
Copy link
Contributor

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by:
Once this PR has been reviewed and has the lgtm label, please ask for approval from sbueringer by writing /assign @sbueringer in a comment. For more information see:The Kubernetes Code Review Process.

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@killianmuldoon
Copy link
Contributor

Thanks @Prajyot-Parab I tried this locally, it seemed to work once (but I was running golangci-lint through the debugger) but I couldn't reproduce with the flow being used in CAPI. I've bumped the version here to see if it works in CI while I try to debug.

@killianmuldoon
Copy link
Contributor

The issue appears to be with revive - mgechev/revive#713 there's an issue up on the repo there so we'll wait and see how long it takes for a fix and a release of golangci-lint that includes it.

IMO it doesn't make sense to remove revive as it's a pretty big linter so re-enabling it in six months would likely result in a large diff. One compromise would be to update golangci-lint, disable revive and then add revive with a working, appropriate version as a separate job in our lint flow. That's not an elegant solution 😆 so I think we can afford to take a wait and see approach, figure out how long the release might take and decide in a couple of weeks whether we need to take action.

@ldez
Copy link

ldez commented Jul 20, 2022

@killianmuldoon there is another workaround: disable the following revive rules: context-keys-type, errorf, modifies-value-receiver, range-val-address, string-of-int, time-equal, time-naming, unexported-return, unhandled-error, var-declaration.

@killianmuldoon killianmuldoon force-pushed the pr-bump-golangci-lint branch from 4e0e3e2 to 1a1fedf Compare July 20, 2022 19:32
@k8s-ci-robot k8s-ci-robot added size/M Denotes a PR that changes 30-99 lines, ignoring generated files. and removed size/S Denotes a PR that changes 10-29 lines, ignoring generated files. labels Jul 20, 2022
@@ -43,6 +43,28 @@ linters:
- whitespace

linters-settings:
revive:
Copy link
Member

Choose a reason for hiding this comment

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

Since the slow performance of revive is tracked as an issue, maybe add a comment to re-enable them once a future release improves performance?

@oscr
Copy link
Contributor

oscr commented Jul 21, 2022

New release out!

https://github.com/golangci/golangci-lint/releases/tag/v1.47.2 with change log: revive: ignore slow rules (https://github.com/golangci/golangci-lint/pull/2999)

@killianmuldoon
Copy link
Contributor

My preference is to keep things really explicit and roll back the exceptions sooner rather than later. My preference is either:

  1. Don't update for now and see if the bug can be fixed in the next couple of weeks
  2. Update but keep the exclusions in the config so we can roll them back once a fix is out

@fabriziopandini WDYT?

@killianmuldoon
Copy link
Contributor

/close
Let's deduplicate this work and continue to track it in #6737 as we try to find a solution to the linting issue.

@k8s-ci-robot
Copy link
Contributor

@killianmuldoon: Closed this PR.

In response to this:

/close
Let's deduplicate this work and continue to track it in #6737 as we try to find a solution to the linting issue.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. size/M Denotes a PR that changes 30-99 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

gci linter no longer autofixing import orders
9 participants