solax-py-library 1.0.0.2601__tar.gz → 1.0.0.2602__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (84) hide show
  1. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/PKG-INFO +1 -1
  2. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/pyproject.toml +1 -1
  3. solax_py_library-1.0.0.2602/solax_py_library/device/types/device.py +26 -0
  4. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/constant/message_entry.py +13 -1
  5. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/cabinet_condition.py +2 -5
  6. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/types/condition.py +8 -1
  7. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/types/condition_value.py +6 -6
  8. solax_py_library-1.0.0.2602/solax_py_library/test/test_smart_scene/test_condition.py +66 -0
  9. solax_py_library-1.0.0.2601/solax_py_library/device/types/device.py +0 -16
  10. solax_py_library-1.0.0.2601/solax_py_library/test/test_smart_scene/test_condition.py +0 -45
  11. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/README.md +0 -0
  12. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/__init__.py +0 -0
  13. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/__init__.py +0 -0
  14. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/constant/__init__.py +0 -0
  15. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/constant/cabinet.py +0 -0
  16. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/constant/inverter_model_info.py +0 -0
  17. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/core/__init__.py +0 -0
  18. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/core/interver/__init__.py +0 -0
  19. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/core/interver/base.py +0 -0
  20. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/types/__init__.py +0 -0
  21. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/types/alarm.py +0 -0
  22. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/types/inverter_config.py +0 -0
  23. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/device/types/modbus_point.py +0 -0
  24. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/exception.py +0 -0
  25. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/__init__.py +0 -0
  26. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/constant/__init__.py +0 -0
  27. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/__init__.py +0 -0
  28. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/action/__init__.py +0 -0
  29. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/action/base.py +0 -0
  30. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/action/ems_action.py +0 -0
  31. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/action/system_action.py +0 -0
  32. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/__init__.py +0 -0
  33. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/base.py +0 -0
  34. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/date_condition.py +0 -0
  35. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/price_condition.py +0 -0
  36. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/system_condition.py +0 -0
  37. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/condition/weather_condition.py +0 -0
  38. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/service/__init__.py +0 -0
  39. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/core/service/runner.py +0 -0
  40. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/exceptions/__init__.py +0 -0
  41. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/exceptions/price.py +0 -0
  42. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/exceptions/smart_scene.py +0 -0
  43. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/exceptions/weather.py +0 -0
  44. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/types/__init__.py +0 -0
  45. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/types/action.py +0 -0
  46. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/smart_scene/types/smart_scene_content.py +0 -0
  47. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/__init__.py +0 -0
  48. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/constant/__init__.py +0 -0
  49. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/constant/crc_table.py +0 -0
  50. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/core/__init__.py +0 -0
  51. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/core/base_modbus.py +0 -0
  52. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/core/parser.py +0 -0
  53. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/core/snap_shot.py +0 -0
  54. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/exceptions/__init__.py +0 -0
  55. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/exceptions/snap_shot.py +0 -0
  56. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/test/__init__.py +0 -0
  57. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/types/__init__.py +0 -0
  58. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/snap_shot/types/address.py +0 -0
  59. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/test/__init__.py +0 -0
  60. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/test/test_smart_scene/__init__.py +0 -0
  61. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/test/test_utils/__init__.py +0 -0
  62. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/test/test_utils/test_cloud_client.py +0 -0
  63. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/__init__.py +0 -0
  64. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/api/__init__.py +0 -0
  65. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/api/service.py +0 -0
  66. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/__init__.py +0 -0
  67. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/data_adapter/__init__.py +0 -0
  68. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/data_adapter/base.py +0 -0
  69. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/data_adapter/csv.py +0 -0
  70. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/upload_service/__init__.py +0 -0
  71. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/upload_service/base.py +0 -0
  72. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/core/upload_service/ftp.py +0 -0
  73. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/exceptions/__init__.py +0 -0
  74. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/exceptions/upload_error.py +0 -0
  75. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/test/__init__.py +0 -0
  76. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/test/test_ftp.py +0 -0
  77. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/types/__init__.py +0 -0
  78. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/types/client.py +0 -0
  79. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/upload/types/ftp.py +0 -0
  80. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/utils/__init__.py +0 -0
  81. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/utils/cloud_client.py +0 -0
  82. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/utils/common.py +0 -0
  83. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/utils/struct_util.py +0 -0
  84. {solax_py_library-1.0.0.2601 → solax_py_library-1.0.0.2602}/solax_py_library/utils/time_util.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: solax-py-library
