kstore_kv_test.go 3.3 KB

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