kbus_base_test.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. package kbus_base
  2. import (
  3. "testing"
  4. "gitp78su.ipnodns.ru/svi/kern/krn/kctx"
  5. . "gitp78su.ipnodns.ru/svi/kern/krn/ktypes"
  6. "gitp78su.ipnodns.ru/svi/kern/mock/mock_hand_serve"
  7. "gitp78su.ipnodns.ru/svi/kern/mock/mock_hand_sub_local"
  8. )
  9. type tester struct {
  10. t *testing.T
  11. bus IKernelBus
  12. handSub *mock_hand_sub_local.MockHandlerSub
  13. handServ *mock_hand_serve.MockHandlerServe
  14. }
  15. func TestKernelBusLocal(t *testing.T) {
  16. sf := &tester{
  17. t: t,
  18. handSub: mock_hand_sub_local.NewMockHandlerSub("topic_hand_sub", "mock_hand_sub"),
  19. handServ: mock_hand_serve.NewMockHandlerServe("topic_hand_serv", "mock_hand_serv"),
  20. }
  21. sf.new()
  22. sf.subBad1()
  23. sf.subGood1()
  24. sf.pubGood10()
  25. sf.reqBad1()
  26. sf.servBad1()
  27. sf.servGood1()
  28. sf.reqGood1()
  29. sf.close()
  30. sf.unsubBad1()
  31. sf.unsubGood1()
  32. }
  33. func (sf *tester) unsubGood1() {
  34. sf.t.Log("unsubBad1")
  35. defer func() {
  36. if _panic := recover(); _panic != nil {
  37. sf.t.Fatalf("unsubGood1(): panic=%v", _panic)
  38. }
  39. }()
  40. sf.bus.Unsubscribe(sf.handSub)
  41. sf.bus.Unsubscribe(sf.handSub)
  42. }
  43. // Отписка от топика, нет обработчика
  44. func (sf *tester) unsubBad1() {
  45. sf.t.Log("unsubBad1")
  46. defer func() {
  47. if _panic := recover(); _panic == nil {
  48. sf.t.Fatalf("unsubBad1(): panic==nil")
  49. }
  50. }()
  51. sf.bus.Unsubscribe(nil)
  52. }
  53. func (sf *tester) reqGood1() {
  54. sf.t.Log("reqGood1")
  55. res := sf.bus.SendRequest(sf.handServ.Topic_, []byte("test_msg"))
  56. if res.IsErr() {
  57. sf.t.Fatalf("reqGood1(): err=%v", res.Error())
  58. }
  59. if res.Unwrap() == nil {
  60. sf.t.Fatalf("reqGood1(): binMsg==nil")
  61. }
  62. }
  63. func (sf *tester) servGood1() {
  64. sf.t.Log("servGood1")
  65. defer func() {
  66. if _panic := recover(); _panic != nil {
  67. sf.t.Fatalf("servGood1(): panic=%v", _panic)
  68. }
  69. }()
  70. sf.bus.RegisterServe(sf.handServ)
  71. }
  72. // Нет обработчика для обслуживания запросов
  73. func (sf *tester) servBad1() {
  74. sf.t.Log("servBad1")
  75. defer func() {
  76. if _panic := recover(); _panic == nil {
  77. sf.t.Fatalf("servBad1(): panic==nil")
  78. }
  79. }()
  80. sf.bus.RegisterServe(nil)
  81. }
  82. // Нет такого топика
  83. func (sf *tester) reqBad1() {
  84. sf.t.Log("reqBad1")
  85. res := sf.bus.SendRequest("test_topic1", []byte("test_msg"))
  86. if res.IsOk() {
  87. sf.t.Fatalf("reqBad1(): err==nil")
  88. }
  89. }
  90. // Нет читателей топика
  91. func (sf *tester) pubGood10() {
  92. sf.t.Log("pubGood10")
  93. defer func() {
  94. if _panic := recover(); _panic != nil {
  95. sf.t.Fatalf("pubGood10(): panic=%v", _panic)
  96. }
  97. }()
  98. res := sf.bus.Publish("test_topic1", []byte("test_msg"))
  99. if res.IsErr() {
  100. sf.t.Fatalf("pubGood10(): err=%v", res.Error())
  101. }
  102. }
  103. func (sf *tester) subGood1() {
  104. sf.t.Log("subGood1")
  105. defer func() {
  106. if _panic := recover(); _panic != nil {
  107. sf.t.Fatalf("subGood1(): panic=%v", _panic)
  108. }
  109. }()
  110. res := sf.bus.Subscribe(sf.handSub)
  111. if res.IsErr() {
  112. sf.t.Fatalf("subGood1(): err=%v", res.Error())
  113. }
  114. }
  115. // Нет обработчик подписки
  116. func (sf *tester) subBad1() {
  117. sf.t.Log("subBad1")
  118. defer func() {
  119. if _panic := recover(); _panic == nil {
  120. sf.t.Fatalf("subBad1(): panic==nil")
  121. }
  122. }()
  123. _ = sf.bus.Subscribe(nil)
  124. }
  125. // Создание локальной шины
  126. func (sf *tester) new() {
  127. sf.t.Log("new")
  128. sf.newGood1()
  129. }
  130. // Закрытие шины
  131. func (sf *tester) close() {
  132. sf.t.Log("close")
  133. ctx := kctx.GetKernelCtx()
  134. ctx.Cancel()
  135. ctx.Wg().Wait()
  136. sf.bus.(*KBusBase).close()
  137. if sf.bus.IsWork() {
  138. sf.t.Fatalf("close(): bus work")
  139. }
  140. res := sf.bus.Subscribe(sf.handSub)
  141. if res.IsOk() {
  142. sf.t.Fatalf("close(): err==nil")
  143. }
  144. res = sf.bus.Publish("test_topic1", []byte("test_msg"))
  145. if res.IsOk() {
  146. sf.t.Fatalf("close(): err==nil")
  147. }
  148. res1 := sf.bus.SendRequest("test_topic", []byte("test_msg"))
  149. if res1.IsOk() {
  150. sf.t.Fatalf("close(): err==nil")
  151. }
  152. }
  153. func (sf *tester) newGood1() {
  154. sf.t.Log("newGood1")
  155. defer func() {
  156. if _panic := recover(); _panic != nil {
  157. sf.t.Fatalf("newGood1(): panic=%v", _panic)
  158. }
  159. }()
  160. sf.bus = GetKernelBusBase()
  161. sf.bus = GetKernelBusBase()
  162. if sf.bus == nil {
  163. sf.t.Fatalf("newGood1(): IKernelBus==nil")
  164. }
  165. if !sf.bus.IsWork() {
  166. sf.t.Fatalf("newGood1(): bus not work")
  167. }
  168. if log := sf.bus.Log(); log == nil {
  169. sf.t.Fatalf("newGood1(): log==nil")
  170. }
  171. }