Revert "Merge sc-d1-dev 6958804 into master."

This reverts commit 3aed9d58ff5cfdbbafc5f8ec8bedd6a6d1ed2221.

Reason for revert: Certain changes were originally not merged from master to sc-d1-dev. By merging sc-d1-dev back to master, those changes would be lost. In addition, sc-d1-dev has never been used for development for platform/tools/test/connectivity.

Bug: 172861149
Change-Id: Ie2d73b100cebfc098a15021c2ed122af165fd869
diff --git a/acts_tests/tests/google/wifi/WifiIOTTwPkg1Test.py b/acts_tests/tests/google/wifi/WifiIOTTwPkg1Test.py
new file mode 100644
index 0000000..ed0d8d7
--- /dev/null
+++ b/acts_tests/tests/google/wifi/WifiIOTTwPkg1Test.py
@@ -0,0 +1,360 @@
+#!/usr/bin/env python3
+#
+#   Copyright 2018 - The Android Open Source Project
+#
+#   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 itertools
+import pprint
+import time
+
+import acts.signals
+import acts.test_utils.wifi.wifi_test_utils as wutils
+
+from acts import asserts
+from acts.test_decorators import test_tracker_info
+from acts.test_utils.wifi.WifiBaseTest import WifiBaseTest
+from acts.controllers import iperf_server as ipf
+
+import json
+import logging
+import math
+import os
+from acts import utils
+import csv
+
+WifiEnums = wutils.WifiEnums
+
+
+class WifiIOTTwPkg1Test(WifiBaseTest):
+    """ Tests for wifi IOT
+
+        Test Bed Requirement:
+          * One Android device
+          * Wi-Fi IOT networks visible to the device
+    """
+
+    def setup_class(self):
+        super().setup_class()
+
+        self.dut = self.android_devices[0]
+        wutils.wifi_test_device_init(self.dut)
+
+        req_params = [ "iot_networks", ]
+        opt_params = [ "open_network",
+                       "iperf_server_address","iperf_port_arg",
+                       "pdu_address" , "pduon_wait_time","pduon_address"
+        ]
+        self.unpack_userparams(req_param_names=req_params,
+                               opt_param_names=opt_params)
+
+        asserts.assert_true(
+            len(self.iot_networks) > 0,
+            "Need at least one iot network with psk.")
+
+        if getattr(self, 'open_network', False):
+            self.iot_networks.append(self.open_network)
+
+        wutils.wifi_toggle_state(self.dut, True)
+        if "iperf_server_address" in self.user_params:
+            self.iperf_server = self.iperf_servers[0]
+
+        # create hashmap for testcase name and SSIDs
+        self.iot_test_prefix = "test_iot_connection_to_"
+        self.ssid_map = {}
+        for network in self.iot_networks:
+            SSID = network['SSID'].replace('-','_')
+            self.ssid_map[SSID] = network
+
+        # create folder for IOT test result
+        self.log_path = os.path.join(logging.log_path, "IOT_results")
+        os.makedirs(self.log_path, exist_ok=True)
+
+        Header=("test_name","throughput_TX","throughput_RX")
+        self.csv_write(Header)
+
+        # check pdu_address
+        if "pdu_address" and "pduon_wait_time" in self.user_params:
+            self.pdu_func()
+
+    def setup_test(self):
+        super().setup_test()
+        self.dut.droid.wakeLockAcquireBright()
+        self.dut.droid.wakeUpNow()
+
+    def teardown_test(self):
+        super().teardown_test()
+        self.dut.droid.wakeLockRelease()
+        self.dut.droid.goToSleepNow()
+        wutils.reset_wifi(self.dut)
+
+    def teardown_class(self):
+        if "iperf_server_address" in self.user_params:
+            self.iperf_server.stop()
+
+    """Helper Functions"""
+
+    def connect_to_wifi_network(self, network):
+        """Connection logic for open and psk wifi networks.
+
+        Args:
+            params: Dictionary with network info.
+        """
+        SSID = network[WifiEnums.SSID_KEY]
+        self.dut.ed.clear_all_events()
+        wutils.start_wifi_connection_scan(self.dut)
+        scan_results = self.dut.droid.wifiGetScanResults()
+        wutils.assert_network_in_list({WifiEnums.SSID_KEY: SSID}, scan_results)
+        wutils.wifi_connect(self.dut, network, num_of_tries=3)
+
+    def run_iperf_client(self, network):
+        """Run iperf TX throughput after connection.
+
+        Args:
+            params: Dictionary with network info.
+        """
+        if "iperf_server_address" in self.user_params:
+
+            # Add iot_result
+            iot_result = []
+            self.iperf_server.start(tag="TX_server_{}".format(
+                self.current_test_name))
+            wait_time = 5
+            SSID = network[WifiEnums.SSID_KEY]
+            self.log.info("Starting iperf traffic TX through {}".format(SSID))
+            time.sleep(wait_time)
+            port_arg = "-p {} -J {}".format(self.iperf_server.port,self.iperf_port_arg)
+            success, data = self.dut.run_iperf_client(self.iperf_server_address,
+                                                      port_arg)
+            # Parse and log result
+            client_output_path = os.path.join(
+                self.iperf_server.log_path, "IperfDUT,{},TX_client_{}".format(
+                    self.iperf_server.port,self.current_test_name))
+            with open(client_output_path, 'w') as out_file:
+                out_file.write("\n".join(data))
+            self.iperf_server.stop()
+
+            iperf_file = self.iperf_server.log_files[-1]
+            try:
+                iperf_result = ipf.IPerfResult(iperf_file)
+                curr_throughput = math.fsum(iperf_result.instantaneous_rates)
+            except:
+                self.log.warning(
+                    "ValueError: Cannot get iperf result. Setting to 0")
+                curr_throughput = 0
+            iot_result.append(curr_throughput)
+            self.log.info("Throughput is {0:.2f} Mbps".format(curr_throughput))
+
+            self.log.debug(pprint.pformat(data))
+            asserts.assert_true(success, "Error occurred in iPerf traffic.")
+            return iot_result
+
+    def run_iperf_server(self, network):
+        """Run iperf RX throughput after connection.
+
+        Args:
+            params: Dictionary with network info.
+
+        Returns:
+            iot_result: dict containing iot_results
+        """
+        if "iperf_server_address" in self.user_params:
+
+            # Add iot_result
+            iot_result = []
+            self.iperf_server.start(tag="RX_client_{}".format(
+                self.current_test_name))
+            wait_time = 5
+            SSID = network[WifiEnums.SSID_KEY]
+            self.log.info("Starting iperf traffic RX through {}".format(SSID))
+            time.sleep(wait_time)
+            port_arg = "-p {} -J -R {}".format(self.iperf_server.port,self.iperf_port_arg)
+            success, data = self.dut.run_iperf_client(self.iperf_server_address,
+                                                      port_arg)
+            client_output_path = os.path.join(
+                self.iperf_server.log_path, "IperfDUT,{},RX_server_{}".format(
+                    self.iperf_server.port,self.current_test_name))
+            with open(client_output_path, 'w') as out_file:
+                out_file.write("\n".join(data))
+            self.iperf_server.stop()
+
+            iperf_file = client_output_path
+            try:
+                iperf_result = ipf.IPerfResult(iperf_file)
+                curr_throughput = math.fsum(iperf_result.instantaneous_rates)
+            except:
+                self.log.warning(
+                    "ValueError: Cannot get iperf result. Setting to 0")
+                curr_throughput = 0
+            iot_result.append(curr_throughput)
+            self.log.info("Throughput is {0:.2f} Mbps".format(curr_throughput))
+
+            self.log.debug(pprint.pformat(data))
+            asserts.assert_true(success, "Error occurred in iPerf traffic.")
+            return iot_result
+
+    def iperf_test_func(self,network):
+        """Main function to test iperf TX/RX.
+
+        Args:
+            params: Dictionary with network info
+        """
+        # Initialize
+        iot_result = {}
+
+        # Run RvR and log result
+        iot_result["throughput_TX"] = self.run_iperf_client(network)
+        iot_result["throughput_RX"] = self.run_iperf_server(network)
+        iot_result["test_name"] = self.current_test_name
+
+        # Save output as text file
+        results_file_path = "{}/{}.json".format(self.log_path,
+                                                self.current_test_name)
+        with open(results_file_path, 'w') as results_file:
+            json.dump(iot_result, results_file, indent=4)
+
+        data=(iot_result["test_name"],iot_result["throughput_TX"][0],
+              iot_result["throughput_RX"][0])
+        self.csv_write(data)
+
+    def csv_write(self,data):
+        with open("{}/Result.csv".format(self.log_path), "a", newline="") as csv_file:
+            csv_writer = csv.writer(csv_file,delimiter=',')
+            csv_writer.writerow(data)
+            csv_file.close()
+
+    def pdu_func(self):
+        """control Power Distribution Units on local machine.
+
+        Logic steps are
+        1. Turn off PDU for all port.
+        2. Turn on PDU for specified port.
+        """
+        out_file_name = "PDU.log"
+        self.full_out_path = os.path.join(self.log_path, out_file_name)
+        cmd = "curl http://snmp:1234@{}/offs.cgi?led=11111111> {}".format(self.pdu_address,
+                                                                          self.full_out_path)
+        self.pdu_process = utils.start_standing_subprocess(cmd)
+        wait_time = 10
+        self.log.info("Starting set PDU to OFF")
+        time.sleep(wait_time)
+        self.full_out_path = os.path.join(self.log_path, out_file_name)
+        cmd = "curl http://snmp:1234@{}/ons.cgi?led={}> {}".format(self.pdu_address,
+                                                                   self.pduon_address,
+                                                                   self.full_out_path)
+        self.pdu_process = utils.start_standing_subprocess(cmd)
+        wait_time = int("{}".format(self.pduon_wait_time))
+        self.log.info("Starting set PDU to ON for port1,"
+                      "wait for {}s".format(self.pduon_wait_time))
+        time.sleep(wait_time)
+        self.log.info("PDU setup complete")
+
+    def connect_to_wifi_network_and_run_iperf(self, network):
+        """Connection logic for open and psk wifi networks.
+
+        Logic steps are
+        1. Connect to the network.
+        2. Run iperf throghput.
+
+        Args:
+            params: A dictionary with network info.
+        """
+        self.connect_to_wifi_network(network)
+        self.iperf_test_func(network)
+
+    """Tests"""
+
+    @test_tracker_info(uuid="0e4ad6ed-595c-4629-a4c9-c6be9c3c58e0")
+    def test_iot_connection_to_ASUS_RT_AC68U_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="a76d8acc-808e-4a5d-a52b-5ba07d07b810")
+    def test_iot_connection_to_ASUS_RT_AC68U_5G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="659a3e5e-07eb-4905-9cda-92e959c7b674")
+    def test_iot_connection_to_D_Link_DIR_868L_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="6bcfd736-30fc-48a8-b4fb-723d1d113f3c")
+    def test_iot_connection_to_D_Link_DIR_868L_5G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="c9da945a-2c4a-44e1-881d-adf307b39b21")
+    def test_iot_connection_to_TP_LINK_WR940N_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="db0d224d-df81-401f-bf35-08ad02e41a71")
+    def test_iot_connection_to_ASUS_RT_N66U_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="845ff1d6-618d-40f3-81c3-6ed3a0751fde")
+    def test_iot_connection_to_ASUS_RT_N66U_5G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="6908039b-ccc9-4777-a0f1-3494ce642014")
+    def test_iot_connection_to_ASUS_RT_AC54U_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="2647c15f-2aad-47d7-8dee-b2ee1ac4cef6")
+    def test_iot_connection_to_ASUS_RT_AC54U_5G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="99678f66-ddf1-454d-87e4-e55177ec380d")
+    def test_iot_connection_to_ASUS_RT_N56U_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="4dd75e81-9a8e-44fd-9449-09f5ab8a63c3")
+    def test_iot_connection_to_ASUS_RT_N56U_5G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="315397ce-50d5-4abf-a11c-1abcaef832d3")
+    def test_iot_connection_to_BELKIN_F9K1002v1_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="05ba464a-b1ef-4ac1-a32f-c919ec4aa1dd")
+    def test_iot_connection_to_CISCO_E1200_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="04912868-4a47-40ce-877e-4e4c89849557")
+    def test_iot_connection_to_TP_LINK_C2_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="53517a21-3802-4185-b8bb-6eaace063a42")
+    def test_iot_connection_to_TP_LINK_C2_5G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="71c08c1c-415d-4da4-a151-feef43fb6ad8")
+    def test_iot_connection_to_ASUS_RT_AC66U_2G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])
+
+    @test_tracker_info(uuid="2322c155-07d1-47c9-bd21-2e358e3df6ee")
+    def test_iot_connection_to_ASUS_RT_AC66U_5G(self):
+        ssid_key = self.current_test_name.replace(self.iot_test_prefix, "")
+        self.connect_to_wifi_network_and_run_iperf(self.ssid_map[ssid_key])