page_monolit_test.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. package page_monolit
  2. import (
  3. "net/http"
  4. "os"
  5. "testing"
  6. . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/helpers"
  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/kmonolit"
  11. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kserv_http"
  12. )
  13. type tester struct {
  14. t *testing.T
  15. ctx IKernelCtx
  16. serv IKernelServerHttp
  17. page *PageMonolit
  18. }
  19. func TestPageMonolit(t *testing.T) {
  20. sf := &tester{
  21. t: t,
  22. ctx: kctx.GetKernelCtx().Hassert("TestPageMonolit()"),
  23. }
  24. sf.new()
  25. sf.getMonolit()
  26. sf.postMonolitState()
  27. sf.postMonolitCtx()
  28. sf.postMonolitLog()
  29. sf.done()
  30. }
  31. // Возвращает состояние лога монолита
  32. func (sf *tester) postMonolitLog() {
  33. sf.t.Log("postMonolitCtx")
  34. mon := sf.ctx.Get("monolit").
  35. Hassert("postMonolitLog()").
  36. Val().(IKernelMonolit)
  37. log := mon.Log()
  38. log.Debug("test msg")
  39. fiberApp := sf.serv.Fiber()
  40. req, err := http.NewRequest("POST", "/monolit_log", nil)
  41. if err != nil {
  42. sf.t.Fatalf("postMonolitLog(): in net request, err=%v", err)
  43. }
  44. resp, err := fiberApp.Test(req)
  45. if err != nil {
  46. sf.t.Fatalf("postMonolitLog(): in make POST, err=%v", err)
  47. }
  48. defer resp.Body.Close()
  49. if resp.StatusCode != 200 {
  50. sf.t.Fatalf("postMonolitLog(): status(%v)!=200", resp.StatusCode)
  51. }
  52. }
  53. // Возвращает состояние контекста монолита
  54. func (sf *tester) postMonolitCtx() {
  55. sf.t.Log("postMonolitCtx")
  56. fiberApp := sf.serv.Fiber()
  57. req, err := http.NewRequest("POST", "/monolit_ctx", nil)
  58. if err != nil {
  59. sf.t.Fatalf("postMonolitCtx(): in net request, err=%v", err)
  60. }
  61. resp, err := fiberApp.Test(req)
  62. if err != nil {
  63. sf.t.Fatalf("postMonolitCtx(): in make POST, err=%v", err)
  64. }
  65. defer resp.Body.Close()
  66. if resp.StatusCode != 200 {
  67. sf.t.Fatalf("postMonolitCtx(): status(%v)!=200", resp.StatusCode)
  68. }
  69. }
  70. // Возвращает состояние монолита
  71. func (sf *tester) postMonolitState() {
  72. sf.t.Log("postMonolitState")
  73. fiberApp := sf.serv.Fiber()
  74. req, err := http.NewRequest("POST", "/monolit_state", nil)
  75. if err != nil {
  76. sf.t.Fatalf("postMonolitState(): in net request, err=%v", err)
  77. }
  78. resp, err := fiberApp.Test(req)
  79. if err != nil {
  80. sf.t.Fatalf("postMonolitState(): in make POST, err=%v", err)
  81. }
  82. defer resp.Body.Close()
  83. if resp.StatusCode != 200 {
  84. sf.t.Fatalf("postMonolitState(): status(%v)!=200", resp.StatusCode)
  85. }
  86. }
  87. // Возвращает главную страницу монолита
  88. func (sf *tester) getMonolit() {
  89. sf.t.Log("getMonolit")
  90. fiberApp := sf.serv.Fiber()
  91. req, err := http.NewRequest("GET", "/monolit", nil)
  92. if err != nil {
  93. sf.t.Fatalf("getMonolit(): in net request, err=%v", err)
  94. }
  95. resp, err := fiberApp.Test(req)
  96. if err != nil {
  97. sf.t.Fatalf("getMonolit(): in make GET, err=%v", err)
  98. }
  99. defer resp.Body.Close()
  100. if resp.StatusCode != 200 {
  101. sf.t.Fatalf("getMonolit(): status(%v)!=200", resp.StatusCode)
  102. }
  103. }
  104. // Освобождает ресурсы
  105. func (sf *tester) done() {
  106. sf.t.Log("done")
  107. sf.page.clickMonolit()
  108. sf.ctx.Cancel()
  109. sf.ctx.Wg().Wait()
  110. }
  111. // Создаёт новую страницу монолита
  112. func (sf *tester) new() {
  113. sf.t.Log("new")
  114. _ = mock_env.MakeEnv()
  115. _ = os.Unsetenv("LOCAL_HTTP_URL")
  116. os.Setenv("LOCAL_HTTP_URL", "http://localhost:18310/")
  117. sf.ctx.Set("isLocal", true, "testing").Hassert("new()")
  118. for {
  119. SleepMs()
  120. if sf.ctx.Get("isLocal") != nil {
  121. break
  122. }
  123. }
  124. _ = kmonolit.GetMonolit("test_monolit")
  125. sf.serv = kserv_http.GetKernelServHttp().Hassert("new()")
  126. sf.page = GetPageMonolit().Hassert("new()")
  127. if sf.page == nil {
  128. sf.t.Fatalf("new(): page==nil")
  129. }
  130. _ = GetPageMonolit()
  131. go sf.serv.Run()
  132. }