fix: typecheck issues should never be ignored (#4870)
This commit is contained in:
parent
597b32a3de
commit
e95ac1b659
@ -63,11 +63,6 @@ func (p *AutogeneratedExclude) Process(issues []result.Issue) ([]result.Issue, e
|
|||||||
func (*AutogeneratedExclude) Finish() {}
|
func (*AutogeneratedExclude) Finish() {}
|
||||||
|
|
||||||
func (p *AutogeneratedExclude) shouldPassIssue(issue *result.Issue) (bool, error) {
|
func (p *AutogeneratedExclude) shouldPassIssue(issue *result.Issue) (bool, error) {
|
||||||
if issue.FromLinter == typeCheckName {
|
|
||||||
// don't hide typechecking errors in generated files: users expect to see why the project isn't compiling
|
|
||||||
return true, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
if filepath.Base(issue.FilePath()) == "go.mod" {
|
if filepath.Base(issue.FilePath()) == "go.mod" {
|
||||||
return true, nil
|
return true, nil
|
||||||
}
|
}
|
||||||
|
@ -158,14 +158,6 @@ func Test_shouldPassIssue(t *testing.T) {
|
|||||||
issue *result.Issue
|
issue *result.Issue
|
||||||
assert assert.BoolAssertionFunc
|
assert assert.BoolAssertionFunc
|
||||||
}{
|
}{
|
||||||
{
|
|
||||||
desc: "typecheck issue",
|
|
||||||
mode: AutogeneratedModeLax,
|
|
||||||
issue: &result.Issue{
|
|
||||||
FromLinter: "typecheck",
|
|
||||||
},
|
|
||||||
assert: assert.True,
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
desc: "lax ",
|
desc: "lax ",
|
||||||
mode: AutogeneratedModeLax,
|
mode: AutogeneratedModeLax,
|
||||||
|
@ -22,7 +22,7 @@ func (InvalidIssue) Name() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (p InvalidIssue) Process(issues []result.Issue) ([]result.Issue, error) {
|
func (p InvalidIssue) Process(issues []result.Issue) ([]result.Issue, error) {
|
||||||
tcIssues := filterIssues(issues, func(issue *result.Issue) bool {
|
tcIssues := filterIssuesUnsafe(issues, func(issue *result.Issue) bool {
|
||||||
return issue.FromLinter == typeCheckName
|
return issue.FromLinter == typeCheckName
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -7,6 +7,23 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func filterIssues(issues []result.Issue, filter func(issue *result.Issue) bool) []result.Issue {
|
func filterIssues(issues []result.Issue, filter func(issue *result.Issue) bool) []result.Issue {
|
||||||
|
retIssues := make([]result.Issue, 0, len(issues))
|
||||||
|
for i := range issues {
|
||||||
|
if issues[i].FromLinter == typeCheckName {
|
||||||
|
// don't hide typechecking errors in generated files: users expect to see why the project isn't compiling
|
||||||
|
retIssues = append(retIssues, issues[i])
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if filter(&issues[i]) {
|
||||||
|
retIssues = append(retIssues, issues[i])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return retIssues
|
||||||
|
}
|
||||||
|
|
||||||
|
func filterIssuesUnsafe(issues []result.Issue, filter func(issue *result.Issue) bool) []result.Issue {
|
||||||
retIssues := make([]result.Issue, 0, len(issues))
|
retIssues := make([]result.Issue, 0, len(issues))
|
||||||
for i := range issues {
|
for i := range issues {
|
||||||
if filter(&issues[i]) {
|
if filter(&issues[i]) {
|
||||||
@ -20,6 +37,12 @@ func filterIssues(issues []result.Issue, filter func(issue *result.Issue) bool)
|
|||||||
func filterIssuesErr(issues []result.Issue, filter func(issue *result.Issue) (bool, error)) ([]result.Issue, error) {
|
func filterIssuesErr(issues []result.Issue, filter func(issue *result.Issue) (bool, error)) ([]result.Issue, error) {
|
||||||
retIssues := make([]result.Issue, 0, len(issues))
|
retIssues := make([]result.Issue, 0, len(issues))
|
||||||
for i := range issues {
|
for i := range issues {
|
||||||
|
if issues[i].FromLinter == typeCheckName {
|
||||||
|
// don't hide typechecking errors in generated files: users expect to see why the project isn't compiling
|
||||||
|
retIssues = append(retIssues, issues[i])
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
ok, err := filter(&issues[i])
|
ok, err := filter(&issues[i])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, fmt.Errorf("can't filter issue %#v: %w", issues[i], err)
|
return nil, fmt.Errorf("can't filter issue %#v: %w", issues[i], err)
|
||||||
|
@ -33,7 +33,7 @@ func (p *MaxFromLinter) Process(issues []result.Issue) ([]result.Issue, error) {
|
|||||||
return issues, nil
|
return issues, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
return filterIssues(issues, func(issue *result.Issue) bool {
|
return filterIssuesUnsafe(issues, func(issue *result.Issue) bool {
|
||||||
if issue.Replacement != nil && p.cfg.Issues.NeedFix {
|
if issue.Replacement != nil && p.cfg.Issues.NeedFix {
|
||||||
// we need to fix all issues at once => we need to return all of them
|
// we need to fix all issues at once => we need to return all of them
|
||||||
return true
|
return true
|
||||||
|
@ -33,7 +33,7 @@ func (*MaxPerFileFromLinter) Name() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (p *MaxPerFileFromLinter) Process(issues []result.Issue) ([]result.Issue, error) {
|
func (p *MaxPerFileFromLinter) Process(issues []result.Issue) ([]result.Issue, error) {
|
||||||
return filterIssues(issues, func(issue *result.Issue) bool {
|
return filterIssuesUnsafe(issues, func(issue *result.Issue) bool {
|
||||||
limit := p.maxPerFileFromLinterConfig[issue.FromLinter]
|
limit := p.maxPerFileFromLinterConfig[issue.FromLinter]
|
||||||
if limit == 0 {
|
if limit == 0 {
|
||||||
return true
|
return true
|
||||||
|
@ -35,7 +35,7 @@ func (p *MaxSameIssues) Process(issues []result.Issue) ([]result.Issue, error) {
|
|||||||
return issues, nil
|
return issues, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
return filterIssues(issues, func(issue *result.Issue) bool {
|
return filterIssuesUnsafe(issues, func(issue *result.Issue) bool {
|
||||||
if issue.Replacement != nil && p.cfg.Issues.NeedFix {
|
if issue.Replacement != nil && p.cfg.Issues.NeedFix {
|
||||||
// we need to fix all issues at once => we need to return all of them
|
// we need to fix all issues at once => we need to return all of them
|
||||||
return true
|
return true
|
||||||
|
@ -30,7 +30,7 @@ func (p *UniqByLine) Process(issues []result.Issue) ([]result.Issue, error) {
|
|||||||
return issues, nil
|
return issues, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
return filterIssues(issues, p.shouldPassIssue), nil
|
return filterIssuesUnsafe(issues, p.shouldPassIssue), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (*UniqByLine) Finish() {}
|
func (*UniqByLine) Finish() {}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user