3
- Version: 1.0.0.2601
3
+ Version: 1.0.0.2602
4
4
  Summary: some common tool
5
5
  Author: shenlvyu
6
6
  Author-email: 13296718439@163.com
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "solax-py-library"
3
- version = "1.0.0.2601"
3
+ version = "1.0.0.2602"
4
4
  description = "some common tool"
5
5
  authors = ["shenlvyu <13296718439@163.com>", "x5m8944pjl <371630856@qq.com>"]
6
6
  readme = "README.md"
@@ -0,0 +1,26 @@
1
+ from enum import IntEnum
2
+
3
+
4
+ class DeviceType(IntEnum):
5
+ EMS_TYPE = 100
6
+ PCS_TYPE = 1
7
+ BMS_TYPE = 2 # 电池簇
8
+ ELM_TYPE = 3
9
+ EVC_TYPE = 4
10
+ IO_TYPE = 5
11
+ ESS_TYPE = 6 # 机柜
12
+ CELL_TYPE = 7 # 单体
13
+ AIRCONDITIONER_TYPE = 501
14
+ FIRE_SAFETY_TYPE = 502
15
+ COLD_TYPE = 503
16
+ DEHUMIDIFY_TYPE = 504
17
+
18
+ def __str__(self):
19
+ return {
20
+ DeviceType.PCS_TYPE: "pcs",
21
+ DeviceType.BMS_TYPE: "bms",
22
+ DeviceType.ELM_TYPE: "elm",
23
+ DeviceType.IO_TYPE: "io",
24
+ DeviceType.AIRCONDITIONER_TYPE: "air_conditioner",
25
+ DeviceType.COLD_TYPE: "liquid_cooling_unit",
26
+ }.get(self)
@@ -170,10 +170,22 @@ MESSAGE_ENTRY = {
170
170
  "EMERGENCY": {"zh_CN": "紧急告警", "en_US": "Emergency alarm"},
171
171
  "TIPS": {"zh_CN": "状态提醒", "en_US": "State Tips"},
172
172
  "NORMAL": {"zh_CN": "普通告警", "en_US": "Normal alarm"},
173
- "cabinetAlarm": {"zh_CN": "机柜发生{}", "en_US": "cabinet occurs {}"},
173
+ "cabinetAlarm": {
174
+ "zh_CN": "机柜下属({})设备发生{}",
175
+ "en_US": "The equipments({}) under the cabinet occurs {}",
176
+ },
174
177
  "OR": {"zh_CN": "满足任一条件", "en_US": "Meet any of the conditions"},
175
178
  "AND": {"zh_CN": "满足所有条件", "en_US": "Meet all conditions"},
176
179
  "tips_alarm": {"zh_CN": "状态提醒", "en_US": "Alarm tips"},
177
180
  "normal_alarm": {"zh_CN": "普通告警", "en_US": "Normal alarm"},
178
181
  "emergency_alarm": {"zh_CN": "紧急告警", "en_US": "Emergency alarm"},
182
+ "pcs": {"zh_CN": "逆变器", "en_US": "Inverter"},
183
+ "bms": {"zh_CN": "电池", "en_US": "Battery"},
184
+ "elm": {
185
+ "zh_CN": "电表",
186
+ "en_US": "Meter",
187
+ },
188
+ "io": {"zh_CN": "IO模块", "en_US": "IO Module"},
189
+ "air_conditioner": {"zh_CN": "空调", "en_US": "Air conditioner"},
190
+ "liquid_cooling_unit": {"zh_CN": "液冷机组", "en_US": "Liquid Cooling Unit"},
179
191
  }
@@ -6,7 +6,6 @@ from solax_py_library.smart_scene.types.condition import (
6
6
  CabinetConditionType,
7
7
  ConditionType,
8
8
  )
