parse_logs_test.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536
  1. package client
  2. import (
  3. "reflect"
  4. "testing"
  5. "github.com/pkg/errors"
  6. )
  7. func TestParseLogDetails(t *testing.T) {
  8. testCases := []struct {
  9. line string
  10. expected map[string]string
  11. err error
  12. }{
  13. {"key=value", map[string]string{"key": "value"}, nil},
  14. {"key1=value1,key2=value2", map[string]string{"key1": "value1", "key2": "value2"}, nil},
  15. {"key+with+spaces=value%3Dequals,asdf%2C=", map[string]string{"key with spaces": "value=equals", "asdf,": ""}, nil},
  16. {"key=,=nothing", map[string]string{"key": "", "": "nothing"}, nil},
  17. {"=", map[string]string{"": ""}, nil},
  18. {"errors", nil, errors.New("invalid details format")},
  19. }
  20. for _, tc := range testCases {
  21. tc := tc // capture range variable
  22. t.Run(tc.line, func(t *testing.T) {
  23. t.Parallel()
  24. res, err := ParseLogDetails(tc.line)
  25. if err != nil && (err.Error() != tc.err.Error()) {
  26. t.Fatalf("unexpected error parsing logs:\nExpected:\n\t%v\nActual:\n\t%v", tc.err, err)
  27. }
  28. if !reflect.DeepEqual(tc.expected, res) {
  29. t.Errorf("result does not match expected:\nExpected:\n\t%#v\nActual:\n\t%#v", tc.expected, res)
  30. }
  31. })
  32. }
  33. }