shared_test.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. package eventstream
  2. import (
  3. "bufio"
  4. "bytes"
  5. "encoding/json"
  6. "fmt"
  7. "io/ioutil"
  8. "path/filepath"
  9. "testing"
  10. )
  11. type testCase struct {
  12. Name string
  13. Encoded []byte
  14. Decoded decodedMessage
  15. }
  16. type testErrorCase struct {
  17. Name string
  18. Encoded []byte
  19. Err string
  20. }
  21. type rawTestCase struct {
  22. Name string
  23. Encoded, Decoded []byte
  24. }
  25. func readRawTestCases(root, class string) (map[string]rawTestCase, error) {
  26. encoded, err := readTests(filepath.Join(root, "encoded", class))
  27. if err != nil {
  28. return nil, err
  29. }
  30. decoded, err := readTests(filepath.Join(root, "decoded", class))
  31. if err != nil {
  32. return nil, err
  33. }
  34. if len(encoded) == 0 {
  35. return nil, fmt.Errorf("expect encoded cases, found none")
  36. }
  37. if len(encoded) != len(decoded) {
  38. return nil, fmt.Errorf("encoded and decoded sets different")
  39. }
  40. rawCases := map[string]rawTestCase{}
  41. for name, encData := range encoded {
  42. decData, ok := decoded[name]
  43. if !ok {
  44. return nil, fmt.Errorf("encoded %q case not found in decoded set", name)
  45. }
  46. rawCases[name] = rawTestCase{
  47. Name: name,
  48. Encoded: encData,
  49. Decoded: decData,
  50. }
  51. }
  52. return rawCases, nil
  53. }
  54. func readNegativeTests(root string) ([]testErrorCase, error) {
  55. rawCases, err := readRawTestCases(root, "negative")
  56. if err != nil {
  57. return nil, err
  58. }
  59. cases := make([]testErrorCase, 0, len(rawCases))
  60. for name, rawCase := range rawCases {
  61. cases = append(cases, testErrorCase{
  62. Name: name,
  63. Encoded: rawCase.Encoded,
  64. Err: string(rawCase.Decoded),
  65. })
  66. }
  67. return cases, nil
  68. }
  69. func readPositiveTests(root string) ([]testCase, error) {
  70. rawCases, err := readRawTestCases(root, "positive")
  71. if err != nil {
  72. return nil, err
  73. }
  74. cases := make([]testCase, 0, len(rawCases))
  75. for name, rawCase := range rawCases {
  76. var dec decodedMessage
  77. if err := json.Unmarshal(rawCase.Decoded, &dec); err != nil {
  78. return nil, fmt.Errorf("failed to decode %q, %v", name, err)
  79. }
  80. cases = append(cases, testCase{
  81. Name: name,
  82. Encoded: rawCase.Encoded,
  83. Decoded: dec,
  84. })
  85. }
  86. return cases, nil
  87. }
  88. func readTests(root string) (map[string][]byte, error) {
  89. items, err := ioutil.ReadDir(root)
  90. if err != nil {
  91. return nil, fmt.Errorf("failed to read test suite %q dirs, %v", root, err)
  92. }
  93. cases := map[string][]byte{}
  94. for _, item := range items {
  95. if item.IsDir() {
  96. continue
  97. }
  98. filename := filepath.Join(root, item.Name())
  99. data, err := ioutil.ReadFile(filename)
  100. if err != nil {
  101. return nil, fmt.Errorf("failed to read test_data file %q, %v", filename, err)
  102. }
  103. cases[item.Name()] = data
  104. }
  105. return cases, nil
  106. }
  107. func compareLines(t *testing.T, a, b []byte) bool {
  108. as := bufio.NewScanner(bytes.NewBuffer(a))
  109. bs := bufio.NewScanner(bytes.NewBuffer(b))
  110. var failed bool
  111. for {
  112. if ab, bb := as.Scan(), bs.Scan(); ab != bb {
  113. t.Errorf("expect a & b to have same number of lines")
  114. return false
  115. } else if !ab {
  116. break
  117. }
  118. if v1, v2 := as.Text(), bs.Text(); v1 != v2 {
  119. t.Errorf("expect %q to be %q", v1, v2)
  120. failed = true
  121. }
  122. }
  123. return !failed
  124. }