gordonklaus/ineffassign

ineffassign flagged on `err` assignment in for-loop.

Opened this issue · 3 comments

I have the following snippet from some code I've written, where I've marked what I believe is a false-positive in-line. The context here is retrying calls with an AWS SDK.

result, err := AssumeRole(roleSessionName, nextClient, roleArn)
retryCount := 0
for err != nil {
	if retryCount < assumeRoleMaxRetries {
		time.Sleep(assumeRoleRetryBackoff)
		nextClient, err = createAssumeRoleSequenceClient(stsClientProviderFunc, lastCredentials, proxyURL)
		result, err = AssumeRole(roleSessionName, nextClient, roleArn) <-- this line, "err" is flagged even though it determines if we keep looping
		retryCount++
	} else {
		return aws.Credentials{}, fmt.Errorf("failed to assume role %v: %w", roleArn, err)
	}
}

For full context, here's a PR I've written that is being held up by this flag. I've linked directly to the line: https://github.com/openshift/backplane-cli/pull/235/files?diff=split&w=0#diff-d6d924fed86757f7dd2d61b335c33abce0fcbbd679ecde5a0c69019e4032412eR129

What's more odd is I've tried to reproduce this in a more simple manner and cannot seem to. For example, this does not get flagged:

import (
	"errors"
	"fmt"
)

var retryCount = 0

func main() {
	result, err := doThing()
	for err != nil {
		retryCount++
		if retryCount < 5 {
			fmt.Println("retrying")
			result, err = doThing()
		} else {
			return
		}
	}
	fmt.Println(result)
}

func doThing() (string, error) {
	if retryCount < 4 {
		return "", errors.New("error")
	} else {
		return "success", nil
	}
}

It's totally possible I'm misunderstanding something here, but to me this appears to be a false positive.

And of course... immediately as I posted this I realized my problem 😅 . Closing.

One quick question - I would've expected the previous line to be the one getting flagged, as that's the err assignment getting wiped out. Is that a potential bug?

Yes, in your original example I would expect the first assignment to err in the loop to be flagged. Can you provide a self-contained example where it is not?