kbus_base_test.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  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. binMsg, err := sf.bus.SendRequest(sf.handServ.Topic_, []byte("test_msg"))
  56. if err != nil {
  57. sf.t.Fatalf("reqGood1(): err=%v", err)
  58. }
  59. if binMsg == 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. binMsg, err := sf.bus.SendRequest("test_topic1", []byte("test_msg"))
  86. if err == nil {
  87. sf.t.Fatalf("reqBad1(): err==nil")
  88. }
  89. if binMsg != nil {
  90. sf.t.Fatalf("reqBad1(): binMsg!=nil")
  91. }
  92. }
  93. // Нет читателей топика
  94. func (sf *tester) pubGood10() {
  95. sf.t.Log("pubGood10")
  96. defer func() {
  97. if _panic := recover(); _panic != nil {
  98. sf.t.Fatalf("pubGood10(): panic=%v", _panic)
  99. }
  100. }()
  101. err := sf.bus.Publish("test_topic1", []byte("test_msg"))
  102. if err != nil {
  103. sf.t.Fatalf("pubGood10(): err=%v", nil)
  104. }
  105. }
  106. func (sf *tester) subGood1() {
  107. sf.t.Log("subGood1")
  108. defer func() {
  109. if _panic := recover(); _panic != nil {
  110. sf.t.Fatalf("subGood1(): panic=%v", _panic)
  111. }
  112. }()
  113. err := sf.bus.Subscribe(sf.handSub)
  114. if err != nil {
  115. sf.t.Fatalf("subGood1(): err=%v", err)
  116. }
  117. }
  118. // Нет обработчик подписки
  119. func (sf *tester) subBad1() {
  120. sf.t.Log("subBad1")
  121. defer func() {
  122. if _panic := recover(); _panic == nil {
  123. sf.t.Fatalf("subBad1(): panic==nil")
  124. }
  125. }()
  126. _ = sf.bus.Subscribe(nil)
  127. }
  128. // Создание локальной шины
  129. func (sf *tester) new() {
  130. sf.t.Log("new")
  131. sf.newGood1()
  132. }
  133. // Закрытие шины
  134. func (sf *tester) close() {
  135. sf.t.Log("close")
  136. ctx := kctx.GetKernelCtx()
  137. ctx.Cancel()
  138. ctx.Wg().Wait()
  139. sf.bus.(*KBusBase).close()
  140. if sf.bus.IsWork() {
  141. sf.t.Fatalf("close(): bus work")
  142. }
  143. err := sf.bus.Subscribe(sf.handSub)
  144. if err == nil {
  145. sf.t.Fatalf("close(): err==nil")
  146. }
  147. err = sf.bus.Publish("test_topic1", []byte("test_msg"))
  148. if err == nil {
  149. sf.t.Fatalf("close(): err==nil")
  150. }
  151. _, err = sf.bus.SendRequest("test_topic", []byte("test_msg"))
  152. if err == nil {
  153. sf.t.Fatalf("close(): err==nil")
  154. }
  155. }
  156. func (sf *tester) newGood1() {
  157. sf.t.Log("newGood1")
  158. defer func() {
  159. if _panic := recover(); _panic != nil {
  160. sf.t.Fatalf("newGood1(): panic=%v", _panic)
  161. }
  162. }()
  163. sf.bus = GetKernelBusBase()
  164. sf.bus = GetKernelBusBase()
  165. if sf.bus == nil {
  166. sf.t.Fatalf("newGood1(): IKernelBus==nil")
  167. }
  168. if !sf.bus.IsWork() {
  169. sf.t.Fatalf("newGood1(): bus not work")
  170. }
  171. if log := sf.bus.Log(); log == nil {
  172. sf.t.Fatalf("newGood1(): log==nil")
  173. }
  174. }