errors_test.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. package errors_test
  2. import (
  3. "io"
  4. "testing"
  5. "v2ray.com/core/common/compare"
  6. . "v2ray.com/core/common/errors"
  7. "v2ray.com/core/common/log"
  8. . "v2ray.com/ext/assert"
  9. )
  10. func TestError(t *testing.T) {
  11. assert := With(t)
  12. err := New("TestError")
  13. assert(GetSeverity(err), Equals, log.Severity_Info)
  14. err = New("TestError2").Base(io.EOF)
  15. assert(GetSeverity(err), Equals, log.Severity_Info)
  16. err = New("TestError3").Base(io.EOF).AtWarning()
  17. assert(GetSeverity(err), Equals, log.Severity_Warning)
  18. err = New("TestError4").Base(io.EOF).AtWarning()
  19. err = New("TestError5").Base(err)
  20. assert(GetSeverity(err), Equals, log.Severity_Warning)
  21. assert(err.Error(), HasSubstring, "EOF")
  22. }
  23. func TestErrorMessage(t *testing.T) {
  24. data := []struct {
  25. err error
  26. msg string
  27. }{
  28. {
  29. err: New("a").Base(New("b")).Path("c", "d", "e"),
  30. msg: "c|d|e: a > b",
  31. },
  32. {
  33. err: New("a").Base(New("b").Path("c")).Path("d", "e"),
  34. msg: "d|e: a > c: b",
  35. },
  36. }
  37. for _, d := range data {
  38. if err := compare.StringEqualWithDetail(d.msg, d.err.Error()); err != nil {
  39. t.Fatal(err)
  40. }
  41. }
  42. }