{
  "id": "django__django-11133",
  "question": "HttpResponse doesn't handle memoryview objects\nDescription\n\t\nI am trying to write a BinaryField retrieved from the database into a HttpResponse. When the database is Sqlite this works correctly, but Postgresql returns the contents of the field as a memoryview object and it seems like current Django doesn't like this combination:\nfrom django.http import HttpResponse\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t \n# String content\nresponse = HttpResponse(\"My Content\")\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\nresponse.content\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t \n# Out: b'My Content'\n# This is correct\n# Bytes content\nresponse = HttpResponse(b\"My Content\")\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t \nresponse.content\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t \n# Out: b'My Content'\n# This is also correct\n# memoryview content\nresponse = HttpResponse(memoryview(b\"My Content\"))\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t \nresponse.content\n# Out: b'<memory at 0x7fcc47ab2648>'\n# This is not correct, I am expecting b'My Content'\n",
  "answer": "{\"task_id\": \"fbeb86a3-2ff4-4d62-bb1e-d92660180a54\", \"workflow_run_id\": \"f89a548a-fe35-49b4-aab1-8c3daa40884b\", \"data\": {\"id\": \"f89a548a-fe35-49b4-aab1-8c3daa40884b\", \"workflow_id\": \"9a0a6efa-4d15-4876-b13f-4fb6a999caa2\", \"status\": \"succeeded\", \"outputs\": {\"final_patch\": [\"--- a/django/http/response.py\\n+++ b/django/http/response.py\\n@@ -342,6 +342,8 @@ class HttpResponse:\\n     @content.setter\\n     def content(self, value):\\n         # Consume iterators and convert bytes to strings\\n+        if isinstance(value, memoryview):\\n+            value = value.tobytes()\\n         if hasattr(value, '__iter__') and not isinstance(value, (bytes, str)):\\n             content = b''.join(self.make_bytes(chunk) for chunk in value)\\n             if hasattr(value, 'close'):\", \"--- a/django/http/response.py\\n+++ b/django/http/response.py\\n@@ -356,6 +356,8 @@ class HttpResponse:\\n \\n     def make_bytes(self, value):\\n         \\\"\\\"\\\"Turn a value into a bytestring encoded in the output charset.\\\"\\\"\\\"\\n+        if isinstance(value, memoryview):\\n+            return value.tobytes()\\n         # Handle string types -- we can't rely on force_bytes here because:\\n         # - Python attempts str conversion first\\n         # - when self._charset != 'utf-8' it re-encodes the content\", \"--- a/django/http/response.py\\n+++ b/django/http/response.py\\n@@ -342,6 +342,8 @@ class HttpResponse:\\n     @content.setter\\n     def content(self, value):\\n         # Consume iterators and convert bytes to strings\\n+        if isinstance(value, memoryview):\\n+            value = value.tobytes()\\n         if hasattr(value, '__iter__') and not isinstance(value, (bytes, str)):\\n             content = b''.join(self.make_bytes(chunk) for chunk in value)\\n             if hasattr(value, 'close'):\\n@@ -356,6 +358,8 @@ class HttpResponse:\\n \\n     def make_bytes(self, value):\\n         \\\"\\\"\\\"Turn a value into a bytestring encoded in the output charset.\\\"\\\"\\\"\\n+        if isinstance(value, memoryview):\\n+            return value.tobytes()\\n         # Handle string types -- we can't rely on force_bytes here because:\\n         # - Python attempts str conversion first\\n         # - when self._charset != 'utf-8' it re-encodes the content\", \"--- a/django/http/response.py\\n+++ b/django/http/response.py\\n@@ -342,7 +342,7 @@ class HttpResponse:\\n     @content.setter\\n     def content(self, value):\\n         # Consume iterators and convert bytes to strings\\n-        if hasattr(value, '__iter__') and not isinstance(value, (bytes, str)):\\n+        if hasattr(value, '__iter__') and not isinstance(value, (bytes, str, memoryview)):\\n             content = b''.join(self.make_bytes(chunk) for chunk in value)\\n             if hasattr(value, 'close'):\\n                 value.close()\\n@@ -356,6 +356,8 @@ class HttpResponse:\\n \\n     def make_bytes(self, value):\\n         \\\"\\\"\\\"Turn a value into a bytestring encoded in the output charset.\\\"\\\"\\\"\\n+        if isinstance(value, memoryview):\\n+            return value.tobytes()\\n         # Handle string types -- we can't rely on force_bytes here because:\\n         # - Python attempts str conversion first\\n         # - when self._charset != 'utf-8' it re-encodes the content\", \"--- a/django/http/response.py\\n+++ b/django/http/response.py\\n@@ -342,6 +342,9 @@ class HttpResponse:\\n     @content.setter\\n     def content(self, value):\\n         # Consume iterators and convert bytes to strings\\n+        # Handle memoryview objects by converting to bytes\\n+        if isinstance(value, memoryview):\\n+            self._content = value.tobytes()\\n+            return\\n         if hasattr(value, '__iter__') and not isinstance(value, (bytes, str)):\\n             content = b''.join(self.make_bytes(chunk) for chunk in value)\\n             if hasattr(value, 'close'):\", \"diff\\n--- a/django/http/response.py\\n+++ b/django/http/response.py\\n@@ -342,6 +342,8 @@ class HttpResponse:\\n     @content.setter\\n     def content(self, value):\\n         # Consume iterators and convert bytes to strings\\n+        if isinstance(value, memoryview):\\n+            value = value.tobytes()\\n         if hasattr(value, '__iter__') and not isinstance(value, (bytes, str)):\\n             content = b''.join(self.make_bytes(chunk) for chunk in value)\\n             if hasattr(value, 'close'):\\n@@ -356,6 +358,8 @@ class HttpResponse:\\n \\n     def make_bytes(self, value):\\n         \\\"\\\"\\\"Turn a value into a bytestring encoded in the output charset.\\\"\\\"\\\"\\n+        if isinstance(value, memoryview):\\n+            return value.tobytes()\\n         # Handle string types -- we can't rely on force_bytes here because:\\n         # - Python attempts str conversion first\\n         # - when self._charset != 'utf-8' it re-encodes the content\\n\", \"diff\\n--- a/django/http/response.py\\n+++ b/django/http/response.py\\n@@ -342,6 +342,8 @@ class HttpResponse:\\n     @content.setter\\n     def content(self, value):\\n         # Consume iterators and convert bytes to strings\\n+        if isinstance(value, memoryview):\\n+            value = value.tobytes()\\n         if hasattr(value, '__iter__') and not isinstance(value, (bytes, str)):\\n             content = b''.join(self.make_bytes(chunk) for chunk in value)\\n             if hasattr(value, 'close'):\\n@@ -356,6 +358,8 @@ class HttpResponse:\\n \\n     def make_bytes(self, value):\\n         \\\"\\\"\\\"Turn a value into a bytestring encoded in the output charset.\\\"\\\"\\\"\\n+        if isinstance(value, memoryview):\\n+            return value.tobytes()\\n         # Handle string types -- we can't rely on force_bytes here because:\\n         # - Python attempts str conversion first\\n         # - when self._charset != 'utf-8' it re-encodes the content\\n\", \"diff\\n--- a/django/http/response.py\\n+++ b/django/http/response.py\\n@@ -342,6 +342,8 @@ class HttpResponse:\\n     @content.setter\\n     def content(self, value):\\n         # Consume iterators and convert bytes to strings\\n+        if isinstance(value, memoryview):\\n+            value = value.tobytes()\\n         if hasattr(value, '__iter__') and not isinstance(value, (bytes, str)):\\n             content = b''.join(self.make_bytes(chunk) for chunk in value)\\n             if hasattr(value, 'close'):\\n@@ -356,6 +358,8 @@ class HttpResponse:\\n \\n     def make_bytes(self, value):\\n         \\\"\\\"\\\"Turn a value into a bytestring encoded in the output charset.\\\"\\\"\\\"\\n+        if isinstance(value, memoryview):\\n+            return value.tobytes()\\n         # Handle string types -- we can't rely on force_bytes here because:\\n         # - Python attempts str conversion first\\n         # - when self._charset != 'utf-8' it re-encodes the content\\n\"]}, \"error\": \"\", \"elapsed_time\": 107.572497, \"total_tokens\": 36111, \"total_steps\": 30, \"created_at\": 1754647646, \"finished_at\": 1754647754}}"
}