kstore_kv_test.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. package kstore_kv
  2. import (
  3. "os"
  4. "testing"
  5. "time"
  6. "gitp78su.ipnodns.ru/svi/kern/krn/kctx"
  7. . "gitp78su.ipnodns.ru/svi/kern/krn/ktypes"
  8. "gitp78su.ipnodns.ru/svi/kern/mock/mock_env"
  9. )
  10. type tester struct {
  11. t *testing.T
  12. me *mock_env.MockEnv
  13. ctx IKernelCtx
  14. wg IKernelWg
  15. }
  16. func TestKernelStore(t *testing.T) {
  17. ctx := kctx.GetKernelCtx()
  18. sf := &tester{
  19. t: t,
  20. me: mock_env.MakeEnv(),
  21. ctx: ctx,
  22. wg: ctx.Wg(),
  23. }
  24. _ = os.Unsetenv("LOCAL_STORE_PATH")
  25. _ = os.Setenv("LOCAL_STORE_PATH", "/store/store_kernel")
  26. fnClear := func() {
  27. pwd := sf.me.Pwd() + "/store/store_kernel"
  28. _ = os.RemoveAll(pwd)
  29. }
  30. fnClear()
  31. sf.new()
  32. sf.set()
  33. sf.get()
  34. sf.byPrefix()
  35. sf.del()
  36. sf.close()
  37. sf.workBad1()
  38. time.Sleep(time.Second * 2)
  39. }
  40. // Установка ключа после закрытия хранилища
  41. func (sf *tester) workBad1() {
  42. sf.t.Log("workBad1")
  43. res := kernStore.Set("test_key", []byte("test_val"))
  44. if res.IsOk() {
  45. sf.t.Fatalf("workBad1(): set, err==nil")
  46. }
  47. res1 := kernStore.Get("test_key")
  48. if res1.IsOk() {
  49. sf.t.Fatalf("workBad1(): get, err==nil")
  50. }
  51. res = kernStore.Delete("test_key")
  52. if res.IsOk() {
  53. sf.t.Fatalf("workBad1(): del, err==nil")
  54. }
  55. }
  56. // Удаляет значение
  57. func (sf *tester) del() {
  58. sf.t.Log("del")
  59. res := kernStore.Delete("test_key")
  60. if res.IsErr() {
  61. sf.t.Fatalf("del(): err=%v", res.Err())
  62. }
  63. res1 := kernStore.Get("test_key")
  64. if res1.IsOk() {
  65. sf.t.Fatalf("del(): err==nil")
  66. }
  67. }
  68. // Поиск по префиксу
  69. func (sf *tester) byPrefix() {
  70. sf.t.Log("byPrefix")
  71. res0 := kernStore.Set("test_key2", []byte("test_key2"))
  72. if res0.IsErr() {
  73. sf.t.Fatalf("byPrefix(): err=%v", res0.Err())
  74. }
  75. res := kernStore.ByPrefix("test")
  76. if res.IsErr() {
  77. sf.t.Fatalf("byPrefix(): err=%v", res.Err())
  78. }
  79. lstKey := res.Val()
  80. if len(lstKey) != 2 {
  81. sf.t.Fatalf("byPrefix(): len(%v)!=2", len(lstKey))
  82. }
  83. }
  84. // Получение значения по ключу
  85. func (sf *tester) get() {
  86. sf.t.Log("get")
  87. res := kernStore.Get("test_key")
  88. if res.IsErr() {
  89. sf.t.Fatalf("get(): err=%v", res.Err())
  90. }
  91. strVal := string(res.Val())
  92. if strVal != "test_val" {
  93. sf.t.Fatalf("get(): strVal(%v)!='test_val'", strVal)
  94. }
  95. }
  96. // Добавление ключа в хранилище
  97. func (sf *tester) set() {
  98. sf.t.Log("set")
  99. res := kernStore.Set("test_key", []byte("test_val"))
  100. if res.IsErr() {
  101. sf.t.Fatalf("set(): err=%v", res.Err())
  102. }
  103. }
  104. // Закрытие хранилища
  105. func (sf *tester) close() {
  106. sf.t.Log("close")
  107. res := sf.wg.Add("123")
  108. if res.IsErr() {
  109. sf.t.Fatalf("close(): err=%v", res.Err())
  110. }
  111. sf.ctx.Cancel()
  112. time.Sleep(time.Millisecond * 20)
  113. go sf.wg.Done("123")
  114. sf.wg.Wait()
  115. kernStore.close()
  116. res_ := kernStore.ByPrefix("test")
  117. if res_.IsOk() {
  118. sf.t.Fatalf("close(): err==nil")
  119. }
  120. }
  121. // Создаёт новое хранилище ядра
  122. func (sf *tester) new() {
  123. sf.t.Log("new")
  124. sf.newGood1()
  125. }
  126. func (sf *tester) newGood1() {
  127. sf.t.Log("newGood1")
  128. defer func() {
  129. if _panic := recover(); _panic != nil {
  130. sf.t.Fatalf("newGood1(): panic=%v", _panic)
  131. }
  132. }()
  133. store := GetKernelStore()
  134. if store == nil {
  135. sf.t.Fatalf("newGood1(): KernelStore==nil")
  136. }
  137. store = GetKernelStore()
  138. if store == nil {
  139. sf.t.Fatalf("newGood1(): KernelStore==nil")
  140. }
  141. if log := store.Log(); log == nil {
  142. sf.t.Fatalf("newGood1(): log==nil")
  143. }
  144. }