mod_wui_test.go 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. package mod_wui
  2. import (
  3. "net/http"
  4. "net/url"
  5. "os"
  6. "strings"
  7. "testing"
  8. "time"
  9. "github.com/gofiber/fiber/v2"
  10. . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/ktypes"
  11. "gitp78su.ipnodns.ru/svi/kern/v4/lev1/mock_env"
  12. . "gitp78su.ipnodns.ru/svi/kern/v4/lev1/result"
  13. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kctx"
  14. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kmonolit"
  15. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/wui/wbutton"
  16. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/wui/wlabel"
  17. )
  18. const (
  19. baseUrl = "http://localhost:18380/"
  20. pathStore = "/store/store_mod_wui"
  21. )
  22. type tester struct {
  23. t *testing.T
  24. me *mock_env.MockEnv
  25. ctx IKernelCtx
  26. fiberApp *fiber.App
  27. mod *ModuleWui
  28. }
  29. func TestModKernelCtx(t *testing.T) {
  30. sf := &tester{
  31. t: t,
  32. me: mock_env.MakeEnv(),
  33. ctx: kctx.GetKernelCtx().Hassert("TestModKernelCtx()"),
  34. }
  35. _ = os.Unsetenv("LOCAL_STORE_PATH")
  36. _ = os.Setenv("LOCAL_STORE_PATH", pathStore)
  37. _ = os.Unsetenv("LOCAL_HTTP_URL")
  38. os.Setenv("LOCAL_HTTP_URL", baseUrl)
  39. fnClear := func() {
  40. pwd := sf.me.Pwd() + pathStore
  41. _ = os.RemoveAll(pwd)
  42. }
  43. fnClear()
  44. defer fnClear()
  45. sf.ctx.Set("monolitName", "test_monolit", "test").Hassert("TestModKernelCtx()")
  46. sf.new()
  47. sf.click()
  48. sf.done()
  49. }
  50. // Кто-то кликнул в сети на кнопку
  51. func (sf *tester) click() {
  52. sf.t.Log("click")
  53. sf.clickBad1()
  54. sf.clickBad2()
  55. sf.clickGood1()
  56. sf.clickGood2()
  57. sf.clickBad3()
  58. }
  59. // С кривой POST-формой
  60. func (sf *tester) clickBad3() {
  61. sf.t.Log("clickBad3")
  62. btn := wbutton.NewWuiButton("test_btn", sf.fnClick).Hassert("clickBad3()")
  63. // Данные формы
  64. reader := strings.NewReader("tra-ta-ta")
  65. req, err := http.NewRequest("POST", "/wui/click/"+btn.Id(), reader)
  66. if err != nil {
  67. sf.t.Fatalf("clickBad3(): in net request, err=%v", err)
  68. }
  69. req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
  70. req.Header.Add("Token-1", "123;original-1")
  71. req.Header.Add("Token-2", "")
  72. resp, err := sf.fiberApp.Test(req)
  73. if err != nil {
  74. sf.t.Fatalf("clickBad3(): in make POST, err=%v", err)
  75. }
  76. if resp.StatusCode != 200 {
  77. sf.t.Fatalf("clickBad3(): status(%v)!=200", resp.StatusCode)
  78. }
  79. }
  80. // С POST-формой
  81. func (sf *tester) clickGood2() {
  82. sf.t.Log("clickGood2")
  83. btn := wbutton.NewWuiButton("test_btn", sf.fnClick).Hassert("clickGood2()")
  84. // Данные формы
  85. formData := url.Values{
  86. "username": {"john_doe"},
  87. "email": {"john.doe@example.com"},
  88. "password": {"s3cr3t", "valid"},
  89. }
  90. reader := strings.NewReader(formData.Encode())
  91. req, err := http.NewRequest("POST", "/wui/click/"+btn.Id(), reader)
  92. if err != nil {
  93. sf.t.Fatalf("clickGood2(): in net request, err=%v", err)
  94. }
  95. req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
  96. req.Header.Add("Token-1", "123;original-1")
  97. req.Header.Add("Token-2", "")
  98. req.Header.Clone().Add("Token-1", "555;original-2")
  99. resp, err := sf.fiberApp.Test(req)
  100. if err != nil {
  101. sf.t.Fatalf("clickGood2(): in make POST, err=%v", err)
  102. }
  103. if resp.StatusCode != 200 {
  104. sf.t.Fatalf("clickGood2(): status(%v)!=200", resp.StatusCode)
  105. }
  106. }
  107. // Без POST-формы
  108. func (sf *tester) clickGood1() {
  109. sf.t.Log("clickGood1")
  110. btn := wbutton.NewWuiButton("test_btn", sf.fnClick).Hassert("clickGood1()")
  111. req, err := http.NewRequest(http.MethodPost, "/wui/click/"+btn.Id(), nil)
  112. if err != nil {
  113. sf.t.Fatalf("clickGood1(): in net request, err=%v", err)
  114. }
  115. resp, err := sf.fiberApp.Test(req)
  116. if err != nil {
  117. sf.t.Fatalf("clickGood1(): in make POST, err=%v", err)
  118. }
  119. if resp.StatusCode != 200 {
  120. sf.t.Fatalf("clickGood1(): status(%v)!=200", resp.StatusCode)
  121. }
  122. }
  123. // Обратный вызов клика
  124. func (sf *tester) fnClick(dict map[string]string) IResult[string] {
  125. sf.t.Log("fnClick")
  126. return NewRes("test_click")
  127. }
  128. // Неправильный тип объекта
  129. func (sf *tester) clickBad2() {
  130. sf.t.Log("clickBad2")
  131. lbl := wlabel.NewWuiLabel("test_lbl").Hassert("clickBad2()")
  132. req, err := http.NewRequest("POST", "/wui/click/"+lbl.Id(), nil)
  133. if err != nil {
  134. sf.t.Fatalf("clickBad2(): in net request, err=%v", err)
  135. }
  136. resp, err := sf.fiberApp.Test(req)
  137. if err != nil {
  138. sf.t.Fatalf("clickBad2(): in make POST, err=%v", err)
  139. }
  140. if resp.StatusCode != 200 {
  141. sf.t.Fatalf("clickBad2(): status(%v)!=200", resp.StatusCode)
  142. }
  143. }
  144. // Нет такой кнопки
  145. func (sf *tester) clickBad1() {
  146. sf.t.Log("clickBad1")
  147. req, err := http.NewRequest("POST", "/wui/click/ert", nil)
  148. if err != nil {
  149. sf.t.Fatalf("clickBad1(): in net request, err=%v", err)
  150. }
  151. resp, err := sf.fiberApp.Test(req)
  152. if err != nil {
  153. sf.t.Fatalf("clickBad1(): in make POST, err=%v", err)
  154. }
  155. if resp.StatusCode != 200 {
  156. sf.t.Fatalf("clickBad1(): status(%v)!=200", resp.StatusCode)
  157. }
  158. }
  159. // Завершение работы
  160. func (sf *tester) done() {
  161. sf.t.Log("done")
  162. if log := sf.mod.Log(); log != sf.mod.log {
  163. sf.t.Fatalf("done(): log is bad")
  164. }
  165. sf.ctx.Cancel()
  166. sf.ctx.Wg().Wait()
  167. if isWork := sf.mod.IsWork(); isWork {
  168. sf.t.Fatalf("done(): isWork==true")
  169. }
  170. }
  171. // Создание нового модуля HTTP-сервера
  172. func (sf *tester) new() {
  173. sf.t.Log("new")
  174. // sf.newBad1()
  175. sf.newGood1()
  176. }
  177. func (sf *tester) newGood1() {
  178. sf.t.Log("newGood1")
  179. _ = mock_env.MakeEnv()
  180. _ = os.Unsetenv("LOCAL_HTTP_URL")
  181. os.Setenv("LOCAL_HTTP_URL", "http://localhost:18334/")
  182. sf.mod = GetModuleWui().Hassert("newGood1()")
  183. kCtx := kctx.GetKernelCtx().Hassert("newGood1()")
  184. kCtx.Set("isLocal", true, "type msg bus").Hassert("newGood1()")
  185. _ = kmonolit.GetMonolit("test_monolit")
  186. _ = GetModuleWui()
  187. sf.mod.Run()
  188. for {
  189. time.Sleep(time.Millisecond * 1)
  190. if sf.mod.IsWork() {
  191. break
  192. }
  193. }
  194. sf.fiberApp = sf.mod.kServHttp.Fiber()
  195. }
  196. // нет ничего для создания модуля
  197. // func (sf *tester) newBad1() {
  198. // sf.t.Log("newBad1")
  199. // defer func() {
  200. // if _panic := recover(); _panic == nil {
  201. // sf.t.Fatalf("newBad1(): panic==nil")
  202. // }
  203. // }()
  204. // _ = GetModuleWui()
  205. // }