wiliot-certificate 4.4.0a1__tar.gz → 4.4.2__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.
- {wiliot_certificate-4.4.0a1/src/wiliot_certificate.egg-info → wiliot_certificate-4.4.2}/PKG-INFO +73 -32
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/README.md +71 -30
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/pyproject.toml +3 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_results.py +2 -2
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/certificate_bcc_test_list.txt +0 -2
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/calibration/interval_test/interval_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/calibration/interval_test/interval_test.py +2 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/calibration/output_power_test/output_power_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/calibration/output_power_test/output_power_test.py +2 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/calibration/pattern_test/pattern_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/calibration/pattern_test/pattern_test.py +4 -8
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/aging_test/aging_test.py +3 -4
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/num_of_tags_test/num_of_tags_test.py +4 -7
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/output_power_test/output_power_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/output_power_test/output_power_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pacer_interval_ble5_test/pacer_interval_ble5_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pacer_interval_ble5_test/pacer_interval_ble5_test.py +2 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pacer_interval_test/pacer_interval_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pattern_test/pattern_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pattern_test/pattern_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pkt_filter_ble5_test/pkt_filter_ble5_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pkt_filter_ble5_test/pkt_filter_ble5_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pkt_filter_gen3_test/pkt_filter_gen3_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pkt_filter_gen3_test/pkt_filter_gen3_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pkt_filter_test/pkt_filter_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pkt_filter_test/pkt_filter_test.py +2 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/rssi_threshold_test/rssi_threshold_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/rssi_threshold_test/rssi_threshold_test.py +2 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/rx_channel_test/rx_channel_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/rx_channel_test/rx_channel_test.py +2 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/rx_rate_gen2_test/rx_rate_gen2_test.py +9 -6
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/rx_rate_gen3_test/rx_rate_gen3_test.py +9 -6
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/stress_gen3_test/stress_gen3_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/stress_gen3_test/stress_gen3_test.py +17 -11
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/stress_test/stress_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/stress_test/stress_test.py +15 -10
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/tx_repetition_test/tx_repetition_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/tx_repetition_test/tx_repetition_test.py +2 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/actions_test/actions_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/actions_test/actions_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/duty_cycle_test/duty_cycle_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/duty_cycle_test/duty_cycle_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/output_power_test/output_power_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/output_power_test/output_power_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/pattern_test/pattern_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/pattern_test/pattern_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy_sub1g/duty_cycle_test/duty_cycle_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy_sub1g/duty_cycle_test/duty_cycle_test.py +2 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy_sub1g/pattern_test/pattern_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy_sub1g/pattern_test/pattern_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy_sub1g/signal_indicator_test/signal_indicator_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy_sub1g/signal_indicator_test/signal_indicator_test.py +2 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/sensors/ext_sensor_test/ext_sensor_test.json +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/sensors/ext_sensor_test/ext_sensor_test.py +1 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/common/serialization_formatter.py +14 -1
- {wiliot_certificate-4.4.0a1/src/brg_certificate → wiliot_certificate-4.4.2/src/gw_certificate/common}/wltPb_pb2.py +4 -4
- {wiliot_certificate-4.4.0a1/src/brg_certificate → wiliot_certificate-4.4.2/src/gw_certificate/common}/wltPb_pb2.pyi +2 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/gw_certificate.py +2 -2
- wiliot_certificate-4.4.2/src/gw_certificate/interface/4.4.91_app.zip +0 -0
- wiliot_certificate-4.4.0a1/src/gw_certificate/interface/4.4.88_sd_bl_app.zip → wiliot_certificate-4.4.2/src/gw_certificate/interface/4.4.91_sd_bl_app.zip +0 -0
- wiliot_certificate-4.4.2/src/gw_certificate/interface/flash_fw.py +90 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/uart_if.py +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/actions.py +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/downlink.py +2 -2
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/generic.py +4 -3
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/static/generated_packet_table.py +16 -16
- wiliot_certificate-4.4.2/src/gw_certificate/tests/static/packet_table.csv +10067 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/static/uplink_defines.py +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/throughput.py +1 -1
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/uplink.py +38 -19
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2/src/wiliot_certificate.egg-info}/PKG-INFO +73 -32
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/wiliot_certificate.egg-info/SOURCES.txt +3 -2
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/wiliot_certificate.egg-info/requires.txt +1 -1
- wiliot_certificate-4.4.0a1/src/gw_certificate/interface/4.4.88_app.zip +0 -0
- wiliot_certificate-4.4.0a1/src/gw_certificate/tests/static/packet_table.csv +0 -10067
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/LICENSE +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/setup.cfg +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/__init__.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/energous_v0_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/energous_v1_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/energous_v2_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/energous_v3_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/energous_v4_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/fanstel_lan_v0_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/fanstel_lte_v0_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/fanstel_wifi_v0_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/minew_lte_v0_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_cmd_if.html +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types.html +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/brg2brg_ota.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/brg2gw_hb.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/brg2gw_hb_sleep.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/calibration.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/custom.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/datapath.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/energy2400.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/energySub1g.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/externalSensor.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/interface.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/powerManagement.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/side_info_sensor.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/signal_indicator_data.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/unified_echo_ext_pkt.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/ag/wlt_types_ag_jsons/unified_echo_pkt.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/brg_certificate.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/brg_certificate_cli.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_common.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_config.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_data_sim.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_gw_sim.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_mqtt.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_prints.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_protobuf.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/cert_utils.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/certificate_bcc_sanity_test_list.txt +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/certificate_sanity_test_list.txt +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/certificate_test_list.txt +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/config/eclipse.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/config/hivemq.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/config/mosquitto.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/config/mosquitto.md +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/config/wiliot-dev.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/restore_brg.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/aging_test/aging_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/num_of_tags_test/num_of_tags_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pacer_interval_tags_count_test/pacer_interval_tags_count_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pacer_interval_tags_count_test/pacer_interval_tags_count_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/pacer_interval_test/pacer_interval_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/rx_rate_gen2_test/rx_rate_gen2_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/rx_rate_gen3_test/rx_rate_gen3_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/tx_repetition_algo_test/tx_repetition_algo_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/datapath/tx_repetition_algo_test/tx_repetition_algo_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/brg2brg_ota_ble5_test/brg2brg_ota_ble5_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/brg2brg_ota_ble5_test/brg2brg_ota_ble5_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/brg2brg_ota_test/brg2brg_ota_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/brg2brg_ota_test/brg2brg_ota_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/leds_test/leds_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/leds_test/leds_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/ota_test/ota_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/ota_test/ota_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/periodic_msgs_test/periodic_msgs_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/edge_mgmt/periodic_msgs_test/periodic_msgs_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/signal_indicator_ble5_10_250k_test/signal_indicator_ble5_10_250k_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/signal_indicator_ble5_10_250k_test/signal_indicator_ble5_10_250k_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/signal_indicator_ble5_10_500k_test/signal_indicator_ble5_10_500k_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/signal_indicator_ble5_10_500k_test/signal_indicator_ble5_10_500k_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/signal_indicator_sub1g_2_4_test/signal_indicator_sub1g_2_4_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/signal_indicator_sub1g_2_4_test/signal_indicator_sub1g_2_4_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/signal_indicator_test/signal_indicator_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy2400/signal_indicator_test/signal_indicator_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy_sub1g/signal_indicator_functionality_test/signal_indicator_functionality_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/energy_sub1g/signal_indicator_functionality_test/signal_indicator_functionality_test.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/pwr_mgmt/pwr_mgmt_test/pwr_mgmt_test.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/tests/pwr_mgmt/pwr_mgmt_test/pwr_mgmt_test.py +0 -0
- {wiliot_certificate-4.4.0a1/src/gw_certificate/common → wiliot_certificate-4.4.2/src/brg_certificate}/wltPb_pb2.py +0 -0
- {wiliot_certificate-4.4.0a1/src/gw_certificate/common → wiliot_certificate-4.4.2/src/brg_certificate}/wltPb_pb2.pyi +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/brg_certificate/wlt_types.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/common/wlt_logo.png +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/__init__.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/ag/ut_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/ag/wlt_types.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/ag/wlt_types_ag.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/ag/wlt_types_data.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api/extended_api.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/200/data.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/200/logs.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/200/status.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/201/data.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/201/logs.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/201/status.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/202/data.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/202/logs.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/202/status.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/203/data.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/203/logs.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/203/status.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/204/data.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/204/logs.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/204/status.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/205/data.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/205/logs.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/205/status.json +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/__init__.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/api_validation.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/api_if/gw_capabilities.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/cert_results.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/common/analysis_data_bricks.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/common/debug.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/common/utils.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/common/utils_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/gw_certificate_cli.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/ble_simulator.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/ble_sniffer.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/if_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/mqtt.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/nrfutil-linux +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/nrfutil-mac +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/nrfutil.exe +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/pkt_generator.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/interface/uart_ports.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/templates/results.html +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/templates/stage.html +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/templates/table.html +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/templates/test.html +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/__init__.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/bad_crc_to_PER_quantization.csv +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/connection.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/registration.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/static/__init__.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/static/connection_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/static/downlink_defines.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/gw_certificate/tests/static/references.py +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/wiliot_certificate.egg-info/dependency_links.txt +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/wiliot_certificate.egg-info/entry_points.txt +0 -0
- {wiliot_certificate-4.4.0a1 → wiliot_certificate-4.4.2}/src/wiliot_certificate.egg-info/top_level.txt +0 -0
{wiliot_certificate-4.4.0a1/src/wiliot_certificate.egg-info → wiliot_certificate-4.4.2}/PKG-INFO
RENAMED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: wiliot_certificate
|
|
3
|
-
Version: 4.4.
|
|
3
|
+
Version: 4.4.2
|
|
4
4
|
Summary: A library for certifying Wiliot-compliant boards
|
|
5
5
|
Author-email: Wiliot <support@wiliot.com>
|
|
6
6
|
License: MIT License
|
|
@@ -30,13 +30,13 @@ Project-URL: Certified, https://www.wiliot.com/product/ambient-iot-network#partn
|
|
|
30
30
|
Classifier: Programming Language :: Python :: 3
|
|
31
31
|
Classifier: License :: OSI Approved :: MIT License
|
|
32
32
|
Classifier: Operating System :: OS Independent
|
|
33
|
-
Requires-Python: >=3.
|
|
33
|
+
Requires-Python: >=3.9
|
|
34
34
|
Description-Content-Type: text/markdown
|
|
35
35
|
License-File: LICENSE
|
|
36
36
|
Requires-Dist: jinja2>=3.1.5
|
|
37
37
|
Requires-Dist: appdirs>=1.4.4
|
|
38
38
|
Requires-Dist: plotly>=6.0.0
|
|
39
|
-
Requires-Dist: numpy>=
|
|
39
|
+
Requires-Dist: numpy>=1.21.5
|
|
40
40
|
Requires-Dist: pandas>=2.2.3
|
|
41
41
|
Requires-Dist: colorama>=0.4.6
|
|
42
42
|
Requires-Dist: tabulate>=0.9.0
|
|
@@ -52,24 +52,33 @@ Requires-Dist: reportlab>=4.3.1
|
|
|
52
52
|
Requires-Dist: google-api-python-client>=2.162.0
|
|
53
53
|
Dynamic: license-file
|
|
54
54
|
|
|
55
|
-
# wiliot-certificate
|
|
55
|
+
# wiliot-certificate Version 4.4.0
|
|
56
56
|
|
|
57
57
|
<!-- Description -->
|
|
58
|
-
wiliot-certificate is a
|
|
58
|
+
wiliot-certificate is a Python library that provides tools for testing and certifying boards for compatibility with Wiliot’s ecosystem.
|
|
59
59
|
This python package includes the following CLI utilities:
|
|
60
60
|
- Gateway Certificate (`wlt-cert-gw`)
|
|
61
61
|
- Bridge Certificate (`wlt-cert-brg`)
|
|
62
62
|
|
|
63
|
+
# Version:
|
|
64
|
+
wiliot-certificate versions 4.4.0 are compatible with firmware version 4.4.6 (ESP: 4.4.44, BLE: 4.4.93)
|
|
65
|
+
|
|
63
66
|
## Installing wiliot-certificate
|
|
67
|
+
Uninstall wiliot-deployment-tools if installed (relevant for old wlt-gw-certificate users):
|
|
68
|
+
````commandline
|
|
69
|
+
pip uninstall wiliot-deployment-tools
|
|
70
|
+
````
|
|
71
|
+
|
|
72
|
+
Install wiliot-certificate:
|
|
64
73
|
````commandline
|
|
65
74
|
pip install wiliot-certificate
|
|
66
75
|
````
|
|
67
76
|
|
|
68
77
|
## Using wiliot-certificate
|
|
69
78
|
### Gateway Certificate
|
|
70
|
-
Test Wiliot
|
|
71
|
-
The
|
|
72
|
-
To run the
|
|
79
|
+
Test Wiliot Gateway capabilities.
|
|
80
|
+
The Gateway Certificate includes different test that run sequentially to test each capability reported by the Gateway.
|
|
81
|
+
To run the Gateway Certificate the Gateway needs to use a public MQTT Broker (Eclipse):
|
|
73
82
|
|
|
74
83
|
Host: mqtt.eclipseprojects.io
|
|
75
84
|
TLS TCP Port: 8883
|
|
@@ -79,59 +88,91 @@ Websocket Port: 80
|
|
|
79
88
|
|
|
80
89
|
More information can be found at https://mqtt.eclipseprojects.io/.
|
|
81
90
|
|
|
82
|
-
####
|
|
91
|
+
#### Gateway Certificate Release Notes:
|
|
83
92
|
Release:
|
|
84
93
|
- Standalone wiliot-certificate package
|
|
85
94
|
- Python 3.13 support
|
|
86
|
-
-
|
|
95
|
+
- Gateway API version 205 support
|
|
87
96
|
- Registration test added
|
|
88
97
|
- Bridge OTA stage added under actions
|
|
89
98
|
- Aggregation flag supported by StressTest
|
|
90
99
|
- -update flag compatibility fix. Upgrades bootloader if needed
|
|
91
100
|
- -actions flag to select specific actions to test
|
|
101
|
+
- ACL (Access control list) test for gateways reporting API version 205 in the connection test
|
|
102
|
+
|
|
103
|
+
#### The following capabilities are not tested in this version
|
|
104
|
+
- Access control list stress stress
|
|
105
|
+
- Validation schema verification
|
|
106
|
+
- Board type registered within the Board Type Management system
|
|
107
|
+
- Bridge OTA progress reporting
|
|
108
|
+
|
|
92
109
|
|
|
93
110
|
```
|
|
94
|
-
|
|
111
|
+
Usage: wlt-cert-gw [-h] -owner OWNER -gw GW [-suffix SUFFIX] [-tests {connection,uplink,downlink,stress}]
|
|
95
112
|
|
|
96
113
|
Gateway Certificate - CLI Tool to test Wiliot GWs
|
|
97
114
|
|
|
98
|
-
|
|
115
|
+
Required arguments:
|
|
99
116
|
-gw GW Gateway ID
|
|
100
117
|
|
|
101
|
-
|
|
118
|
+
Optional arguments:
|
|
102
119
|
-owner OWNER Owner ID (Required for non-registration tests)
|
|
103
120
|
-tests Pick specific tests to run
|
|
104
121
|
-actions Pick specific actions to test during the ActionsTest
|
|
105
122
|
-update Update the firmware of the test board
|
|
106
123
|
-pps Pick specific PPS rate for the stress test
|
|
107
|
-
-agg
|
|
108
|
-
-suffix Allow for different suffixes after the
|
|
109
|
-
-env Wiliot
|
|
124
|
+
-agg Duration uplink stages wait before processing packets
|
|
125
|
+
-suffix Allow for different suffixes after the Gateway ID in MQTT topics
|
|
126
|
+
-env Wiliot environment for registration and bridgeOTA tests
|
|
110
127
|
-h, --help show this help message and exit
|
|
111
128
|
```
|
|
112
129
|
|
|
113
130
|
### Bridge Certificate
|
|
114
|
-
Test Wiliot
|
|
115
|
-
The
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
131
|
+
Test Wiliot Bridge capabilities.
|
|
132
|
+
The Bridge Certificate includes different tests that run sequentially to test each capability reported by the bridge.
|
|
133
|
+
|
|
134
|
+
|
|
135
|
+
# update Gateway sim version :
|
|
136
|
+
- Update your gateway and bridge using Wiliot's platform. (https://platform.wiliot.com/)
|
|
137
|
+
- Transfer the gateway to dev mode - run the following command: py ut\dev_mode.py --gw [GW] --enable
|
|
138
|
+
- Connect the gateway to your laptop via USB connection:
|
|
139
|
+
- Run the following: wlt-cert-brg --gw SIM --brg <XXXXXXXXXXXX> --port <COM_PORT>
|
|
140
|
+
- For other options of running, see the 'run example' section.
|
|
141
|
+
|
|
142
|
+
#### Bridge Certificate Release Notes:
|
|
143
|
+
Release
|
|
144
|
+
- First release of Bridge Certificate – includes validation tests for bridge functionality.
|
|
145
|
+
- Additional details are available in the JSON files.
|
|
146
|
+
|
|
147
|
+
# The following capabilities are not tested in this version
|
|
148
|
+
|
|
149
|
+
## Power management
|
|
150
|
+
- Functionality of energize and transmit in sleep mode
|
|
151
|
+
## Edge management
|
|
152
|
+
- Timing of heartbeat and interface packets
|
|
153
|
+
## Module Energy 2400
|
|
154
|
+
- Functionality of energy pattern, output power and duty cycle
|
|
155
|
+
## Module Energy SUB1G
|
|
156
|
+
- Functionality of energy pattern and duty cycle
|
|
157
|
+
## Module Datapath
|
|
158
|
+
- RSSI edge cases: -127 and 0
|
|
159
|
+
- Functionality of transmission pattern, output power
|
|
160
|
+
- Pacer interval with channel 10 and 500k modulation
|
|
161
|
+
- Pacer interval using GEN3 Pixels
|
|
162
|
+
- Packet filter: the following configuration - DEBUG, TEMP & DEBUG, TEMPS & DEBUG & ADVANCE
|
|
163
|
+
- Rx rate feature with extended advertising
|
|
164
|
+
- Functionality of adaptive pacer algorithm
|
|
165
|
+
- Supported Pixels for extended advertising and GEN3
|
|
166
|
+
## Calibration
|
|
167
|
+
- Functionality of output power and interval calibration
|
|
168
|
+
- Functionality of calibration transmission patterns for the configuration STANDARD & EU & DISABLE
|
|
125
169
|
|
|
126
|
-
#### BRG Certificate Release Notes:
|
|
127
|
-
1.3.0:
|
|
128
|
-
- FIRST VERSION
|
|
129
170
|
|
|
130
171
|
```
|
|
131
|
-
usage:
|
|
172
|
+
usage: wlt-cert-brg [-h] [--brg BRG] [--brg_cloud_connectivity BRG_CLOUD_CONNECTIVITY] [--brg1 BRG1] --gw GW [--data {tags,sim}] [--port PORT] [--clean] [--tl TL] [--run RUN]
|
|
132
173
|
[--drun DRUN] [--exit_on_test_failure] [--exit_on_param_failure] [--analyze_interference]
|
|
133
174
|
|
|
134
|
-
Bridge Certificate CLI
|
|
175
|
+
# Bridge Certificate CLI
|
|
135
176
|
|
|
136
177
|
options:
|
|
137
178
|
-h, --help show this help message and exit
|
|
@@ -1,21 +1,30 @@
|
|
|
1
|
-
# wiliot-certificate
|
|
1
|
+
# wiliot-certificate Version 4.4.0
|
|
2
2
|
|
|
3
3
|
<!-- Description -->
|
|
4
|
-
wiliot-certificate is a
|
|
4
|
+
wiliot-certificate is a Python library that provides tools for testing and certifying boards for compatibility with Wiliot’s ecosystem.
|
|
5
5
|
This python package includes the following CLI utilities:
|
|
6
6
|
- Gateway Certificate (`wlt-cert-gw`)
|
|
7
7
|
- Bridge Certificate (`wlt-cert-brg`)
|
|
8
8
|
|
|
9
|
+
# Version:
|
|
10
|
+
wiliot-certificate versions 4.4.0 are compatible with firmware version 4.4.6 (ESP: 4.4.44, BLE: 4.4.93)
|
|
11
|
+
|
|
9
12
|
## Installing wiliot-certificate
|
|
13
|
+
Uninstall wiliot-deployment-tools if installed (relevant for old wlt-gw-certificate users):
|
|
14
|
+
````commandline
|
|
15
|
+
pip uninstall wiliot-deployment-tools
|
|
16
|
+
````
|
|
17
|
+
|
|
18
|
+
Install wiliot-certificate:
|
|
10
19
|
````commandline
|
|
11
20
|
pip install wiliot-certificate
|
|
12
21
|
````
|
|
13
22
|
|
|
14
23
|
## Using wiliot-certificate
|
|
15
24
|
### Gateway Certificate
|
|
16
|
-
Test Wiliot
|
|
17
|
-
The
|
|
18
|
-
To run the
|
|
25
|
+
Test Wiliot Gateway capabilities.
|
|
26
|
+
The Gateway Certificate includes different test that run sequentially to test each capability reported by the Gateway.
|
|
27
|
+
To run the Gateway Certificate the Gateway needs to use a public MQTT Broker (Eclipse):
|
|
19
28
|
|
|
20
29
|
Host: mqtt.eclipseprojects.io
|
|
21
30
|
TLS TCP Port: 8883
|
|
@@ -25,59 +34,91 @@ Websocket Port: 80
|
|
|
25
34
|
|
|
26
35
|
More information can be found at https://mqtt.eclipseprojects.io/.
|
|
27
36
|
|
|
28
|
-
####
|
|
37
|
+
#### Gateway Certificate Release Notes:
|
|
29
38
|
Release:
|
|
30
39
|
- Standalone wiliot-certificate package
|
|
31
40
|
- Python 3.13 support
|
|
32
|
-
-
|
|
41
|
+
- Gateway API version 205 support
|
|
33
42
|
- Registration test added
|
|
34
43
|
- Bridge OTA stage added under actions
|
|
35
44
|
- Aggregation flag supported by StressTest
|
|
36
45
|
- -update flag compatibility fix. Upgrades bootloader if needed
|
|
37
46
|
- -actions flag to select specific actions to test
|
|
47
|
+
- ACL (Access control list) test for gateways reporting API version 205 in the connection test
|
|
48
|
+
|
|
49
|
+
#### The following capabilities are not tested in this version
|
|
50
|
+
- Access control list stress stress
|
|
51
|
+
- Validation schema verification
|
|
52
|
+
- Board type registered within the Board Type Management system
|
|
53
|
+
- Bridge OTA progress reporting
|
|
54
|
+
|
|
38
55
|
|
|
39
56
|
```
|
|
40
|
-
|
|
57
|
+
Usage: wlt-cert-gw [-h] -owner OWNER -gw GW [-suffix SUFFIX] [-tests {connection,uplink,downlink,stress}]
|
|
41
58
|
|
|
42
59
|
Gateway Certificate - CLI Tool to test Wiliot GWs
|
|
43
60
|
|
|
44
|
-
|
|
61
|
+
Required arguments:
|
|
45
62
|
-gw GW Gateway ID
|
|
46
63
|
|
|
47
|
-
|
|
64
|
+
Optional arguments:
|
|
48
65
|
-owner OWNER Owner ID (Required for non-registration tests)
|
|
49
66
|
-tests Pick specific tests to run
|
|
50
67
|
-actions Pick specific actions to test during the ActionsTest
|
|
51
68
|
-update Update the firmware of the test board
|
|
52
69
|
-pps Pick specific PPS rate for the stress test
|
|
53
|
-
-agg
|
|
54
|
-
-suffix Allow for different suffixes after the
|
|
55
|
-
-env Wiliot
|
|
70
|
+
-agg Duration uplink stages wait before processing packets
|
|
71
|
+
-suffix Allow for different suffixes after the Gateway ID in MQTT topics
|
|
72
|
+
-env Wiliot environment for registration and bridgeOTA tests
|
|
56
73
|
-h, --help show this help message and exit
|
|
57
74
|
```
|
|
58
75
|
|
|
59
76
|
### Bridge Certificate
|
|
60
|
-
Test Wiliot
|
|
61
|
-
The
|
|
62
|
-
|
|
77
|
+
Test Wiliot Bridge capabilities.
|
|
78
|
+
The Bridge Certificate includes different tests that run sequentially to test each capability reported by the bridge.
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
# update Gateway sim version :
|
|
82
|
+
- Update your gateway and bridge using Wiliot's platform. (https://platform.wiliot.com/)
|
|
83
|
+
- Transfer the gateway to dev mode - run the following command: py ut\dev_mode.py --gw [GW] --enable
|
|
84
|
+
- Connect the gateway to your laptop via USB connection:
|
|
85
|
+
- Run the following: wlt-cert-brg --gw SIM --brg <XXXXXXXXXXXX> --port <COM_PORT>
|
|
86
|
+
- For other options of running, see the 'run example' section.
|
|
87
|
+
|
|
88
|
+
#### Bridge Certificate Release Notes:
|
|
89
|
+
Release
|
|
90
|
+
- First release of Bridge Certificate – includes validation tests for bridge functionality.
|
|
91
|
+
- Additional details are available in the JSON files.
|
|
92
|
+
|
|
93
|
+
# The following capabilities are not tested in this version
|
|
94
|
+
|
|
95
|
+
## Power management
|
|
96
|
+
- Functionality of energize and transmit in sleep mode
|
|
97
|
+
## Edge management
|
|
98
|
+
- Timing of heartbeat and interface packets
|
|
99
|
+
## Module Energy 2400
|
|
100
|
+
- Functionality of energy pattern, output power and duty cycle
|
|
101
|
+
## Module Energy SUB1G
|
|
102
|
+
- Functionality of energy pattern and duty cycle
|
|
103
|
+
## Module Datapath
|
|
104
|
+
- RSSI edge cases: -127 and 0
|
|
105
|
+
- Functionality of transmission pattern, output power
|
|
106
|
+
- Pacer interval with channel 10 and 500k modulation
|
|
107
|
+
- Pacer interval using GEN3 Pixels
|
|
108
|
+
- Packet filter: the following configuration - DEBUG, TEMP & DEBUG, TEMPS & DEBUG & ADVANCE
|
|
109
|
+
- Rx rate feature with extended advertising
|
|
110
|
+
- Functionality of adaptive pacer algorithm
|
|
111
|
+
- Supported Pixels for extended advertising and GEN3
|
|
112
|
+
## Calibration
|
|
113
|
+
- Functionality of output power and interval calibration
|
|
114
|
+
- Functionality of calibration transmission patterns for the configuration STANDARD & EU & DISABLE
|
|
63
115
|
|
|
64
|
-
Host: mqtt.eclipseprojects.io
|
|
65
|
-
TLS TCP Port: 8883
|
|
66
|
-
TLS Websocket Port: 443
|
|
67
|
-
TCP Port: 1883
|
|
68
|
-
Websocket Port: 80
|
|
69
|
-
|
|
70
|
-
More information can be found at https://mqtt.eclipseprojects.io/.
|
|
71
|
-
|
|
72
|
-
#### BRG Certificate Release Notes:
|
|
73
|
-
1.3.0:
|
|
74
|
-
- FIRST VERSION
|
|
75
116
|
|
|
76
117
|
```
|
|
77
|
-
usage:
|
|
118
|
+
usage: wlt-cert-brg [-h] [--brg BRG] [--brg_cloud_connectivity BRG_CLOUD_CONNECTIVITY] [--brg1 BRG1] --gw GW [--data {tags,sim}] [--port PORT] [--clean] [--tl TL] [--run RUN]
|
|
78
119
|
[--drun DRUN] [--exit_on_test_failure] [--exit_on_param_failure] [--analyze_interference]
|
|
79
120
|
|
|
80
|
-
Bridge Certificate CLI
|
|
121
|
+
# Bridge Certificate CLI
|
|
81
122
|
|
|
82
123
|
options:
|
|
83
124
|
-h, --help show this help message and exit
|
|
@@ -113,4 +154,4 @@ run examples:
|
|
|
113
154
|
wlt-cert-brg --gw SIM --brg_cloud_connectivity <XXXXXXXXXXXX> --tl certificate_bcc_test_list.txt --port <COM_PORT>
|
|
114
155
|
Run command example with remote GW connection for bridge with cloud connectivity:
|
|
115
156
|
wlt-cert-brg --gw <YYYYYYYYYYYY> --brg_cloud_connectivity <XXXXXXXXXXXX> --tl certificate_bcc_test_list.txt
|
|
116
|
-
```
|
|
157
|
+
```
|
|
@@ -4,13 +4,13 @@ build-backend = "setuptools.build_meta"
|
|
|
4
4
|
|
|
5
5
|
[project]
|
|
6
6
|
name = "wiliot_certificate"
|
|
7
|
-
version = "4.4.
|
|
7
|
+
version = "4.4.2"
|
|
8
8
|
authors = [
|
|
9
9
|
{ name="Wiliot", email="support@wiliot.com" }
|
|
10
10
|
]
|
|
11
11
|
description = "A library for certifying Wiliot-compliant boards"
|
|
12
12
|
readme = "README.md"
|
|
13
|
-
requires-python = ">=3.
|
|
13
|
+
requires-python = ">=3.9"
|
|
14
14
|
classifiers = [
|
|
15
15
|
"Programming Language :: Python :: 3",
|
|
16
16
|
"License :: OSI Approved :: MIT License",
|
|
@@ -22,7 +22,7 @@ dependencies = [
|
|
|
22
22
|
"jinja2>=3.1.5",
|
|
23
23
|
"appdirs>=1.4.4",
|
|
24
24
|
"plotly>=6.0.0",
|
|
25
|
-
"numpy>=
|
|
25
|
+
"numpy>=1.21.5",
|
|
26
26
|
"pandas>=2.2.3",
|
|
27
27
|
"colorama>=0.4.6",
|
|
28
28
|
"tabulate>=0.9.0",
|
|
@@ -117,7 +117,7 @@ def generate_results_files(html=True, pdf=True, failures=0, skipped=0, start_tim
|
|
|
117
117
|
f.write("<p><a href='https://bitbucket.org/wiliot/wiliot-nordic-firmware/commits/{}'>Commit page on bitbucket</a><hr>".format(os.environ['BITBUCKET_COMMIT']))
|
|
118
118
|
f.write(update_status + "<br><br>")
|
|
119
119
|
f.write(error + "<br><br>")
|
|
120
|
-
f.write(f"{RUN_DUR}: {str(duration).split(
|
|
120
|
+
f.write(f"{RUN_DUR}: {str(duration).split('.')[0]} <br><br>")
|
|
121
121
|
if brg:
|
|
122
122
|
f.write(f"{BRG} {BLE_VER}: {brg.version} <br><br>")
|
|
123
123
|
elif tests:
|
|
@@ -130,7 +130,7 @@ def generate_results_files(html=True, pdf=True, failures=0, skipped=0, start_tim
|
|
|
130
130
|
f.write("<p><a href='https://bitbucket.org/wiliot/wiliot-nordic-firmware/commits/{}'>Commit page on bitbucket</a><hr>".format(os.environ['BITBUCKET_COMMIT']))
|
|
131
131
|
f.write(update_status + "<br><br>")
|
|
132
132
|
f.write(f"{RUN_DATETIME}: {start_time.strftime('%d/%m/%Y, %H:%M:%S')} <br><br>")
|
|
133
|
-
f.write(f"{RUN_DUR}: {str(duration).split(
|
|
133
|
+
f.write(f"{RUN_DUR}: {str(duration).split('.')[0]} <br><br>")
|
|
134
134
|
f.write(f"{CERT_VER}: {CERT_VERSION} <br><br>")
|
|
135
135
|
if internal_brg:
|
|
136
136
|
f.write(f"{SIM} {BLE_MAC_ADDRESS}: {internal_brg.id_str} <br><br>")
|
|
@@ -14,8 +14,6 @@ energy2400/pattern_test ENERGY_PATTERN_2_4_NO_ENERGIZING ENERGY_PATTERN_2_4_CHAN
|
|
|
14
14
|
energy2400/output_power_test -12 -8 -4 0 2 3
|
|
15
15
|
energy2400/duty_cycle_test 1 25 50 75
|
|
16
16
|
energy2400/signal_indicator_test internal_brg rssi_threshold brg0_rx_brg1_tx brg0_none_brg1_rx brg0_rxtx_brg1_rxtx brg0_tx_brg1_none
|
|
17
|
-
energy2400/signal_indicator_ble5_10_500k_test internal_brg rssi_threshold brg0_tx_brg1_rx brg0_none_brg1_rx brg0_rxtx_brg1_rxtx brg0_tx_brg1_none
|
|
18
|
-
energy2400/signal_indicator_ble5_10_250k_test internal_brg rssi_threshold brg0_tx_brg1_rx brg0_none_brg1_rx brg0_rxtx_brg1_rxtx brg0_tx_brg1_none
|
|
19
17
|
|
|
20
18
|
# ------------- energy_sub1g -------------
|
|
21
19
|
energy_sub1g/pattern_test SUB1G_ENERGY_PATTERN_NO_ENERGIZING SUB1G_ENERGY_PATTERN_SINGLE_TONE_915000 SUB1G_ENERGY_PATTERN_FCC_HOPPING SUB1G_ENERGY_PATTERN_SINGLE_TONE_917500 SUB1G_ENERGY_PATTERN_NZ_HOPPING
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
"initialCondition": "Bridge configured to defaults",
|
|
7
7
|
"procedure": ["Test prolog", "Configurations", "Test epilog and revert to defaults"],
|
|
8
8
|
"expectedOutcome": "All values configured successfully",
|
|
9
|
-
"mandatory":
|
|
9
|
+
"mandatory": 0,
|
|
10
10
|
"multiBridgeTest": 0,
|
|
11
11
|
"gwOnlyTest": 0,
|
|
12
12
|
"internalBridge": 1,
|
|
@@ -23,7 +23,6 @@ def run(test):
|
|
|
23
23
|
if test.rc == TEST_FAILED:
|
|
24
24
|
if test.exit_on_param_failure:
|
|
25
25
|
break # break the whole for loop and keep the test as failed
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
continue
|
|
26
|
+
test.reset_result() # reset result and continue to next param
|
|
27
|
+
|
|
29
28
|
return cert_common.test_epilog(test, revert_brgs=True, modules=[calib_module])
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
"For each supported value - configure the BRG and verify the value",
|
|
9
9
|
"Test epilog and revert to defaults"],
|
|
10
10
|
"expectedOutcome": "All values configured successfully",
|
|
11
|
-
"mandatory":
|
|
11
|
+
"mandatory": 0,
|
|
12
12
|
"multiBridgeTest": 0,
|
|
13
13
|
"gwOnlyTest": 0,
|
|
14
14
|
"internalBridge": 1,
|
|
@@ -23,7 +23,6 @@ def run(test):
|
|
|
23
23
|
if test.rc == TEST_FAILED:
|
|
24
24
|
if test.exit_on_param_failure:
|
|
25
25
|
break # break the whole for loop and keep the test as failed
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
continue
|
|
26
|
+
test.reset_result() # reset result and continue to next param
|
|
27
|
+
|
|
29
28
|
return cert_common.test_epilog(test, revert_brgs=True, modules=[calib_module])
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
"For each supported value - Configure the BRG and verify packet reception functionality (for specific patterns)",
|
|
9
9
|
"Test epilog and revert to defaults"],
|
|
10
10
|
"expectedOutcome": "All values configured successfully and packets received only on included channels. When configuring the brg to CALIBRATION_PATTERN_38_38_39 we configure the GW to rx channel 37 and make sure GW doesn't get any pixels",
|
|
11
|
-
"mandatory":
|
|
11
|
+
"mandatory": 0,
|
|
12
12
|
"multiBridgeTest": 0,
|
|
13
13
|
"gwOnlyTest": 0,
|
|
14
14
|
"internalBridge": 1,
|
|
@@ -29,8 +29,8 @@ def run(test):
|
|
|
29
29
|
if test.exit_on_param_failure:
|
|
30
30
|
break # break the whole for loop and keep the test as failed
|
|
31
31
|
else:
|
|
32
|
-
test.reset_result() # reset result
|
|
33
|
-
continue
|
|
32
|
+
test.reset_result() # reset result
|
|
33
|
+
continue # skip the current phase and continue to next param
|
|
34
34
|
cert_common.wait_time_n_print(CLEAR_DATA_PATH_TIMEOUT)
|
|
35
35
|
# MQTT scan
|
|
36
36
|
if test.data == DATA_SIMULATION:
|
|
@@ -60,9 +60,7 @@ def run(test):
|
|
|
60
60
|
if test.rc == TEST_FAILED:
|
|
61
61
|
if test.exit_on_param_failure:
|
|
62
62
|
break # break the whole for loop and keep the test as failed
|
|
63
|
-
|
|
64
|
-
test.reset_result() # reset result and continue to next param
|
|
65
|
-
continue
|
|
63
|
+
test.reset_result() # reset result and continue to next param
|
|
66
64
|
else:
|
|
67
65
|
test = cert_config.brg_configure(test, fields=fields, values=[param.value], module=calib_module)[0]
|
|
68
66
|
generate_log_file(test, param.name)
|
|
@@ -72,8 +70,6 @@ def run(test):
|
|
|
72
70
|
if test.rc == TEST_FAILED:
|
|
73
71
|
if test.exit_on_param_failure:
|
|
74
72
|
break # break the whole for loop and keep the test as failed
|
|
75
|
-
|
|
76
|
-
test.reset_result() # reset result and continue to next param
|
|
77
|
-
continue
|
|
73
|
+
test.reset_result() # reset result and continue to next param
|
|
78
74
|
|
|
79
75
|
return cert_common.test_epilog(test, revert_brgs=True, modules=[calib_module, datapath_module])
|
|
@@ -135,10 +135,9 @@ def run(test):
|
|
|
135
135
|
test.add_phase_reason(param.name, test.reason)
|
|
136
136
|
if test.rc == TEST_FAILED:
|
|
137
137
|
if test.exit_on_param_failure:
|
|
138
|
-
break
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
continue
|
|
138
|
+
break # break the whole for loop and keep the test as failed
|
|
139
|
+
test.reset_result() # reset result and continue to next param
|
|
140
|
+
|
|
142
141
|
time.sleep(5)
|
|
143
142
|
|
|
144
143
|
return cert_common.test_epilog(test, revert_brgs=True, modules=[datapath_module])
|
|
@@ -60,13 +60,11 @@ def run(test):
|
|
|
60
60
|
|
|
61
61
|
# compare the numbers of tags that come from the brg, success in 95% from number of tags (value) or more.
|
|
62
62
|
if num_of_tags < (param.value * 0.95):
|
|
63
|
-
test.add_reason(f"
|
|
64
|
-
test.add_reason(f"HB: {num_of_tags_HB}, Df: {num_of_tags}")
|
|
63
|
+
test.add_reason(f"Received {num_of_tags} pixels, expected: {param.name} pixels!")
|
|
65
64
|
|
|
66
65
|
# compare the counter tags in the HB packet
|
|
67
66
|
if num_of_tags_HB < 0.95 * param.value or num_of_tags_HB > (param.value + 100):
|
|
68
|
-
test.add_reason(f"
|
|
69
|
-
test.add_reason(f"HB: {num_of_tags_HB}, Df: {num_of_tags}")
|
|
67
|
+
test.add_reason(f"HB counter: {num_of_tags_HB}, expected: {param.name}!")
|
|
70
68
|
# param epilog
|
|
71
69
|
time.sleep(10)
|
|
72
70
|
generate_log_file(test, param.name)
|
|
@@ -75,8 +73,7 @@ def run(test):
|
|
|
75
73
|
test.add_phase_reason(param.name, test.reason)
|
|
76
74
|
if test.rc == TEST_FAILED:
|
|
77
75
|
if test.exit_on_param_failure:
|
|
78
|
-
break
|
|
79
|
-
|
|
80
|
-
test.reset_result()
|
|
76
|
+
break # break the whole for loop and keep the test as failed
|
|
77
|
+
test.reset_result() # reset result and continue to next param
|
|
81
78
|
|
|
82
79
|
return cert_common.test_epilog(test)
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
"For each supported value - configure the BRG and verify the value",
|
|
9
9
|
"Test epilog and revert to defaults"],
|
|
10
10
|
"expectedOutcome": "All values configured successfully",
|
|
11
|
-
"mandatory":
|
|
11
|
+
"mandatory": 0,
|
|
12
12
|
"multiBridgeTest": 0,
|
|
13
13
|
"gwOnlyTest": 0,
|
|
14
14
|
"internalBridge": 1,
|
|
@@ -23,8 +23,6 @@ def run(test):
|
|
|
23
23
|
if test.rc == TEST_FAILED:
|
|
24
24
|
if test.exit_on_param_failure:
|
|
25
25
|
break # break the whole for loop and keep the test as failed
|
|
26
|
-
|
|
27
|
-
test.reset_result() # reset result and continue to next param
|
|
28
|
-
continue
|
|
26
|
+
test.reset_result() # reset result and continue to next param
|
|
29
27
|
|
|
30
28
|
return cert_common.test_epilog(test, revert_brgs=True, modules=[datapath_module])
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
"For each supported value - Configure the pacer interval, Generate GEN3 pixels packets & scan for packets in the bridge, Compare pacer interval mean per pixel to the configured value",
|
|
9
9
|
"Test epilog and revert to defaults"],
|
|
10
10
|
"expectedOutcome": "All values configured successfully and actual pacing found matching to the configured values",
|
|
11
|
-
"mandatory":
|
|
11
|
+
"mandatory": 0,
|
|
12
12
|
"multiBridgeTest": 0,
|
|
13
13
|
"gwOnlyTest": 0,
|
|
14
14
|
"internalBridge": 1,
|
|
@@ -45,7 +45,6 @@ def run(test):
|
|
|
45
45
|
if test.rc == TEST_FAILED:
|
|
46
46
|
if test.exit_on_param_failure:
|
|
47
47
|
break # break the whole for loop and keep the test as failed
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
continue
|
|
48
|
+
test.reset_result() # reset result and continue to next param
|
|
49
|
+
|
|
51
50
|
return cert_common.test_epilog(test, revert_brgs=True, revert_gws=test.internal_brg, modules=[datapath_module], ble5=True)
|
|
@@ -47,8 +47,6 @@ def run(test):
|
|
|
47
47
|
if test.rc == TEST_FAILED:
|
|
48
48
|
if test.exit_on_param_failure:
|
|
49
49
|
break # break the whole for loop and keep the test as failed
|
|
50
|
-
|
|
51
|
-
test.reset_result() # reset result and continue to next param
|
|
52
|
-
continue
|
|
50
|
+
test.reset_result() # reset result and continue to next param
|
|
53
51
|
|
|
54
52
|
return cert_common.test_epilog(test, revert_brgs=True, revert_gws=test.internal_brg, modules=[datapath_module])
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
"For each supported value - configure the BRG and verify the value",
|
|
9
9
|
"Test epilog and revert to defaults"],
|
|
10
10
|
"expectedOutcome": "All values configured successfully",
|
|
11
|
-
"mandatory":
|
|
11
|
+
"mandatory": 0,
|
|
12
12
|
"multiBridgeTest": 0,
|
|
13
13
|
"gwOnlyTest": 0,
|
|
14
14
|
"internalBridge": 1,
|
|
@@ -24,7 +24,5 @@ def run(test):
|
|
|
24
24
|
if test.rc == TEST_FAILED:
|
|
25
25
|
if test.exit_on_param_failure:
|
|
26
26
|
break # break the whole for loop and keep the test as failed
|
|
27
|
-
|
|
28
|
-
test.reset_result() # reset result and continue to next param
|
|
29
|
-
continue
|
|
27
|
+
test.reset_result() # reset result and continue to next param
|
|
30
28
|
return cert_common.test_epilog(test, revert_brgs=True, modules=[datapath_module])
|
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
"Repeat for all given packet filter values",
|
|
12
12
|
"Test epilog and revert to defaults"],
|
|
13
13
|
"expectedOutcome": "All values configured successfully and actual pacing found matching to the configured values",
|
|
14
|
-
"mandatory":
|
|
14
|
+
"mandatory": 0,
|
|
15
15
|
"multiBridgeTest": 0,
|
|
16
16
|
"gwOnlyTest": 0,
|
|
17
17
|
"internalBridge": 1,
|
|
@@ -54,8 +54,6 @@ def run(test):
|
|
|
54
54
|
if test.rc == TEST_FAILED:
|
|
55
55
|
if test.exit_on_param_failure:
|
|
56
56
|
break # break the whole for loop and keep the test as failed
|
|
57
|
-
|
|
58
|
-
test.reset_result() # reset result and continue to next param
|
|
59
|
-
continue
|
|
57
|
+
test.reset_result() # reset result and continue to next param
|
|
60
58
|
|
|
61
59
|
return cert_common.test_epilog(test, revert_brgs=True, revert_gws=test.internal_brg, modules=[datapath_module], ble5=True)
|
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
"Repeat for all given packet filter values",
|
|
12
12
|
"Test epilog and revert to defaults"],
|
|
13
13
|
"expectedOutcome": "All values configured successfully and actual pacing found matching to the configured values",
|
|
14
|
-
"mandatory":
|
|
14
|
+
"mandatory": 0,
|
|
15
15
|
"multiBridgeTest": 0,
|
|
16
16
|
"gwOnlyTest": 0,
|
|
17
17
|
"internalBridge": 1,
|
|
@@ -55,8 +55,6 @@ def run(test):
|
|
|
55
55
|
if test.rc == TEST_FAILED:
|
|
56
56
|
if test.exit_on_param_failure:
|
|
57
57
|
break # break the whole for loop and keep the test as failed
|
|
58
|
-
|
|
59
|
-
test.reset_result() # reset result and continue to next param
|
|
60
|
-
continue
|
|
58
|
+
test.reset_result() # reset result and continue to next param
|
|
61
59
|
|
|
62
60
|
return cert_common.test_epilog(test, revert_brgs=True, revert_gws=test.internal_brg, modules=[datapath_module])
|