registry_test.go 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303
  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 TestProtoRegistry(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, 0o755)
  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. SoPath: endpoint + "/fake.so",
  102. }
  103. err = CreateOrUpdateSchema(updatedSchema2)
  104. if err != nil {
  105. t.Errorf("Update Schema2 error: %v", err)
  106. return
  107. }
  108. // List & check file
  109. regSchemas, err := GetAllForType("protobuf")
  110. expectedSchemas := []string{
  111. "init", "test1", "test2",
  112. }
  113. if !reflect.DeepEqual(len(regSchemas), len(expectedSchemas)) {
  114. t.Errorf("Expect\n%v\nbut got\n%v", expectedSchemas, regSchemas)
  115. return
  116. }
  117. expectedFiles := []string{
  118. "init.proto", "test1.proto", "test2.proto", "test2.so",
  119. }
  120. checkFile(etcDir, expectedFiles, t)
  121. // Delete 2
  122. err = DeleteSchema("protobuf", "test2")
  123. if err != nil {
  124. t.Errorf("Delete Schema2 error: %v", err)
  125. return
  126. }
  127. // Update 1 by content
  128. updatedSchema1 := &Info{
  129. Name: "test1",
  130. Type: "protobuf",
  131. Content: "message Person{required string name = 1;required int32 id = 2;optional string email = 3;}",
  132. }
  133. err = CreateOrUpdateSchema(updatedSchema1)
  134. if err != nil {
  135. t.Errorf("Update Schema1 error: %v", err)
  136. return
  137. }
  138. // List & check file
  139. regSchemas, err = GetAllForType("protobuf")
  140. expectedSchemas = []string{
  141. "init", "test1",
  142. }
  143. if !reflect.DeepEqual(len(regSchemas), len(expectedSchemas)) {
  144. t.Errorf("Expect\n%v\nbut got\n%v", expectedSchemas, regSchemas)
  145. return
  146. }
  147. expectedFiles = []string{
  148. "init.proto", "test1.proto",
  149. }
  150. checkFile(etcDir, expectedFiles, t)
  151. // Delete 1
  152. err = DeleteSchema("protobuf", "test1")
  153. if err != nil {
  154. t.Errorf("Delete Schema1 error: %v", err)
  155. return
  156. }
  157. // List & check file
  158. regSchemas, err = GetAllForType("protobuf")
  159. expectedSchemas = []string{
  160. "init",
  161. }
  162. if !reflect.DeepEqual(regSchemas, expectedSchemas) {
  163. t.Errorf("Expect\n%v\nbut got\n%v", expectedSchemas, regSchemas)
  164. return
  165. }
  166. expectedFiles = []string{
  167. "init.proto",
  168. }
  169. checkFile(etcDir, expectedFiles, t)
  170. }
  171. func TestCustomRegistry(t *testing.T) {
  172. testx.InitEnv()
  173. // Move test schema file to etc dir
  174. etcDir, err := conf.GetDataLoc()
  175. if err != nil {
  176. t.Fatal(err)
  177. }
  178. etcDir = filepath.Join(etcDir, "schemas", "custom")
  179. err = os.MkdirAll(etcDir, os.ModePerm)
  180. if err != nil {
  181. t.Fatal(err)
  182. }
  183. // Copy fake.so as init
  184. bytesRead, err := os.ReadFile("test/fake.so")
  185. if err != nil {
  186. t.Fatal(err)
  187. }
  188. err = os.WriteFile(filepath.Join(etcDir, "init.so"), bytesRead, 0o755)
  189. if err != nil {
  190. t.Fatal(err)
  191. }
  192. defer func() {
  193. err = os.RemoveAll(etcDir)
  194. if err != nil {
  195. t.Fatal(err)
  196. }
  197. }()
  198. err = InitRegistry()
  199. if err != nil {
  200. t.Errorf("InitRegistry error: %v", err)
  201. return
  202. }
  203. s := httptest.NewServer(
  204. http.FileServer(http.Dir("test")),
  205. )
  206. defer s.Close()
  207. endpoint := s.URL
  208. // Create 1 by file
  209. schema1 := &Info{
  210. Name: "test1",
  211. Type: "custom",
  212. SoPath: endpoint + "/fake.so",
  213. }
  214. err = Register(schema1)
  215. if err != nil {
  216. t.Errorf("Register schema1 error: %v", err)
  217. return
  218. }
  219. // Get 1
  220. expectedSchema := &Info{
  221. Type: "custom",
  222. Name: "test1",
  223. SoPath: filepath.Join(etcDir, "test1.so"),
  224. }
  225. gottenSchema, err := GetSchema("custom", "test1")
  226. if !reflect.DeepEqual(gottenSchema, expectedSchema) {
  227. t.Errorf("Get test1 unmatch: Expect\n%v\nbut got\n%v", *expectedSchema, *gottenSchema)
  228. return
  229. }
  230. // Update 1 by file
  231. updatedSchema2 := &Info{
  232. Name: "test1",
  233. Type: "custom",
  234. SoPath: endpoint + "/fake.so",
  235. }
  236. err = CreateOrUpdateSchema(updatedSchema2)
  237. if err != nil {
  238. t.Errorf("Update Schema2 error: %v", err)
  239. return
  240. }
  241. // List & check file
  242. regSchemas, err := GetAllForType("custom")
  243. expectedSchemas := []string{
  244. "init", "test1",
  245. }
  246. if !reflect.DeepEqual(len(regSchemas), len(expectedSchemas)) {
  247. t.Errorf("Expect\n%v\nbut got\n%v", expectedSchemas, regSchemas)
  248. return
  249. }
  250. expectedFiles := []string{
  251. "init.so", "test1.so",
  252. }
  253. checkFile(etcDir, expectedFiles, t)
  254. // Delete 2
  255. err = DeleteSchema("custom", "init")
  256. if err != nil {
  257. t.Errorf("Delete Schema2 error: %v", err)
  258. return
  259. }
  260. // List & check file
  261. regSchemas, err = GetAllForType("custom")
  262. expectedSchemas = []string{
  263. "test1",
  264. }
  265. if !reflect.DeepEqual(len(regSchemas), len(expectedSchemas)) {
  266. t.Errorf("Expect\n%v\nbut got\n%v", expectedSchemas, regSchemas)
  267. return
  268. }
  269. expectedFiles = []string{
  270. "test1.so",
  271. }
  272. checkFile(etcDir, expectedFiles, t)
  273. }
  274. func checkFile(etcDir string, schemas []string, t *testing.T) {
  275. files, err := os.ReadDir(etcDir)
  276. if err != nil {
  277. t.Fatal(err)
  278. }
  279. if len(files) != len(schemas) {
  280. t.Errorf("Expect %d files but got %d", len(schemas), len(files))
  281. return
  282. }
  283. for _, file := range files {
  284. fileName := filepath.Base(file.Name())
  285. found := false
  286. for _, schema := range schemas {
  287. if fileName == schema {
  288. found = true
  289. break
  290. }
  291. }
  292. if !found {
  293. t.Errorf("Expect %s but got %s", schemas, fileName)
  294. return
  295. }
  296. }
  297. }