{
  "Selected_candidate": {
    "pr_number": 1537,
    "pr_title": "Allow non-string objects to be posted as data alongside files.",
    "pr_body": "This should resolve #1462.\n",
    "issue_id": 1462,
    "issue_title": "multipart/form-data and datetime data",
    "issue_body": "I raise an bug that you already fix in the past on this issue : https://github.com/kennethreitz/requests/issues/661 or https://github.com/kennethreitz/requests/issues/737\n\nI tried the same methodology with that code :\n\n```\nimport requets\n\nrequests.post(\"http://httpbin.org/post\", data={'a': 0})\nrequests.post(\"http://httpbin.org/post\", data={'a': 0.0})\nrequests.post(\"http://httpbin.org/post\", data={'a': 0}, files={'b': 'foo'})\nrequests.post(\"http://httpbin.org/post\", data={'a': 0.0}, files={'b': 'foo'})\n```\n\nWith the 1.2.0 version, no error is raised.\n\nWith 1.2.3 version, I have that traceback :\n\n```\nTraceback (most recent call last):\n  File \"test.py\", line 8, in <module>\n    requests.post(\"http://httpbin.org/post\", data={'a': 0.0}, files={'b': 'foo'})\n  File \".../dev/lib/python2.7/site-packages/requests/api.py\", line 88, in post\n    return request('post', url, data=data, **kwargs)\n  File \".../dev/lib/python2.7/site-packages/requests/api.py\", line 44, in request\n    return session.request(method=method, url=url, **kwargs)\n  File \".../dev/lib/python2.7/site-packages/requests/sessions.py\", line 324, in request\n    prep = req.prepare()\n  File \".../dev/lib/python2.7/site-packages/requests/models.py\", line 225, in prepare\n    p.prepare_body(self.data, self.files)\n  File \".../dev/lib/python2.7/site-packages/requests/models.py\", line 385, in prepare_body\n    (body, content_type) = self._encode_files(files, data)\n  File \".../dev/lib/python2.7/site-packages/requests/models.py\", line 133, in _encode_files\n    body, content_type = encode_multipart_formdata(new_fields)\n  File \".../dev/lib/python2.7/site-packages/requests/packages/urllib3/filepost.py\", line 90, in encode_multipart_formdata\n    body.write(data)\nTypeError: 'float' does not have the buffer interface\n```\n\nMy original problem was with a python datetime in the data dict\nThanks,\n",
    "issue_closed_at": "2013-08-27T07:59:06Z",
    "base_commit": "d8268fb7b44da7b8aa225eb1ca6fbdb4f9dc2457",
    "changes": [
      {
        "file": "requests/models.py",
        "type": "function",
        "name": "_encode_files",
        "class_name": "RequestEncodingMixin",
        "code": "def _encode_files(files, data):\n        \"\"\"Build the body for a multipart/form-data request.\n\n        Will successfully encode files when passed as a dict or a list of\n        2-tuples. Order is retained if data is a list of 2-tuples but abritrary\n        if parameters are supplied as a dict.\n\n        \"\"\"\n        if (not files) or isinstance(data, str):\n            return None\n\n        new_fields = []\n        fields = to_key_val_list(data or {})\n        files = to_key_val_list(files or {})\n\n        for field, val in fields:\n            if isinstance(val, basestring) or not hasattr(val, '__iter__'):\n                val = [val]\n            for v in val:\n                if v is not None:\n                    new_fields.append(\n                        (field.decode('utf-8') if isinstance(field, bytes) else field,\n                         v.encode('utf-8') if isinstance(v, str) else v))\n\n        for (k, v) in files:\n            # support for explicit filename\n            ft = None\n            if isinstance(v, (tuple, list)):\n                if len(v) == 2:\n                    fn, fp = v\n                else:\n                    fn, fp, ft = v\n            else:\n                fn = guess_filename(v) or k\n                fp = v\n            if isinstance(fp, str):\n                fp = StringIO(fp)\n            if isinstance(fp, bytes):\n                fp = BytesIO(fp)\n\n            if ft:\n                new_v = (fn, fp.read(), ft)\n            else:\n                new_v = (fn, fp.read())\n            new_fields.append((k, new_v))\n\n        body, content_type = encode_multipart_formdata(new_fields)\n\n        return body, content_type"
      }
    ]
  },
  "Justification": "Candidate A has a direct correlation with the current issue since both involve the requests package. The error handling aspect of candidate A is closely related to how exceptions are raised and managed in the requests library; it highlights a previous instance where an unexpected error was raised, which could guide the developer in understanding the implications of unhandled socket errors. Moreover, this report also discusses fixing how data is sent, paralleling the ERROR handling within `requests.models.py`, making it structurally similar as well. Overall, it encompasses a patch that aims to improve error management, which could be useful for addressing the current bug.",
  "instance_id": "psf__requests-2148",
  "repo": "psf/requests",
  "created_at": "2014-07-24T21:03:03Z",
  "problem_statement": "socket.error exception not caught/wrapped in a requests exception (ConnectionError perhaps?)\nI just noticed a case where I had a socket reset on me, and was raised to me as a raw socket error as opposed to something like a requests.exceptions.ConnectionError:\n\n```\n  File \"/home/rtdean/***/***/***/***/***/***.py\", line 67, in dir_parse\n    root = ElementTree.fromstring(response.text)\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/site-packages/requests-2.3.0-py2.7.egg/requests/models.py\", line 721, in text\n    if not self.content:\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/site-packages/requests-2.3.0-py2.7.egg/requests/models.py\", line 694, in content\n    self._content = bytes().join(self.iter_content(CONTENT_CHUNK_SIZE)) or bytes()\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/site-packages/requests-2.3.0-py2.7.egg/requests/models.py\", line 627, in generate\n    for chunk in self.raw.stream(chunk_size, decode_content=True):\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/site-packages/requests-2.3.0-py2.7.egg/requests/packages/urllib3/response.py\", line 240, in stream\n    data = self.read(amt=amt, decode_content=decode_content)\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/site-packages/requests-2.3.0-py2.7.egg/requests/packages/urllib3/response.py\", line 187, in read\n    data = self._fp.read(amt)\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/httplib.py\", line 543, in read\n    return self._read_chunked(amt)\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/httplib.py\", line 612, in _read_chunked\n    value.append(self._safe_read(chunk_left))\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/httplib.py\", line 658, in _safe_read\n    chunk = self.fp.read(min(amt, MAXAMOUNT))\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/socket.py\", line 380, in read\n    data = self._sock.recv(left)\n  File \"/home/rtdean/.pyenv/versions/2.7.6/lib/python2.7/site-packages/gevent-1.0.1-py2.7-linux-x86_64.egg/gevent/socket.py\", line 385, in recv\n    return sock.recv(*args)\nsocket.error: [Errno 104] Connection reset by peer\n```\n\nNot sure if this is by accident or design... in general, I guess I'd expect a requests exception when using requests, but I can start looking for socket errors and the like as well.\n\n",
  "patch": "diff --git a/requests/models.py b/requests/models.py\n--- a/requests/models.py\n+++ b/requests/models.py\n@@ -9,6 +9,7 @@\n \n import collections\n import datetime\n+import socket\n \n from io import BytesIO, UnsupportedOperation\n from .hooks import default_hooks\n@@ -22,7 +23,7 @@\n from .packages.urllib3.exceptions import DecodeError\n from .exceptions import (\n     HTTPError, RequestException, MissingSchema, InvalidURL,\n-    ChunkedEncodingError, ContentDecodingError)\n+    ChunkedEncodingError, ContentDecodingError, ConnectionError)\n from .utils import (\n     guess_filename, get_auth_from_url, requote_uri,\n     stream_decode_response_unicode, to_key_val_list, parse_header_links,\n@@ -640,6 +641,8 @@ def generate():\n                     raise ChunkedEncodingError(e)\n                 except DecodeError as e:\n                     raise ContentDecodingError(e)\n+                except socket.error as e:\n+                    raise ConnectionError(e)\n             except AttributeError:\n                 # Standard file-like object.\n                 while True:\n"
}