9
- from solax_py_library.device.types.alarm import AlarmLevel
10
9
  from solax_py_library.smart_scene.types.condition_value import CabinetValue
11
10
 
12
11
 
@@ -15,9 +14,7 @@ class CabinetCondition(BaseCondition):
15
14
 
16
15
  def __init__(self, update_value_function, **kwargs):
17
16
  super().__init__(update_value_function, **kwargs)
18
- self.value = defaultdict(
19
- lambda: CabinetValue
20
- )
17
+ self.value = defaultdict(lambda: CabinetValue)
21
18
 
22
19
  def meet_func(self, data: CabinetConditionItemData, ctx):
23
20
  if not self.value:
@@ -42,6 +39,6 @@ class CabinetCondition(BaseCondition):
42
39
  alarm_info = cabinet_value.alarm_info(device_type)
43
40
  if not alarm_info:
44
41
  continue
45
- if alarm_info[alarm_type-1] is True:
42
+ if alarm_info[alarm_type - 1] is True:
46
43
  return True
47
44
  return False
@@ -5,6 +5,7 @@ from typing import Optional, List, Union, Any
5
5
  from pydantic import BaseModel, validator, root_validator
6
6
 
7
7
  from solax_py_library.device.types.alarm import AlarmLevel
8
+ from solax_py_library.device.types.device import DeviceType
8
9
  from solax_py_library.smart_scene.constant.message_entry import MESSAGE_ENTRY
9
10
 
10
11
 
@@ -181,7 +182,13 @@ class CabinetConditionItemData(BaseModel):
181
182
  )
182
183
  elif self.childType == CabinetConditionType.cabinetAlarm:
183
184
  return MESSAGE_ENTRY[self.childType][lang].format(
184
- MESSAGE_ENTRY[str(AlarmLevel(data[0]))][lang], lang
185
+ ",".join(
186
+ [
187
+ MESSAGE_ENTRY[str(DeviceType(device_type))][lang]
188
+ for device_type in data[:-1]
189
+ ]
190
+ ),
191
+ MESSAGE_ENTRY[str(AlarmLevel(data[-1]))][lang],
185
192
  )
186
193
 
187
194
 
@@ -7,12 +7,12 @@ from solax_py_library.device.types.device import DeviceType
7
7
 
8
8
  class CabinetValue(BaseModel):
9
9
  soc: int = None
10
- cabinet_alarm: List[bool] = Field(default_factory=lambda :[False, False, False])
11
- pcs_alarm: List[bool] = Field(default_factory=lambda :[False, False, False])
12
- io_alarm: List[bool] = Field(default_factory=lambda :[False, False, False])
13
- bms_alarm: List[bool] = Field(default_factory=lambda :[False, False, False])
14
- air_alarm: List[bool] = Field(default_factory=lambda :[False, False, False])
15
- liquid_alarm: List[bool] = Field(default_factory=lambda :[False, False, False])
10
+ cabinet_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
11
+ pcs_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
12
+ io_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
13
+ bms_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
14
+ air_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
15
+ liquid_alarm: List[bool] = Field(default_factory=lambda: [False, False, False])
16
16
 
17
17
  def alarm_info(self, device_type):
18
18
  if device_type == DeviceType.EMS_TYPE:
