{
  "Selected_candidate": {
    "pr_number": 10781,
    "pr_title": "Fixed #30054 -- Implemented cascaded flush on SQLite.",
    "pr_body": "This is required to maintain foreign key integrity when using the `TransactionTestCase.available_apps` feature.\r\n\r\nRefs [#30033](https://code.djangoproject.com/ticket/30033), [#14204](https://code.djangoproject.com/ticket/14204), [#20483](https://code.djangoproject.com/ticket/20483).",
    "issue_id": 30054,
    "issue_title": "SQLite doesn't implement cascading flush and breaks available_apps feature.",
    "issue_body": "#30033\nstarted performing constraint checks on schema alteration commits on SQLite and uncovered a data integrity issue of our SQLite backend flushing of data.\nWhen\nTransactionTestCase.available_apps\nis specfied only the specified apps subset of tested model tables are flushed for performance reasons. Thing is when this happens all rows referring to\nflushed\ntable rows must also be flushed as specified by the\nDatabaseOperations.sql_flush(allow_cascade)\nflag that SQLite completely ignores.\nThis issue has been around since foreign keys were enabled on SQLite because\nexecute_sql_flush\nhappens to disable constraint checks and allow foreign key integrity to be silently broken.\nIn order to address this issue\nsql_flush\nmust consider\nallow_cascade\nand\nexecute_sql_flush\nshould stop disabling constraints.\nMore context from\n​\nhttps://github.com/django/django/pull/10779#issuecomment-449483709",
    "issue_closed_at": "2018-12-22T16:48:11",
    "base_commit": "790d108c97f0cf9caa02c72791f2bf158d308fcd",
    "changes": [
      {
        "file": "django/db/backends/sqlite3/operations.py",
        "type": "function",
        "name": "no_limit_value",
        "class_name": "DatabaseOperations",
        "code": "def no_limit_value(self):\n        return -1"
      },
      {
        "file": "django/db/backends/sqlite3/operations.py",
        "type": "function",
        "name": "sql_flush",
        "class_name": "DatabaseOperations",
        "code": "def sql_flush(self, style, tables, sequences, allow_cascade=False):\n        sql = ['%s %s %s;' % (\n            style.SQL_KEYWORD('DELETE'),\n            style.SQL_KEYWORD('FROM'),\n            style.SQL_FIELD(self.quote_name(table))\n        ) for table in tables]\n        # Note: No requirement for reset of auto-incremented indices (cf. other\n        # sql_flush() implementations). Just return SQL at this point\n        return sql"
      }
    ]
  },
  "Justification": "Candidate A relates closely to database handling with SQLite, which is relevant to the CURRENT bug that involves a memoryview object returned from a database in PostgreSQL. Even though they deal with different databases, both bugs are connected through their storage backend behavior and how data integrity can lead to issues with Django's response handling. The fix applied in Candidate A could provide insights into handling unexpected data types when retrieved from different databases. This understanding is valuable for adjusting how HttpResponse treats binary objects, including memoryviews.",
  "instance_id": "django__django-11133",
  "repo": "django/django",
  "created_at": "2019-03-27T06:48:09Z",
  "problem_statement": "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",
  "patch": "diff --git a/django/http/response.py b/django/http/response.py\n--- a/django/http/response.py\n+++ b/django/http/response.py\n@@ -229,7 +229,7 @@ def make_bytes(self, value):\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-        if isinstance(value, bytes):\n+        if isinstance(value, (bytes, memoryview)):\n             return bytes(value)\n         if isinstance(value, str):\n             return bytes(value.encode(self.charset))\n"
}