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

Upgrade to golangci-lint 1.60.1 #548

Merged
merged 1 commit into from
Aug 23, 2024
Merged

Conversation

brandur
Copy link
Contributor

@brandur brandur commented Aug 22, 2024

Here, take the project to golangci-lint 1.60.1, which is now widely
available on Homebrew and elsewhere. It comes with a number of breaking
changes, so I figure it's not the worst idea to keep us on latest so
that future upgrades are less painful.

All breakages are related to overflow checking in gosec getting more
strict. The strictness is kind of useful in that it reminds us to check
bounds with something like min(limit, math.MaxInt32), but it can't
detect that a bounds check is done with min(...), which is kind of
annoying because it means you need a nolint tag on all of these.

Here, take the project to golangci-lint 1.60.1, which is now widely
available on Homebrew and elsewhere. It comes with a number of breaking
changes, so I figure it's not the worst idea to keep us on latest so
that future upgrades are less painful.

All breakages are related to overflow checking in `gosec` getting more
strict. The strictness is kind of useful in that it reminds us to check
bounds with something like `min(limit, math.MaxInt32)`, but it can't
detect that a bounds check is done with `min(...)`, which is kind of
annoying because it means you need a `nolint` tag on all of these.
@@ -327,7 +327,7 @@ func (p *JobListParams) First(count int) *JobListParams {
panic("count must be <= 10000")
}
paramsCopy := p.copy()
paramsCopy.paginationCount = int32(count)
paramsCopy.paginationCount = int32(count) //nolint:gosec
Copy link
Contributor Author

Choose a reason for hiding this comment

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

Bounds are checked a little higher up in this function.

@@ -35,6 +35,6 @@ func (p *QueueListParams) First(count int) *QueueListParams {
panic("count must be <= 10000")
}
result := p.copy()
result.paginationCount = int32(count)
result.paginationCount = int32(count) //nolint:gosec
Copy link
Contributor Author

Choose a reason for hiding this comment

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

Bounds are checked a little higher up in this function.

@brandur brandur requested a review from bgentry August 22, 2024 13:07
@ccoVeille
Copy link

ccoVeille commented Aug 22, 2024

A lot of nolint you add are caused by the gosec G115 that was added recently and that are currently being reviewed as it causes a lot of problems

securego/gosec#1149 (comment)
Or here
securego/gosec#1185

I would wait a few days if I was you

Side remark,I thought the gosec G115 was only added in golangci-lint 1.60.2

@brandur
Copy link
Contributor Author

brandur commented Aug 22, 2024

Ah interesting. I'm glad they're reconsidering. There's some overflow check logic that's clearly just wrong (e.g. uint8 -> int64).

@ccoVeille
Copy link

Ah interesting. I'm glad they're reconsidering. There's some overflow check logic that's clearly just wrong (e.g. uint8 -> int64).

This one was a bug

securego/gosec#1188

Length 2, so 8 was not caught

@brandur
Copy link
Contributor Author

brandur commented Aug 23, 2024

@bgentry Actually, can we move forward with this? Even if some of the gosec stuff is retooled, it's not like golangci-lint 1.60.2 is going to re-released. If they do anything, they'll roll forward to a new 1.60.3, at which point we can upgrade and remove some nolints if they're no longer necessary. This is basically blocking me from running lint locally because linting always fails on the top level package, so make lint can't descend into any of the submodules.

Copy link
Contributor

@bgentry bgentry left a comment

Choose a reason for hiding this comment

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

Sweet, good to go. I guess we'd better get the other projects upgrade too then.

@brandur
Copy link
Contributor Author

brandur commented Aug 23, 2024

ty.

Yeah I checked the other projects and a couple fixes will be required, but they're similar to these ones and should only take a couple min.

@brandur brandur merged commit 394aa68 into master Aug 23, 2024
14 checks passed
@brandur brandur deleted the brandur-golangci-lint-1-60-1 branch August 23, 2024 15:00
tigrato pushed a commit to gravitational/river that referenced this pull request Dec 18, 2024
Here, take the project to golangci-lint 1.60.1, which is now widely
available on Homebrew and elsewhere. It comes with a number of breaking
changes, so I figure it's not the worst idea to keep us on latest so
that future upgrades are less painful.

All breakages are related to overflow checking in `gosec` getting more
strict. The strictness is kind of useful in that it reminds us to check
bounds with something like `min(limit, math.MaxInt32)`, but it can't
detect that a bounds check is done with `min(...)`, which is kind of
annoying because it means you need a `nolint` tag on all of these.
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.

3 participants