kwg_test.go 2.9 KB

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