{
  "id": "marshmallow-code__marshmallow-1164",
  "question": "2.x: Nested(many=True) eats first element from generator value when dumping\nAs reproduced in Python 3.6.8:\r\n\r\n```py\r\nfrom marshmallow import Schema, fields\r\n\r\nclass O(Schema):\r\n    i = fields.Int()\r\n\r\nclass P(Schema):\r\n    os = fields.Nested(O, many=True)\r\n\r\ndef gen():\r\n    yield {'i': 1}\r\n    yield {'i': 0}\r\n\r\np = P()\r\np.dump({'os': gen()})\r\n# MarshalResult(data={'os': [{'i': 0}]}, errors={})\r\n```\r\n\r\nProblematic code is here:\r\n\r\nhttps://github.com/marshmallow-code/marshmallow/blob/2.x-line/src/marshmallow/fields.py#L447\r\n\r\nAnd here:\r\n\r\nhttps://github.com/marshmallow-code/marshmallow/blob/2.x-line/src/marshmallow/schema.py#L832\r\n\r\nThe easiest solution would be to cast `nested_obj` to list before calling `schema._update_fields`, just like a normal Schema with `many=True` does.\n",
  "answer": "{\"task_id\": \"e0717f8c-e914-4f82-8d28-436f928207d3\", \"workflow_run_id\": \"f7ce3c2d-941d-427c-8366-2208e0127fe1\", \"data\": {\"id\": \"f7ce3c2d-941d-427c-8366-2208e0127fe1\", \"workflow_id\": \"4faf996e-a613-49ba-90e4-a0af9c740cdf\", \"status\": \"succeeded\", \"outputs\": {\"ranked_patches\": \"```json\\n{\\n  \\\"ranked_patches\\\": [\\n    {\\n      \\\"patch_id\\\": 2,\\n      \\\"patch\\\": \\\"diff --git a/src/marshmallow/fields.py b/src/marshmallow/fields.py\\\\nindex abcd123..ijkl789 100644\\\\n--- a/src/marshmallow/fields.py\\\\n+++ b/src/marshmallow/fields.py\\\\n@@ -447,6 +447,9 @@ class Nested(Field):\\\\n         if not value:\\\\n             return [] if self.many else None\\\\n         nested_obj = value\\\\n+        # Handle generator by converting to list when many=True\\\\n+        if self.many and hasattr(nested_obj, '__iter__') and not isinstance(nested_obj, list):\\\\n+            nested_obj = list(nested_obj)\\\\n         return schema.dump(nested_obj)\\\\n \\\\n     def _has_default(self):\\\",\\n      \\\"rank\\\": 1,\\n      \\\"score\\\": 0.95,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.95,\\n        \\\"code_quality\\\": 0.95,\\n        \\\"risk_level\\\": 0.05,\\n        \\\"best_practices\\\": 0.95,\\n        \\\"test_coverage\\\": 0.9\\n      },\\n      \\\"reasoning\\\": \\\"This patch correctly identifies iterable objects and converts them to lists only when necessary, ensuring minimal performance impact and maintaining code clarity.\\\",\\n      \\\"recommendation\\\": \\\"Highly recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 3,\\n      \\\"patch\\\": \\\"diff --git a/src/marshmallow/fields.py b/src/marshmallow/fields.py\\\\nindex abcd123..mnop012 100644\\\\n--- a/src/marshmallow/fields.py\\\\n+++ b/src/marshmallow/fields.py\\\\n@@ -447,6 +447,9 @@ class Nested(Field):\\\\n         if not value:\\\\n             return [] if self.many else None\\\\n         nested_obj = value\\\\n+        # Ensure value is list if many=True, accounts for generators\\\\n+        if self.many and (callable(getattr(nested_obj, '__iter__', None)) and not isinstance(nested_obj, list)):\\\\n+            nested_obj = list(nested_obj)\\\\n         return schema.dump(nested_obj)\\\\n \\\\n     def _has_default(self):\\\",\\n      \\\"rank\\\": 2,\\n      \\\"score\\\": 0.9,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.9,\\n        \\\"code_quality\\\": 0.9,\\n        \\\"risk_level\\\": 0.1,\\n        \\\"best_practices\\\": 0.9,\\n        \\\"test_coverage\\\": 0.85\\n      },\\n      \\\"reasoning\\\": \\\"This patch uses a slightly more complex method to check for iterability, which is correct but less straightforward than necessary.\\\",\\n      \\\"recommendation\\\": \\\"Recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 1,\\n      \\\"patch\\\": \\\"diff --git a/src/marshmallow/fields.py b/src/marshmallow/fields.py\\\\nindex abcd123..efgh456 100644\\\\n--- a/src/marshmallow/fields.py\\\\n+++ b/src/marshmallow/fields.py\\\\n@@ -447,6 +447,10 @@ class Nested(Field):\\\\n         if not value:\\\\n             return [] if self.many else None\\\\n         nested_obj = value\\\\n+        # Convert generator to list to ensure all items are processed\\\\n+        if self.many and not isinstance(nested_obj, list):\\\\n+            nested_obj = list(nested_obj)\\\\n+\\\\n         return schema.dump(nested_obj)\\\\n \\\\n     def _has_default(self):\\\",\\n      \\\"rank\\\": 3,\\n      \\\"score\\\": 0.85,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.85,\\n        \\\"code_quality\\\": 0.85,\\n        \\\"risk_level\\\": 0.15,\\n        \\\"best_practices\\\": 0.85,\\n        \\\"test_coverage\\\": 0.8\\n      },\\n      \\\"reasoning\\\": \\\"This patch converts any non-list object to a list, which might be unnecessary for non-iterable objects, potentially leading to unintended behavior.\\\",\\n      \\\"recommendation\\\": \\\"Use with caution\\\"\\n    }\\n  ],\\n  \\\"evaluation_summary\\\": \\\"Patch 2 is the best choice as it correctly handles iterable objects with minimal performance impact and maintains code clarity. Patch 3 is also correct but uses a more complex method to check for iterability. Patch 1 is less precise, converting any non-list object to a list, which could lead to unintended behavior.\\\"\\n}\\n```\", \"generated_tests\": \"{\\n  \\\"reproduction_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_issue\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_issue():\\\\n    from marshmallow import Schema, fields\\\\n\\\\n    class O(Schema):\\\\n        i = fields.Int()\\\\n\\\\n    class P(Schema):\\\\n        os = fields.Nested(O, many=True)\\\\n\\\\n    def gen():\\\\n        yield {'i': 1}\\\\n        yield {'i': 0}\\\\n\\\\n    p = P()\\\\n    result = p.dump({'os': gen()})\\\\n    assert result == {'os': [{'i': 1}, {'i': 0}]}\\\\n\\\",\\n      \\\"description\\\": \\\"This test reproduces the original issue by dumping a generator value with Nested(many=True)\\\",\\n      \\\"expected_behavior\\\": \\\"The test should fail before applying the patch due to the missing first element in the dumped result, and pass after applying the patch\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_edge_cases\\\",\\n      \\\"test_code\\\": \\\"def test_edge_cases():\\\\n    from marshmallow import Schema, fields\\\\n\\\\n    class O(Schema):\\\\n        i = fields.Int()\\\\n\\\\n    class P(Schema):\\\\n        os = fields.Nested(O, many=True)\\\\n\\\\n    def gen_empty():\\\\n        yield\\\\n\\\\n    p = P()\\\\n    result_empty = p.dump({'os': gen_empty()})\\\\n\\\\n    assert result_empty == {'os': []}\\\\n\\\\n    def gen_single():\\\\n        yield {'i': 5}\\\\n\\\\n    result_single = p.dump({'os': gen_single()})\\\\n\\\\n    assert result_single == {'os': [{'i': 5}]}\\\\n\\\",\\n      \\\"description\\\": \\\"This test covers edge cases where the generator is empty or has a single element to ensure correct handling\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass for both cases\\\"\\n    }\\n  ],\\n  \\\"validation_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation():\\\\n    from marshmallow import Schema, fields\\\\n\\\\n    class O(Schema):\\\\n        i = fields.Int()\\\\n\\\\n    class P(Schema):\\\\n        os = fields.Nested(O, many=True)\\\\n\\\\n    def gen():\\\\n        yield {'i': 1}\\\\n        yield {'i': 0}\\\\n\\\\n    p = P()\\\\n    result = p.dump({'os': gen()})\\\\n    assert result == {'os': [{'i': 1}, {'i': 0}]}\\\\n\\\",\\n      \\\"description\\\": \\\"This test validates that the patch correctly handles the generator value with Nested(many=True)\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass after applying the patch\\\"\\n    }\\n  ],\\n  \\\"test_summary\\\": \\\"Generated comprehensive test cases for reproducing the original issue, testing edge cases, and validating the patch\\\"\\n}\"}, \"error\": \"\", \"elapsed_time\": 393.279608, \"total_tokens\": 22703, \"total_steps\": 9, \"created_at\": 1753365100, \"finished_at\": 1753365493}}"
}