ast_test.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. package xsql
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/emqx/kuiper/pkg/ast"
  6. "reflect"
  7. "testing"
  8. )
  9. func Test_MessageValTest(t *testing.T) {
  10. var tests = []struct {
  11. key string
  12. message Message
  13. exptV interface{}
  14. exptOk bool
  15. }{
  16. {
  17. key: "key1",
  18. message: Message{
  19. "key1": "val1",
  20. "key2": "val2",
  21. },
  22. exptV: "val1",
  23. exptOk: true,
  24. },
  25. {
  26. key: "key0",
  27. message: Message{
  28. "key1": "val1",
  29. "key2": "val2",
  30. },
  31. exptV: nil,
  32. exptOk: false,
  33. },
  34. {
  35. key: "key1",
  36. message: Message{
  37. "Key1": "val1",
  38. "key2": "val2",
  39. },
  40. exptV: "val1",
  41. exptOk: true,
  42. },
  43. {
  44. key: "key1" + ast.COLUMN_SEPARATOR + "subkey",
  45. message: Message{
  46. "Key1": "val1",
  47. "subkey": "subval",
  48. },
  49. exptV: "subval",
  50. exptOk: true,
  51. },
  52. {
  53. key: "192.168.0.1",
  54. message: Message{
  55. "Key1": "val1",
  56. "192.168.0.1": "000",
  57. },
  58. exptV: "000",
  59. exptOk: true,
  60. },
  61. {
  62. key: "parent" + ast.COLUMN_SEPARATOR + "child",
  63. message: Message{
  64. "key1": "val1",
  65. "child": "child_val",
  66. "parent.child": "demo",
  67. },
  68. exptV: "child_val",
  69. exptOk: true,
  70. },
  71. {
  72. key: "parent.child",
  73. message: Message{
  74. "key1": "val1",
  75. "child": "child_val",
  76. "parent.child": "demo",
  77. },
  78. exptV: "demo",
  79. exptOk: true,
  80. },
  81. {
  82. key: "parent.Child",
  83. message: Message{
  84. "key1": "val1",
  85. "child": "child_val",
  86. "parent.child": "demo",
  87. },
  88. exptV: "demo",
  89. exptOk: true,
  90. },
  91. }
  92. fmt.Printf("The test bucket size is %d.\n\n", len(tests))
  93. for i, tt := range tests {
  94. //fmt.Printf("Parsing SQL %q.\n", tt.s)
  95. v, ok := tt.message.Value(tt.key)
  96. if tt.exptOk != ok {
  97. t.Errorf("%d. error mismatch:\n exp=%t\n got=%t\n\n", i, tt.exptOk, ok)
  98. } else if tt.exptOk && !reflect.DeepEqual(tt.exptV, v) {
  99. t.Errorf("%d. \n\nstmt mismatch:\n\nexp=%#v\n\ngot=%#v\n\n", i, tt.exptV, v)
  100. }
  101. }
  102. }
  103. func Test_StreamFieldsMarshall(t *testing.T) {
  104. var tests = []struct {
  105. sf ast.StreamFields
  106. r string
  107. }{{
  108. sf: []ast.StreamField{
  109. {Name: "USERID", FieldType: &ast.BasicType{Type: ast.BIGINT}},
  110. {Name: "FIRST_NAME", FieldType: &ast.BasicType{Type: ast.STRINGS}},
  111. {Name: "LAST_NAME", FieldType: &ast.BasicType{Type: ast.STRINGS}},
  112. {Name: "NICKNAMES", FieldType: &ast.ArrayType{Type: ast.STRINGS}},
  113. {Name: "Gender", FieldType: &ast.BasicType{Type: ast.BOOLEAN}},
  114. {Name: "ADDRESS", FieldType: &ast.RecType{
  115. StreamFields: []ast.StreamField{
  116. {Name: "STREET_NAME", FieldType: &ast.BasicType{Type: ast.STRINGS}},
  117. {Name: "NUMBER", FieldType: &ast.BasicType{Type: ast.BIGINT}},
  118. },
  119. }},
  120. },
  121. r: `[{"FieldType":"bigint","Name":"USERID"},{"FieldType":"string","Name":"FIRST_NAME"},{"FieldType":"string","Name":"LAST_NAME"},{"FieldType":{"Type":"array","ElementType":"string"},"Name":"NICKNAMES"},{"FieldType":"boolean","Name":"Gender"},{"FieldType":{"Type":"struct","Fields":[{"FieldType":"string","Name":"STREET_NAME"},{"FieldType":"bigint","Name":"NUMBER"}]},"Name":"ADDRESS"}]`,
  122. }, {
  123. sf: []ast.StreamField{
  124. {Name: "USERID", FieldType: &ast.BasicType{Type: ast.BIGINT}},
  125. },
  126. r: `[{"FieldType":"bigint","Name":"USERID"}]`,
  127. }}
  128. fmt.Printf("The test bucket size is %d.\n\n", len(tests))
  129. for i, tt := range tests {
  130. r, err := json.Marshal(tt.sf)
  131. if err != nil {
  132. t.Errorf("%d. \nmarshall error: %v", i, err)
  133. t.FailNow()
  134. }
  135. result := string(r)
  136. if !reflect.DeepEqual(tt.r, result) {
  137. t.Errorf("%d. \nstmt mismatch:\n\nexp=%#v\n\ngot=%#v\n\n", i, tt.r, result)
  138. }
  139. }
  140. }