kwg_test.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. package kwg
  2. import (
  3. "context"
  4. "testing"
  5. "time"
  6. . "gitp78su.ipnodns.ru/svi/kern/krn/ktypes"
  7. )
  8. type tester struct {
  9. t *testing.T
  10. ctx context.Context
  11. fnCancel func()
  12. wg IKernelWg
  13. }
  14. func TestKernelWG(t *testing.T) {
  15. ctxBg := context.Background()
  16. ctx, fnCancel := context.WithCancel(ctxBg)
  17. defer fnCancel()
  18. sf := &tester{
  19. t: t,
  20. ctx: ctx,
  21. fnCancel: fnCancel,
  22. }
  23. sf.new()
  24. sf.add()
  25. sf.done()
  26. sf.wait()
  27. sf.addBad3()
  28. }
  29. // Попытка добавления после закрытия ожидателя
  30. func (sf *tester) addBad3() {
  31. sf.t.Log("addBad3")
  32. res := sf.wg.Add("test_stream")
  33. if res.IsOk() {
  34. sf.t.Fatalf("addBad3(): err==nil")
  35. }
  36. _len := sf.wg.Len()
  37. if _len != 0 {
  38. sf.t.Fatalf("addBad3(): len(%v)!=0", _len)
  39. }
  40. sf.fnCancel()
  41. kernWg.close()
  42. }
  43. // Убирает имя потока из ожидателя
  44. func (sf *tester) done() {
  45. sf.t.Log("done")
  46. sf.wg.Done("test_stream")
  47. lst := sf.wg.List()
  48. if len(lst) != 0 {
  49. sf.t.Fatalf("addBad1(): len(lst)!=0, lst=%#v", lst)
  50. }
  51. }
  52. // Добавление потока ожидания
  53. func (sf *tester) add() {
  54. sf.t.Log("add")
  55. sf.addGood1()
  56. sf.addBad1()
  57. sf.addBad2()
  58. }
  59. // Уже есть такое имя потока
  60. func (sf *tester) addBad2() {
  61. sf.t.Log("addBad2")
  62. defer func() {
  63. if _panic := recover(); _panic == nil {
  64. sf.t.Fatalf("addBad1(): panic==nil")
  65. }
  66. lst := sf.wg.List()
  67. if len(lst) != 1 {
  68. sf.t.Fatalf("addBad1(): len(lst)!=1, lst=%#v", lst)
  69. }
  70. }()
  71. _ = sf.wg.Add("test_stream")
  72. }
  73. // Пустое имя потока
  74. func (sf *tester) addBad1() {
  75. sf.t.Log("addBad1")
  76. defer func() {
  77. if _panic := recover(); _panic == nil {
  78. sf.t.Fatalf("addBad1(): panic==nil")
  79. }
  80. }()
  81. _ = sf.wg.Add("")
  82. }
  83. func (sf *tester) addGood1() {
  84. sf.t.Log("addGood1")
  85. res := sf.wg.Add("test_stream")
  86. if res.IsErr() {
  87. sf.t.Fatalf("addGood1(): err=%v", res.Error())
  88. }
  89. }
  90. // Ожидание завершения ожидателя потоков
  91. func (sf *tester) wait() {
  92. sf.t.Log("wait")
  93. go sf.wg.Wait()
  94. time.Sleep(time.Millisecond * 5)
  95. sf.fnCancel()
  96. for {
  97. time.Sleep(time.Millisecond * 10)
  98. if !sf.wg.IsWork() {
  99. break
  100. }
  101. }
  102. }
  103. // Создаёт ожидатель потоков ядра
  104. func (sf *tester) new() {
  105. sf.t.Log("new")
  106. sf.newBad1()
  107. sf.newGood1()
  108. }
  109. func (sf *tester) newGood1() {
  110. sf.t.Log("newGood1")
  111. defer func() {
  112. if _panic := recover(); _panic != nil {
  113. sf.t.Fatalf("newGood1(): panic=%v", _panic)
  114. }
  115. }()
  116. sf.wg = GetKernelWg(sf.ctx)
  117. if sf.wg == nil {
  118. sf.t.Fatalf("newGood1(): KernelWg==nil")
  119. }
  120. if !sf.wg.IsWork() {
  121. sf.t.Fatalf("wait(): isWork==false")
  122. }
  123. wg := GetKernelWg(sf.ctx)
  124. if sf.wg != wg {
  125. sf.t.Fatalf("newGood1(): bad IKernelWg")
  126. }
  127. if log := sf.wg.Log(); log == nil {
  128. sf.t.Fatalf("newGood1(): log==nil")
  129. }
  130. }
  131. // Нет контекста ядра
  132. func (sf *tester) newBad1() {
  133. sf.t.Log("newBad1")
  134. defer func() {
  135. if _panic := recover(); _panic == nil {
  136. sf.t.Fatalf("newBad1(): panic=nil")
  137. }
  138. }()
  139. // defer sf.panicUse("newBad1(): ")
  140. var ctx context.Context
  141. _ = GetKernelWg(ctx)
  142. }