| #!/usr/bin/env python3 |
| """ |
| Copyright (c) 2020 Project CHIP Authors |
| |
| Licensed under the Apache License, Version 2.0 (the "License"); |
| you may not use this file except in compliance with the License. |
| You may obtain a copy of the License at |
| |
| http://www.apache.org/licenses/LICENSE-2.0 |
| |
| Unless required by applicable law or agreed to in writing, software |
| distributed under the License is distributed on an "AS IS" BASIS, |
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| See the License for the specific language governing permissions and |
| limitations under the License. |
| """ |
| |
| import logging |
| import os |
| import sys |
| import time |
| |
| from helper.CHIPTestBase import CHIPVirtualHome |
| |
| logger = logging.getLogger('CHIPOnOffTest') |
| logger.setLevel(logging.INFO) |
| |
| sh = logging.StreamHandler() |
| sh.setFormatter( |
| logging.Formatter( |
| '%(asctime)s [%(name)s] %(levelname)s %(message)s')) |
| logger.addHandler(sh) |
| |
| SETUPPINCODE = 20202021 |
| DISCRIMINATOR = 1 # Randomw number, not used |
| CHIP_PORT = 5540 |
| CHIP_REPO = os.path.join(os.path.abspath( |
| os.path.dirname(__file__)), "..", "..", "..") |
| |
| CIRQUE_URL = "http://localhost:5000" |
| |
| DEVICE_CONFIG = { |
| 'device0': { |
| 'type': 'CHIP-Server', |
| 'base_image': 'connectedhomeip/chip-cirque-device-base', |
| 'capability': ['Thread', 'Interactive', 'Mount'], |
| 'rcp_mode': True, |
| "mount_pairs": [[CHIP_REPO, CHIP_REPO]], |
| }, |
| 'device1': { |
| 'type': 'CHIP-Tool', |
| 'base_image': 'connectedhomeip/chip-cirque-device-base', |
| 'capability': ['Thread', 'Interactive', 'Mount'], |
| 'rcp_mode': True, |
| "mount_pairs": [[CHIP_REPO, CHIP_REPO]], |
| } |
| } |
| |
| |
| class TestOnOffCluster(CHIPVirtualHome): |
| def __init__(self, device_config): |
| super().__init__(CIRQUE_URL, device_config) |
| self.logger = logger |
| |
| def setup(self): |
| self.initialize_home() |
| self.connect_to_thread_network() |
| |
| def test_routine(self): |
| self.run_data_model_test() |
| |
| def run_data_model_test(self): |
| server_ip_address = set() |
| tool_device_id = '' |
| |
| server_ids = [device['id'] for device in self.non_ap_devices |
| if device['type'] == 'CHIP-Server'] |
| tool_ids = [device['id'] for device in self.non_ap_devices |
| if device['type'] == 'CHIP-Tool'] |
| |
| tool_device_id = tool_ids[0] |
| |
| for device_id in server_ids: |
| self.execute_device_cmd(device_id, "CHIPCirqueDaemon.py -- run {} --thread".format( |
| os.path.join(CHIP_REPO, "out/debug/standalone/chip-lighting-app"))) |
| server_ip_address.add(self.get_device_thread_ip(device_id)) |
| |
| chip_tool_path = os.path.join( |
| CHIP_REPO, "out/debug/standalone/chip-tool") |
| |
| command = chip_tool_path + " onoff {} 1" |
| |
| for ip in server_ip_address: |
| ret = self.execute_device_cmd( |
| tool_device_id, chip_tool_path + " pairing softap {} {} {} {}".format(SETUPPINCODE, DISCRIMINATOR, ip, CHIP_PORT)) |
| self.assertEqual(ret['return_code'], '0', "{} command failure: {}".format( |
| "pairing softap", ret['output'])) |
| |
| ret = self.execute_device_cmd(tool_device_id, command.format("on")) |
| self.assertEqual( |
| ret['return_code'], '0', "{} command failure: {}".format("on", ret['output'])) |
| |
| ret = self.execute_device_cmd( |
| tool_device_id, command.format("off")) |
| self.assertEqual( |
| ret['return_code'], '0', "{} command failure: {}".format("off", ret['output'])) |
| |
| ret = self.execute_device_cmd( |
| tool_device_id, "chip-tool pairing unpair") |
| self.assertEqual(ret['return_code'], '0', "{} command failure: {}".format( |
| "pairing unpair", ret['output'])) |
| |
| time.sleep(1) |
| |
| for device_id in server_ids: |
| self.logger.info("checking device log for {}".format( |
| self.get_device_pretty_id(device_id))) |
| self.assertTrue(self.sequenceMatch(self.get_device_log(device_id).decode('utf-8'), [ |
| "Thread initialized.", |
| "LightingManager::InitiateAction(ON_ACTION)", |
| "LightingManager::InitiateAction(OFF_ACTION)" |
| ]), "Datamodel test failed: cannot find matching string from device {}".format(device_id)) |
| |
| |
| if __name__ == "__main__": |
| sys.exit(TestOnOffCluster(DEVICE_CONFIG).run_test()) |