```
service/logs/parse_logs_test.go:26:35: Using the variable on range scope `testcase` in function literal (scopelint)
actual, err := ParseLogDetails(testcase.line)
^
service/logs/parse_logs_test.go:27:7: Using the variable on range scope `testcase` in function literal (scopelint)
if testcase.err != nil {
^
service/logs/parse_logs_test.go:28:26: Using the variable on range scope `testcase` in function literal (scopelint)
assert.Error(t, err, testcase.err.Error())
^
```
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
36 lines
1004 B
Go
36 lines
1004 B
Go
package logs
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/pkg/errors"
|
|
"gotest.tools/assert"
|
|
is "gotest.tools/assert/cmp"
|
|
)
|
|
|
|
func TestParseLogDetails(t *testing.T) {
|
|
testCases := []struct {
|
|
line string
|
|
expected map[string]string
|
|
err error
|
|
}{
|
|
{"key=value", map[string]string{"key": "value"}, nil},
|
|
{"key1=value1,key2=value2", map[string]string{"key1": "value1", "key2": "value2"}, nil},
|
|
{"key+with+spaces=value%3Dequals,asdf%2C=", map[string]string{"key with spaces": "value=equals", "asdf,": ""}, nil},
|
|
{"key=,=nothing", map[string]string{"key": "", "": "nothing"}, nil},
|
|
{"=", map[string]string{"": ""}, nil},
|
|
{"errors", nil, errors.New("invalid details format")},
|
|
}
|
|
for _, testcase := range testCases {
|
|
testcase := testcase
|
|
t.Run(testcase.line, func(t *testing.T) {
|
|
actual, err := ParseLogDetails(testcase.line)
|
|
if testcase.err != nil {
|
|
assert.Error(t, err, testcase.err.Error())
|
|
return
|
|
}
|
|
assert.Check(t, is.DeepEqual(testcase.expected, actual))
|
|
})
|
|
}
|
|
}
|