Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 1 | #!/usr/bin/env python2 |
| 2 | # -*- coding: utf-8 -*- |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 3 | # Copyright (c) 2012 The Chromium OS Authors. All rights reserved. |
| 4 | # Use of this source code is governed by a BSD-style license that can be |
| 5 | # found in the LICENSE file. |
| 6 | |
Gilad Arnold | c65330c | 2012-09-20 22:17:48 | [diff] [blame] | 7 | """Unit tests for build_artifact module. |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 8 | |
| 9 | These unit tests take tarball from google storage locations to fully test |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 10 | the artifact download process. Please make sure to set up your boto file. |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 11 | """ |
| 12 | |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 13 | from __future__ import print_function |
| 14 | |
| 15 | import itertools |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 16 | import os |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 17 | import random |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 18 | import shutil |
| 19 | import subprocess |
| 20 | import tempfile |
| 21 | import unittest |
| 22 | |
Gilad Arnold | abb352e | 2012-09-23 08:24:27 | [diff] [blame] | 23 | import mox |
| 24 | |
Gilad Arnold | c65330c | 2012-09-20 22:17:48 | [diff] [blame] | 25 | import build_artifact |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 26 | import devserver_constants |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 27 | import downloader |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 28 | |
Gilad Arnold | abb352e | 2012-09-23 08:24:27 | [diff] [blame] | 29 | |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 30 | _VERSION = 'R26-3646.0.0-rc1' |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 31 | _TEST_GOLO_BUILD_ID = 'x86-generic-chromium-pfq/R26-3646.0.0-rc1' |
| 32 | _TEST_GOLO_ARCHIVE = 'gs://chromeos-image-archive/' + _TEST_GOLO_BUILD_ID |
| 33 | _TEST_NON_EXISTING_GOLO_BUILD_ID = 'x86-generic-chromium-pfq/R26-no_such_build' |
Dan Shi | 6e50c72 | 2013-08-19 22:05:06 | [diff] [blame] | 34 | _TEST_NON_EXISTING_GOLO_ARCHIVE = ( |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 35 | 'gs://chromeos-image-archive/' + _TEST_NON_EXISTING_GOLO_BUILD_ID) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 36 | |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 37 | _TEST_GOLO_ARCHIVE_TEST_TARBALL_CONTENT = [ |
| 38 | 'autotest/test_suites/control.PGO_record', |
| 39 | 'autotest/test_suites/control.au', |
| 40 | 'autotest/test_suites/control.audio', |
| 41 | 'autotest/test_suites/control.browsertests', |
| 42 | 'autotest/test_suites/control.bvt', |
| 43 | 'autotest/test_suites/control.dummy', |
| 44 | 'autotest/test_suites/control.enterprise', |
| 45 | 'autotest/test_suites/control.enterprise_enroll', |
| 46 | 'autotest/test_suites/control.faft_dev', |
| 47 | 'autotest/test_suites/control.faft_ec', |
| 48 | 'autotest/test_suites/control.faft_normal', |
| 49 | 'autotest/test_suites/control.graphics', |
| 50 | 'autotest/test_suites/control.graphicsGLES', |
| 51 | 'autotest/test_suites/control.hwqual', |
| 52 | 'autotest/test_suites/control.kernel_daily_benchmarks', |
| 53 | 'autotest/test_suites/control.kernel_daily_regression', |
| 54 | 'autotest/test_suites/control.kernel_per-build_benchmarks', |
| 55 | 'autotest/test_suites/control.kernel_per-build_regression', |
| 56 | 'autotest/test_suites/control.kernel_weekly_regression', |
| 57 | 'autotest/test_suites/control.link_perf', |
| 58 | 'autotest/test_suites/control.network3g', |
| 59 | 'autotest/test_suites/control.network3g_gobi', |
| 60 | 'autotest/test_suites/control.network_wifi', |
| 61 | 'autotest/test_suites/control.onccell', |
| 62 | 'autotest/test_suites/control.pagecycler', |
| 63 | 'autotest/test_suites/control.perfalerts', |
| 64 | 'autotest/test_suites/control.power_build', |
| 65 | 'autotest/test_suites/control.power_daily', |
| 66 | 'autotest/test_suites/control.power_requirements', |
| 67 | 'autotest/test_suites/control.pyauto', |
| 68 | 'autotest/test_suites/control.pyauto_basic', |
| 69 | 'autotest/test_suites/control.pyauto_endurance', |
| 70 | 'autotest/test_suites/control.pyauto_perf', |
| 71 | 'autotest/test_suites/control.regression', |
| 72 | 'autotest/test_suites/control.security', |
| 73 | 'autotest/test_suites/control.servo', |
| 74 | 'autotest/test_suites/control.smoke', |
| 75 | 'autotest/test_suites/control.sync', |
| 76 | 'autotest/test_suites/control.vda', |
| 77 | 'autotest/test_suites/control.video', |
| 78 | 'autotest/test_suites/control.webrtc', |
| 79 | 'autotest/test_suites/control.wificell', |
| 80 | 'autotest/test_suites/control.wifichaos', |
| 81 | 'autotest/test_suites/dependency_info', |
| 82 | 'autotest/test_suites/dev_harness.py', |
| 83 | ] |
| 84 | |
| 85 | _TEST_GOLO_ARCHIVE_IMAGE_ZIPFILE_CONTENT = [ |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 86 | 'boot.config', |
| 87 | 'boot.desc', |
| 88 | 'chromiumos_qemu_image.bin', |
| 89 | 'chromiumos_test_image.bin', |
| 90 | 'config.txt', |
| 91 | 'mount_image.sh', |
| 92 | 'oem.image', |
| 93 | 'pack_partitions.sh', |
| 94 | 'umount_image.sh', |
| 95 | 'unpack_partitions.sh', |
| 96 | ] |
| 97 | |
| 98 | |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 99 | # Different as the above does not have deltas (for smaller artifacts). |
| 100 | _DELTA_VERSION = 'R26-3645.0.0' |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 101 | _TEST_GOLO_FOR_DELTAS_BUILD_ID = 'x86-mario-release/' + _DELTA_VERSION |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 102 | _TEST_GOLO_FOR_DELTAS = ( |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 103 | 'gs://chromeos-image-archive/' + _TEST_GOLO_FOR_DELTAS_BUILD_ID) |
Yu-Ju Hong | e61cbe9 | 2012-07-10 21:10:26 | [diff] [blame] | 104 | |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 105 | |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 106 | # pylint: disable=W0212 |
Gilad Arnold | c65330c | 2012-09-20 22:17:48 | [diff] [blame] | 107 | class BuildArtifactTest(mox.MoxTestBase): |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 108 | """Test different BuildArtifact operations.""" |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 109 | |
| 110 | def setUp(self): |
| 111 | mox.MoxTestBase.setUp(self) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 112 | self.work_dir = tempfile.mkdtemp('build_artifact_unittest') |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 113 | |
| 114 | def tearDown(self): |
| 115 | shutil.rmtree(self.work_dir) |
| 116 | |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 117 | def _CheckMarker(self, marker_file, installed_files): |
| 118 | with open(os.path.join(self.work_dir, marker_file)) as f: |
| 119 | self.assertItemsEqual(installed_files, [line.strip() for line in f]) |
| 120 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 121 | @unittest.skip('crbug.com/640063 Broken test.') |
Yu-Ju Hong | 5d5bf0d | 2014-02-12 05:38:20 | [diff] [blame] | 122 | def testBundledArtifactTypes(self): |
| 123 | """Tests that all known bundled artifacts are either zip or tar files.""" |
| 124 | known_names = ['zip', '.tgz', '.tar', 'tar.bz2', 'tar.xz', 'tar.gz'] |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 125 | for d in itertools.chain(*build_artifact.chromeos_artifact_map.values()): |
| 126 | if issubclass(d, build_artifact.BundledArtifact): |
| 127 | self.assertTrue(any(d.ARTIFACT_NAME.endswith(name) |
| 128 | for name in known_names)) |
Yu-Ju Hong | 5d5bf0d | 2014-02-12 05:38:20 | [diff] [blame] | 129 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 130 | @unittest.skip('crbug.com/640063 Broken test.') |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 131 | def testProcessBuildArtifact(self): |
| 132 | """Processes a real tarball from GSUtil and stages it.""" |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 133 | artifact = build_artifact.Artifact( |
| 134 | build_artifact.TEST_SUITES_FILE, self.work_dir, _VERSION) |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 135 | dl = downloader.GoogleStorageDownloader(self.work_dir, _TEST_GOLO_ARCHIVE, |
| 136 | _TEST_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 137 | artifact.Process(dl, False) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 138 | self.assertItemsEqual( |
| 139 | artifact.installed_files, |
| 140 | [os.path.join(self.work_dir, build_artifact.TEST_SUITES_FILE)]) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 141 | self.assertTrue(os.path.exists(os.path.join( |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 142 | self.work_dir, build_artifact.TEST_SUITES_FILE))) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 143 | self._CheckMarker(artifact.marker_name, artifact.installed_files) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 144 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 145 | @unittest.skip('crbug.com/640063 Broken test.') |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 146 | def testProcessTarball(self): |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 147 | """Downloads a real tarball and untars it.""" |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 148 | artifact = build_artifact.BundledArtifact( |
| 149 | build_artifact.TEST_SUITES_FILE, self.work_dir, _VERSION) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 150 | expected_installed_files = [ |
| 151 | os.path.join(self.work_dir, filename) |
| 152 | for filename in ([build_artifact.TEST_SUITES_FILE] + |
| 153 | _TEST_GOLO_ARCHIVE_TEST_TARBALL_CONTENT)] |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 154 | dl = downloader.GoogleStorageDownloader(self.work_dir, _TEST_GOLO_ARCHIVE, |
| 155 | _TEST_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 156 | artifact.Process(dl, False) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 157 | self.assertItemsEqual(artifact.installed_files, expected_installed_files) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 158 | self.assertTrue(os.path.isdir(os.path.join( |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 159 | self.work_dir, 'autotest', 'test_suites'))) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 160 | self._CheckMarker(artifact.marker_name, artifact.installed_files) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 161 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 162 | @unittest.skip('crbug.com/640063 Broken test.') |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 163 | def testProcessTarballWithFile(self): |
| 164 | """Downloads a real tarball and only untars one file from it.""" |
| 165 | file_to_download = 'autotest/test_suites/control.au' |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 166 | artifact = build_artifact.BundledArtifact( |
| 167 | build_artifact.TEST_SUITES_FILE, self.work_dir, _VERSION, |
| 168 | files_to_extract=[file_to_download]) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 169 | expected_installed_files = [ |
| 170 | os.path.join(self.work_dir, filename) |
| 171 | for filename in [build_artifact.TEST_SUITES_FILE] + [file_to_download]] |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 172 | dl = downloader.GoogleStorageDownloader(self.work_dir, _TEST_GOLO_ARCHIVE, |
| 173 | _TEST_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 174 | artifact.Process(dl, False) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 175 | self.assertItemsEqual(artifact.installed_files, expected_installed_files) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 176 | self.assertTrue(os.path.exists(os.path.join( |
| 177 | self.work_dir, file_to_download))) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 178 | self._CheckMarker(artifact.marker_name, artifact.installed_files) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 179 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 180 | @unittest.skip('crbug.com/640063 Broken test.') |
joychen | 0a8e34e | 2013-06-25 00:58:36 | [diff] [blame] | 181 | def testDownloadAutotest(self): |
Yu-Ju Hong | e61cbe9 | 2012-07-10 21:10:26 | [diff] [blame] | 182 | """Downloads a real autotest tarball for test.""" |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 183 | self.mox.StubOutWithMock(build_artifact.AutotestTarball, '_Extract') |
| 184 | artifact = build_artifact.AutotestTarball( |
| 185 | build_artifact.AUTOTEST_FILE, self.work_dir, _VERSION, |
| 186 | files_to_extract=None, exclude=['autotest/test_suites']) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 187 | |
joychen | 0a8e34e | 2013-06-25 00:58:36 | [diff] [blame] | 188 | install_dir = self.work_dir |
| 189 | artifact.staging_dir = install_dir |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 190 | self.mox.StubOutWithMock(subprocess, 'check_call') |
joychen | 0a8e34e | 2013-06-25 00:58:36 | [diff] [blame] | 191 | subprocess.check_call(mox.In('autotest/utils/packager.py'), cwd=install_dir) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 192 | self.mox.StubOutWithMock(downloader.GoogleStorageDownloader, 'Wait') |
Yu-Ju Hong | 5d5bf0d | 2014-02-12 05:38:20 | [diff] [blame] | 193 | self.mox.StubOutWithMock(artifact, '_UpdateName') |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 194 | dl = downloader.GoogleStorageDownloader(self.work_dir, _TEST_GOLO_ARCHIVE, |
| 195 | _TEST_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 196 | dl.Wait(artifact.name, False, 1) |
Yu-Ju Hong | 5d5bf0d | 2014-02-12 05:38:20 | [diff] [blame] | 197 | artifact._UpdateName(mox.IgnoreArg()) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 198 | dl.Fetch(artifact.name, install_dir) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 199 | artifact._Extract() |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 200 | self.mox.ReplayAll() |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 201 | artifact.Process(dl, True) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 202 | self.mox.VerifyAll() |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 203 | self.assertItemsEqual(artifact.installed_files, []) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 204 | self.assertTrue(os.path.isdir( |
| 205 | os.path.join(self.work_dir, 'autotest', 'packages'))) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 206 | self._CheckMarker(artifact.marker_name, []) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 207 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 208 | @unittest.skip('crbug.com/640063 Broken test.') |
Gilad Arnold | c65330c | 2012-09-20 22:17:48 | [diff] [blame] | 209 | def testAUTestPayloadBuildArtifact(self): |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 210 | """Downloads a real tarball and treats it like an AU payload.""" |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 211 | artifact = build_artifact.AUTestPayload( |
| 212 | build_artifact.TEST_SUITES_FILE, self.work_dir, _VERSION) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 213 | expected_installed_files = [ |
| 214 | os.path.join(self.work_dir, devserver_constants.UPDATE_FILE)] |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 215 | dl = downloader.GoogleStorageDownloader(self.work_dir, _TEST_GOLO_ARCHIVE, |
| 216 | _TEST_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 217 | artifact.Process(dl, False) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 218 | self.assertItemsEqual(artifact.installed_files, expected_installed_files) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 219 | self.assertTrue(os.path.exists(os.path.join( |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 220 | self.work_dir, devserver_constants.UPDATE_FILE))) |
| 221 | self._CheckMarker(artifact.marker_name, artifact.installed_files) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 222 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 223 | @unittest.skip('crbug.com/640063 Broken test.') |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 224 | def testDeltaPayloadsArtifact(self): |
| 225 | """Downloads delta paylaods from test bucket.""" |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 226 | nton = build_artifact.DeltaPayloadNtoN(self.work_dir, _DELTA_VERSION) |
| 227 | mton = build_artifact.DeltaPayloadMtoN(self.work_dir, _DELTA_VERSION) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 228 | delta_installed_files = ('update.gz', 'stateful.tgz') |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 229 | nton_dir = os.path.join(self.work_dir, 'au', '%s_nton' % _DELTA_VERSION) |
| 230 | mton_dir = os.path.join(self.work_dir, 'au', '%s_mton' % _DELTA_VERSION) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 231 | dl = downloader.GoogleStorageDownloader(self.work_dir, |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 232 | _TEST_GOLO_FOR_DELTAS, |
| 233 | _TEST_GOLO_FOR_DELTAS_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 234 | nton.Process(dl, False) |
| 235 | mton.Process(dl, False) |
| 236 | self.assertItemsEqual(nton.installed_files, |
| 237 | [os.path.join(nton_dir, filename) |
| 238 | for filename in delta_installed_files]) |
| 239 | self.assertItemsEqual(mton.installed_files, |
| 240 | [os.path.join(mton_dir, filename) |
| 241 | for filename in delta_installed_files]) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 242 | self.assertTrue(os.path.exists(os.path.join(nton_dir, 'update.gz'))) |
| 243 | self.assertTrue(os.path.exists(os.path.join(mton_dir, 'update.gz'))) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 244 | self._CheckMarker(nton.marker_name, nton.installed_files) |
| 245 | self._CheckMarker(mton.marker_name, mton.installed_files) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 246 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 247 | @unittest.skip('crbug.com/640063 Broken test.') |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 248 | def testImageUnzip(self): |
| 249 | """Downloads and stages a zip file and extracts a test image.""" |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 250 | files_to_extract = ['chromiumos_test_image.bin'] |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 251 | artifact = build_artifact.BundledArtifact( |
| 252 | build_artifact.IMAGE_FILE, self.work_dir, _VERSION, |
| 253 | files_to_extract=files_to_extract) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 254 | expected_installed_files = [ |
| 255 | os.path.join(self.work_dir, filename) |
| 256 | for filename in [build_artifact.IMAGE_FILE] + files_to_extract] |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 257 | dl = downloader.GoogleStorageDownloader(self.work_dir, _TEST_GOLO_ARCHIVE, |
| 258 | _TEST_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 259 | artifact.Process(dl, False) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 260 | self.assertItemsEqual(expected_installed_files, artifact.installed_files) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 261 | self.assertTrue(os.path.exists(os.path.join( |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 262 | self.work_dir, 'chromiumos_test_image.bin'))) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 263 | self._CheckMarker(artifact.marker_name, artifact.installed_files) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 264 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 265 | @unittest.skip('crbug.com/640063 Broken test.') |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 266 | def testImageUnzipWithExcludes(self): |
| 267 | """Downloads and stages a zip file while excluding all large files.""" |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 268 | artifact = build_artifact.BundledArtifact( |
| 269 | build_artifact.IMAGE_FILE, self.work_dir, _VERSION, exclude=['*.bin']) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 270 | expected_extracted_files = [ |
| 271 | filename for filename in _TEST_GOLO_ARCHIVE_IMAGE_ZIPFILE_CONTENT |
| 272 | if not filename.endswith('.bin')] |
| 273 | expected_installed_files = [ |
| 274 | os.path.join(self.work_dir, filename) |
| 275 | for filename in [build_artifact.IMAGE_FILE] + expected_extracted_files] |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 276 | dl = downloader.GoogleStorageDownloader(self.work_dir, _TEST_GOLO_ARCHIVE, |
| 277 | _TEST_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 278 | artifact.Process(dl, False) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 279 | self.assertItemsEqual(expected_installed_files, artifact.installed_files) |
Chris Sosa | 76e44b9 | 2013-01-31 20:11:38 | [diff] [blame] | 280 | self.assertFalse(os.path.exists(os.path.join( |
| 281 | self.work_dir, 'chromiumos_test_image.bin'))) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 282 | self._CheckMarker(artifact.marker_name, artifact.installed_files) |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 283 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 284 | @unittest.skip('crbug.com/640063 Broken test.') |
Chris Sosa | 6b0c617 | 2013-08-06 00:01:33 | [diff] [blame] | 285 | def testArtifactFactory(self): |
Don Garrett | fb15e32 | 2016-06-22 02:12:08 | [diff] [blame] | 286 | """Tests that BuildArtifact works for both named and file artifacts.""" |
Chris Sosa | 6b0c617 | 2013-08-06 00:01:33 | [diff] [blame] | 287 | name_artifact = 'test_suites' # This file is in every real GS dir. |
| 288 | file_artifact = 'metadata.json' # This file is in every real GS dir. |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 289 | factory = build_artifact.ChromeOSArtifactFactory( |
| 290 | self.work_dir, [name_artifact], [file_artifact], _VERSION) |
Chris Sosa | 6b0c617 | 2013-08-06 00:01:33 | [diff] [blame] | 291 | artifacts = factory.RequiredArtifacts() |
| 292 | self.assertEqual(len(artifacts), 2) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 293 | expected_installed_files_0 = [ |
| 294 | os.path.join(self.work_dir, filename) for filename |
| 295 | in ([build_artifact.TEST_SUITES_FILE] + |
| 296 | _TEST_GOLO_ARCHIVE_TEST_TARBALL_CONTENT)] |
| 297 | expected_installed_files_1 = [os.path.join(self.work_dir, file_artifact)] |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 298 | dl = downloader.GoogleStorageDownloader(self.work_dir, _TEST_GOLO_ARCHIVE, |
| 299 | _TEST_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 300 | artifacts[0].Process(dl, False) |
| 301 | artifacts[1].Process(dl, False) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 302 | self.assertItemsEqual(artifacts[0].installed_files, |
| 303 | expected_installed_files_0) |
| 304 | self.assertItemsEqual(artifacts[1].installed_files, |
| 305 | expected_installed_files_1) |
Chris Sosa | 6b0c617 | 2013-08-06 00:01:33 | [diff] [blame] | 306 | # Test suites directory exists. |
| 307 | self.assertTrue(os.path.exists(os.path.join( |
| 308 | self.work_dir, 'autotest', 'test_suites'))) |
| 309 | # File artifact was staged. |
| 310 | self.assertTrue(os.path.exists(os.path.join(self.work_dir, |
| 311 | file_artifact))) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 312 | self._CheckMarker(artifacts[0].marker_name, artifacts[0].installed_files) |
| 313 | self._CheckMarker(artifacts[1].marker_name, artifacts[1].installed_files) |
Chris Sosa | 6b0c617 | 2013-08-06 00:01:33 | [diff] [blame] | 314 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 315 | @unittest.skip('crbug.com/640063 Broken test.') |
Dan Shi | 6e50c72 | 2013-08-19 22:05:06 | [diff] [blame] | 316 | def testProcessBuildArtifactWithException(self): |
| 317 | """Test processing a non-existing artifact from GSUtil.""" |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 318 | artifact = build_artifact.Artifact( |
| 319 | build_artifact.TEST_SUITES_FILE, self.work_dir, _VERSION) |
Dan Shi | 6e50c72 | 2013-08-19 22:05:06 | [diff] [blame] | 320 | try: |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 321 | dl = downloader.GoogleStorageDownloader(self.work_dir, |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 322 | _TEST_NON_EXISTING_GOLO_ARCHIVE, |
| 323 | _TEST_NON_EXISTING_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 324 | artifact.Process(dl, False) |
Dan Shi | 6e50c72 | 2013-08-19 22:05:06 | [diff] [blame] | 325 | except Exception as e: |
| 326 | expected_exception = e |
| 327 | exception = artifact.GetException() |
| 328 | self.assertEqual(str(exception), str(expected_exception)) |
| 329 | |
Don Garrett | 15daac8 | 2016-08-23 01:56:00 | [diff] [blame] | 330 | @unittest.skip('crbug.com/640063 Broken test.') |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 331 | def testArtifactStaged(self): |
| 332 | """Tests the artifact staging verification logic.""" |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 333 | artifact = build_artifact.BundledArtifact( |
| 334 | build_artifact.TEST_SUITES_FILE, self.work_dir, _VERSION) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 335 | expected_installed_files = [ |
| 336 | os.path.join(self.work_dir, filename) |
| 337 | for filename in ([build_artifact.TEST_SUITES_FILE] + |
| 338 | _TEST_GOLO_ARCHIVE_TEST_TARBALL_CONTENT)] |
Luis Hector Chavez | dca9dd7 | 2018-06-12 19:56:30 | [diff] [blame] | 339 | dl = downloader.GoogleStorageDownloader(self.work_dir, _TEST_GOLO_ARCHIVE, |
| 340 | _TEST_GOLO_BUILD_ID) |
Gabe Black | 3b56720 | 2015-09-23 21:07:59 | [diff] [blame] | 341 | artifact.Process(dl, False) |
Gilad Arnold | 1638d82 | 2013-11-08 07:38:16 | [diff] [blame] | 342 | |
| 343 | # Check that it works when all files are there. |
| 344 | self.assertTrue(artifact.ArtifactStaged()) |
| 345 | |
| 346 | # Remove an arbitrary file among the ones staged, ensure the check fails |
| 347 | # and that the marker files is removed. |
| 348 | os.remove(random.choice(expected_installed_files)) |
| 349 | self.assertTrue(os.path.exists(os.path.join(self.work_dir, |
| 350 | artifact.marker_name))) |
| 351 | self.assertFalse(artifact.ArtifactStaged()) |
| 352 | self.assertFalse(os.path.exists(os.path.join(self.work_dir, |
| 353 | artifact.marker_name))) |
| 354 | |
Chris Sosa | 47a7d4e | 2012-03-28 18:26:55 | [diff] [blame] | 355 | |
| 356 | if __name__ == '__main__': |
| 357 | unittest.main() |