kmonolit_test.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. package kmonolit
  2. import (
  3. "os"
  4. "testing"
  5. . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/helpers"
  6. . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/kalias"
  7. . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/ktypes"
  8. "gitp78su.ipnodns.ru/svi/kern/v4/lev1/mock_env"
  9. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kctx"
  10. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kmodule"
  11. )
  12. const (
  13. baseUrl = "http://127.0.0.1:18430/"
  14. pathStore = "/store/store_kmonolit"
  15. )
  16. type tester struct {
  17. t *testing.T
  18. me *mock_env.MockEnv
  19. mon IKernelMonolit
  20. }
  21. func TestKernMono(t *testing.T) {
  22. sf := &tester{
  23. t: t,
  24. me: mock_env.MakeEnv(),
  25. }
  26. _ = os.Unsetenv("LOCAL_STORE_PATH")
  27. _ = os.Setenv("LOCAL_STORE_PATH", pathStore)
  28. _ = os.Unsetenv("LOCAL_HTTP_URL")
  29. os.Setenv("LOCAL_HTTP_URL", baseUrl)
  30. fnClear := func() {
  31. _ = os.RemoveAll(pathStore)
  32. }
  33. fnClear()
  34. defer fnClear()
  35. sf.new()
  36. sf.run()
  37. sf.add()
  38. sf.done()
  39. }
  40. func (sf *tester) done() {
  41. sf.t.Log("done")
  42. ctx := kctx.GetKernelCtx().Hassert("done()")
  43. ctx.Cancel()
  44. ctx.Wg().Wait()
  45. sf.mon.Run()
  46. sf.mon.Wait()
  47. sf.mon.Run()
  48. }
  49. // Добавление модуля в монолит.
  50. func (sf *tester) add() {
  51. sf.t.Log("add")
  52. sf.addGood1()
  53. }
  54. type mod struct {
  55. IKernelModule
  56. }
  57. func newMod(name AModuleName) IKernelModule {
  58. sf := &mod{
  59. IKernelModule: kmodule.NewKernelModule(name).Hassert("newMod()"),
  60. }
  61. return sf
  62. }
  63. func (sf *mod) Run() {}
  64. func (sf *tester) addGood1() {
  65. sf.t.Log("addGood1")
  66. mod := newMod("test_module")
  67. sf.mon.Add(mod).Hassert("addGood1()")
  68. }
  69. func (sf *tester) run() {
  70. sf.t.Log("run")
  71. mod := newMod("test_mod1")
  72. sf.mon.Add(mod).Hassert("run()")
  73. sf.mon.Run()
  74. isWork := sf.mon.IsWork()
  75. if !isWork {
  76. sf.t.Fatalf("newGood1(): isWork==false")
  77. }
  78. }
  79. // Создаёт новый монолит.
  80. func (sf *tester) new() {
  81. sf.t.Log("new")
  82. sf.newBad1()
  83. sf.newGood1()
  84. }
  85. func (sf *tester) newGood1() {
  86. sf.t.Log("newGood1")
  87. defer func() {
  88. if _panic := recover(); _panic != nil {
  89. sf.t.Fatalf("newGood1(): panic=%v", _panic)
  90. }
  91. }()
  92. ctx := kctx.GetKernelCtx().Hassert("newGood1()")
  93. ctx.Set("isLocal", true, "type bus").Hassert("newGood1()")
  94. for {
  95. SleepMs()
  96. if ctx.Get("isLocal") != nil {
  97. break
  98. }
  99. }
  100. resMon := GetMonolit("test_monolit")
  101. sf.mon = resMon.Hassert("newGood1()")
  102. isLocal := sf.mon.IsLocal()
  103. if !isLocal {
  104. sf.t.Fatalf("newGood1(): isLocal==false")
  105. }
  106. if name := sf.mon.Name(); name != "test_monolit" {
  107. sf.t.Fatalf("newGood1(): name(%v)!='test_monolit'", name)
  108. }
  109. if log := sf.mon.Log(); log == nil {
  110. sf.t.Fatalf("newGood1(): log==nil")
  111. }
  112. if ctx := sf.mon.Ctx(); ctx == nil {
  113. sf.t.Fatalf("newGood1(): ctx==nil")
  114. }
  115. resMon = GetMonolit("")
  116. sf.mon = resMon.Hassert("newGood1()")
  117. }
  118. // Нет признака локальности.
  119. func (sf *tester) newBad1() {
  120. sf.t.Log("newBad1")
  121. res := GetMonolit("test_32")
  122. if res.IsOk() {
  123. sf.t.Fatalf("newBad1(): res.IsOk()==true")
  124. }
  125. }