kstore_kv_test.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. package kstore_kv
  2. import (
  3. "os"
  4. "testing"
  5. "time"
  6. "gitp78su.ipnodns.ru/svi/kern/v4/krn/kctx"
  7. . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/ktypes"
  8. "gitp78su.ipnodns.ru/svi/kern/v4/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. opt := kernStore.Get("test_key")
  48. opt.Hassert("workBad1(): in get, err==nil")
  49. res = kernStore.Delete("test_key")
  50. if res.IsOk() {
  51. sf.t.Fatalf("workBad1(): del, err==nil")
  52. }
  53. }
  54. // Удаляет значение
  55. func (sf *tester) del() {
  56. sf.t.Log("del")
  57. res := kernStore.Delete("test_key")
  58. if res.IsErr() {
  59. sf.t.Fatalf("del(): err=%v", res.Err())
  60. }
  61. opt := kernStore.Get("test_key")
  62. opt.Hassert("del(): val!==nil")
  63. }
  64. // Поиск по префиксу
  65. func (sf *tester) byPrefix() {
  66. sf.t.Log("byPrefix")
  67. res0 := kernStore.Set("test_key2", []byte("test_key2"))
  68. if res0.IsErr() {
  69. sf.t.Fatalf("byPrefix(): err=%v", res0.Err())
  70. }
  71. res := kernStore.ByPrefix("test")
  72. res.Hassert("byPrefix(): val == nil")
  73. lstKey := res.Val()
  74. if len(lstKey) != 2 {
  75. sf.t.Fatalf("byPrefix(): len(%v)!=2", len(lstKey))
  76. }
  77. }
  78. // Получение значения по ключу
  79. func (sf *tester) get() {
  80. sf.t.Log("get")
  81. opt := kernStore.Get("test_key")
  82. opt.Hassert("get(): val==nil")
  83. strVal := string(opt.Val())
  84. if strVal != "test_val" {
  85. sf.t.Fatalf("get(): strVal(%v)!='test_val'", strVal)
  86. }
  87. }
  88. // Добавление ключа в хранилище
  89. func (sf *tester) set() {
  90. sf.t.Log("set")
  91. res := kernStore.Set("test_key", []byte("test_val"))
  92. if res.IsErr() {
  93. sf.t.Fatalf("set(): err=%v", res.Err())
  94. }
  95. }
  96. // Закрытие хранилища
  97. func (sf *tester) close() {
  98. sf.t.Log("close")
  99. res := sf.wg.Add("123")
  100. if res.IsErr() {
  101. sf.t.Fatalf("close(): err=%v", res.Err())
  102. }
  103. sf.ctx.Cancel()
  104. time.Sleep(time.Millisecond * 20)
  105. go sf.wg.Done("123")
  106. sf.wg.Wait()
  107. kernStore.close()
  108. res1 := kernStore.ByPrefix("test")
  109. if res1.IsOk() {
  110. sf.t.Fatalf("close(): val!=nil")
  111. }
  112. }
  113. // Создаёт новое хранилище ядра
  114. func (sf *tester) new() {
  115. sf.t.Log("new")
  116. sf.newGood1()
  117. }
  118. func (sf *tester) newGood1() {
  119. sf.t.Log("newGood1")
  120. defer func() {
  121. if _panic := recover(); _panic != nil {
  122. sf.t.Fatalf("newGood1(): panic=%v", _panic)
  123. }
  124. }()
  125. store := GetKernelStore()
  126. if store == nil {
  127. sf.t.Fatalf("newGood1(): KernelStore==nil")
  128. }
  129. store = GetKernelStore()
  130. if store == nil {
  131. sf.t.Fatalf("newGood1(): KernelStore==nil")
  132. }
  133. if log := store.Log(); log == nil {
  134. sf.t.Fatalf("newGood1(): log==nil")
  135. }
  136. }