@@ -0,0 +1,66 @@
1
+ from unittest import TestCase
2
+
3
+ from solax_py_library.device.types.device import DeviceType
4
+ from solax_py_library.smart_scene.core.condition import (
5
+ DateCondition,
6
+ BaseCondition,
7
+ CabinetCondition,
8
+ )
9
+ from solax_py_library.smart_scene.types.condition import (
10
+ CabinetConditionItemData,
11
+ CabinetConditionType,
12
+ ConditionItemChildData,
13
+ )
14
+ from solax_py_library.smart_scene.types.condition_value import CabinetValue
15
+
16
+
17
+ class TestCondition(TestCase):
18
+ def test_condition_build(self):
19
+ date_condition = DateCondition(
20
+ update_value_function=lambda: 1,
21
+ )
22
+ assert isinstance(date_condition, BaseCondition)
23
+
24
+ def test_cabinet_condition_to_text(self):
25
+ cabinet_condition = CabinetConditionItemData(
26
+ childType=CabinetConditionType.cabinetAlarm,
27
+ childData=ConditionItemChildData(
28
+ data=[DeviceType.IO_TYPE, DeviceType.COLD_TYPE, 1]
29
+ ),
30
+ )
31
+ print(cabinet_condition.to_text(lang="zh_CN", unit="嘻嘻"))
32
+
33
+ def test_cabinet_condition_check(self):
34
+ cabinet_condition = CabinetCondition(
35
+ update_value_function=lambda: {
36
+ "SN1": CabinetValue(
37
+ soc=0,
38
+ io_alarm=[False, True, False],
39
+ ),
40
+ },
41
+ )
42
+ cabinet_condition.update_value()
43
+ assert (
44
+ cabinet_condition.meet_func(
45
+ data=CabinetConditionItemData(
46
+ childType=CabinetConditionType.cabinetAlarm,
47
+ childData=ConditionItemChildData(
48
+ data=[DeviceType.IO_TYPE, DeviceType.COLD_TYPE, 1]
49
+ ),
50
+ ),
51
+ ctx={"cabinet": ["SN1"]},
52
+ )
53
+ is False
54
+ )
55
+ assert (
56
+ cabinet_condition.meet_func(
57
+ data=CabinetConditionItemData(
58
+ childType=CabinetConditionType.cabinetAlarm,
59
+ childData=ConditionItemChildData(
60
+ data=[DeviceType.IO_TYPE, DeviceType.COLD_TYPE, 2]
61
+ ),
62
+ ),
63
+ ctx={"cabinet": ["SN1"]},
64
+ )
65
+ is True
66
+ )
@@ -1,16 +0,0 @@
1
- from enum import IntEnum
2
-
3
-
4
- class DeviceType(IntEnum):
5
- EMS_TYPE = 100
6
- PCS_TYPE = 1
7
- BMS_TYPE = 2 # 电池簇
8
- ELM_TYPE = 3
9
- EVC_TYPE = 4
10
- IO_TYPE = 5
11
- ESS_TYPE = 6 # 机柜
12
- CELL_TYPE = 7 # 单体
13
- AIRCONDITIONER_TYPE = 501
14
- FIRE_SAFETY_TYPE = 502
15
- COLD_TYPE = 503
16
- DEHUMIDIFY_TYPE = 504
@@ -1,45 +0,0 @@
1
- from unittest import TestCase
2
-
3
- from solax_py_library.device.types.device import DeviceType
4
- from solax_py_library.smart_scene.core.condition import DateCondition, BaseCondition, CabinetCondition
5
- from solax_py_library.smart_scene.types.condition import CabinetConditionItemData, CabinetConditionType, \
6
- ConditionItemChildData
7
- from solax_py_library.smart_scene.types.condition_value import CabinetValue
8
-
9
-
10
- class TestCondition(TestCase):
11
- def test_condition(self):
12
- date_condition = DateCondition(
13
- update_value_function=lambda: 1,
14
- )
15
- assert isinstance(date_condition, BaseCondition)
16
-
17
- def test_cabinet_condition(self):
18
- cabinet_condition = CabinetCondition(
19
- update_value_function=lambda: {
20
- "SN1": CabinetValue(
21
- soc=0,
22
- io_alarm=[False, True, False],
23
- ),
24
- },
25
- )
26
- cabinet_condition.update_value()
27
- assert cabinet_condition.meet_func(
28
- data=CabinetConditionItemData(
29
- childType=CabinetConditionType.cabinetAlarm,
30
- childData=ConditionItemChildData(
31
- data=[DeviceType.IO_TYPE, DeviceType.COLD_TYPE, 1]
32
- )
33
- ),
34
- ctx={"cabinet": ["SN1"]}
35
- ) is False
36
- assert cabinet_condition.meet_func(
37
- data=CabinetConditionItemData(
38
- childType=CabinetConditionType.cabinetAlarm,
39
- childData=ConditionItemChildData(
40
- data=[DeviceType.IO_TYPE, DeviceType.COLD_TYPE, 2]
41
- )
42
- ),
43
- ctx={"cabinet": ["SN1"]}
44
- ) is True
45
-