|
| 1 | +"""Test mower data containers.""" |
| 2 | + |
| 3 | +import dataclasses |
| 4 | + |
| 5 | +from roborock.data import MowerStatus |
| 6 | +from roborock.roborock_message import RoborockMowerDataProtocol |
| 7 | + |
| 8 | + |
| 9 | +def test_mower_status_from_dict() -> None: |
| 10 | + status = MowerStatus.from_dict( |
| 11 | + { |
| 12 | + "error_code": 0, |
| 13 | + "battery": 82, |
| 14 | + "mow_state": 3, |
| 15 | + "mowHeight": 70, |
| 16 | + "gpsCoordinate": {"latitude": 1, "longitude": 2}, |
| 17 | + "unknown": "ignored", |
| 18 | + } |
| 19 | + ) |
| 20 | + |
| 21 | + assert status.error_code == 0 |
| 22 | + assert status.battery == 82 |
| 23 | + assert status.mow_state == 3 |
| 24 | + assert status.mow_height == 70 |
| 25 | + assert status.gps_coordinate == {"latitude": 1, "longitude": 2} |
| 26 | + |
| 27 | + |
| 28 | +def test_mower_status_dps_metadata() -> None: |
| 29 | + dps_by_field = { |
| 30 | + field.name: field.metadata["dps"] |
| 31 | + for field in dataclasses.fields(MowerStatus) |
| 32 | + if field.metadata and "dps" in field.metadata |
| 33 | + } |
| 34 | + |
| 35 | + assert dps_by_field == { |
| 36 | + "error_code": RoborockMowerDataProtocol.ERROR_CODE, |
| 37 | + "battery": RoborockMowerDataProtocol.BATTERY, |
| 38 | + "mow_type": RoborockMowerDataProtocol.MOW_TYPE, |
| 39 | + "mow_state": RoborockMowerDataProtocol.MOW_STATE, |
| 40 | + "mapping_type": RoborockMowerDataProtocol.MAPPING_TYPE, |
| 41 | + "mapping_state": RoborockMowerDataProtocol.MAPPING_STATE, |
| 42 | + "ota_state": RoborockMowerDataProtocol.OTA_STATE, |
| 43 | + "charge_state": RoborockMowerDataProtocol.CHARGE_STATE, |
| 44 | + "dock_state": RoborockMowerDataProtocol.DOCK_STATE, |
| 45 | + "charge_type": RoborockMowerDataProtocol.CHARGE_TYPE, |
| 46 | + "pend_type": RoborockMowerDataProtocol.PEND_TYPE, |
| 47 | + "remote_state": RoborockMowerDataProtocol.REMOTE_STATE, |
| 48 | + "mow_start_type": RoborockMowerDataProtocol.MOW_START_TYPE, |
| 49 | + "mow_eff_mode": RoborockMowerDataProtocol.MOW_EFF_MODE, |
| 50 | + "mow_height": RoborockMowerDataProtocol.MOW_HEIGHT, |
| 51 | + "mow_direction_angle": RoborockMowerDataProtocol.MOW_DIRECTION_ANGLE, |
| 52 | + "mow_patten": RoborockMowerDataProtocol.MOW_PATTEN, |
| 53 | + "mow_conf_mode": RoborockMowerDataProtocol.MOW_CONF_MODE, |
| 54 | + "offline_status": RoborockMowerDataProtocol.OFFLINE_STATUS, |
| 55 | + "mow_progress": RoborockMowerDataProtocol.MOW_PROGRESS, |
| 56 | + "blade_lifespan": RoborockMowerDataProtocol.BLADE_LIFESPAN, |
| 57 | + "fc_state": RoborockMowerDataProtocol.FC_STATE, |
| 58 | + "gps_coordinate": RoborockMowerDataProtocol.GPS_COORDINATE, |
| 59 | + "off_dock_no_task_status": RoborockMowerDataProtocol.OFF_DOCK_NO_TASK_STATUS, |
| 60 | + "afs_status": RoborockMowerDataProtocol.AFS_STATUS, |
| 61 | + "network_channel": RoborockMowerDataProtocol.NETWORK_CHANNEL, |
| 62 | + } |
| 63 | + |
| 64 | + |
| 65 | +def test_mower_command_dps_are_not_status_fields() -> None: |
| 66 | + status_dps = { |
| 67 | + field.metadata["dps"] for field in dataclasses.fields(MowerStatus) if field.metadata and "dps" in field.metadata |
| 68 | + } |
| 69 | + |
| 70 | + assert RoborockMowerDataProtocol.START not in status_dps |
| 71 | + assert RoborockMowerDataProtocol.DOCK not in status_dps |
| 72 | + assert RoborockMowerDataProtocol.PAUSE not in status_dps |
| 73 | + assert RoborockMowerDataProtocol.RESUME not in status_dps |
| 74 | + assert RoborockMowerDataProtocol.STOP not in status_dps |
0 commit comments