writer_test.go 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. // Copyright 2020 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package dbutil
  5. import (
  6. "bytes"
  7. "testing"
  8. "github.com/stretchr/testify/assert"
  9. )
  10. func TestWriter_Print(t *testing.T) {
  11. tests := []struct {
  12. name string
  13. vs []interface{}
  14. expOutput string
  15. }{
  16. {
  17. name: "no values",
  18. },
  19. {
  20. name: "only one value",
  21. vs: []interface{}{"test"},
  22. expOutput: "test",
  23. },
  24. {
  25. name: "two values",
  26. vs: []interface{}{"test", "output"},
  27. expOutput: "testoutput",
  28. },
  29. {
  30. name: "sql",
  31. vs: []interface{}{"sql", "writer.go:65", "1ms", "SELECT * FROM users WHERE user_id = $1", []int{1}, 1},
  32. expOutput: "[sql] [writer.go:65] [1ms] SELECT * FROM users WHERE user_id = $1 [1] (1 rows affected)",
  33. },
  34. {
  35. name: "log",
  36. vs: []interface{}{"log", "writer.go:65", "something"},
  37. expOutput: "[log] [writer.go:65] something",
  38. },
  39. {
  40. name: "error",
  41. vs: []interface{}{"error", "writer.go:65", "something bad"},
  42. expOutput: "[err] [writer.go:65] something bad",
  43. },
  44. }
  45. for _, test := range tests {
  46. t.Run(test.name, func(t *testing.T) {
  47. var buf bytes.Buffer
  48. w := &Writer{Writer: &buf}
  49. w.Print(test.vs...)
  50. assert.Equal(t, test.expOutput, buf.String())
  51. })
  52. }
  53. }