migration_test.go 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package util
  2. import (
  3. "github.com/emqx/kuiper/common/kv"
  4. "github.com/patrickmn/go-cache"
  5. "os"
  6. "path"
  7. "path/filepath"
  8. "testing"
  9. )
  10. func TestDataMigration(t *testing.T) {
  11. kvs := make(map[string]string)
  12. kvs["mqtt"] = `{"sql":"create stream mqtt(age BIGINT) WITH (DATASOURCE = \"dev/+/msg\", FORMAT = \"json\");"}`
  13. kvs["log"] = `{"id":"log","sql":"SELECT * FROM mqtt","actions":[{"log":{}}]}`
  14. dir, _ := filepath.Abs("testMigration")
  15. dirSqlite, _ := filepath.Split(dir)
  16. fpath := path.Join(dir, "stores.data")
  17. if f, _ := os.Stat(fpath); f != nil {
  18. os.Remove(fpath)
  19. }
  20. if _, err := os.Stat(dir); os.IsNotExist(err) {
  21. os.MkdirAll(dir, os.ModePerm)
  22. }
  23. defer os.RemoveAll(dir)
  24. defer os.Remove(path.Join(dirSqlite, "sqliteKV.db"))
  25. c := cache.New(cache.NoExpiration, 0)
  26. if err := gocacheOpen(c, fpath); nil != err {
  27. t.Error(err)
  28. return
  29. }
  30. for k, v := range kvs {
  31. if err := gocacheSet(c, fpath, k, v); nil != err {
  32. t.Error(err)
  33. return
  34. }
  35. }
  36. if err := gocacheClose(c, fpath); nil != err {
  37. t.Error(err)
  38. }
  39. if err := DataMigration(dir); nil != err {
  40. t.Error(err)
  41. return
  42. }
  43. store := kv.GetDefaultKVStore(dir)
  44. if err := store.Open(); nil != err {
  45. t.Error(err)
  46. return
  47. }
  48. defer store.Close()
  49. for k, v := range kvs {
  50. var dbVal string
  51. if ok, _ := store.Get(k, &dbVal); !ok {
  52. t.Error("not found key ", k)
  53. return
  54. } else if v != dbVal {
  55. t.Error("gocache save:", v, "sqlite save:", dbVal)
  56. return
  57. }
  58. }
  59. }