def test_gateway_send_data_for_device(test_topic, test_registry_id, device_and_gateways, capsys): # noqa (device_id, gateway_id, _) = device_and_gateways # Setup for listening for config messages num_messages = 5 jwt_exp_time = 60 listen_time = 20 # Connect the gateway cloudiot_mqtt_example.send_data_from_bound_device( service_account_json, project_id, cloud_region, test_registry_id, device_id, gateway_id, num_messages, rsa_private_path, "RS256", ca_cert_path, mqtt_bridge_hostname, mqtt_bridge_port, jwt_exp_time, listen_time, ) out, _ = capsys.readouterr() assert "Publishing message 5/5" in out assert "Received message" in out
def test_gateway_send_data_for_device(test_topic, capsys): gateway_id = device_id_template.format('RS256') device_id = device_id_template.format('noauthbind') manager.create_registry( service_account_json, project_id, cloud_region, pubsub_topic, registry_id) manager.create_gateway( service_account_json, project_id, cloud_region, registry_id, None, gateway_id, rsa_cert_path, 'RS256') manager.create_device( service_account_json, project_id, cloud_region, registry_id, device_id) manager.bind_device_to_gateway( service_account_json, project_id, cloud_region, registry_id, device_id, gateway_id) # Setup for listening for config messages num_messages = 5 jwt_exp_time = 60 listen_time = 20 # Connect the gateway cloudiot_mqtt_example.send_data_from_bound_device( service_account_json, project_id, cloud_region, registry_id, device_id, gateway_id, num_messages, rsa_private_path, 'RS256', ca_cert_path, mqtt_bridge_hostname, mqtt_bridge_port, jwt_exp_time, listen_time) # Clean up manager.unbind_device_from_gateway( service_account_json, project_id, cloud_region, registry_id, device_id, gateway_id) manager.delete_device( service_account_json, project_id, cloud_region, registry_id, device_id) manager.delete_device( service_account_json, project_id, cloud_region, registry_id, gateway_id) manager.delete_registry( service_account_json, project_id, cloud_region, registry_id) out, _ = capsys.readouterr() assert 'Publishing message 5/5' in out assert 'Out of memory' not in out # Indicates could not connect
def test_gateway_send_data_for_device(test_topic, capsys): gateway_id = device_id_template.format('RS256') device_id = device_id_template.format('noauthbind') manager.create_registry( service_account_json, project_id, cloud_region, pubsub_topic, registry_id) manager.create_gateway( service_account_json, project_id, cloud_region, registry_id, None, gateway_id, rsa_cert_path, 'RS256') manager.create_device( service_account_json, project_id, cloud_region, registry_id, device_id) manager.bind_device_to_gateway( service_account_json, project_id, cloud_region, registry_id, device_id, gateway_id) # Setup for listening for config messages num_messages = 5 jwt_exp_time = 60 listen_time = 20 # Connect the gateway cloudiot_mqtt_example.send_data_from_bound_device( service_account_json, project_id, cloud_region, registry_id, device_id, gateway_id, num_messages, rsa_private_path, 'RS256', ca_cert_path, mqtt_bridge_hostname, mqtt_bridge_port, jwt_exp_time, listen_time) # Clean up manager.unbind_device_from_gateway( service_account_json, project_id, cloud_region, registry_id, device_id, gateway_id) manager.delete_device( service_account_json, project_id, cloud_region, registry_id, device_id) manager.delete_device( service_account_json, project_id, cloud_region, registry_id, gateway_id) manager.delete_registry( service_account_json, project_id, cloud_region, registry_id) out, _ = capsys.readouterr() assert 'Publishing message 5/5' in out assert 'Out of memory' not in out # Indicates could not connect
def test_gateway_send_data_for_device(test_topic, test_registry_id, device_and_gateways, capsys): # noqa (device_id, gateway_id, _) = device_and_gateways # Setup for listening for config messages num_messages = 5 jwt_exp_time = 60 listen_time = 20 # Connect the gateway cloudiot_mqtt_example.send_data_from_bound_device( service_account_json, project_id, cloud_region, test_registry_id, device_id, gateway_id, num_messages, rsa_private_path, 'RS256', ca_cert_path, mqtt_bridge_hostname, mqtt_bridge_port, jwt_exp_time, listen_time) out, _ = capsys.readouterr() assert 'Publishing message 5/5' in out assert 'Received message' in out # We know we sometimes get 'Out of memory' in the output. # We'd like to know when this occurs with verbose log output. assert 'Out of memory' not in out # Indicates could not connect
client.on_message = log_on_message cloudiot_mqtt_example.listen_for_messages( service_account_json, project_id, cloud_region, registry_id, device_id, gateway_id, num_messages, rsa_private_path, 'RS256', ca_cert_path, mqtt_bridge_hostname, mqtt_bridge_port, jwt_exp_time, listen_time, log_callback) # [END iot_gateway_demo_listen] # [START iot_gateway_demo_publish] print('Publishing messages demo') print('Publishing: {} messages'.format(num_messages)) cloudiot_mqtt_example.send_data_from_bound_device( service_account_json, project_id, cloud_region, registry_id, device_id, gateway_id, num_messages, rsa_private_path, 'RS256', ca_cert_path, mqtt_bridge_hostname, mqtt_bridge_port, jwt_exp_time, "Hello from gateway_demo.py") print('You can read the state messages for your device at this URL:') print('\t{}'.format(device_url_template).format( registry_id, device_id, project_id)) try: input('Press enter to continue after reading the messages.') except SyntaxError: pass # [END iot_gateway_demo_publish] # [START iot_gateway_demo_cleanup] # Clean up manager.unbind_device_from_gateway(
listen_time, log_callback, ) # [END iot_gateway_demo_listen] # [START iot_gateway_demo_publish] print("Publishing messages demo") print("Publishing: {} messages".format(num_messages)) cloudiot_mqtt_example.send_data_from_bound_device( service_account_json, project_id, cloud_region, registry_id, device_id, gateway_id, num_messages, rsa_private_path, "RS256", ca_cert_path, mqtt_bridge_hostname, mqtt_bridge_port, jwt_exp_time, "Hello from gateway_demo.py", ) print("You can read the state messages for your device at this URL:") print("\t{}".format(device_url_template).format(registry_id, device_id, project_id)) try: input("Press enter to continue after reading the messages.") except SyntaxError: pass # [END iot_gateway_demo_publish]