{
  "Selected_candidate": {
    "pr_number": 11119,
    "pr_title": "Fixed #29791 -- Honor engine's autoescape attribute in render_to_string",
    "pr_body": "Passed down autoescape value from Engine to Context in Engine.render_to_string.",
    "issue_id": 29791,
    "issue_title": "Engine.render_to_string() should honor the autoescape attribute",
    "issue_body": "In\nEngine.render_to_string\n, a\nContext\nis created without specifying the engine\nautoescape\nattribute. So if you create en engine with\nautoescape=False\nand then call its\nrender_to_string()\nmethod, the result will always be autoescaped. It was probably overlooked in\n[19a5f6da329d58653bcda85]\n.",
    "issue_closed_at": "2019-03-25T17:26:24",
    "base_commit": "d4df5e1b0b1c643fe0fc521add0236764ec8e92a",
    "changes": [
      {
        "file": "django/template/engine.py",
        "type": "function",
        "name": "render_to_string",
        "class_name": "Engine",
        "code": "def render_to_string(self, template_name, context=None):\n        \"\"\"\n        Render the template specified by template_name with the given context.\n        For use in Django's test suite.\n        \"\"\"\n        if isinstance(template_name, (list, tuple)):\n            t = self.select_template(template_name)\n        else:\n            t = self.get_template(template_name)\n        # Django < 1.8 accepted a Context in `context` even though that's\n        # unintended. Preserve this ability but don't rewrap `context`.\n        if isinstance(context, Context):\n            return t.render(context)\n        else:\n            return t.render(Context(context))"
      }
    ]
  },
  "Justification": "Candidate E addresses a modification in the way templates are rendered with specific considerations for attributes that can affect JSON outputs. The CURRENT bug report discusses enhancing the JSON serialization by passing a custom encoder, which ties closely to the need for precise control over rendering and output formatting as seen in Candidate E. Additionally, both bugs involve core features within Django's template management, making the insights from fixing the autoescape issue particularly relevant for understanding how to introduce customizable parameters like an encoder in the CURRENT context.",
  "instance_id": "django__django-15789",
  "repo": "django/django",
  "created_at": "2022-06-23T08:59:04Z",
  "problem_statement": "Add an encoder parameter to django.utils.html.json_script().\nDescription\n\t\nI have a use case where I want to customize the JSON encoding of some values to output to the template layer. It looks like django.utils.html.json_script is a good utility for that, however the JSON encoder is hardcoded to DjangoJSONEncoder. I think it would be nice to be able to pass a custom encoder class.\nBy the way, django.utils.html.json_script is not documented (only its template filter counterpart is), would it be a good thing to add to the docs?\n",
  "patch": "diff --git a/django/utils/html.py b/django/utils/html.py\n--- a/django/utils/html.py\n+++ b/django/utils/html.py\n@@ -59,7 +59,7 @@ def escapejs(value):\n }\n \n \n-def json_script(value, element_id=None):\n+def json_script(value, element_id=None, encoder=None):\n     \"\"\"\n     Escape all the HTML/XML special characters with their unicode escapes, so\n     value is safe to be output anywhere except for inside a tag attribute. Wrap\n@@ -67,7 +67,9 @@ def json_script(value, element_id=None):\n     \"\"\"\n     from django.core.serializers.json import DjangoJSONEncoder\n \n-    json_str = json.dumps(value, cls=DjangoJSONEncoder).translate(_json_script_escapes)\n+    json_str = json.dumps(value, cls=encoder or DjangoJSONEncoder).translate(\n+        _json_script_escapes\n+    )\n     if element_id:\n         template = '<script id=\"{}\" type=\"application/json\">{}</script>'\n         args = (element_id, mark_safe(json_str))\n"
}