func_test.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. package envitem
  2. import (
  3. "encoding/json"
  4. "github.com/go-redis/redis/v8"
  5. "testing"
  6. "time"
  7. )
  8. func TestEnvItem_GetCurrentData(t *testing.T) {
  9. SetOptions(Options{GtServerIp: "47.96.12.136:8788"})
  10. e := EnvItem{
  11. ProjectId: 92,
  12. Item: "C.M.LT_QSC@out",
  13. }
  14. v, ht, err := e.getCurrentValue()
  15. t.Log(v, ht, err)
  16. }
  17. func TestMultiEnvItem_FillCurrentValue(t *testing.T) {
  18. cache := redis.NewClient(&redis.Options{Addr: "47.96.12.136:6379", Password: "", MaxRetries: 5})
  19. SetOptions(Options{GtServerIp: "47.96.12.136:8788", FetchMultiItem: false, Cache: cache, AdjustValue: true})
  20. m := make(MultiEnvItem, 2)
  21. m["C.M.LT_CIP@out"] = &EnvItem{
  22. ProjectId: 92,
  23. Item: "C.M.LT_CIP@out",
  24. }
  25. m["C.M.RO1_DB@time_CS_display"] = &EnvItem{
  26. ProjectId: 92,
  27. Item: "C.M.RO1_DB@time_CS_display",
  28. }
  29. m["C.M.LT_QSC@out"] = &EnvItem{
  30. ProjectId: 92,
  31. Item: "C.M.LT_QSC@out",
  32. }
  33. err := m.FillCurrentValue()
  34. t.Log(err)
  35. for s, item := range m {
  36. t.Logf("item: %s value: %s htime: %s", s, item.Value, item.Htime)
  37. }
  38. m["C.M.LT_QSC@out"].ClearAdjust()
  39. }
  40. func TestMultiEnvItem_FillCurrentValue2(t *testing.T) {
  41. cache := redis.NewClient(&redis.Options{Addr: "47.96.12.136:6379", Password: "", MaxRetries: 5})
  42. SetOptions(Options{GtServerIp: "47.96.12.136:8788", FetchMultiItem: false, Cache: cache})
  43. js := `{"tmp":{"project_id":92,"device_code":"UF-4001A","plc_device_id":"0","item":"C.M.UF1_DB@press_PV","default_val":0},"feed_flow":{"project_id":92,"device_code":"UF-4001A","plc_device_id":"0","item":"C.M.UF1_FT_JS@out","default_val":0},"feed_pressure":{"project_id":92,"device_code":"UF-4001A","plc_device_id":"0","item":"C.M.UF1_PT_JS@out","default_val":0},"product_pressure":{"project_id":92,"device_code":"UF-4001A","plc_device_id":"0","item":"C.M.UF1_PT_CS@out","default_val":0},"feed_wq_turbidity":{"project_id":92,"device_code":"AIT-94061","plc_device_id":"0","item":"C.M.UF_Tur_ZJS@out","default_val":0},"water_temperature":{"project_id":92,"device_code":"TIT-34061","plc_device_id":"0","item":"C.M.RO_TT_ZJS@out","default_val":0},"product_wq_ph":{"project_id":92,"device_code":"AIT-95065b","plc_device_id":"0","item":"C.M.UF_PH_ZCS@out","default_val":0},"step":{"project_id":92,"device_code":"HB","plc_device_id":"0","item":"C.M.UF1_DB@word_control","default_val":0}}`
  44. var multiEnvItems MultiEnvItem
  45. _ = json.Unmarshal([]byte(js), &multiEnvItems)
  46. t.Log(multiEnvItems)
  47. _ = multiEnvItems.FillCurrentValue()
  48. for {
  49. //_ = multiEnvItems.FillCurrentValue()
  50. multiEnvItems.ClearValues()
  51. v := multiEnvItems.GetItemFloat64Value("feed_flow")
  52. t.Logf("item: %s, %f", "feed_flow", v)
  53. //for s, item := range multiEnvItems {
  54. // if item != nil {
  55. // t.Logf("item: %s value: %f htime: %v", s, item.GetItemFloat64Val(), item.GetItemHtime())
  56. // } else {
  57. // t.Logf("item: %s fetch failure", s)
  58. // }
  59. //
  60. //}
  61. time.Sleep(2 * time.Second)
  62. //ms := multiEnvItems.FindString()
  63. //t.Logf("%+v", multiEnvItems)
  64. //t.Logf("step: %d", multiEnvItems.GetItemInt64Value("step"))
  65. //early := checkEarly(multiEnvItems.GetItemFloat64Value("Display_Time"), multiEnvItems.GetItemFloat64Value("Filter_Time_Set"), multiEnvItems.GetItemStringValue("Step"))
  66. //advanced := checkAdvanced(multiEnvItems.GetItemFloat64Value("Display_Time"), multiEnvItems.GetItemFloat64Value("Filter_Time_Set"), multiEnvItems.GetItemStringValue("Step"))
  67. //
  68. //t.Logf("early: %v, advanced: %v, step: %s filterNumber: %s Display_Time: %s Filter_Time_Set: %s", early, advanced, multiEnvItems.GetItemStringValue("Step"), multiEnvItems.GetItemStringValue("Filter_Number"), multiEnvItems.GetItemStringValue("Display_Time"), multiEnvItems.GetItemStringValue("Filter_Time_Set"))
  69. //t.Log(err)
  70. //for s, item := range multiEnvItems {
  71. // t.Logf("item: %s value: %s htime: %s", s, item.Value, item.Htime)
  72. //}
  73. }
  74. }
  75. func TestEnvItem_Adjust(t *testing.T) {
  76. cache := redis.NewClient(&redis.Options{Addr: "47.96.12.136:6379", Password: "", MaxRetries: 5})
  77. SetOptions(Options{GtServerIp: "47.96.12.136:8788", Cache: cache, AdjustValue: true})
  78. e := EnvItem{
  79. ProjectId: 92,
  80. Item: "C.M.LT_QSC@out",
  81. }
  82. //v, ht, err := e.getCurrentValue()
  83. //e.IncreAdjust(3600 * time.Second)
  84. //e.IncreAdjust(3600 * time.Second)
  85. e.IncreAdjust(3600 * time.Second)
  86. //
  87. //e.SetAdjust("65325", 3*time.Second)
  88. adjust, err := e.GetAdjustInt64Val()
  89. //t.Log(v, ht, err)
  90. t.Log(adjust, err)
  91. }
  92. func TestEnvItem_GetValueForAdjust(t *testing.T) {
  93. cache := redis.NewClient(&redis.Options{Addr: "47.96.12.136:6379", Password: "", MaxRetries: 5})
  94. SetOptions(Options{GtServerIp: "47.96.12.136:8788", Cache: cache, AdjustValue: false})
  95. e := EnvItem{
  96. ProjectId: 92,
  97. Item: "C.M.LT_QSC@out",
  98. }
  99. v := e.GetItemFloat64Val()
  100. t.Log(v)
  101. }