Пример #1
0
    def configure_beacon(self, rate_set, interval, preamble):
        """
        Configure beacon that will set:
            - beacon operational rate set
            - interval between beacons
            - beacon preamble

        :type rate_set: str
        :param rate_set: operational rate set. Allowed values are:
            - ALL
            - SINGLE
            - MULTIPLE
            - USER

        :type interval: int
        :param interval: interval in ms between beacons (20 to 1000)

        :type preamble: str
        :param preamble: beacon preamble. Allowed values are:
            - LONG
            - SHORT

        :return: None
        """
        # Set beacon operational rate set
        (err, msg) = W.SetOperationalRate(self, rate_set)
        self.__error_check(err, msg)
        # Set beacon interval
        (err, msg) = W.SetBeaconInterval(self, interval)
        self.__error_check(err, msg)
        # Set beacon preamble
        (err, msg) = W.SetBeaconPreamble(self, preamble)
        self.__error_check(err, msg)
Пример #2
0
    def check_dut_disconnected_before_timeout(self, dut_mac_address, timeout):
        """
        Checks that DUT is disconnected until timeout seconds.
        :type dut_mac_address: str
        :param dut_mac_address: MAC address of the DUT.
        :type timeout: int
        :param timeout: Timeout in seconds.
        """
        connect_time = 0
        connect_state = False
        self.get_logger().info(
            "Check DUT gets disconnected before %d seconds", timeout)
        while connect_time <= timeout:
            time.sleep(1)
            connect_time += 1

            (err, dut_state, msg) = W.GetDUTConnectionState(
                self,
                dut_mac_address)
            self.__error_check(err, msg)

            if dut_state == b"DISCONNECTED":
                self.get_logger().info("DUT is disconnected!")
                connect_state = True
                break

        if not connect_state:
            error_msg = "Disconnection failure: timeout!"
            self.get_logger().error(error_msg)
            raise TestEquipmentException(TestEquipmentException.CONNECTION_ERROR, error_msg)
Пример #3
0
    def check_connectivity(self, expected_ue_power, margin):
        """
        Checks that DUT is correctly connected to the wlan network simulator.
        Connectivity is well connected if retrieved power is equal to
        expectedUEPower +/- margin.
        :type expected_ue_power: integer
        :param expected_ue_power: Expected user equipment power (in dBm).
        :type margin: integer
        :param margin: admissible margin (in dB).
        """
        (err, retrieved_ue_power, msg) = W.GetPowerPeak(self)
        self.__error_check(err, msg)

        self.get_logger().info(
            "Wlan power peak: %s dBm",
            str(retrieved_ue_power))
        positive_margin = margin
        if margin < 0:
            positive_margin = -margin
        min_power = expected_ue_power - positive_margin
        max_power = expected_ue_power + positive_margin
        if (retrieved_ue_power < min_power) or (retrieved_ue_power > max_power):
            msg = "DUT isn't correctly connected to the WLAN network simulator"
            self.get_logger().error(msg)
            raise TestEquipmentException(TestEquipmentException.CONNECTION_ERROR, msg)
Пример #4
0
 def set_dut_power(self, power):
     """
     Wraps the SetDutPower driver function
     :type power: integer
     :param power: DUT power level in dBm (between -30 and 30).
     """
     (err, msg) = W.SetDutPower(self, int(power))
     self.__error_check(err, msg)
Пример #5
0
 def set_dut_ip(self, ip_addr):
     """
     Wraps the SetDutIp driver function
     :type ip_addr: str
     :param ip_addr: Device Under Test IP V4 address.
     """
     (err, msg) = W.SetDutIp(self, ip_addr)
     self.__error_check(err, msg)
Пример #6
0
 def set_dut_mac_address(self, mac):
     """
     Wraps the SetDutMacAddress driver function
     :type mac: str
     :param mac: The DUT MAC address to set.
     """
     (err, msg) = W.SetDutMacAddress(self, mac)
     self.__error_check(err, msg)
Пример #7
0
 def set_transmit_power(self, power):
     """
     Wraps the SetTransmitPower driver function
     :type power: double
     :param power: Power level at the test port connector.
     :raise TestEquipmentException: Failed to set transmit power.
     """
     (err, msg) = W.SetTransmitPower(self, power)
     self.__error_check(err, msg)
Пример #8
0
 def set_wlan_channel(self, channel):
     """
     Wraps the SetWlanChannel driver function
     :type channel: integer
     :param channel: WLAN channel to set (1 to 196).
     :raise TestEquipmentException: Invalid channel, must be 1 to 196.
     """
     (err, msg) = W.SetWlanChannel(self, channel)
     self.__error_check(err, msg)
Пример #9
0
 def create_network(self, ssid):
     """
     Wraps the CreateNetwork driver function
     :type ssid: str
     :param ssid: Service Set Identity of the Wlan network (32 characters max).
     :raise TestEquipmentException: SSID has more than 32 characters.
     """
     (err, msg) = W.CreateNetwork(self, ssid)
     self.__error_check(err, msg)
Пример #10
0
 def __connect_via_TCPIP(self):
     """
     Connect to equipment via TCPIP
     """
     ip_addr = int(self.__bench_params.get_param_value("TcpIpAddress"))
     (err, handle, msg) = W.Connect(self, "TCPIP", 0, 0, ip_addr)
     self.__error_check(err, msg)
     # Update handle value
     self._set_handle(handle)
Пример #11
0
 def get_packet_error_rate(self):
     """
     Gets the packet error rate
     :rtype: double
     :return: measured packet error Rate.
     """
     (err, per, msg) = W.GetPacketErrorRate(self)
     self.__error_check(err, msg)
     return per
