Skip to content

Commit

Permalink
fix: Incorrect diagnostics summary count (#823)
Browse files Browse the repository at this point in the history
* fix: Incorrect diagnostics summary count
  • Loading branch information
roneli committed Jun 1, 2022
1 parent 67b0bd3 commit 58760b4
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 6 deletions.
17 changes: 11 additions & 6 deletions pkg/core/diagnostics.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
package core

import (
"strings"

"github.com/cloudquery/cloudquery/pkg/plugin"
"github.com/cloudquery/cq-provider-sdk/provider/diag"
"github.com/spf13/viper"
Expand Down Expand Up @@ -31,16 +33,19 @@ func SummarizeDiagnostics(diags diag.Diagnostics) DiagnosticsSummary {
}
for _, d := range diags {
summary.Total++
if _, ok := summary.BySeverity[d.Severity().String()]; ok {
summary.BySeverity[d.Severity().String()] = 1
severity := strings.ToLower(d.Severity().String())
dtype := strings.ToLower(d.Type().String())

if count, ok := summary.BySeverity[severity]; ok {
summary.BySeverity[severity] = count + 1
} else {
summary.BySeverity[d.Severity().String()]++
summary.BySeverity[severity] = 1
}

if _, ok := summary.ByType[d.Type().String()]; ok {
summary.ByType[d.Type().String()] = 1
if count, ok := summary.ByType[dtype]; ok {
summary.ByType[dtype] = count + 1
} else {
summary.ByType[d.Type().String()]++
summary.ByType[dtype] = 1
}
}
return summary
Expand Down
46 changes: 46 additions & 0 deletions pkg/core/diagnostics_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
package core

import (
"errors"
"testing"

"github.com/cloudquery/cq-provider-sdk/provider/diag"
"github.com/stretchr/testify/assert"
)

func Test_SummarizeDiagnostics(t *testing.T) {
testCases := []struct {
Name string
Diags diag.Diagnostics
ExpectedSummary DiagnosticsSummary
}{
{
Name: "simple",
Diags: diag.FromError(errors.New("1"), diag.USER),
ExpectedSummary: DiagnosticsSummary{Total: 1, ByType: map[string]int{"user": 1}, BySeverity: map[string]int{"error": 1}},
},

{
Name: "multi-severity",
Diags: diag.Diagnostics{}.Add(
diag.FromError(errors.New("1"), diag.USER),
diag.FromError(errors.New("1"), diag.USER, diag.WithSeverity(diag.WARNING)),
),
ExpectedSummary: DiagnosticsSummary{Total: 2, ByType: map[string]int{"user": 2}, BySeverity: map[string]int{"error": 1, "warning": 1}},
},
{
Name: "multi-type",
Diags: diag.Diagnostics{}.Add(
diag.FromError(errors.New("1"), diag.USER),
diag.FromError(errors.New("1"), diag.DATABASE),
diag.FromError(errors.New("1"), diag.USER, diag.WithSeverity(diag.WARNING)),
),
ExpectedSummary: DiagnosticsSummary{Total: 3, ByType: map[string]int{"user": 2, "database": 1}, BySeverity: map[string]int{"error": 2, "warning": 1}},
},
}
for _, tc := range testCases {
t.Run(tc.Name, func(t *testing.T) {
assert.Equal(t, tc.ExpectedSummary, SummarizeDiagnostics(tc.Diags))
})
}
}

0 comments on commit 58760b4

Please sign in to comment.