{
  "original_problem": {
    "instance_id": "psf__requests-2317",
    "repo": "psf/requests",
    "created_at": "2014-11-01T02:20:16Z",
    "problem_statement": "method = builtin_str(method) problem\nIn requests/sessions.py is a command:\n\nmethod = builtin_str(method)\nConverts method from\nb’GET’\nto\n\"b'GET’\"\n\nWhich is the literal string, no longer a binary string.  When requests tries to use the method \"b'GET’”, it gets a 404 Not Found response.\n\nI am using python3.4 and python-neutronclient (2.3.9) with requests (2.4.3).  neutronclient is broken because it uses this \"args = utils.safe_encode_list(args)\" command which converts all the values to binary string, including method.\n\nI'm not sure if this is a bug with neutronclient or a bug with requests, but I'm starting here.  Seems if requests handled the method value being a binary string, we wouldn't have any problem.\n\nAlso, I tried in python2.6 and this bug doesn't exist there. Some difference between 2.6 and 3.4 makes this not work right.\n\n",
    "patch": "diff --git a/requests/sessions.py b/requests/sessions.py\n--- a/requests/sessions.py\n+++ b/requests/sessions.py\n@@ -13,7 +13,7 @@\n from datetime import datetime\n \n from .auth import _basic_auth_str\n-from .compat import cookielib, OrderedDict, urljoin, urlparse, builtin_str\n+from .compat import cookielib, OrderedDict, urljoin, urlparse\n from .cookies import (\n     cookiejar_from_dict, extract_cookies_to_jar, RequestsCookieJar, merge_cookies)\n from .models import Request, PreparedRequest, DEFAULT_REDIRECT_LIMIT\n@@ -425,7 +425,7 @@ def request(self, method, url,\n             If Tuple, ('cert', 'key') pair.\n         \"\"\"\n \n-        method = builtin_str(method)\n+        method = to_native_string(method)\n \n         # Create the Request.\n         req = Request(\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_1887",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve type conversion problems between bytes and strings, requiring adaptation to maintain compatibility."
      },
      {
        "idx": 2,
        "id": "similar_1462",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about handling non-string data types in multipart requests, which is unrelated to the current issue's type conversion problem."
      },
      {
        "idx": 3,
        "id": "similar_2144",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue focuses on exception handling rather than type conversion, which is not relevant to the current problem."
      },
      {
        "idx": 4,
        "id": "similar_1711",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about cookie management and dictionary access, unrelated to type conversion between bytes and strings."
      },
      {
        "idx": 5,
        "id": "similar_1360",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue deals with redirect handling and not with type conversion or encoding issues."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "301 redirect broken with latest pyopenssl/SNI",
        "issue_body": "With the latest pyopenssl on Windows 64bit:\n\n```\ncryptography==0.2.dev1\nndg-httpsclient==0.3.2\npyOpenSSL==0.13\npyasn1==0.1.7\n```\n\nI get an exception raised when `GET`ing a `301` response to a HTTPS request. I see that after the redirect is received the returned URL is [decoded to a Unicode string](https://github.com/kennethreitz/requests/blob/master/requests/adapters.py#L181). Then requests passes the response to `resolve_redirects` which uses the url to make a new request. This leads to a Unicode string being passed to urllib3 and eventually pyopenssl. And because in pyopenssl they now check that the data is of type bytes, an exception is thrown. \n\nI Wrote this test:\n\n```\n    def test_pyopenssl_redirect(self):\n        requests.get('https://httpbin.org/status/301')\n```\n\nand this is the result of py.test:\n\n```\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\n\nself = <OpenSSL.SSL.Connection object at 0x000000000345CC50>\nbuf = u'GET /redirect/1 HTTP/1.1\\r\\nHost: httpbin.org\\r\\nAccept-Encoding: gzip, defl...cept: */*\\r\\nUser-Agent: python-r\nequests/2.2.1 CPython/2.7.6 Windows/8\\r\\n\\r\\n'\nflags = 0\n\n    def sendall(self, buf, flags=0):\n        \"\"\"\n            Send \"all\" data on the connection. This calls send() repeatedly until\n            all data is sent. If an error occurs, it's impossible to tell how much\n            data has been sent.\n\n            :param buf: The string to send\n            :param flags: (optional) Included for compatibility with the socket\n                          API, the value is ignored\n            :return: The number of bytes written\n            \"\"\"\n        if isinstance(buf, _memoryview):\n            buf = buf.tobytes()\n        if not isinstance(buf, bytes):\n>           raise TypeError(\"buf must be a byte string\")\nE           TypeError: buf must be a byte string\n\n..\\testreq\\lib\\site-packages\\OpenSSL\\SSL.py:968: TypeError\n=================================== 117 tests deselected by '-kpyopenssl_redirect' ====================================\n====================================== 1 failed, 117 deselected in 4.47 seconds =======================================\n```\n",
        "issue_id": 1887,
        "pr_number": 1888,
        "pr_title": "Fix for 301 redirect and latest PyOpenSSL.",
        "pr_body": "Fixes #1887\n",
        "issue_closed_at": "2014-01-28T20:14:38Z",
        "base_commit": "19756d57f73c2062240dd477dd8f8d8a7c0c512a"
      },
      "summary": "### Summary:\nThis issue pertains to a compatibility problem between the `requests` library and the `pyOpenSSL` library on Windows 64-bit systems. Specifically, when handling a `301` HTTP redirect response over HTTPS, the updated version of `pyOpenSSL` raises a `TypeError` due to the handling of URL strings. The crux of the problem lies in the conversion of the redirected URL to a Unicode string, which is then passed to the underlying libraries, eventually reaching `pyOpenSSL`. The recent changes in `pyOpenSSL` now enforce that data must be of type `bytes`, leading to an exception when a Unicode string is encountered.\n\nKey symptoms include the failure of HTTP requests that involve redirects, resulting in a `TypeError` with the message \"buf must be a byte string.\" This issue primarily affects the `requests` library's interaction with `pyOpenSSL`, specifically when using the `resolve_redirects` function which manages HTTP redirects.\n\nThe affected components include the `requests` library, particularly the `SessionRedirectMixin.resolve_redirects` function, and the `pyOpenSSL` library, both of which are integral to handling secure HTTP connections.\n\nThe potential impact of this issue is significant for applications relying on the `requests` library for HTTP/HTTPS interactions, as it could lead to failure in processing redirects, affecting data retrieval and communication over secure channels.\n\nRelevant technical details include the transition of URL handling from Unicode to byte strings, as dictated by the changes in `pyOpenSSL`, and the need for libraries like `requests` to adapt to this change to maintain compatibility and functionality.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: 301 redirect broken with latest pyopenssl/SNI\n\nBody:\nWith the latest pyopenssl on Windows 64bit:\n\n```\ncryptography==0.2.dev1\nndg-httpsclient==0.3.2\npyOpenSSL==0.13\npyasn1==0.1.7\n```\n\nI get an exception raised when `GET`ing a `301` response to a HTTPS request. I see that after the redirect is received the returned URL is [decoded to a Unicode string](https://github.com/kennethreitz/requests/blob/master/requests/adapters.py#L181). Then requests passes the response to `resolve_redirects` which uses the url to make a new request. This leads to a Unicode string being passed to urllib3 and eventually pyopenssl. And because in pyopenssl they now check that the data is of type bytes, an exception is thrown. \n\nI Wrote this test:\n\n```\n    def test_pyopenssl_redirect(self):\n        requests.get('https://httpbin.org/status/301')\n```\n\nand this is the result of py.test:\n\n```\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _\n\nself = <OpenSSL.SSL.Connection object at 0x000000000345CC50>\nbuf = u'GET /redirect/1 HTTP/1.1\\r\\nHost: httpbin.org\\r\\nAccept-Encoding: gzip, defl...cept: */*\\r\\nUser-Agent: python-r\nequests/2.2.1 CPython/2.7.6 Windows/8\\r\\n\\r\\n'\nflags = 0\n\n    def sendall(self, buf, flags=0):\n        \"\"\"\n            Send \"all\" data on the connection. This calls send() repeatedly until\n            all data is sent. If an error occurs, it's impossible to tell how much\n            data has been sent.\n\n            :param buf: The string to send\n            :param flags: (optional) Included for compatibility with the socket\n                          API, the value is ignored\n            :return: The number of bytes written\n            \"\"\"\n        if isinstance(buf, _memoryview):\n            buf = buf.tobytes()\n        if not isinstance(buf, bytes):\n>           raise TypeError(\"buf must be a byte string\")\nE           TypeError: buf must be a byte string\n\n..\\testreq\\lib\\site-packages\\OpenSSL\\SSL.py:968: TypeError\n=================================== 117 tests deselected by '-kpyopenssl_redirect' ====================================\n====================================== 1 failed, 117 deselected in 4.47 seconds =======================================\n```\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/sessions.py\n  line: line 17\n  function: SessionRedirectMixin.resolve_redirects\n"
    },
    {
      "similar_issue": {
        "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_id": 1462,
        "pr_number": 1537,
        "pr_title": "Allow non-string objects to be posted as data alongside files.",
        "pr_body": "This should resolve #1462.\n",
        "issue_closed_at": "2013-08-27T07:59:06Z",
        "base_commit": "d8268fb7b44da7b8aa225eb1ca6fbdb4f9dc2457"
      },
      "summary": "### Summary:\nThis issue pertains to a regression in the `requests` library, where providing certain data types within multipart form-data requests leads to a TypeError. Specifically, the error arises when attempting to send data that includes non-string types, such as floats and potentially datetime objects, in conjunction with files. This problem was previously identified and addressed in an earlier version of the library but seems to have reappeared in version 1.2.3. \n\n1. **Problem Description in General Terms:** \n   The issue manifests as a failure to handle non-string data types correctly when they are included in multipart form-data HTTP requests, specifically when combined with file uploads. This results in a traceback error due to the library's inability to process these types correctly.\n\n2. **Key Symptoms and Behaviors Observed:** \n   The primary symptom is a traceback error indicating a `TypeError`, specifically noting that a 'float' or similar non-string type does not have a buffer interface. This error occurs during the encoding process of the request body when attempting to send data and files together in a POST request.\n\n3. **Affected Components or Systems:** \n   The problem affects the `requests` library, particularly the `RequestEncodingMixin._encode_files` function within `requests/models.py`, which is responsible for encoding files and data into a format suitable for HTTP transmission.\n\n4. **Potential Impact or Severity:** \n   The impact is significant for users of the `requests` library who need to send multipart form-data requests containing non-string data types. This can disrupt applications relying on such functionality, potentially leading to a failure in HTTP communication and data transmission.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:** \n   The issue surfaces due to the library's encoding mechanism failing to handle non-string types gracefully. The library attempts to write these data types to a buffer, which is not supported for floats and possibly other non-string types like datetime objects. This necessitates a patch to ensure type compatibility in the encoding process, allowing the library to handle various data types without errors.\n\nChanges Summary:\nThe fix involves modifications to `requests/models.py` to address the encoding logic in the `RequestEncodingMixin._encode_files` function, ensuring proper handling and conversion of non-string data types included with file uploads in multipart form-data requests.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: multipart/form-data and datetime data\n\nBody:\nI 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\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/models.py\n  function: RequestEncodingMixin._encode_files\n"
    },
    {
      "similar_issue": {
        "issue_title": "socket.error exception not caught/wrapped in a requests exception (ConnectionError perhaps?)",
        "issue_body": "I 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",
        "issue_id": 2144,
        "pr_number": 2148,
        "pr_title": "Handle socket errors in iter_content",
        "pr_body": "My first PR for Requests, so I probably did something terribly wrong.\n\nCloses #2144.\n",
        "issue_closed_at": "2014-07-27T13:59:08Z",
        "base_commit": "fe693c492242ae532211e0c173324f09ca8cf227"
      },
      "summary": "### Summary:\nThis issue is related to exception handling within the Requests library, where a low-level socket error is not appropriately caught and wrapped in a higher-level Requests exception, such as a `ConnectionError`. This behavior was observed when a socket connection was unexpectedly reset by a peer, leading to a raw `socket.error` being raised instead of a more user-friendly Requests exception. The user expected the library to provide a consistent exception interface.\n\n1. **Problem description in general terms**: The problem arises from a lack of appropriate exception handling in the Requests library, resulting in raw socket errors being exposed to the user instead of being encapsulated in higher-level exceptions that are consistent with the library's usual behavior.\n\n2. **Key symptoms and behaviors observed**: The main symptom is the raising of a raw `socket.error` with the message \"Connection reset by peer\" during a network operation, which is not caught and translated into a Requests-specific exception.\n\n3. **Affected components or systems**: The issue affects the Requests library, specifically within the `models.py` file's `Response` class, and its interaction with the `urllib3` package and the lower-level `socket` module.\n\n4. **Potential impact or severity**: The severity is moderate as it affects error handling and consistency in the library's API, potentially leading to confusion and additional error handling requirements for developers using the Requests library in network applications.\n\n5. **Any relevant technical details abstracted for broader understanding**: The problem occurs during the reading of response content in a streaming manner, where exceptions from the socket layer propagate up to the application layer without being properly wrapped. The fix involved modifying the `Response.generate` function and other areas in the `models.py` file to ensure socket errors are caught and re-raised as `requests.exceptions.ConnectionError`, maintaining consistency in exception handling across the library.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: socket.error exception not caught/wrapped in a requests exception (ConnectionError perhaps?)\n\nBody:\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\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/models.py\n  line: line 9\n  line: line 22\n  function: Response.generate\n"
    },
    {
      "similar_issue": {
        "issue_title": "Regression 2.0.1: Using MozillaCookieJar does not work",
        "issue_body": "Could not find an issue raised for this, not sure if this was an expected change either. This is reproducible on master.\n\nExisting code fails on update to `requests-2.0.1`. The cause seems to be triggered by the change at https://github.com/kennethreitz/requests/commit/012f0334ce43fe23044fc58e4246a804db88650d#diff-28e67177469c0d36b068d68d9f6043bfR326\n\nThe parameter `cookies` expects either `Dict` or `CookieJar`. Treating `MozillaCookieJar` as a dict triggers the error in this instance.\n\nThe following code highlights the issue:\n\n``` py\nimport sys\nimport requests\nfrom os.path import expanduser\n\nif sys.version_info.major >= 3:\n    from http.cookiejar import MozillaCookieJar\nelse:\n    from cookielib import MozillaCookieJar\n\nURL = 'https://bugzilla.redhat.com'\nCOOKIE_FILE = expanduser('~/.bugzillacookies')\n\ncookiejar = MozillaCookieJar(COOKIE_FILE)\ncookiejar.load()\n\nrequests.get(URL, cookies=cookiejar)\n```\n\nThe following `AttributeError` is thrown:\n\n```\nTraceback (most recent call last):\n  File \"rtest.py\", line 16, in <module>\n    requests.get(URL, cookies=cookiejar)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/api.py\", line 55, in get\n    return request('get', url, **kwargs)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/api.py\", line 44, in request\n    return session.request(method=method, url=url, **kwargs)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/sessions.py\", line 327, in request\n    self.cookies = cookiejar_from_dict(cookies, cookiejar=self.cookies, overwrite=False)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/cookies.py\", line 410, in cookiejar_from_dict\n    cookiejar.set_cookie(create_cookie(name, cookie_dict[name]))\nAttributeError: MozillaCookieJar instance has no attribute '__getitem__'\n```\n",
        "issue_id": 1711,
        "pr_number": 1713,
        "pr_title": "Fixed #1711",
        "pr_body": "I think i missed the point that cookies can be Dict or CookieJar.\nThis fix will work for MozillaCookieJar.\n",
        "issue_closed_at": "2013-12-04T01:33:33Z",
        "base_commit": "340b2459031feb421d678c3c75865c3b11c07938"
      },
      "summary": "### Summary:\n\nThis issue is a regression problem encountered after updating to the `requests` library version 2.0.1, which affects the handling of cookie management when interacting with web services. The problem occurs when the `MozillaCookieJar`, a class used for cookie handling in Python, is treated as a dictionary, which is incompatible with the expected input types in the updated `requests` library functions. This results in an `AttributeError` because `MozillaCookieJar` does not support dictionary-like item access.\n\n1. **Problem Description in General Terms**: The issue arises from a change in the `requests` library that affects how cookies are managed, specifically when using `MozillaCookieJar`. The library expects cookies to be passed in as either a dictionary or a `CookieJar` instance, but it mistakenly tries to access `MozillaCookieJar` as if it were a dictionary.\n\n2. **Key Symptoms and Behaviors Observed**: The main symptom is an `AttributeError` which states that the `MozillaCookieJar` instance does not have the `__getitem__` attribute. This occurs when attempting to make an HTTP GET request with cookies managed by a `MozillaCookieJar` object.\n\n3. **Affected Components or Systems**: The issue affects the `requests` library, specifically the functions involved in preparing and executing HTTP requests that involve cookie management. This impacts any system or application that relies on `requests` for HTTP operations involving `MozillaCookieJar`.\n\n4. **Potential Impact or Severity**: The impact of this issue can be significant for applications that depend on session management and cookie persistence, as it can break functionality related to HTTP requests. This may lead to disrupted communications with web services, especially those requiring authentication or session tracking.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The technical root of the problem lies in the recent changes in the `requests` library's internal handling of cookies, specifically in the `cookiejar_from_dict` function. The fix involves ensuring that `MozillaCookieJar` is correctly handled and not treated as a dictionary, which requires changes in the `requests/cookies.py` and `requests/sessions.py` modules. Understanding these changes is crucial for developers relying on `requests` for robust HTTP client functionality.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Regression 2.0.1: Using MozillaCookieJar does not work\n\nBody:\nCould not find an issue raised for this, not sure if this was an expected change either. This is reproducible on master.\n\nExisting code fails on update to `requests-2.0.1`. The cause seems to be triggered by the change at https://github.com/kennethreitz/requests/commit/012f0334ce43fe23044fc58e4246a804db88650d#diff-28e67177469c0d36b068d68d9f6043bfR326\n\nThe parameter `cookies` expects either `Dict` or `CookieJar`. Treating `MozillaCookieJar` as a dict triggers the error in this instance.\n\nThe following code highlights the issue:\n\n``` py\nimport sys\nimport requests\nfrom os.path import expanduser\n\nif sys.version_info.major >= 3:\n    from http.cookiejar import MozillaCookieJar\nelse:\n    from cookielib import MozillaCookieJar\n\nURL = 'https://bugzilla.redhat.com'\nCOOKIE_FILE = expanduser('~/.bugzillacookies')\n\ncookiejar = MozillaCookieJar(COOKIE_FILE)\ncookiejar.load()\n\nrequests.get(URL, cookies=cookiejar)\n```\n\nThe following `AttributeError` is thrown:\n\n```\nTraceback (most recent call last):\n  File \"rtest.py\", line 16, in <module>\n    requests.get(URL, cookies=cookiejar)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/api.py\", line 55, in get\n    return request('get', url, **kwargs)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/api.py\", line 44, in request\n    return session.request(method=method, url=url, **kwargs)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/sessions.py\", line 327, in request\n    self.cookies = cookiejar_from_dict(cookies, cookiejar=self.cookies, overwrite=False)\n  File \"/tmp/rtestenv/lib/python2.7/site-packages/requests/cookies.py\", line 410, in cookiejar_from_dict\n    cookiejar.set_cookie(create_cookie(name, cookie_dict[name]))\nAttributeError: MozillaCookieJar instance has no attribute '__getitem__'\n```\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/cookies.py\n  function: cookiejar_from_dict\n\nrequests/sessions.py\n  line: line 13\n  function: Session.prepare_request\n  function: Session.request\n"
    },
    {
      "similar_issue": {
        "issue_title": "Problem with 301-redirect",
        "issue_body": "I have a problem with downloading a file, when the server returns the 301 code:\n\n``` python\nr = requests.get('http://servag.rupsy.ru/track.php?url=2013-04-11/Haatzumaniak_-_Dark_Sadhu_[2013]/03.%20Haatzumaniak_-_777_Dark%20Sadhu%202013.mp3&arj=Haatzumaniak_-_Dark_Sadhu_[2013].ZIP')\nprint(r)\n```\n\nIf you do redirect manually - it works fine:\n\n``` python\nr = requests.get('http://servag.rupsy.ru/track.php?url=2013-04-11/Haatzumaniak_-_Dark_Sadhu_[2013]/03.%20Haatzumaniak_-_777_Dark%20Sadhu%202013.mp3&arj=Haatzumaniak_-_Dark_Sadhu_[2013].ZIP', allow_redirects=False)\nr = requests.get(r.headers['Location'])\nprint(r)\n```\n\nThe problem appears to Python 3.3 and python-requests-1.2.0/python-requests-dev\n\n```\nTraceback (most recent call last):\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\packages\\urllib3\\connectionpool.py\", line 428, in urlopen\n    body=body, headers=headers)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\packages\\urllib3\\connectionpool.py\", line 290, in _make_request\n    httplib_response = conn.getresponse()\n  File \"c:\\Python33\\lib\\http\\client.py\", line 1143, in getresponse\n    response.begin()\n  File \"c:\\Python33\\lib\\http\\client.py\", line 354, in begin\n    version, status, reason = self._read_status()\n  File \"c:\\Python33\\lib\\http\\client.py\", line 324, in _read_status\n    raise BadStatusLine(line)\nhttp.client.BadStatusLine: ''\n\nDuring handling of the above exception, another exception occurred:\n\nTraceback (most recent call last):\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\adapters.py\", line 283, in send\n    timeout=timeout\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\packages\\urllib3\\connectionpool.py\", line 474, in urlopen\n    raise MaxRetryError(self, url, e)\nrequests.packages.urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='servag.rupsy.ru', port=80): Max retries exceeded with url: /media/2/Haatzumaniak_-_Dark_Sadhu_[2013]/03. Haatzumaniak_-_777_Dark Sadhu 2013.mp3 (Caused by <class 'http.client.BadStatusLine'>: '')\n\nDuring handling of the above exception, another exception occurred:\n\nTraceback (most recent call last):\n  File \"C:/Dropbox/projects/InfoStreams/test.py\", line 25, in <module>\n    allow_redirects=True)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\api.py\", line 55, in get\n    return request('get', url, **kwargs)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\api.py\", line 44, in request\n    return session.request(method=method, url=url, **kwargs)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 345, in request\n    resp = self.send(prep, **send_kwargs)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 464, in send\n    history = [resp for resp in gen] if allow_redirects else []\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 464, in <listcomp>\n    history = [resp for resp in gen] if allow_redirects else []\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 154, in resolve_redirects\n    allow_redirects=False,\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 448, in send\n    r = adapter.send(request, **kwargs)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\adapters.py\", line 318, in send\n    raise ConnectionError(e)\nrequests.exceptions.ConnectionError: HTTPConnectionPool(host='servag.rupsy.ru', port=80): Max retries exceeded with url: /media/2/Haatzumaniak_-_Dark_Sadhu_[2013]/03. Haatzumaniak_-_777_Dark Sadhu 2013.mp3 (Caused by <class 'http.client.BadStatusLine'>: '')\n```\n",
        "issue_id": 1360,
        "pr_number": 1361,
        "pr_title": "Always percent-encode location headers.",
        "pr_body": "If we don't, stupid servers that don't do it themselves can hurt us badly.\n\nResolves #1360.\n",
        "issue_closed_at": "2013-05-20T20:04:08Z",
        "base_commit": "eacb91afb1c5dee8a6fcdadc9473463008e791c6"
      },
      "summary": "### Summary:\nThis issue is related to handling HTTP 301 redirects when attempting to download a file using the Python `requests` library. The problem occurs when the server returns a 301 status code, which is a redirect response, and the download process fails if redirects are not manually handled. The error manifests as a `http.client.BadStatusLine` exception, indicating an issue with the response status line being improperly parsed, leading to a `ConnectionError` due to exceeding the maximum number of retries.\n\n1. **Problem description in general terms**: The problem arises from an automatic redirect mechanism in the Python `requests` library, which fails to process an HTTP 301 redirect properly, resulting in an inability to download files from certain URLs.\n   \n2. **Key symptoms and behaviors observed**: The key symptom is an exception traceback, specifically a `http.client.BadStatusLine` error followed by a `MaxRetryError` and a `ConnectionError`, indicating that the library is unable to handle the redirect and subsequently fails to complete the request.\n\n3. **Affected components or systems**: The issue affects the Python `requests` library, particularly in versions 1.2.0 and the development version, in conjunction with Python 3.3. The problematic component is the `SessionRedirectMixin.resolve_redirects` function within `requests/sessions.py`.\n\n4. **Potential impact or severity**: The severity of this issue is moderate, as it prevents automated file downloads via HTTP 301 redirects, potentially affecting any applications relying on this functionality for file retrieval.\n\n5. **Any relevant technical details abstracted for broader understanding**: The problem is rooted in the handling of HTTP status lines and redirect logic within the `requests` library. The library needs to correctly interpret and follow redirect responses to avoid connection errors and ensure smooth file downloads. The manual workaround involves explicitly handling the redirect by setting `allow_redirects=False` and manually following the `Location` header in the response. The issue may impact systems that require reliable handling of HTTP redirects.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Problem with 301-redirect\n\nBody:\nI have a problem with downloading a file, when the server returns the 301 code:\n\n``` python\nr = requests.get('http://servag.rupsy.ru/track.php?url=2013-04-11/Haatzumaniak_-_Dark_Sadhu_[2013]/03.%20Haatzumaniak_-_777_Dark%20Sadhu%202013.mp3&arj=Haatzumaniak_-_Dark_Sadhu_[2013].ZIP')\nprint(r)\n```\n\nIf you do redirect manually - it works fine:\n\n``` python\nr = requests.get('http://servag.rupsy.ru/track.php?url=2013-04-11/Haatzumaniak_-_Dark_Sadhu_[2013]/03.%20Haatzumaniak_-_777_Dark%20Sadhu%202013.mp3&arj=Haatzumaniak_-_Dark_Sadhu_[2013].ZIP', allow_redirects=False)\nr = requests.get(r.headers['Location'])\nprint(r)\n```\n\nThe problem appears to Python 3.3 and python-requests-1.2.0/python-requests-dev\n\n```\nTraceback (most recent call last):\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\packages\\urllib3\\connectionpool.py\", line 428, in urlopen\n    body=body, headers=headers)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\packages\\urllib3\\connectionpool.py\", line 290, in _make_request\n    httplib_response = conn.getresponse()\n  File \"c:\\Python33\\lib\\http\\client.py\", line 1143, in getresponse\n    response.begin()\n  File \"c:\\Python33\\lib\\http\\client.py\", line 354, in begin\n    version, status, reason = self._read_status()\n  File \"c:\\Python33\\lib\\http\\client.py\", line 324, in _read_status\n    raise BadStatusLine(line)\nhttp.client.BadStatusLine: ''\n\nDuring handling of the above exception, another exception occurred:\n\nTraceback (most recent call last):\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\adapters.py\", line 283, in send\n    timeout=timeout\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\packages\\urllib3\\connectionpool.py\", line 474, in urlopen\n    raise MaxRetryError(self, url, e)\nrequests.packages.urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='servag.rupsy.ru', port=80): Max retries exceeded with url: /media/2/Haatzumaniak_-_Dark_Sadhu_[2013]/03. Haatzumaniak_-_777_Dark Sadhu 2013.mp3 (Caused by <class 'http.client.BadStatusLine'>: '')\n\nDuring handling of the above exception, another exception occurred:\n\nTraceback (most recent call last):\n  File \"C:/Dropbox/projects/InfoStreams/test.py\", line 25, in <module>\n    allow_redirects=True)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\api.py\", line 55, in get\n    return request('get', url, **kwargs)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\api.py\", line 44, in request\n    return session.request(method=method, url=url, **kwargs)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 345, in request\n    resp = self.send(prep, **send_kwargs)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 464, in send\n    history = [resp for resp in gen] if allow_redirects else []\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 464, in <listcomp>\n    history = [resp for resp in gen] if allow_redirects else []\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 154, in resolve_redirects\n    allow_redirects=False,\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\sessions.py\", line 448, in send\n    r = adapter.send(request, **kwargs)\n  File \"C:\\Dropbox\\projects\\Helpers\\ph\\.envwin32\\lib\\site-packages\\requests\\adapters.py\", line 318, in send\n    raise ConnectionError(e)\nrequests.exceptions.ConnectionError: HTTPConnectionPool(host='servag.rupsy.ru', port=80): Max retries exceeded with url: /media/2/Haatzumaniak_-_Dark_Sadhu_[2013]/03. Haatzumaniak_-_777_Dark Sadhu 2013.mp3 (Caused by <class 'http.client.BadStatusLine'>: '')\n```\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nrequests/sessions.py\n  function: SessionRedirectMixin.resolve_redirects\n"
    }
  ]
}