kwg_test.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. package kwg
  2. import (
  3. "context"
  4. "testing"
  5. "time"
  6. "gitp78su.ipnodns.ru/svi/kern/v4/lev0/defs"
  7. . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/kspec"
  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 = defs.NewStreamName("test_stream")
  32. )
  33. // Попытка добавления после закрытия ожидателя.
  34. func (sf *tester) addBad3() {
  35. sf.t.Log("addBad3")
  36. sf.wg.Add(qName)
  37. _len := sf.wg.Len()
  38. if _len != 0 {
  39. sf.t.Fatalf("addBad3(): len(%v)!=0", _len)
  40. }
  41. sf.fnCancel()
  42. kernWg.close()
  43. }
  44. // Убирает имя потока из ожидателя.
  45. func (sf *tester) done() {
  46. sf.t.Log("done")
  47. sf.wg.Done(qName)
  48. lst := sf.wg.List()
  49. if len(lst) != 0 {
  50. sf.t.Fatalf("addBad1(): len(lst)!=0, lst=%#v", lst)
  51. }
  52. }
  53. // Добавление потока ожидания.
  54. func (sf *tester) add() {
  55. sf.t.Log("add")
  56. sf.addGood1()
  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(qName)
  72. }
  73. func (sf *tester) addGood1() {
  74. sf.t.Log("addGood1")
  75. sf.wg.Add(qName)
  76. }
  77. // Ожидание завершения ожидателя потоков.
  78. func (sf *tester) wait() {
  79. sf.t.Log("wait")
  80. go sf.wg.Wait()
  81. time.Sleep(time.Millisecond * 5)
  82. sf.fnCancel()
  83. for {
  84. time.Sleep(time.Millisecond * 10)
  85. if !sf.wg.IsWork() {
  86. break
  87. }
  88. }
  89. }
  90. // Создаёт ожидатель потоков ядра.
  91. func (sf *tester) new() {
  92. sf.t.Log("new")
  93. sf.newBad1()
  94. sf.newGood1()
  95. }
  96. func (sf *tester) newGood1() {
  97. sf.t.Log("newGood1")
  98. defer func() {
  99. if _panic := recover(); _panic != nil {
  100. sf.t.Fatalf("newGood1(): panic=%v", _panic)
  101. }
  102. }()
  103. sf.wg = GetKernelWg(sf.ctx)
  104. if sf.wg == nil {
  105. sf.t.Fatalf("newGood1(): KernelWg==nil")
  106. }
  107. if !sf.wg.IsWork() {
  108. sf.t.Fatalf("wait(): isWork==false")
  109. }
  110. wg := GetKernelWg(sf.ctx)
  111. if sf.wg != wg {
  112. sf.t.Fatalf("newGood1(): bad IKernelWg")
  113. }
  114. if log := sf.wg.Log(); log == nil {
  115. sf.t.Fatalf("newGood1(): log==nil")
  116. }
  117. }
  118. // Нет контекста ядра.
  119. func (sf *tester) newBad1() {
  120. sf.t.Log("newBad1")
  121. defer func() {
  122. if _panic := recover(); _panic == nil {
  123. sf.t.Fatalf("newBad1(): panic=nil")
  124. }
  125. }()
  126. // defer sf.panicUse("newBad1(): ")
  127. var ctx context.Context
  128. _ = GetKernelWg(ctx)
  129. }