Пример #12
0
 def __connect_via_GPIB(self):
     """
     Connect to equipment via GPIB
     """
     board_id = int(self.__bench_params.get_param_value("GPIBBoardId"))
     gpib_addr = int(self.__bench_params.get_param_value("GPIBAddress"))
     (err, handle, msg) = W.Connect(self, "GPIB", board_id, gpib_addr, "")
     self.__error_check(err, msg)
     # Update handle value
     self._set_handle(handle)
Пример #13
0
 def set_per_packet_number(self, packet_number):
     """
     Wraps the SetPERPacketNumber driver function
     :type packet_number: integer
     :param packet_number : Number of packets to send for Packet
     Error Rate Measurement.
     """
     (err, msg) = W.SetPERPacketNumber(self,
                                       packet_number)
     self.__error_check(err, msg)
Пример #14
0
 def set_loss_table_state(self, state):
     """
     Wraps the SetLossTableState driver function
     :type state: str
     :param state: The loss table state. Possible values :
         - OFF (Disable the path loss table)
         - ON (Enable the path loss table (Default Value))
     """
     (err, msg) = W.SetLossTableState(self, state)
     self.__error_check(err, msg)
Пример #15
0
 def set_wlan_ip_params(self, ip_addr, subnet):
     """
     Wraps the SetWlanIpParams driver function
     :type ip_addr: str
     :param ip_addr: WLAN IP Address.
     :type subnet: str
     :param subnet: WLAN Subnet Mask.
     """
     (err, msg) = W.SetWlanIpParams(self, ip_addr, subnet)
     self.__error_check(err, msg)
Пример #16
0
 def set_signal_state(self, state):
     """
     Wraps the SetSignalState driver function
     :type state: str
     :param state: The signal generator state. Possible values :
         - OFF (Disable the signal generator function)
         - ON (Enable the signal generator function (Default Value))
     """
     (err, msg) = W.SetSignalState(self, state)
     self.__error_check(err, msg)
Пример #17
0
 def release(self):
     """
     Release the equipment and all associated resources
     """
     self.get_logger().info("Release")
     if self.get_handle() is not None:
         (err, msg) = W.Disconnect(self)
         self.unload_driver()
         self.__error_check(err, msg)
         # Update handle value
         self._set_handle(None)
Пример #18
0
 def set_measurement_mode(self, mode):
     """
     Wraps to SetMeasurementMode function
     :type mode: str
     :param mode: measurement mode. Possible values:
         - "TXMODE"
         - "RXMODE"
     :raise TestEquipmentException: Invalid measurement mode.
     """
     (err, msg) = W.SetMeasurementMode(self, mode)
     self.__error_check(err, msg)
Пример #19
0
 def set_test_mode(self, mode):
     """
     Wraps the SetTestMode driver function
     :type mode: str
     :param mode: Equipment test mode. Possible values :
         - "DIRECT"
         - "NETWORK"
     :raise TestEquipmentException: Invalid test mode.
     """
     (err, msg) = W.SetTestMode(self, mode)
     self.__error_check(err, msg)
Пример #20
0
 def set_ip_properties_mode(self, mode):
     """
     Wraps the SetIpPropertiesMode driver function
     :type mode: str
     :param mode: Mode for IP properties. Possible values :
         - "AUTO"
         - "MANUAL"
     :raise TestEquipmentException: Invalid IP properties mode.
     """
     (err, msg) = W.SetIpPropertiesMode(self, mode)
     self.__error_check(err, msg)
Пример #21
0
 def set_wlan_data_rate(self, rate):
     """
     Wraps the SetWlanDataRate driver function
     :type rate: str
     :param rate: WLAN data rate. Possible values :
         - {"1"; "2"; "5.5"; "6"; "9"; "11"; "12"; "18"; "24";
            "36"; "48"; "54"}
     :raise TestEquipmentException: Invalid data rate.
     """
     (err, msg) = W.SetWlanDataRate(self, rate)
     self.__error_check(err, msg)
Пример #22
0
 def set_wlan_standard(self, standard):
     """
     Wraps the SetWlanStandard driver function
     :type standard: str
     :param standard: WLAN Standard. Possible values :
         - "802.11a"
         - "802.11b"
         - "802.11g"
     :raise TestEquipmentException: Invalid Wlan standard.
     """
     (err, msg) = W.SetWlanStandard(self, standard)
     self.__error_check(err, msg)
Пример #23
0
 def set_network_type(self, nw_type):
     """
     Wraps the SetNetworkType driver function
     :type nw_type: str
     :param nw_type: Network type. Possible values :
         - "ADHOC"
         - "ACCESS_POINT"
         - "STATION"
     :raise TestEquipmentException: Invalid network type.
     """
     (err, msg) = W.SetNetworkType(self, nw_type)
     self.__error_check(err, msg)
Пример #24
0
 def add_loss_entry(self, channel, offset):
     """
     Wraps to AddLossEntry driver function
     :type channel: integer
     :param channel: The channel number
     :type channel: double
     :param channel: The offset to set in dBm
     :raise TestEquipmentException: failed to add loss entry
     :rtype: integer
     :return: the error code of the driver function
     """
     (err, msg) = W.AddLossEntry(self, channel, offset)
     self.__error_check(err, msg)
Пример #25
0
 def launch_auto_setup(self):
     """
     Wraps the LaunchAutoSetup driver function
     """
     (err, msg) = W.LaunchAutoSetup(self)
     self.__error_check(err, msg)
Пример #26
0
 def perform_full_preset(self):
     """
     Wraps to PerformFullPreset function
     """
     (err, msg) = W.PerformFullPreset(self)
     self.__error_check(err, msg)