registry_test.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. // Copyright 2022 EMQ Technologies Co., Ltd.
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package schema
  15. import (
  16. "net/http"
  17. "net/http/httptest"
  18. "os"
  19. "path/filepath"
  20. "reflect"
  21. "testing"
  22. "github.com/lf-edge/ekuiper/internal/conf"
  23. "github.com/lf-edge/ekuiper/internal/testx"
  24. )
  25. func TestRegistry(t *testing.T) {
  26. testx.InitEnv()
  27. // Move test schema file to etc dir
  28. etcDir, err := conf.GetDataLoc()
  29. if err != nil {
  30. t.Fatal(err)
  31. }
  32. etcDir = filepath.Join(etcDir, "schemas", "protobuf")
  33. err = os.MkdirAll(etcDir, os.ModePerm)
  34. if err != nil {
  35. t.Fatal(err)
  36. }
  37. //Copy init.proto
  38. bytesRead, err := os.ReadFile("test/init.proto")
  39. if err != nil {
  40. t.Fatal(err)
  41. }
  42. err = os.WriteFile(filepath.Join(etcDir, "init.proto"), bytesRead, 0755)
  43. if err != nil {
  44. t.Fatal(err)
  45. }
  46. defer func() {
  47. err = os.RemoveAll(etcDir)
  48. if err != nil {
  49. t.Fatal(err)
  50. }
  51. }()
  52. err = InitRegistry()
  53. if err != nil {
  54. t.Errorf("InitRegistry error: %v", err)
  55. return
  56. }
  57. s := httptest.NewServer(
  58. http.FileServer(http.Dir("test")),
  59. )
  60. defer s.Close()
  61. endpoint := s.URL
  62. // Create 1 by file
  63. schema1 := &Info{
  64. Name: "test1",
  65. Type: "protobuf",
  66. FilePath: endpoint + "/test1.proto",
  67. }
  68. err = Register(schema1)
  69. if err != nil {
  70. t.Errorf("Register schema1 error: %v", err)
  71. return
  72. }
  73. // Get 1
  74. expectedSchema := &Info{
  75. Type: "protobuf",
  76. Name: "test1",
  77. Content: "syntax = \"proto2\";message Person {required string name = 1;optional int32 id = 2;optional string email = 3;repeated ListOfDoubles code = 4;}message ListOfDoubles {repeated double doubles=1;}",
  78. FilePath: filepath.Join(etcDir, "test1.proto"),
  79. }
  80. gottenSchema, err := GetSchema("protobuf", "test1")
  81. if !reflect.DeepEqual(gottenSchema, expectedSchema) {
  82. t.Errorf("Get test1 unmatch: Expect\n%v\nbut got\n%v", *expectedSchema, *gottenSchema)
  83. return
  84. }
  85. // Create 2 by content
  86. schema2 := &Info{
  87. Name: "test2",
  88. Type: "protobuf",
  89. Content: "message Book{\n required string name = 1;}",
  90. }
  91. err = Register(schema2)
  92. if err != nil {
  93. t.Errorf("Register schema2 error: %v", err)
  94. return
  95. }
  96. // Update 2 by file
  97. updatedSchema2 := &Info{
  98. Name: "test2",
  99. Type: "protobuf",
  100. FilePath: endpoint + "/test2.proto",
  101. }
  102. err = CreateOrUpdateSchema(updatedSchema2)
  103. if err != nil {
  104. t.Errorf("Update Schema2 error: %v", err)
  105. return
  106. }
  107. // List & check file
  108. regSchemas, err := GetAllForType("protobuf")
  109. expectedSchemas := []string{
  110. "init", "test1", "test2",
  111. }
  112. if !reflect.DeepEqual(len(regSchemas), len(expectedSchemas)) {
  113. t.Errorf("Expect\n%v\nbut got\n%v", expectedSchemas, regSchemas)
  114. return
  115. }
  116. checkFile(etcDir, expectedSchemas, t)
  117. // Delete 2
  118. err = DeleteSchema("protobuf", "test2")
  119. if err != nil {
  120. t.Errorf("Delete Schema2 error: %v", err)
  121. return
  122. }
  123. // Update 1 by content
  124. updatedSchema1 := &Info{
  125. Name: "test1",
  126. Type: "protobuf",
  127. Content: "message Person{required string name = 1;required int32 id = 2;optional string email = 3;}",
  128. }
  129. err = CreateOrUpdateSchema(updatedSchema1)
  130. if err != nil {
  131. t.Errorf("Update Schema1 error: %v", err)
  132. return
  133. }
  134. // List & check file
  135. regSchemas, err = GetAllForType("protobuf")
  136. expectedSchemas = []string{
  137. "init", "test1",
  138. }
  139. if !reflect.DeepEqual(len(regSchemas), len(expectedSchemas)) {
  140. t.Errorf("Expect\n%v\nbut got\n%v", expectedSchemas, regSchemas)
  141. return
  142. }
  143. checkFile(etcDir, expectedSchemas, t)
  144. // Delete 1
  145. err = DeleteSchema("protobuf", "test1")
  146. if err != nil {
  147. t.Errorf("Delete Schema1 error: %v", err)
  148. return
  149. }
  150. // List & check file
  151. regSchemas, err = GetAllForType("protobuf")
  152. expectedSchemas = []string{
  153. "init",
  154. }
  155. if !reflect.DeepEqual(regSchemas, expectedSchemas) {
  156. t.Errorf("Expect\n%v\nbut got\n%v", expectedSchemas, regSchemas)
  157. return
  158. }
  159. checkFile(etcDir, expectedSchemas, t)
  160. }
  161. func checkFile(etcDir string, schemas []string, t *testing.T) {
  162. files, err := os.ReadDir(etcDir)
  163. if err != nil {
  164. t.Fatal(err)
  165. }
  166. if len(files) != len(schemas) {
  167. t.Errorf("Expect %d files but got %d", len(schemas), len(files))
  168. return
  169. }
  170. for _, file := range files {
  171. fileName := filepath.Base(file.Name())
  172. found := false
  173. for _, schema := range schemas {
  174. if fileName == schema+".proto" {
  175. found = true
  176. break
  177. }
  178. }
  179. if !found {
  180. t.Errorf("Expect %s but got %s", schemas, fileName)
  181. return
  182. }
  183. }
  184. }