diff options
author | Brent Stapleton <brent.stapleton@ettus.com> | 2018-08-24 10:58:19 -0700 |
---|---|---|
committer | Brent Stapleton <bstapleton@g.hmc.edu> | 2018-08-28 15:04:17 -0700 |
commit | 87e7d712d96adf4c5f4ce3e9cc11b2bd3faae701 (patch) | |
tree | d08e3aae30c1cdbebd23bf5d16ea23225df8f374 | |
parent | 05564d67f061db712a91c3fb64a73b3332c78dab (diff) | |
download | uhd-87e7d712d96adf4c5f4ce3e9cc11b2bd3faae701.tar.gz uhd-87e7d712d96adf4c5f4ce3e9cc11b2bd3faae701.tar.bz2 uhd-87e7d712d96adf4c5f4ce3e9cc11b2bd3faae701.zip |
uhd: utils: Add Zip test to downloader
Users can supply the --test/-T option to test the downloaded archive
before extracting it, using the Python zipfile.testzip() function.
-rw-r--r-- | host/utils/uhd_images_downloader.py.in | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/host/utils/uhd_images_downloader.py.in b/host/utils/uhd_images_downloader.py.in index 96f56e64f..465fd2400 100644 --- a/host/utils/uhd_images_downloader.py.in +++ b/host/utils/uhd_images_downloader.py.in @@ -75,6 +75,8 @@ def parse_args(): .format(",".join(_ARCHIVE_ALGS)))) parser.add_argument("-k", "--keep", action="store_true", default=False, help="Keep the downloaded images archives in the image directory") + parser.add_argument("-T", "--test", action="store_true", default=False, + help="Verify the downloaded archives before extracting them") parser.add_argument("-n", "--dry-run", action="store_true", default=False, help="Print selected target without actually downloading them.") parser.add_argument("--refetch", action="store_true", default=False, @@ -262,11 +264,22 @@ def delete_from_inv(target_info, inventory, images_dir): return True -def extract(archive_path, images_dir, archive_type): +def extract(archive_path, images_dir, archive_type, test_zip=False): """Extract the contents of the archive into `images_dir`""" if archive_type == "zip": log("TRACE", "Attempting to extracted files from {}".format(archive_path)) with zipfile.ZipFile(archive_path) as images_zip: + # Check that the Zip file is valid, in which case `testzip()` returns None. + # If its bad, that function will return a list of bad files + try: + if test_zip and images_zip.testzip(): + log("ERROR", "Could not extract the following invalid Zip file:" + " {}".format(archive_path)) + return [] + except OSError: + log("ERROR", "Could not extract the following invalid Zip file:" + " {}".format(archive_path)) + return [] images_zip.extractall(images_dir) archive_namelist = images_zip.namelist() log("TRACE", "Extracted files: {}".format(archive_namelist)) @@ -388,7 +401,7 @@ def main(): # Otherwise, the check has succeeded, and we can proceed delete_from_inv(target_info, inventory, images_dir) - archive_namelist = extract(temp_path, images_dir, archive_type) + archive_namelist = extract(temp_path, images_dir, archive_type, args.test) if args.keep: # If the user wants to keep the downloaded archive, # save it to the images directory and add it to the inventory |