{
  "id": "django__django-11119",
  "question": "Engine.render_to_string() should honor the autoescape attribute\nDescription\n\t\nIn Engine.render_to_string, a Context is created without specifying the engine autoescape attribute. So if you create en engine with autoescape=False and then call its render_to_string() method, the result will always be autoescaped. It was probably overlooked in [19a5f6da329d58653bcda85].\n",
  "answer": "{\"task_id\": \"61a44b34-f5f0-46d8-b1c8-8684b46bed38\", \"workflow_run_id\": \"54ce09b5-c1d7-4d12-a7fa-cebba43ea16c\", \"data\": {\"id\": \"54ce09b5-c1d7-4d12-a7fa-cebba43ea16c\", \"workflow_id\": \"9a0a6efa-4d15-4876-b13f-4fb6a999caa2\", \"status\": \"succeeded\", \"outputs\": {\"final_patch\": [\"--- a/django/template/engine.py\\n+++ b/django/template/engine.py\\n@@ -185,7 +185,7 @@ class Engine:\\n         if context is None:\\n             context = {}\\n         if isinstance(context, dict):\\n-            context = Context(context)\\n+            context = Context(context, autoescape=self.autoescape)\\n         try:\\n             return template.render(context, request)\\n         except TemplateDoesNotExist:\", \"--- a/django/template/context.py\\n+++ b/django/template/context.py\\n@@ -32,11 +32,12 @@ class Context:\\n     \\\"\\\"\\\"\\n     A stack container for variable context\\n     \\\"\\\"\\\"\\n-    def __init__(self, dict_=None, current_app=None, use_l10n=None, use_tz=None):\\n+    def __init__(self, dict_=None, current_app=None, use_l10n=None, use_tz=None, autoescape=True):\\n         self.dicts = [{}]\\n         self.current_app = current_app\\n         self.use_l10n = use_l10n\\n         self.use_tz = use_tz\\n+        self.autoescape = autoescape\\n         if dict_ is not None:\\n             self.dicts = [dict_]\\n\", \"--- a/django/template/engine.py\\n+++ b/django/template/engine.py\\n@@ -185,7 +185,7 @@ class Engine:\\n         if context is None:\\n             context = {}\\n         if isinstance(context, dict):\\n-            context = Context(context)\\n+            context = Context(context, autoescape=self.autoescape)\\n         try:\\n             return template.render(context, request)\\n         except TemplateDoesNotExist:\\n--- a/django/template/context.py\\n+++ b/django/template/context.py\\n@@ -32,11 +32,12 @@ class Context:\\n     \\\"\\\"\\\"\\n     A stack container for variable context\\n     \\\"\\\"\\\"\\n-    def __init__(self, dict_=None, current_app=None, use_l10n=None, use_tz=None):\\n+    def __init__(self, dict_=None, current_app=None, use_l10n=None, use_tz=None, autoescape=True):\\n         self.dicts = [{}]\\n         self.current_app = current_app\\n         self.use_l10n = use_l10n\\n         self.use_tz = use_tz\\n+        self.autoescape = autoescape\\n         if dict_ is not None:\\n             self.dicts = [dict_]\", \"--- a/django/template/engine.py\\n+++ b/django/template/engine.py\\n@@ -185,7 +185,10 @@ class Engine:\\n         if context is None:\\n             context = {}\\n         if isinstance(context, dict):\\n-            context = Context(context)\\n+            context = Context(context, autoescape=self.autoescape)\\n+        elif hasattr(context, 'autoescape') and context.autoescape != self.autoescape:\\n+            # Update existing context's autoescape setting if different\\n+            context.autoescape = self.autoescape\\n         try:\\n             return template.render(context, request)\\n         except TemplateDoesNotExist:\", \"--- a/django/template/engine.py\\n+++ b/django/template/engine.py\\n@@ -183,9 +183,12 @@ class Engine:\\n         \\\"\\\"\\\"\\n         template = self.get_template(template_name)\\n         if context is None:\\n             context = {}\\n         if isinstance(context, dict):\\n-            context = Context(context)\\n+            # Pass the engine's autoescape setting to the context\\n+            context = Context(context, autoescape=self.autoescape)\\n+        elif hasattr(context, 'autoescape'):\\n+            # Ensure existing context respects engine's autoescape setting\\n+            context.autoescape = self.autoescape\\n         try:\\n             return template.render(context, request)\\n         except TemplateDoesNotExist:\", \"diff\\n--- a/django/template/engine.py\\n+++ b/django/template/engine.py\\n@@ -185,7 +185,7 @@ class Engine:\\n         if context is None:\\n             context = {}\\n         if isinstance(context, dict):\\n-            context = Context(context)\\n+            context = Context(context, autoescape=self.autoescape)\\n         try:\\n             return template.render(context, request)\\n         except TemplateDoesNotExist:\\n\", \"diff\\n--- a/django/template/engine.py\\n+++ b/django/template/engine.py\\n@@ -185,7 +185,10 @@ class Engine:\\n         if context is None:\\n             context = {}\\n         if isinstance(context, dict):\\n-            context = Context(context)\\n+            # Pass the engine's autoescape setting to the context\\n+            context = Context(context, autoescape=self.autoescape)\\n+        elif hasattr(context, 'autoescape'):\\n+            # Ensure existing context respects engine's autoescape setting\\n+            context.autoescape = self.autoescape\\n         try:\\n             return template.render(context, request)\\n         except TemplateDoesNotExist:\\n\", \"diff\\n--- a/django/template/engine.py\\n+++ b/django/template/engine.py\\n@@ -185,7 +185,10 @@ class Engine:\\n         if context is None:\\n             context = {}\\n         if isinstance(context, dict):\\n-            context = Context(context)\\n+            context = Context(context, autoescape=self.autoescape)\\n+        elif hasattr(context, 'autoescape'):\\n+            # Ensure existing context respects engine's autoescape setting\\n+            context.autoescape = self.autoescape\\n         try:\\n             return template.render(context, request)\\n         except TemplateDoesNotExist:\\n\"]}, \"error\": \"\", \"elapsed_time\": 87.345677, \"total_tokens\": 32485, \"total_steps\": 30, \"created_at\": 1754647559, \"finished_at\": 1754647646}}"
}