Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion googleapiclient/http.py
Original file line number Diff line number Diff line change
Expand Up @@ -558,9 +558,13 @@ def __init__(self, filename, mimetype=None, chunksize=DEFAULT_CHUNK_SIZE,
if mimetype is None:
# Guess failed, use octet-stream.
mimetype = 'application/octet-stream'
super(MediaFileUpload, self).__init__(fd, mimetype, chunksize=chunksize,
super(MediaFileUpload, self).__init__(fd, mimetype,
chunksize=chunksize,
resumable=resumable)

def __del__(self):
self._fd.close()

def to_json(self):
"""Creating a JSON representation of an instance of MediaFileUpload.

Expand Down
12 changes: 11 additions & 1 deletion tests/test_http.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
# Do not remove the httplib2 import
import json
import httplib2
import io
import logging
import mock
import os
Expand Down Expand Up @@ -209,6 +210,15 @@ def test_set_user_agent_nested(self):

class TestMediaUpload(unittest.TestCase):

def test_media_file_upload_closes_fd_in___del__(self):
file_desc = mock.Mock(spec=io.TextIOWrapper)
opener = mock.mock_open(file_desc)
with mock.patch('__builtin__.open', return_value=opener):
upload = MediaFileUpload(datafile('test_close'), mimetype='text/plain')
self.assertIs(upload.stream(), file_desc)
del upload
file_desc.close.assert_called_once_with()

def test_media_file_upload_mimetype_detection(self):
upload = MediaFileUpload(datafile('small.png'))
self.assertEqual('image/png', upload.mimetype())
Expand Down Expand Up @@ -861,7 +871,7 @@ def test_empty_content_type(self):
headers={'content-type': ''})
request.execute()
self.assertEqual('', http.headers.get('content-type'))

def test_no_retry_connection_errors(self):
model = JsonModel()
request = HttpRequest(
Expand Down