blob: 237d3ea99c43002344759b978c87422981431bab [file] [log] [blame]
Tri Vo29ac1822016-10-01 17:06:29 -07001#!/usr/bin/env python
2#
3# Copyright 2016 - The Android Open Source Project
4#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16
17"""Tests for acloud.public.device_driver."""
18
19import datetime
20import uuid
21
Kevin Cheng5c124ec2018-05-16 13:28:51 -070022import unittest
Tri Vo29ac1822016-10-01 17:06:29 -070023import mock
24
Kevin Cheng86d43c72018-08-30 10:59:14 -070025# pylint: disable=import-error
Kevin Cheng5c124ec2018-05-16 13:28:51 -070026import dateutil.parser
27
Tri Vo29ac1822016-10-01 17:06:29 -070028from acloud.internal.lib import auth
Tri Vo05f01892017-03-02 11:28:31 -080029from acloud.internal.lib import android_build_client
Tri Vo29ac1822016-10-01 17:06:29 -070030from acloud.internal.lib import android_compute_client
31from acloud.internal.lib import driver_test_lib
32from acloud.internal.lib import gstorage_client
herbertxue140b6b42019-10-14 20:24:10 +080033from acloud.internal.lib import ssh
Tri Vo29ac1822016-10-01 17:06:29 -070034from acloud.public import device_driver
35
36
Kevin Cheng5c124ec2018-05-16 13:28:51 -070037def _CreateCfg():
38 """A helper method that creates a mock configuration object."""
39 cfg = mock.MagicMock()
40 cfg.service_account_name = "fake@service.com"
41 cfg.service_account_private_key_path = "/fake/path/to/key"
42 cfg.zone = "fake_zone"
43 cfg.disk_image_name = "fake_image.tar.gz"
44 cfg.disk_image_mime_type = "fake/type"
45 cfg.storage_bucket_name = "fake_bucket"
46 cfg.extra_data_disk_size_gb = 4
47 cfg.precreated_data_image_map = {
48 4: "extradisk-image-4gb",
49 10: "extradisk-image-10gb"
50 }
Kevin Chengc330f6f2019-05-13 09:32:42 -070051 cfg.extra_scopes = None
Kevin Cheng5c124ec2018-05-16 13:28:51 -070052 cfg.ssh_private_key_path = ""
53 cfg.ssh_public_key_path = ""
54
55 return cfg
56
57
Tri Vo29ac1822016-10-01 17:06:29 -070058class DeviceDriverTest(driver_test_lib.BaseDriverTest):
59 """Test device_driver."""
60
61 def setUp(self):
62 """Set up the test."""
63 super(DeviceDriverTest, self).setUp()
64 self.build_client = mock.MagicMock()
65 self.Patch(android_build_client, "AndroidBuildClient",
Kevin Cheng5c124ec2018-05-16 13:28:51 -070066 return_value=self.build_client)
Tri Vo29ac1822016-10-01 17:06:29 -070067 self.storage_client = mock.MagicMock()
68 self.Patch(
69 gstorage_client, "StorageClient", return_value=self.storage_client)
70 self.compute_client = mock.MagicMock()
71 self.Patch(
72 android_compute_client,
73 "AndroidComputeClient",
74 return_value=self.compute_client)
75 self.Patch(auth, "CreateCredentials", return_value=mock.MagicMock())
chojoycec60fa582019-07-11 16:09:02 +080076 self.fake_avd_spec = mock.MagicMock()
77 self.fake_avd_spec.unlock_screen = False
78 self.fake_avd_spec.client_adb_port = 1234
Tri Vo29ac1822016-10-01 17:06:29 -070079
chojoyceacc404b2019-06-25 16:06:45 +080080 def testCreateGCETypeAVD(self):
81 """Test CreateGCETypeAVD."""
Kevin Cheng5c124ec2018-05-16 13:28:51 -070082 cfg = _CreateCfg()
Tri Vo29ac1822016-10-01 17:06:29 -070083 fake_gs_url = "fake_gs_url"
herbertxue140b6b42019-10-14 20:24:10 +080084 fake_ip = ssh.IP(external="140.1.1.1", internal="10.1.1.1")
Tri Vo29ac1822016-10-01 17:06:29 -070085 fake_instance = "fake-instance"
86 fake_image = "fake-image"
87 fake_build_target = "fake_target"
88 fake_build_id = "12345"
89
90 # Mock uuid
91 fake_uuid = mock.MagicMock(hex="1234")
92 self.Patch(uuid, "uuid4", return_value=fake_uuid)
93 fake_gs_object = fake_uuid.hex + "-" + cfg.disk_image_name
94 self.storage_client.GetUrl.return_value = fake_gs_url
95
96 # Mock compute client methods
97 disk_name = "extradisk-image-4gb"
98 self.compute_client.GetInstanceIP.return_value = fake_ip
99 self.compute_client.GenerateImageName.return_value = fake_image
100 self.compute_client.GenerateInstanceName.return_value = fake_instance
101 self.compute_client.GetDataDiskName.return_value = disk_name
102
103 # Verify
chojoyceacc404b2019-06-25 16:06:45 +0800104 report = device_driver.CreateGCETypeAVD(
chojoycec60fa582019-07-11 16:09:02 +0800105 cfg, fake_build_target, fake_build_id, avd_spec=self.fake_avd_spec)
Tri Vo29ac1822016-10-01 17:06:29 -0700106 self.build_client.CopyTo.assert_called_with(
Kevin Cheng5c124ec2018-05-16 13:28:51 -0700107 fake_build_target, fake_build_id, artifact_name=cfg.disk_image_name,
108 destination_bucket=cfg.storage_bucket_name,
109 destination_path=fake_gs_object)
Tri Vo29ac1822016-10-01 17:06:29 -0700110 self.compute_client.CreateImage.assert_called_with(
Kevin Cheng5c124ec2018-05-16 13:28:51 -0700111 image_name=fake_image, source_uri=fake_gs_url)
Tri Vo29ac1822016-10-01 17:06:29 -0700112 self.compute_client.CreateInstance.assert_called_with(
Kevin Chengb5963882018-05-09 00:06:27 -0700113 instance=fake_instance,
114 image_name=fake_image,
chojoyce7a361732018-11-26 16:26:13 +0800115 extra_disk_name=disk_name,
chojoycec60fa582019-07-11 16:09:02 +0800116 avd_spec=self.fake_avd_spec,
Kevin Chengc330f6f2019-05-13 09:32:42 -0700117 extra_scopes=None)
Tri Vo29ac1822016-10-01 17:06:29 -0700118 self.compute_client.DeleteImage.assert_called_with(fake_image)
119 self.storage_client.Delete(cfg.storage_bucket_name, fake_gs_object)
120
chojoyce7307f5f2019-09-18 17:56:05 +0800121 self.assertEqual(
Kevin Cheng5c124ec2018-05-16 13:28:51 -0700122 report.data,
Tri Vo29ac1822016-10-01 17:06:29 -0700123 {
124 "devices": [
125 {
126 "instance_name": fake_instance,
Kevin Cheng86d43c72018-08-30 10:59:14 -0700127 "ip": fake_ip.external,
Tri Vo29ac1822016-10-01 17:06:29 -0700128 },
129 ],
130 }
131 )
chojoyce7307f5f2019-09-18 17:56:05 +0800132 self.assertEqual(report.command, "create")
133 self.assertEqual(report.status, "SUCCESS")
Tri Vo29ac1822016-10-01 17:06:29 -0700134
Kevin Cheng86d43c72018-08-30 10:59:14 -0700135 # pylint: disable=invalid-name
chojoyceacc404b2019-06-25 16:06:45 +0800136 def testCreateGCETypeAVDInternalIP(self):
137 """Test CreateGCETypeAVD with internal IP."""
Kevin Cheng86d43c72018-08-30 10:59:14 -0700138 cfg = _CreateCfg()
herbertxue140b6b42019-10-14 20:24:10 +0800139 fake_ip = ssh.IP(external="140.1.1.1", internal="10.1.1.1")
Kevin Cheng86d43c72018-08-30 10:59:14 -0700140 fake_instance = "fake-instance"
141 fake_build_target = "fake_target"
142 fake_build_id = "12345"
143
144 self.compute_client.GetInstanceIP.return_value = fake_ip
145 self.compute_client.GenerateInstanceName.return_value = fake_instance
146
chojoyceacc404b2019-06-25 16:06:45 +0800147 report = device_driver.CreateGCETypeAVD(
chojoycec60fa582019-07-11 16:09:02 +0800148 cfg, fake_build_target, fake_build_id, report_internal_ip=True,
149 avd_spec=self.fake_avd_spec)
Kevin Cheng86d43c72018-08-30 10:59:14 -0700150
chojoyce7307f5f2019-09-18 17:56:05 +0800151 self.assertEqual(
Kevin Cheng86d43c72018-08-30 10:59:14 -0700152 report.data,
153 {
154 "devices": [
155 {
156 "instance_name": fake_instance,
157 "ip": fake_ip.internal,
158 },
159 ],
160 }
161 )
Tri Vo29ac1822016-10-01 17:06:29 -0700162
163 def testDeleteAndroidVirtualDevices(self):
164 """Test DeleteAndroidVirtualDevices."""
165 instance_names = ["fake-instance-1", "fake-instance-2"]
166 self.compute_client.DeleteInstances.return_value = (instance_names, [],
167 [])
Kevin Cheng5c124ec2018-05-16 13:28:51 -0700168 cfg = _CreateCfg()
169 report = device_driver.DeleteAndroidVirtualDevices(cfg, instance_names)
Tri Vo29ac1822016-10-01 17:06:29 -0700170 self.compute_client.DeleteInstances.assert_called_once_with(
171 instance_names, cfg.zone)
chojoyce7307f5f2019-09-18 17:56:05 +0800172 self.assertEqual(report.data, {
Tri Vo29ac1822016-10-01 17:06:29 -0700173 "deleted": [
174 {
175 "name": instance_names[0],
176 "type": "instance",
177 },
178 {
179 "name": instance_names[1],
180 "type": "instance",
181 },
182 ],
183 })
chojoyce7307f5f2019-09-18 17:56:05 +0800184 self.assertEqual(report.command, "delete")
185 self.assertEqual(report.status, "SUCCESS")
Tri Vo29ac1822016-10-01 17:06:29 -0700186
187 def testCleanup(self):
Kevin Cheng5c124ec2018-05-16 13:28:51 -0700188 """Test Cleanup."""
Tri Vo29ac1822016-10-01 17:06:29 -0700189 expiration_mins = 30
190 before_deadline = "2015-10-29T12:00:30.018-07:00"
191 after_deadline = "2015-10-29T12:45:30.018-07:00"
192 now = "2015-10-29T13:00:30.018-07:00"
193 self.Patch(device_driver, "datetime")
194 device_driver.datetime.datetime.now.return_value = dateutil.parser.parse(
195 now)
196 device_driver.datetime.timedelta.return_value = datetime.timedelta(
197 minutes=expiration_mins)
198 fake_instances = [
199 {
200 "name": "fake_instance_1",
201 "creationTimestamp": before_deadline,
202 }, {
203 "name": "fake_instance_2",
204 "creationTimestamp": after_deadline,
205 }
206 ]
207 fake_images = [
208 {
209 "name": "extradisk-image-4gb",
210 "creationTimestamp": before_deadline,
211 }, {
212 "name": "fake_image_1",
213 "creationTimestamp": before_deadline,
214 }, {
215 "name": "fake_image_2",
216 "creationTimestamp": after_deadline,
217 }
218 ]
219 fake_disks = [
220 {
221 "name": "fake_disk_1",
222 "creationTimestamp": before_deadline,
223 }, {
224 "name": "fake_disk_2",
225 "creationTimestamp": before_deadline,
226 "users": ["some-instance-using-the-disk"]
227 }, {
228 "name": "fake_disk_3",
229 "creationTimestamp": after_deadline,
230 }
231 ]
232 fake_objects = [
233 {
234 "name": "fake_object_1",
235 "timeCreated": before_deadline,
236 }, {
237 "name": "fake_object_2",
238 "timeCreated": after_deadline,
239 }
240 ]
241 self.compute_client.ListInstances.return_value = fake_instances
242 self.compute_client.ListImages.return_value = fake_images
243 self.compute_client.ListDisks.return_value = fake_disks
244 self.storage_client.List.return_value = fake_objects
245 self.compute_client.DeleteInstances.return_value = (
246 ["fake_instance_1"], [], [])
247 self.compute_client.DeleteImages.return_value = (["fake_image_1"], [],
248 [])
249 self.compute_client.DeleteDisks.return_value = (["fake_disk_1"], [],
250 [])
251 self.storage_client.DeleteFiles.return_value = (["fake_object_1"], [],
252 [])
Kevin Cheng5c124ec2018-05-16 13:28:51 -0700253 cfg = _CreateCfg()
254 report = device_driver.Cleanup(cfg, expiration_mins)
255 self.assertEqual(report.errors, [])
Tri Vo29ac1822016-10-01 17:06:29 -0700256 expected_report_data = {
257 "deleted": [
258 {"name": "fake_instance_1",
259 "type": "instance"},
260 {"name": "fake_image_1",
261 "type": "image"},
262 {"name": "fake_disk_1",
263 "type": "disk"},
264 {"name": "fake_object_1",
265 "type": "cached_build_artifact"},
266 ]
267 }
Kevin Cheng5c124ec2018-05-16 13:28:51 -0700268 self.assertEqual(report.data, expected_report_data)
Tri Vo29ac1822016-10-01 17:06:29 -0700269
270 self.compute_client.ListInstances.assert_called_once_with(
271 zone=cfg.zone)
272 self.compute_client.DeleteInstances.assert_called_once_with(
273 instances=["fake_instance_1"], zone=cfg.zone)
274
275 self.compute_client.ListImages.assert_called_once_with()
276 self.compute_client.DeleteImages.assert_called_once_with(
277 image_names=["fake_image_1"])
278
279 self.compute_client.ListDisks.assert_called_once_with(zone=cfg.zone)
280 self.compute_client.DeleteDisks.assert_called_once_with(
281 disk_names=["fake_disk_1"], zone=cfg.zone)
282
283 self.storage_client.List.assert_called_once_with(
284 bucket_name=cfg.storage_bucket_name)
285 self.storage_client.DeleteFiles.assert_called_once_with(
286 bucket_name=cfg.storage_bucket_name,
287 object_names=["fake_object_1"])
288
289
290if __name__ == "__main__":
291 unittest.main()