func_test.go 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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", ms)
  44. //early := checkEarly(multiEnvItems.GetItemFloat64Value("Display_Time"), multiEnvItems.GetItemFloat64Value("Filter_Time_Set"), multiEnvItems.GetItemStringValue("Step"))
  45. //advanced := checkAdvanced(multiEnvItems.GetItemFloat64Value("Display_Time"), multiEnvItems.GetItemFloat64Value("Filter_Time_Set"), multiEnvItems.GetItemStringValue("Step"))
  46. //
  47. //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"))
  48. //t.Log(err)
  49. //for s, item := range multiEnvItems {
  50. // t.Logf("item: %s value: %s htime: %s", s, item.Value, item.Htime)
  51. //}
  52. }
  53. }
  54. func checkEarly(ft, fst float64, step string) bool {
  55. return step == "26" && ft >= 360 && ft <= 660
  56. }
  57. func checkAdvanced(ft, fst float64, step string) bool {
  58. return step == "26" && ft+360 >= fst && ft+60 <= fst
  59. }