# 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. """Tests for list.""" import unittest import mock from acloud import errors from acloud.internal.lib import cvd_runtime_config from acloud.internal.lib import driver_test_lib from acloud.internal.lib import utils from acloud.list import list as list_instance from acloud.list import instance class InstanceObject(object): """Mock to store data of instance.""" def __init__(self, name): self.name = name class ListTest(driver_test_lib.BaseDriverTest): """Test list.""" def testGetInstancesFromInstanceNames(self): """test get instances from instance names.""" cfg = mock.MagicMock() instance_names = ["alive_instance1", "alive_local_instance"] alive_instance1 = InstanceObject("alive_instance1") alive_instance2 = InstanceObject("alive_instance2") alive_local_instance = InstanceObject("alive_local_instance") instance_alive = [alive_instance1, alive_instance2, alive_local_instance] self.Patch(list_instance, "GetInstances", return_value=instance_alive) instances_list = list_instance.GetInstancesFromInstanceNames(cfg, instance_names) instances_name_in_list = [instance_object.name for instance_object in instances_list] self.assertEqual(instances_name_in_list.sort(), instance_names.sort()) instance_names = ["alive_instance1", "alive_local_instance", "alive_local_instance"] instances_list = list_instance.GetInstancesFromInstanceNames(cfg, instance_names) instances_name_in_list = [instance_object.name for instance_object in instances_list] self.assertEqual(instances_name_in_list.sort(), instance_names.sort()) # test get instance from instance name error with invalid input. instance_names = ["miss2_local_instance", "alive_instance1"] miss_instance_names = ["miss2_local_instance"] self.assertRaisesRegexp( errors.NoInstancesFound, "Did not find the following instances: %s" % ' '.join(miss_instance_names), list_instance.GetInstancesFromInstanceNames, cfg=cfg, instance_names=instance_names) def testChooseOneRemoteInstance(self): """test choose one remote instance from instance names.""" cfg = mock.MagicMock() # Test only one instance case instance_names = ["cf_instance1"] self.Patch(list_instance, "GetCFRemoteInstances", return_value=instance_names) expected_instance = "cf_instance1" self.assertEqual(list_instance.ChooseOneRemoteInstance(cfg), expected_instance) # Test no instance case self.Patch(list_instance, "GetCFRemoteInstances", return_value=[]) with self.assertRaises(errors.NoInstancesFound): list_instance.ChooseOneRemoteInstance(cfg) # Test two instances case. instance_names = ["cf_instance1", "cf_instance2"] choose_instance = ["cf_instance2"] self.Patch(list_instance, "GetCFRemoteInstances", return_value=instance_names) self.Patch(utils, "GetAnswerFromList", return_value=choose_instance) expected_instance = "cf_instance2" self.assertEqual(list_instance.ChooseOneRemoteInstance(cfg), expected_instance) # pylint: disable=attribute-defined-outside-init def testFilterInstancesByAdbPort(self): """test FilterInstancesByAdbPort.""" alive_instance1 = InstanceObject("alive_instance1") alive_instance1.adb_port = 1111 alive_instance1.fullname = "device serial: 127.0.0.1:1111 alive_instance1" expected_instance = [alive_instance1] # Test to find instance by adb port number. self.assertEqual( expected_instance, list_instance.FilterInstancesByAdbPort(expected_instance, 1111)) # Test for instance can't be found by adb port number. with self.assertRaises(errors.NoInstancesFound): list_instance.FilterInstancesByAdbPort(expected_instance, 2222) # pylint: disable=protected-access def testGetLocalCuttlefishInstances(self): """test _GetLocalCuttlefishInstances.""" # Test getting two instance case self.Patch(instance, "GetAllLocalInstanceConfigs", return_value=["fake_path1", "fake_path2"]) self.Patch(instance, "GetLocalInstanceRuntimeDir") local_ins = mock.MagicMock() local_ins.CvdStatus.return_value = True self.Patch(instance, "LocalInstance", return_value=local_ins) ins_list = list_instance._GetLocalCuttlefishInstances() self.assertEqual(2, len(ins_list)) local_ins = mock.MagicMock() local_ins.CvdStatus.return_value = False self.Patch(instance, "LocalInstance", return_value=local_ins) ins_list = list_instance._GetLocalCuttlefishInstances() self.assertEqual(0, len(ins_list)) # pylint: disable=no-member def testPrintInstancesDetails(self): """test PrintInstancesDetails.""" # Test instance Summary should be called if verbose self.Patch(instance.Instance, "Summary") cf_config = mock.MagicMock( x_res=728, y_res=728, dpi=240, instance_dir="fake_dir", adb_ip_port="127.0.0.1:6520" ) self.Patch(cvd_runtime_config, "CvdRuntimeConfig", return_value=cf_config) ins = instance.LocalInstance("fake_cf_path") list_instance.PrintInstancesDetails([ins], verbose=True) instance.Instance.Summary.assert_called_once() # Test Summary shouldn't be called if not verbose self.Patch(instance.Instance, "Summary") list_instance.PrintInstancesDetails([ins], verbose=False) instance.Instance.Summary.assert_not_called() # Test Summary shouldn't be called if no instance found. list_instance.PrintInstancesDetails([], verbose=True) instance.Instance.Summary.assert_not_called() if __name__ == "__main__": unittest.main()