From e6ad2970c337d71c5b2a9b38fed9188d0df81fd3 Mon Sep 17 00:00:00 2001 From: Tres Seaver Date: Fri, 26 Sep 2014 14:17:49 -0400 Subject: [PATCH] Fix #137: default key based on filename. When no key is passed, guess it based on the basename of filename. --- gcloud/storage/bucket.py | 4 ++++ gcloud/storage/test_bucket.py | 18 ++++++++++++++++-- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/gcloud/storage/bucket.py b/gcloud/storage/bucket.py index 37691396db5e..05515af0d514 100644 --- a/gcloud/storage/bucket.py +++ b/gcloud/storage/bucket.py @@ -1,3 +1,5 @@ +import os + from gcloud.storage import exceptions from gcloud.storage.acl import BucketACL from gcloud.storage.acl import DefaultObjectACL @@ -230,6 +232,8 @@ def upload_file(self, filename, key=None): to the root of the bucket with the same name as on your local file system. """ + if key is None: + key = os.path.basename(filename) key = self.new_key(key) return key.set_contents_from_filename(filename) diff --git a/gcloud/storage/test_bucket.py b/gcloud/storage/test_bucket.py index fa5f0e9e5b14..b63b060ce9f0 100644 --- a/gcloud/storage/test_bucket.py +++ b/gcloud/storage/test_bucket.py @@ -246,8 +246,22 @@ def test_delete_keys_miss(self): self.assertEqual(kw[1]['method'], 'DELETE') self.assertEqual(kw[1]['path'], '/b/%s/o/%s' % (NAME, NONESUCH)) - # See: https://github.com/GoogleCloudPlatform/gcloud-python/issues/137 - #def test_upload_file_default_key(self): + def test_upload_file_default_key(self): + from gcloud.test_credentials import _Monkey + from gcloud.storage import bucket as MUT + BASENAME = 'file.ext' + FILENAME = '/path/to/%s' % BASENAME + _uploaded = [] + class _Key(object): + def __init__(self, bucket, name): + self._bucket = bucket + self._name = name + def set_contents_from_filename(self, filename): + _uploaded.append((self._bucket, self._name, filename)) + bucket = self._makeOne() + with _Monkey(MUT, Key=_Key): + bucket.upload_file(FILENAME) + self.assertEqual(_uploaded, [(bucket, BASENAME, FILENAME)]) def test_upload_file_explicit_key(self): from gcloud.test_credentials import _Monkey