func_test.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package envitem
  2. import (
  3. "encoding/json"
  4. "testing"
  5. "time"
  6. )
  7. func TestEnvItem_GetCurrentData(t *testing.T) {
  8. SetOptions(Options{GtServerIp: "47.96.12.136:8788"})
  9. e := EnvItem{
  10. ProjectId: 92,
  11. Item: "C.M.LT_CIP@out,C.M.RO1_DB@time_CS_display",
  12. }
  13. v, ht, err := e.getCurrentValue()
  14. t.Log(v, ht, err)
  15. }
  16. func TestMultiEnvItem_FillCurrentValue(t *testing.T) {
  17. SetOptions(Options{GtServerIp: "47.96.12.136:8788"})
  18. m := make(MultiEnvItem, 2)
  19. m["C.M.LT_CIP@out"] = &EnvItem{
  20. ProjectId: 92,
  21. Item: "C.M.LT_CIP@out",
  22. }
  23. m["C.M.RO1_DB@time_CS_display"] = &EnvItem{
  24. ProjectId: 92,
  25. Item: "C.M.RO1_DB@time_CS_display",
  26. }
  27. err := m.FillCurrentValue()
  28. t.Log(err)
  29. for s, item := range m {
  30. t.Logf("item: %s value: %s htime: %s", s, item.Value, item.Htime)
  31. }
  32. }
  33. func TestMultiEnvItem_FillCurrentValue2(t *testing.T) {
  34. SetOptions(Options{GtServerIp: "47.96.12.136:8788"})
  35. 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}}`
  36. var multiEnvItems MultiEnvItem
  37. _ = json.Unmarshal([]byte(js), &multiEnvItems)
  38. t.Log(multiEnvItems)
  39. for {
  40. _ = multiEnvItems.FillCurrentValue()
  41. time.Sleep(2 * time.Second)
  42. //ms := multiEnvItems.FindString()
  43. t.Logf("%+v", multiEnvItems)
  44. t.Logf("step: %d", multiEnvItems.GetItemInt64Value("step"))
  45. //early := checkEarly(multiEnvItems.GetItemFloat64Value("Display_Time"), multiEnvItems.GetItemFloat64Value("Filter_Time_Set"), multiEnvItems.GetItemStringValue("Step"))
  46. //advanced := checkAdvanced(multiEnvItems.GetItemFloat64Value("Display_Time"), multiEnvItems.GetItemFloat64Value("Filter_Time_Set"), multiEnvItems.GetItemStringValue("Step"))
  47. //
  48. //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"))
  49. //t.Log(err)
  50. //for s, item := range multiEnvItems {
  51. // t.Logf("item: %s value: %s htime: %s", s, item.Value, item.Htime)
  52. //}
  53. }
  54. }
  55. func checkEarly(ft, fst float64, step string) bool {
  56. return step == "26" && ft >= 360 && ft <= 660
  57. }
  58. func checkAdvanced(ft, fst float64, step string) bool {
  59. return step == "26" && ft+360 >= fst && ft+60 <= fst
  60. }