{
  "id": "django__django-11163",
  "question": "model_to_dict() should return an empty dict for an empty list of fields.\nDescription\n\t\nBeen called as model_to_dict(instance, fields=[]) function should return empty dict, because no fields were requested. But it returns all fields\nThe problem point is\nif fields and f.name not in fields:\nwhich should be\nif fields is not None and f.name not in fields:\nPR: ​https://github.com/django/django/pull/11150/files\n",
  "answer": "{\"task_id\": \"6d023866-4a37-4bc0-8b6c-9bb3fd20c464\", \"workflow_run_id\": \"72f22c6c-6ebd-4c75-af17-9bc88579240b\", \"data\": {\"id\": \"72f22c6c-6ebd-4c75-af17-9bc88579240b\", \"workflow_id\": \"9a0a6efa-4d15-4876-b13f-4fb6a999caa2\", \"status\": \"succeeded\", \"outputs\": {\"final_patch\": [\"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -89,7 +89,7 @@ def model_to_dict(instance, fields=None, exclude=None):\\n     opts = instance._meta\\n     data = {}\\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\\n-        if fields and f.name not in fields:\\n+        if fields is not None and f.name not in fields:\\n             continue\\n         if exclude and f.name in exclude:\\n             continue\", \"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -89,9 +89,9 @@ def model_to_dict(instance, fields=None, exclude=None):\\n     opts = instance._meta\\n     data = {}\\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\\n-        if fields and f.name not in fields:\\n+        if fields is not None and f.name not in fields:\\n             continue\\n-        if exclude and f.name in exclude:\\n+        if exclude is not None and f.name in exclude:\\n             continue\", \"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -86,10 +86,13 @@ def model_to_dict(instance, fields=None, exclude=None):\\n     if exclude is None:\\n         exclude = []\\n \\n+    # If fields is an empty list, return empty dict immediately\\n+    if fields is not None and not fields:\\n+        return {}\\n+\\n     opts = instance._meta\\n     data = {}\\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\\n-        if fields and f.name not in fields:\\n+        if fields is not None and f.name not in fields:\\n             continue\\n         if exclude and f.name in exclude:\\n             continue\", \"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -89,7 +89,7 @@ def model_to_dict(instance, fields=None, exclude=None):\\n     opts = instance._meta\\n     data = {}\\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\\n-        if fields and f.name not in fields:\\n+        if fields is not None and f.name not in fields:\\n             continue\\n         if exclude and f.name in exclude:\\n             continue\\n--- a/tests/forms_tests/tests/test_models.py\\n+++ b/tests/forms_tests/tests/test_models.py\\n@@ -42,6 +42,11 @@ class ModelToDictTests(TestCase):\\n         d = model_to_dict(writer, fields=['name'])\\n         self.assertEqual(d, {'name': 'Bob Woodward'})\\n \\n+    def test_model_to_dict_empty_fields(self):\\n+        writer = Writer.objects.create(name='Bob Woodward')\\n+        d = model_to_dict(writer, fields=[])\\n+        self.assertEqual(d, {})\\n+\\n     def test_model_to_dict_exclude(self):\\n         writer = Writer.objects.create(name='Bob Woodward')\\n         d = model_to_dict(writer, exclude=['name'])\", \"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -75,7 +75,8 @@ def model_to_dict(instance, fields=None, exclude=None):\\n     Return a dict containing the data in ``instance`` suitable for passing as\\n     a Form's ``initial`` keyword argument.\\n \\n-    ``fields`` is an optional list of field names. If provided, return only the\\n+    ``fields`` is an optional list of field names. If provided, return only the \\n+    named fields. If an empty list is provided, return an empty dict.\\n     named fields.\\n \\n     ``exclude`` is an optional list of field names. If provided, exclude the\\n@@ -89,7 +90,7 @@ def model_to_dict(instance, fields=None, exclude=None):\\n     opts = instance._meta\\n     data = {}\\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\\n-        if fields and f.name not in fields:\\n+        if fields is not None and f.name not in fields:\\n             continue\\n         if exclude and f.name in exclude:\\n             continue\", \"diff\\n--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -86,10 +86,13 @@ def model_to_dict(instance, fields=None, exclude=None):\\n     if exclude is None:\\n         exclude = []\\n \\n+    # If fields is an empty list, return empty dict immediately\\n+    if fields is not None and not fields:\\n+        return {}\\n+\\n     opts = instance._meta\\n     data = {}\\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\\n-        if fields and f.name not in fields:\\n+        if fields is not None and f.name not in fields:\\n             continue\\n         if exclude and f.name in exclude:\\n             continue\\n--- a/tests/forms_tests/tests/test_models.py\\n+++ b/tests/forms_tests/tests/test_models.py\\n@@ -42,6 +42,11 @@ class ModelToDictTests(TestCase):\\n         d = model_to_dict(writer, fields=['name'])\\n         self.assertEqual(d, {'name': 'Bob Woodward'})\\n \\n+    def test_model_to_dict_empty_fields(self):\\n+        writer = Writer.objects.create(name='Bob Woodward')\\n+        d = model_to_dict(writer, fields=[])\\n+        self.assertEqual(d, {})\\n+\\n     def test_model_to_dict_exclude(self):\\n         writer = Writer.objects.create(name='Bob Woodward')\\n         d = model_to_dict(writer, exclude=['name'])\\n\", \"diff\\n--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -86,10 +86,13 @@ def model_to_dict(instance, fields=None, exclude=None):\\n     if exclude is None:\\n         exclude = []\\n \\n+    # If fields is an empty list, return empty dict immediately\\n+    if fields is not None and not fields:\\n+        return {}\\n+\\n     opts = instance._meta\\n     data = {}\\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\\n-        if fields and f.name not in fields:\\n+        if fields is not None and f.name not in fields:\\n             continue\\n         if exclude and f.name in exclude:\\n             continue\\n--- a/tests/forms_tests/tests/test_models.py\\n+++ b/tests/forms_tests/tests/test_models.py\\n@@ -42,6 +42,11 @@ class ModelToDictTests(TestCase):\\n         d = model_to_dict(writer, fields=['name'])\\n         self.assertEqual(d, {'name': 'Bob Woodward'})\\n \\n+    def test_model_to_dict_empty_fields(self):\\n+        writer = Writer.objects.create(name='Bob Woodward')\\n+        d = model_to_dict(writer, fields=[])\\n+        self.assertEqual(d, {})\\n+\\n     def test_model_to_dict_exclude(self):\\n         writer = Writer.objects.create(name='Bob Woodward')\\n         d = model_to_dict(writer, exclude=['name'])\\n\", \"diff\\n--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -86,10 +86,13 @@ def model_to_dict(instance, fields=None, exclude=None):\\n     if exclude is None:\\n         exclude = []\\n \\n+    # If fields is an empty list, return empty dict immediately\\n+    if fields is not None and not fields:\\n+        return {}\\n+\\n     opts = instance._meta\\n     data = {}\\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\\n-        if fields and f.name not in fields:\\n+        if fields is not None and f.name not in fields:\\n             continue\\n         if exclude and f.name in exclude:\\n             continue\\n--- a/tests/forms_tests/tests/test_models.py\\n+++ b/tests/forms_tests/tests/test_models.py\\n@@ -42,6 +42,11 @@ class ModelToDictTests(TestCase):\\n         d = model_to_dict(writer, fields=['name'])\\n         self.assertEqual(d, {'name': 'Bob Woodward'})\\n \\n+    def test_model_to_dict_empty_fields(self):\\n+        writer = Writer.objects.create(name='Bob Woodward')\\n+        d = model_to_dict(writer, fields=[])\\n+        self.assertEqual(d, {})\\n+\\n     def test_model_to_dict_exclude(self):\\n         writer = Writer.objects.create(name='Bob Woodward')\\n         d = model_to_dict(writer, exclude=['name'])\\n\"]}, \"error\": \"\", \"elapsed_time\": 99.170872, \"total_tokens\": 35893, \"total_steps\": 30, \"created_at\": 1754648100, \"finished_at\": 1754648199}}"
}