[{"repo": "sqlfluff/sqlfluff", "instance_id": "sqlfluff__sqlfluff-2419", "base_commit": "f1dba0e1dd764ae72d67c3d5e1471cf14d3db030", "patch": "diff --git a/src/sqlfluff/rules/L060.py b/src/sqlfluff/rules/L060.py\n--- a/src/sqlfluff/rules/L060.py\n+++ b/src/sqlfluff/rules/L060.py\n@@ -59,4 +59,8 @@ def _eval(self, context: RuleContext) -> Optional[LintResult]:\n             ],\n         )\n \n-        return LintResult(context.segment, [fix])\n+        return LintResult(\n+            anchor=context.segment,\n+            fixes=[fix],\n+            description=f\"Use 'COALESCE' instead of '{context.segment.raw_upper}'.\",\n+        )\n", "test_patch": "diff --git a/test/rules/std_L060_test.py b/test/rules/std_L060_test.py\nnew file mode 100644\n--- /dev/null\n+++ b/test/rules/std_L060_test.py\n@@ -0,0 +1,12 @@\n+\"\"\"Tests the python routines within L060.\"\"\"\n+import sqlfluff\n+\n+\n+def test__rules__std_L060_raised() -> None:\n+    \"\"\"L060 is raised for use of ``IFNULL`` or ``NVL``.\"\"\"\n+    sql = \"SELECT\\n\\tIFNULL(NULL, 100),\\n\\tNVL(NULL,100);\"\n+    result = sqlfluff.lint(sql, rules=[\"L060\"])\n+\n+    assert len(result) == 2\n+    assert result[0][\"description\"] == \"Use 'COALESCE' instead of 'IFNULL'.\"\n+    assert result[1][\"description\"] == \"Use 'COALESCE' instead of 'NVL'.\"\n", "problem_statement": "Rule L060 could give a specific error message\nAt the moment rule L060 flags something like this:\r\n\r\n```\r\nL:  21 | P:   9 | L060 | Use 'COALESCE' instead of 'IFNULL' or 'NVL'.\r\n```\r\n\r\nSince we likely know the wrong word, it might be nice to actually flag that instead of both `IFNULL` and `NVL` - like most of the other rules do.\r\n\r\nThat is it should flag this:\r\n\r\n```\r\nL:  21 | P:   9 | L060 | Use 'COALESCE' instead of 'IFNULL'.\r\n```\r\n Or this:\r\n\r\n```\r\nL:  21 | P:   9 | L060 | Use 'COALESCE' instead of 'NVL'.\r\n```\r\n\r\nAs appropriate.\r\n\r\nWhat do you think @jpy-git ?\r\n\n", "hints_text": "@tunetheweb Yeah definitely, should be a pretty quick change \ud83d\ude0a", "created_at": "2022-01-22T12:21:52Z", "version": "0.8", "FAIL_TO_PASS": ["test/rules/std_L060_test.py::test__rules__std_L060_raised"], "PASS_TO_PASS": [], "environment_setup_commit": "a5c4eae4e3e419fe95460c9afd9cf39a35a470c4", "query": "Rule L060 could give a specific error message\nAt the moment rule L060 flags something like this:\r\n\r\n```\r\nL:  21 | P:   9 | L060 | Use 'COALESCE' instead of 'IFNULL' or 'NVL'.\r\n```\r\n\r\nSince we likely know the wrong word, it might be nice to actually flag that instead of both `IFNULL` and `NVL` - like most of the other rules do.\r\n\r\nThat is it should flag this:\r\n\r\n```\r\nL:  21 | P:   9 | L060 | Use 'COALESCE' instead of 'IFNULL'.\r\n```\r\n Or this:\r\n\r\n```\r\nL:  21 | P:   9 | L060 | Use 'COALESCE' instead of 'NVL'.\r\n```\r\n\r\nAs appropriate.\r\n\r\nWhat do you think @jpy-git ?\r\n\n", "task_id": "sqlfluff__sqlfluff-2419"}, {"repo": "sqlfluff/sqlfluff", "instance_id": "sqlfluff__sqlfluff-2386", "base_commit": "23d698607b45b8469c766b521d27e9a6e92e8739", "patch": "diff --git a/src/sqlfluff/core/rules/base.py b/src/sqlfluff/core/rules/base.py\n--- a/src/sqlfluff/core/rules/base.py\n+++ b/src/sqlfluff/core/rules/base.py\n@@ -875,7 +875,7 @@ def eval(self, **kwargs):\n \n         plugin_name, code = rule_name_match.groups()\n         # If the docstring is multiline, then we extract just summary.\n-        description = cls.__doc__.split(\"\\n\")[0]\n+        description = cls.__doc__.replace(\"``\", \"'\").split(\"\\n\")[0]\n \n         if plugin_name:\n             code = f\"{plugin_name}_{code}\"\n", "test_patch": "diff --git a/test/core/rules/docstring_test.py b/test/core/rules/docstring_test.py\n--- a/test/core/rules/docstring_test.py\n+++ b/test/core/rules/docstring_test.py\n@@ -1,6 +1,7 @@\n \"\"\"Test rules docstring.\"\"\"\n import pytest\n \n+from sqlfluff import lint\n from sqlfluff.core.plugin.host import get_plugin_manager\n \n KEYWORD_ANTI = \"\\n    | **Anti-pattern**\"\n@@ -34,3 +35,19 @@ def test_keyword_anti_before_best():\n                 assert rule.__doc__.index(KEYWORD_ANTI) < rule.__doc__.index(\n                     KEYWORD_BEST\n                 ), f\"{rule.__name__} keyword {KEYWORD_BEST} appears before {KEYWORD_ANTI}\"\n+\n+\n+def test_backtick_replace():\n+    \"\"\"Test replacing docstring double backticks for lint results.\"\"\"\n+    sql = \"\"\"\n+    SELECT\n+        foo.a,\n+        bar.b\n+    FROM foo\n+    JOIN bar;\n+    \"\"\"\n+    result = lint(sql, rules=[\"L051\"])\n+    # L051 docstring looks like:\n+    # ``INNER JOIN`` must be fully qualified.\n+    # Check the double bacticks (``) get replaced by a single quote (').\n+    assert result[0][\"description\"] == \"'INNER JOIN' must be fully qualified.\"\ndiff --git a/test/rules/std_L054_test.py b/test/rules/std_L054_test.py\n--- a/test/rules/std_L054_test.py\n+++ b/test/rules/std_L054_test.py\n@@ -29,7 +29,7 @@ def test__rules__std_L054_raised() -> None:\n     assert len(results_l054) == 2\n     assert (\n         results_l054[0][\"description\"]\n-        == \"Inconsistent column references in ``GROUP BY/ORDER BY`` clauses.\"\n+        == \"Inconsistent column references in 'GROUP BY/ORDER BY' clauses.\"\n     )\n \n \n", "problem_statement": "Double backticks in Lint description\n![image](https://user-images.githubusercontent.com/80432516/150420352-57452c80-ad25-423b-8251-645e541579ad.png)\r\n(n.b. this affects a lot more rules than L051)\r\n\r\nThis was introduced in #2234 in which docstrings such as\r\n```\r\n`INNER JOIN` must be fully qualified.\r\n```\r\nwere replaced with \r\n```\r\n``INNER JOIN`` must be fully qualified.\r\n```\r\nso that they appear as code blocks in Sphinx for docs.\r\n![image](https://user-images.githubusercontent.com/80432516/150420294-eb9d3127-db1d-457c-a637-d614e0267277.png)\r\n\r\nHowever, our rules will use the first line of these docstrings in the event that no `description` is provided to the lint results.\r\n\r\nThis doesn't look great on the CLI so we should fix this. As far as I'm aware there are two approaches for this:\r\n1. Pass a `description` to all the `LintResult`s.\r\n2. Update the code that gets the default description from the docstring to do something like, replace the double backticks with a single one, or remove them, or do something clever like make them bold for the CLI and remove them for non-CLI.\r\n\r\nMy strong preference is number 2, but I'm open to discussion as to how exactly we do this \ud83d\ude04 \r\n\r\n@barrywhart @tunetheweb \n", "hints_text": "Number 2 sounds good to me!\n@barrywhart which variation?\nI would replace with single \"normal\" quotes: ' rather than \\`.\r\n\r\nThe clever approach could be cool for later, but I wouldn't try it now. I can't remember if we already handle detecting whether we're running in a terminal or not, because the techniques for doing bold or colored text don't work well when redirecting output to a file, etc.\n> The clever approach could be cool for later, but I wouldn't try it now. I can't remember if we already handle detecting whether we're running in a terminal or not, because the techniques for doing bold or colored text don't work well when redirecting output to a file, etc.\r\n\r\nYeah I think there's some `isatty` function we use in the formatter, but agree on the simple replace method for now \ud83d\ude04 ", "created_at": "2022-01-21T00:03:48Z", "version": "0.8", "FAIL_TO_PASS": ["test/core/rules/docstring_test.py::test_backtick_replace", "test/rules/std_L054_test.py::test__rules__std_L054_raised"], "PASS_TO_PASS": ["test/core/rules/docstring_test.py::test_content_count[\\n", "test/core/rules/docstring_test.py::test_keyword_anti_before_best", "test/rules/std_L054_test.py::test__rules__std_L054_unparsable", "test/rules/std_L054_test.py::test__rules__std_L054_noqa"], "environment_setup_commit": "a5c4eae4e3e419fe95460c9afd9cf39a35a470c4", "query": "Double backticks in Lint description\n![image](https://user-images.githubusercontent.com/80432516/150420352-57452c80-ad25-423b-8251-645e541579ad.png)\r\n(n.b. this affects a lot more rules than L051)\r\n\r\nThis was introduced in #2234 in which docstrings such as\r\n```\r\n`INNER JOIN` must be fully qualified.\r\n```\r\nwere replaced with \r\n```\r\n``INNER JOIN`` must be fully qualified.\r\n```\r\nso that they appear as code blocks in Sphinx for docs.\r\n![image](https://user-images.githubusercontent.com/80432516/150420294-eb9d3127-db1d-457c-a637-d614e0267277.png)\r\n\r\nHowever, our rules will use the first line of these docstrings in the event that no `description` is provided to the lint results.\r\n\r\nThis doesn't look great on the CLI so we should fix this. As far as I'm aware there are two approaches for this:\r\n1. Pass a `description` to all the `LintResult`s.\r\n2. Update the code that gets the default description from the docstring to do something like, replace the double backticks with a single one, or remove them, or do something clever like make them bold for the CLI and remove them for non-CLI.\r\n\r\nMy strong preference is number 2, but I'm open to discussion as to how exactly we do this \ud83d\ude04 \r\n\r\n@barrywhart @tunetheweb \n", "task_id": "sqlfluff__sqlfluff-2386"}, {"repo": "marshmallow-code/marshmallow", "instance_id": "marshmallow-code__marshmallow-1252", "base_commit": "b063a103ae5222a5953cd7453a1eb0d161dc5b52", "patch": "diff --git a/src/marshmallow/utils.py b/src/marshmallow/utils.py\n--- a/src/marshmallow/utils.py\n+++ b/src/marshmallow/utils.py\n@@ -285,6 +285,9 @@ def from_iso(datestring, use_dateutil=True):\n         # Strip off timezone info.\n         if '.' in datestring:\n             # datestring contains microseconds\n+            (dt_nomstz, mstz) = datestring.split('.')\n+            ms_notz = mstz[:len(mstz) - len(mstz.lstrip('0123456789'))]\n+            datestring = '.'.join((dt_nomstz, ms_notz))\n             return datetime.datetime.strptime(datestring[:26], '%Y-%m-%dT%H:%M:%S.%f')\n         return datetime.datetime.strptime(datestring[:19], '%Y-%m-%dT%H:%M:%S')\n \n", "test_patch": "diff --git a/tests/test_utils.py b/tests/test_utils.py\n--- a/tests/test_utils.py\n+++ b/tests/test_utils.py\n@@ -200,6 +200,15 @@ def test_from_iso_datetime(use_dateutil, timezone):\n     assert type(result) == dt.datetime\n     assert_datetime_equal(result, d)\n \n+    # Test with 3-digit only microseconds\n+    #\u00a0Regression test for https://github.com/marshmallow-code/marshmallow/issues/1251\n+    d = dt.datetime.now(tz=timezone).replace(microsecond=123000)\n+    formatted = d.isoformat()\n+    formatted = formatted[:23] + formatted[26:]\n+    result = utils.from_iso(formatted, use_dateutil=use_dateutil)\n+    assert type(result) == dt.datetime\n+    assert_datetime_equal(result, d)\n+\n def test_from_iso_with_tz():\n     d = central.localize(dt.datetime.now())\n     formatted = d.isoformat()\n", "problem_statement": "ISO8601 DateTimes ending with Z considered not valid in 2.19.4\nProbably related to #1247 and #1234 - in marshmallow `2.19.4`, with `python-dateutil` _not_ installed, it seems that loading a datetime in ISO8601 that ends in `Z` (UTC time) results in an error:\r\n\r\n```python\r\nclass Foo(Schema):\r\n    date = DateTime(required=True)\r\n\r\n\r\nfoo_schema = Foo(strict=True)\r\n\r\na_date_with_z = '2019-06-17T00:57:41.000Z'\r\nfoo_schema.load({'date': a_date_with_z})\r\n```\r\n\r\n```\r\nmarshmallow.exceptions.ValidationError: {'date': ['Not a valid datetime.']}\r\n```\r\n\r\nDigging a bit deeper, it seems [`from_iso_datetime`](https://github.com/marshmallow-code/marshmallow/blob/dev/src/marshmallow/utils.py#L213-L215) is failing with a `unconverted data remains: Z` - my understanding of the spec is rather limited, but it seems that they are indeed valid ISO8601 dates (and in `marshmallow==2.19.3` and earlier, the previous snippet seems to work without raising validation errors).\r\n\n", "hints_text": "@lafrech Would you mind looking into this?\nThanks for reporting.\r\n\r\nThis is definitely a side effect of https://github.com/marshmallow-code/marshmallow/pull/1249/files. Sorry about that.\r\n\r\nI don't own a copy of the spec, so the work on this is based on examples... I assumed that microseconds always came as a six-pack. It seems only three digits (your example) is acceptable. From what I understand in the regex we copied from Django, we could even expect any number of digits in [1; 6].\r\n\r\nI see two solutions to this:\r\n\r\n- Split around `\".\"`, then in the right part, get all numbers and ignore letters/symbols.\r\n- Split around `\".\"`, then split the right part around anything that delimitates a timezone (`\"Z\"`, `\"+\"`, `\"-\"`, what else?).\r\n\r\n\nThanks both for the prompt reply! I don't have a copy of the spec myself either - for the timezone suffix, I have based my previous comment on [the Wikipedia entry](https://en.wikipedia.org/wiki/ISO_8601#Time_zone_designators), which seems to hint at the following designators being allowed:\r\n```\r\n<time>Z\r\n<time>\u00b1hh:mm\r\n<time>\u00b1hhmm\r\n<time>\u00b1hh\r\n```\nI also use this WP page, but it doesn't show much about milli/microseconds.", "created_at": "2019-06-17T13:44:50Z", "version": "2.19", "FAIL_TO_PASS": ["tests/test_utils.py::test_from_iso_datetime[timezone1-False]"], "PASS_TO_PASS": ["tests/test_utils.py::test_missing_singleton_copy", "tests/test_utils.py::test_to_marshallable_type", "tests/test_utils.py::test_to_marshallable_type_none", "tests/test_utils.py::test_to_marshallable_type_with_namedtuple", "tests/test_utils.py::test_get_value_from_object[obj0]", "tests/test_utils.py::test_get_value_from_object[obj1]", "tests/test_utils.py::test_get_value_from_object[obj2]", "tests/test_utils.py::test_get_value_from_namedtuple_with_default", "tests/test_utils.py::test_get_value_for_nested_object", "tests/test_utils.py::test_get_value_from_dict", "tests/test_utils.py::test_get_value", "tests/test_utils.py::test_set_value", "tests/test_utils.py::test_is_keyed_tuple", "tests/test_utils.py::test_to_marshallable_type_list", "tests/test_utils.py::test_to_marshallable_type_generator", "tests/test_utils.py::test_marshallable", "tests/test_utils.py::test_is_collection", "tests/test_utils.py::test_rfcformat_gmt_naive", "tests/test_utils.py::test_rfcformat_central", "tests/test_utils.py::test_rfcformat_central_localized", "tests/test_utils.py::test_isoformat", "tests/test_utils.py::test_isoformat_tzaware", "tests/test_utils.py::test_isoformat_localtime", "tests/test_utils.py::test_from_datestring", "tests/test_utils.py::test_from_rfc[True]", "tests/test_utils.py::test_from_rfc[False]", "tests/test_utils.py::test_from_iso_datetime[None-True]", "tests/test_utils.py::test_from_iso_datetime[None-False]", "tests/test_utils.py::test_from_iso_datetime[timezone1-True]", "tests/test_utils.py::test_from_iso_with_tz", "tests/test_utils.py::test_from_iso_time_with_microseconds[True]", "tests/test_utils.py::test_from_iso_time_with_microseconds[False]", "tests/test_utils.py::test_from_iso_time_without_microseconds[True]", "tests/test_utils.py::test_from_iso_time_without_microseconds[False]", "tests/test_utils.py::test_from_iso_date[True]", "tests/test_utils.py::test_from_iso_date[False]", "tests/test_utils.py::test_get_func_args"], "environment_setup_commit": "dd72a797ceeea63ee04d5e1838c3a5a1432347e3", "query": "ISO8601 DateTimes ending with Z considered not valid in 2.19.4\nProbably related to #1247 and #1234 - in marshmallow `2.19.4`, with `python-dateutil` _not_ installed, it seems that loading a datetime in ISO8601 that ends in `Z` (UTC time) results in an error:\r\n\r\n```python\r\nclass Foo(Schema):\r\n    date = DateTime(required=True)\r\n\r\n\r\nfoo_schema = Foo(strict=True)\r\n\r\na_date_with_z = '2019-06-17T00:57:41.000Z'\r\nfoo_schema.load({'date': a_date_with_z})\r\n```\r\n\r\n```\r\nmarshmallow.exceptions.ValidationError: {'date': ['Not a valid datetime.']}\r\n```\r\n\r\nDigging a bit deeper, it seems [`from_iso_datetime`](https://github.com/marshmallow-code/marshmallow/blob/dev/src/marshmallow/utils.py#L213-L215) is failing with a `unconverted data remains: Z` - my understanding of the spec is rather limited, but it seems that they are indeed valid ISO8601 dates (and in `marshmallow==2.19.3` and earlier, the previous snippet seems to work without raising validation errors).\r\n\n", "task_id": "marshmallow-code__marshmallow-1252"}, {"repo": "marshmallow-code/marshmallow", "instance_id": "marshmallow-code__marshmallow-1702", "base_commit": "fa6c7379468f59d4568e29cbbeb06b797d656215", "patch": "diff --git a/src/marshmallow/fields.py b/src/marshmallow/fields.py\n--- a/src/marshmallow/fields.py\n+++ b/src/marshmallow/fields.py\n@@ -101,7 +101,7 @@ class Field(FieldABC):\n         its value will be present in the deserialized object. In the context of an\n         HTTP API, this effectively marks the field as \"read-only\".\n     :param dict error_messages: Overrides for `Field.default_error_messages`.\n-    :param metadata: Extra arguments to be stored as metadata.\n+    :param metadata: Extra information to be stored as field metadata.\n \n     .. versionchanged:: 2.0.0\n         Removed `error` parameter. Use ``error_messages`` instead.\n@@ -160,7 +160,8 @@ def __init__(\n         load_only: bool = False,\n         dump_only: bool = False,\n         error_messages: typing.Optional[typing.Dict[str, str]] = None,\n-        **metadata\n+        metadata: typing.Optional[typing.Mapping[str, typing.Any]] = None,\n+        **additional_metadata\n     ) -> None:\n         self.default = default\n         self.attribute = attribute\n@@ -187,7 +188,16 @@ def __init__(\n             raise ValueError(\"'missing' must not be set for required fields.\")\n         self.required = required\n         self.missing = missing\n-        self.metadata = metadata\n+\n+        metadata = metadata or {}\n+        self.metadata = {**metadata, **additional_metadata}\n+        if additional_metadata:\n+            warnings.warn(\n+                \"Passing field metadata as a keyword arg is deprecated. Use the \"\n+                \"explicit `metadata=...` argument instead.\",\n+                RemovedInMarshmallow4Warning,\n+            )\n+\n         self._creation_index = Field._creation_index\n         Field._creation_index += 1\n \n", "test_patch": "diff --git a/tests/test_fields.py b/tests/test_fields.py\n--- a/tests/test_fields.py\n+++ b/tests/test_fields.py\n@@ -197,11 +197,27 @@ def test_extra_metadata_may_be_added_to_field(self, FieldClass):  # noqa\n             required=True,\n             default=None,\n             validate=lambda v: True,\n-            description=\"foo\",\n-            widget=\"select\",\n+            metadata={\"description\": \"foo\", \"widget\": \"select\"},\n         )\n         assert field.metadata == {\"description\": \"foo\", \"widget\": \"select\"}\n \n+    @pytest.mark.parametrize(\"FieldClass\", ALL_FIELDS)\n+    def test_field_metadata_added_in_deprecated_style_warns(self, FieldClass):  # noqa\n+        # just the old style\n+        with pytest.warns(DeprecationWarning):\n+            field = FieldClass(description=\"Just a normal field.\")\n+            assert field.metadata[\"description\"] == \"Just a normal field.\"\n+        # mixed styles\n+        with pytest.warns(DeprecationWarning):\n+            field = FieldClass(\n+                required=True,\n+                default=None,\n+                validate=lambda v: True,\n+                description=\"foo\",\n+                metadata={\"widget\": \"select\"},\n+            )\n+        assert field.metadata == {\"description\": \"foo\", \"widget\": \"select\"}\n+\n \n class TestErrorMessages:\n     class MyField(fields.Field):\n", "problem_statement": "RFC: Change the way we store metadata?\nUsers are often bit by the fact that fields store arbitrary keyword arguments as metadata. See https://github.com/marshmallow-code/marshmallow/issues/683.\r\n\r\n> ...The reasons we use **kwargs instead of e.g. `metadata=` are mostly historical. The original decision was that storing kwargs 1) was more concise and 2) saved us from having to come up with an appropriate name... \"metadata\" didn't seem right because there are use cases where the things your storing aren't really metadata. At this point, it's not worth breaking the API.\r\n\r\n> Not the best reasons, but I think it's not terrible. We've discussed adding a [whitelist of metadata keys](https://github.com/marshmallow-code/marshmallow/issues/683#issuecomment-385113845) in the past, but we decided it wasn't worth the added API surface.\r\n\r\n_Originally posted by @sloria in https://github.com/marshmallow-code/marshmallow/issues/779#issuecomment-522283135_\r\n\r\nPossible solutions:\r\n\r\n1. Use `metadata=`.\r\n2. Specify a whitelist of allowed metadata arguments.\r\n\r\nFeedback welcome!\n", "hints_text": "Solution 1. is preferable to 2., I think. That said, there are some use cases where it's awkward to call additional kwargs \"metadata\". `location` in webargs is one that comes to mind.\r\n\r\n```python\r\n# current API\r\n\"some_query_param\": fields.Bool(location=\"query\")\r\n```\r\n\r\nthough we could probably wrap all the fields in webargs to take the additional `location` argument. \ud83e\udd14 \nI wanted to note that even webargs' `location` doesn't necessarily make the case against `metadata=...`. I was surprised/confused at first when I went looking for `location` in marshmallow and found no mention of it. At the cost of a little bit of verbosity, it would make it easier to understand how marshmallow is functioning.\r\n\r\nRelatedly, the plan in https://github.com/marshmallow-code/webargs/issues/419 includes making `location=...` for webargs a thing of the past.\ncc @jtrakk . This was your suggestion in https://github.com/marshmallow-code/marshmallow/issues/779#issuecomment-522282845 . I'm leaning towards this more and more.\n+1 on this, IMHO biggest problem of `self.metadata=kwargs` is not that it's unexpected, but that it's not generating errors on wrong keyword arguments, which is pretty annoying due frequent api changes :-) so - you can find mistakes only later, all your typos in metadata field...\nOne one hand, I think it is better to specify `metadata=`. More explicit.\r\n\r\nOTOH, this will make my models a bit more verbose:\r\n\r\n```py\r\nclass MyModel(ma.Schema:\r\n    some_int = ma.fields.Int(\r\n        required=True,\r\n        validate=ma.validate.OneOf([1, 2, 3]),\r\n        metadata={\"description\": \"This string explains what this is all about\"}\r\n    )\r\n```\r\n\r\nFor such a use case, the shortcut of using extra kwargs as metadata is nice.\r\n\r\nIf we went with solution 2, users would be able to extend the whitelist with their own stuff. Apispec could extend it with the keyword arguments it expects (valid OpenAPI attributes) and we could even catch typos inside metadata, while solution 1 blindly accepts anything in metadata.\r\n\r\nHowever, this would prevent accepting arbitrary attributes in metadata, which sucks. E.g. in apispec, we also accept any `\"x-...\"` attribute. So we'd need to genericize the whitelist to a callable mechanism. And we end up with a gas factory feature while we wanted to make thing simple.\r\n\r\nOverall, perhaps the downside of 1 (model verbosity) is not that bad.\nAgreed. Consider this accepted.\r\n\r\nMy plan is to deprecate `metadata=kwargs` in a later 3.x release. Let's let the dust settle on v3 before bombarding users with DeprecationWarnings \ud83d\ude05 ", "created_at": "2020-12-02T20:37:47Z", "version": "3.9", "FAIL_TO_PASS": ["tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[String]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Integer]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Boolean]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Float]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Number]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[DateTime]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Time]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Date]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[TimeDelta]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Dict]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Url]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Email]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[UUID]", "tests/test_fields.py::TestMetadata::test_extra_metadata_may_be_added_to_field[Decimal]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[String]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Integer]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Boolean]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Float]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Number]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[DateTime]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Time]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Date]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[TimeDelta]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Dict]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Url]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Email]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[UUID]", "tests/test_fields.py::TestMetadata::test_field_metadata_added_in_deprecated_style_warns[Decimal]"], "PASS_TO_PASS": ["tests/test_fields.py::test_field_aliases[Integer-Integer]", "tests/test_fields.py::test_field_aliases[String-String]", "tests/test_fields.py::test_field_aliases[Boolean-Boolean]", "tests/test_fields.py::test_field_aliases[Url-Url]", "tests/test_fields.py::TestField::test_repr", "tests/test_fields.py::TestField::test_error_raised_if_uncallable_validator_passed", "tests/test_fields.py::TestField::test_error_raised_if_missing_is_set_on_required_field", "tests/test_fields.py::TestField::test_custom_field_receives_attr_and_obj", "tests/test_fields.py::TestField::test_custom_field_receives_data_key_if_set", "tests/test_fields.py::TestField::test_custom_field_follows_data_key_if_set", "tests/test_fields.py::TestParentAndName::test_simple_field_parent_and_name", "tests/test_fields.py::TestParentAndName::test_unbound_field_root_returns_none", "tests/test_fields.py::TestParentAndName::test_list_field_inner_parent_and_name", "tests/test_fields.py::TestParentAndName::test_tuple_field_inner_parent_and_name", "tests/test_fields.py::TestParentAndName::test_mapping_field_inner_parent_and_name", "tests/test_fields.py::TestParentAndName::test_simple_field_root", "tests/test_fields.py::TestParentAndName::test_list_field_inner_root", "tests/test_fields.py::TestParentAndName::test_tuple_field_inner_root", "tests/test_fields.py::TestParentAndName::test_list_root_inheritance", "tests/test_fields.py::TestParentAndName::test_dict_root_inheritance", "tests/test_fields.py::TestParentAndName::test_datetime_list_inner_format", "tests/test_fields.py::TestErrorMessages::test_default_error_messages_get_merged_with_parent_error_messages_cstm_msg", "tests/test_fields.py::TestErrorMessages::test_default_error_messages_get_merged_with_parent_error_messages", "tests/test_fields.py::TestErrorMessages::test_make_error[required-Missing", "tests/test_fields.py::TestErrorMessages::test_make_error[null-Field", "tests/test_fields.py::TestErrorMessages::test_make_error[custom-Custom", "tests/test_fields.py::TestErrorMessages::test_make_error[validator_failed-Invalid", "tests/test_fields.py::TestErrorMessages::test_fail[required-Missing", "tests/test_fields.py::TestErrorMessages::test_fail[null-Field", "tests/test_fields.py::TestErrorMessages::test_fail[custom-Custom", "tests/test_fields.py::TestErrorMessages::test_fail[validator_failed-Invalid", "tests/test_fields.py::TestErrorMessages::test_make_error_key_doesnt_exist", "tests/test_fields.py::TestNestedField::test_nested_only_and_exclude_as_string[only]", "tests/test_fields.py::TestNestedField::test_nested_only_and_exclude_as_string[exclude]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[None-exclude]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[None-include]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[None-raise]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[exclude-exclude]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[exclude-include]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[exclude-raise]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[include-exclude]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[include-include]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[include-raise]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[raise-exclude]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[raise-include]", "tests/test_fields.py::TestNestedField::test_nested_unknown_override[raise-raise]", "tests/test_fields.py::TestNestedField::test_ordered_instanced_nested_schema_only_and_exclude[only-fields_list0]", "tests/test_fields.py::TestNestedField::test_ordered_instanced_nested_schema_only_and_exclude[exclude-fields_list1]", "tests/test_fields.py::TestListNested::test_list_nested_only_exclude_dump_only_load_only_propagated_to_nested[only]", "tests/test_fields.py::TestListNested::test_list_nested_only_exclude_dump_only_load_only_propagated_to_nested[exclude]", "tests/test_fields.py::TestListNested::test_list_nested_only_exclude_dump_only_load_only_propagated_to_nested[dump_only]", "tests/test_fields.py::TestListNested::test_list_nested_only_exclude_dump_only_load_only_propagated_to_nested[load_only]", "tests/test_fields.py::TestListNested::test_list_nested_class_only_and_exclude_merged_with_nested[only-expected_attribute0-expected_dump0]", "tests/test_fields.py::TestListNested::test_list_nested_class_only_and_exclude_merged_with_nested[exclude-expected_attribute1-expected_dump1]", "tests/test_fields.py::TestListNested::test_list_nested_class_multiple_dumps", "tests/test_fields.py::TestListNested::test_list_nested_instance_only_and_exclude_merged_with_nested[only-expected_attribute0-expected_dump0]", "tests/test_fields.py::TestListNested::test_list_nested_instance_only_and_exclude_merged_with_nested[exclude-expected_attribute1-expected_dump1]", "tests/test_fields.py::TestListNested::test_list_nested_instance_multiple_dumps", "tests/test_fields.py::TestListNested::test_list_nested_lambda_only_and_exclude_merged_with_nested[only-expected_attribute0-expected_dump0]", "tests/test_fields.py::TestListNested::test_list_nested_lambda_only_and_exclude_merged_with_nested[exclude-expected_attribute1-expected_dump1]", "tests/test_fields.py::TestListNested::test_list_nested_partial_propagated_to_nested", "tests/test_fields.py::TestTupleNested::test_tuple_nested_only_exclude_dump_only_load_only_propagated_to_nested[dump_only]", "tests/test_fields.py::TestTupleNested::test_tuple_nested_only_exclude_dump_only_load_only_propagated_to_nested[load_only]", "tests/test_fields.py::TestTupleNested::test_tuple_nested_partial_propagated_to_nested", "tests/test_fields.py::TestDictNested::test_dict_nested_only_exclude_dump_only_load_only_propagated_to_nested[only]", "tests/test_fields.py::TestDictNested::test_dict_nested_only_exclude_dump_only_load_only_propagated_to_nested[exclude]", "tests/test_fields.py::TestDictNested::test_dict_nested_only_exclude_dump_only_load_only_propagated_to_nested[dump_only]", "tests/test_fields.py::TestDictNested::test_dict_nested_only_exclude_dump_only_load_only_propagated_to_nested[load_only]", "tests/test_fields.py::TestDictNested::test_dict_nested_only_and_exclude_merged_with_nested[only-expected0]", "tests/test_fields.py::TestDictNested::test_dict_nested_only_and_exclude_merged_with_nested[exclude-expected1]", "tests/test_fields.py::TestDictNested::test_dict_nested_partial_propagated_to_nested"], "environment_setup_commit": "fa6c7379468f59d4568e29cbbeb06b797d656215", "query": "RFC: Change the way we store metadata?\nUsers are often bit by the fact that fields store arbitrary keyword arguments as metadata. See https://github.com/marshmallow-code/marshmallow/issues/683.\r\n\r\n> ...The reasons we use **kwargs instead of e.g. `metadata=` are mostly historical. The original decision was that storing kwargs 1) was more concise and 2) saved us from having to come up with an appropriate name... \"metadata\" didn't seem right because there are use cases where the things your storing aren't really metadata. At this point, it's not worth breaking the API.\r\n\r\n> Not the best reasons, but I think it's not terrible. We've discussed adding a [whitelist of metadata keys](https://github.com/marshmallow-code/marshmallow/issues/683#issuecomment-385113845) in the past, but we decided it wasn't worth the added API surface.\r\n\r\n_Originally posted by @sloria in https://github.com/marshmallow-code/marshmallow/issues/779#issuecomment-522283135_\r\n\r\nPossible solutions:\r\n\r\n1. Use `metadata=`.\r\n2. Specify a whitelist of allowed metadata arguments.\r\n\r\nFeedback welcome!\n", "task_id": "marshmallow-code__marshmallow-1702"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1738", "base_commit": "275e6718caf7486cb5b7dcf29acd59499ad51f7f", "patch": "diff --git a/pvlib/soiling.py b/pvlib/soiling.py\n--- a/pvlib/soiling.py\n+++ b/pvlib/soiling.py\n@@ -10,7 +10,7 @@\n from pvlib.tools import cosd\n \n \n-def hsu(rainfall, cleaning_threshold, tilt, pm2_5, pm10,\n+def hsu(rainfall, cleaning_threshold, surface_tilt, pm2_5, pm10,\n         depo_veloc=None, rain_accum_period=pd.Timedelta('1h')):\n     \"\"\"\n     Calculates soiling ratio given particulate and rain data using the\n@@ -30,7 +30,7 @@ def hsu(rainfall, cleaning_threshold, tilt, pm2_5, pm10,\n         Amount of rain in an accumulation period needed to clean the PV\n         modules. [mm]\n \n-    tilt : float\n+    surface_tilt : numeric\n         Tilt of the PV panels from horizontal. [degree]\n \n     pm2_5 : numeric\n@@ -83,7 +83,7 @@ def hsu(rainfall, cleaning_threshold, tilt, pm2_5, pm10,\n     horiz_mass_rate = (\n         pm2_5 * depo_veloc['2_5'] + np.maximum(pm10 - pm2_5, 0.)\n         * depo_veloc['10']) * dt_sec\n-    tilted_mass_rate = horiz_mass_rate * cosd(tilt)  # assuming no rain\n+    tilted_mass_rate = horiz_mass_rate * cosd(surface_tilt)  # assuming no rain\n \n     # tms -> tilt_mass_rate\n     tms_cumsum = np.cumsum(tilted_mass_rate * np.ones(rainfall.shape))\n", "test_patch": "diff --git a/pvlib/tests/test_soiling.py b/pvlib/tests/test_soiling.py\n--- a/pvlib/tests/test_soiling.py\n+++ b/pvlib/tests/test_soiling.py\n@@ -92,7 +92,7 @@ def test_hsu_no_cleaning(rainfall_input, expected_output):\n     tilt = 0.\n     expected_no_cleaning = expected_output\n \n-    result = hsu(rainfall=rainfall, cleaning_threshold=10., tilt=tilt,\n+    result = hsu(rainfall=rainfall, cleaning_threshold=10., surface_tilt=tilt,\n                  pm2_5=pm2_5, pm10=pm10, depo_veloc=depo_veloc,\n                  rain_accum_period=pd.Timedelta('1h'))\n     assert_series_equal(result, expected_no_cleaning)\n@@ -108,7 +108,7 @@ def test_hsu(rainfall_input, expected_output_2):\n     tilt = 0.\n \n     # three cleaning events at 4:00-6:00, 8:00-11:00, and 17:00-20:00\n-    result = hsu(rainfall=rainfall, cleaning_threshold=0.5, tilt=tilt,\n+    result = hsu(rainfall=rainfall, cleaning_threshold=0.5, surface_tilt=tilt,\n                  pm2_5=pm2_5, pm10=pm10, depo_veloc=depo_veloc,\n                  rain_accum_period=pd.Timedelta('3h'))\n \n@@ -120,8 +120,8 @@ def test_hsu_defaults(rainfall_input, expected_output_1):\n     Test Soiling HSU function with default deposition velocity and default rain\n     accumulation period.\n     \"\"\"\n-    result = hsu(rainfall=rainfall_input, cleaning_threshold=0.5, tilt=0.0,\n-                 pm2_5=1.0e-2, pm10=2.0e-2)\n+    result = hsu(rainfall=rainfall_input, cleaning_threshold=0.5,\n+                 surface_tilt=0.0, pm2_5=1.0e-2, pm10=2.0e-2)\n     assert np.allclose(result.values, expected_output_1)\n \n \n@@ -138,7 +138,7 @@ def test_hsu_variable_time_intervals(rainfall_input, expected_output_3):\n     rain['new_time'] = rain.index + rain['mins_added']\n     rain_var_times = rain.set_index('new_time').iloc[:, 0]\n     result = hsu(\n-        rainfall=rain_var_times, cleaning_threshold=0.5, tilt=50.0,\n+        rainfall=rain_var_times, cleaning_threshold=0.5, surface_tilt=50.0,\n         pm2_5=1, pm10=2, depo_veloc=depo_veloc,\n         rain_accum_period=pd.Timedelta('2h'))\n     assert np.allclose(result, expected_output_3)\n", "problem_statement": "`pvlib.soiling.hsu` takes `tilt` instead of `surface_tilt`\n`pvlib.soiling.hsu` takes a `tilt` parameter representing the same thing we normally call `surface_tilt`:\r\n\r\nhttps://github.com/pvlib/pvlib-python/blob/7a2ec9b4765124463bf0ddd0a49dcfedc4cbcad7/pvlib/soiling.py#L13-L14\r\n\r\nhttps://github.com/pvlib/pvlib-python/blob/7a2ec9b4765124463bf0ddd0a49dcfedc4cbcad7/pvlib/soiling.py#L33-L34\r\n\r\nI don't see any good reason for this naming inconsistency (I suspect `tilt` just got copied from the matlab implementation) and suggest we rename the parameter to `surface_tilt` with a deprecation.\r\n\r\nAlso, the docstring parameter type description says it must be `float`, but the model's reference explicitly says time series tilt is allowed: \r\n\r\n> The angle is variable for tracking systems and is taken as the average angle over the time step.\r\n\r\n\n", "hints_text": "On second thought, I'm not seeing how this can be deprecated without reordering the parameters, which doesn't seem worth it to me.  I'm inclined to rename it without deprecation in 0.10.0. ", "created_at": "2023-05-16T21:31:11Z", "version": "0.9", "FAIL_TO_PASS": ["pvlib/tests/test_soiling.py::test_hsu_no_cleaning", "pvlib/tests/test_soiling.py::test_hsu", "pvlib/tests/test_soiling.py::test_hsu_defaults", "pvlib/tests/test_soiling.py::test_hsu_variable_time_intervals"], "PASS_TO_PASS": ["pvlib/tests/test_soiling.py::test_kimber_nowash", "pvlib/tests/test_soiling.py::test_kimber_manwash", "pvlib/tests/test_soiling.py::test_kimber_norain", "pvlib/tests/test_soiling.py::test_kimber_initial_soil"], "environment_setup_commit": "6072e0982c3c0236f532ddfa48fbf461180d834e", "query": "`pvlib.soiling.hsu` takes `tilt` instead of `surface_tilt`\n`pvlib.soiling.hsu` takes a `tilt` parameter representing the same thing we normally call `surface_tilt`:\r\n\r\nhttps://github.com/pvlib/pvlib-python/blob/7a2ec9b4765124463bf0ddd0a49dcfedc4cbcad7/pvlib/soiling.py#L13-L14\r\n\r\nhttps://github.com/pvlib/pvlib-python/blob/7a2ec9b4765124463bf0ddd0a49dcfedc4cbcad7/pvlib/soiling.py#L33-L34\r\n\r\nI don't see any good reason for this naming inconsistency (I suspect `tilt` just got copied from the matlab implementation) and suggest we rename the parameter to `surface_tilt` with a deprecation.\r\n\r\nAlso, the docstring parameter type description says it must be `float`, but the model's reference explicitly says time series tilt is allowed: \r\n\r\n> The angle is variable for tracking systems and is taken as the average angle over the time step.\r\n\r\n\n", "task_id": "pvlib__pvlib-python-1738"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1707", "base_commit": "40e9e978c170bdde4eeee1547729417665dbc34c", "patch": "diff --git a/pvlib/iam.py b/pvlib/iam.py\n--- a/pvlib/iam.py\n+++ b/pvlib/iam.py\n@@ -175,8 +175,12 @@ def physical(aoi, n=1.526, K=4.0, L=0.002, *, n_ar=None):\n     n2costheta2 = n2 * costheta\n \n     # reflectance of s-, p-polarized, and normal light by the first interface\n-    rho12_s = ((n1costheta1 - n2costheta2) / (n1costheta1 + n2costheta2)) ** 2\n-    rho12_p = ((n1costheta2 - n2costheta1) / (n1costheta2 + n2costheta1)) ** 2\n+    with np.errstate(divide='ignore', invalid='ignore'):\n+        rho12_s = \\\n+            ((n1costheta1 - n2costheta2) / (n1costheta1 + n2costheta2)) ** 2\n+        rho12_p = \\\n+            ((n1costheta2 - n2costheta1) / (n1costheta2 + n2costheta1)) ** 2\n+\n     rho12_0 = ((n1 - n2) / (n1 + n2)) ** 2\n \n     # transmittance through the first interface\n@@ -208,13 +212,22 @@ def physical(aoi, n=1.526, K=4.0, L=0.002, *, n_ar=None):\n         tau_0 *= (1 - rho23_0) / (1 - rho23_0 * rho12_0)\n \n     # transmittance after absorption in the glass\n-    tau_s *= np.exp(-K * L / costheta)\n-    tau_p *= np.exp(-K * L / costheta)\n+    with np.errstate(divide='ignore', invalid='ignore'):\n+        tau_s *= np.exp(-K * L / costheta)\n+        tau_p *= np.exp(-K * L / costheta)\n+\n     tau_0 *= np.exp(-K * L)\n \n     # incidence angle modifier\n     iam = (tau_s + tau_p) / 2 / tau_0\n \n+    # for light coming from behind the plane, none can enter the module\n+    # when n2 > 1, this is already the case\n+    if np.isclose(n2, 1).any():\n+        iam = np.where(aoi >= 90, 0, iam)\n+        if isinstance(aoi, pd.Series):\n+            iam = pd.Series(iam, index=aoi.index)\n+\n     return iam\n \n \n", "test_patch": "diff --git a/pvlib/tests/test_iam.py b/pvlib/tests/test_iam.py\n--- a/pvlib/tests/test_iam.py\n+++ b/pvlib/tests/test_iam.py\n@@ -51,6 +51,18 @@ def test_physical():\n     assert_series_equal(iam, expected)\n \n \n+def test_physical_n1_L0():\n+    aoi = np.array([0, 22.5, 45, 67.5, 90, 100, np.nan])\n+    expected = np.array([1, 1, 1, 1, 0, 0, np.nan])\n+    iam = _iam.physical(aoi, n=1, L=0)\n+    assert_allclose(iam, expected, equal_nan=True)\n+\n+    aoi = pd.Series(aoi)\n+    expected = pd.Series(expected)\n+    iam = _iam.physical(aoi, n=1, L=0)\n+    assert_series_equal(iam, expected)\n+\n+\n def test_physical_ar():\n     aoi = np.array([0, 22.5, 45, 67.5, 90, 100, np.nan])\n     expected = np.array([1, 0.99944171, 0.9917463, 0.91506158, 0, 0, np.nan])\n", "problem_statement": "regression: iam.physical returns nan for aoi > 90\u00b0 when n = 1\n**Describe the bug**\r\nFor pvlib==0.9.5, when n = 1 (no reflection) and aoi > 90\u00b0, we get nan as result.\r\n\r\n**To Reproduce**\r\n```python\r\nimport pvlib\r\npvlib.iam.physical(aoi=100, n=1)\r\n```\r\nreturns `nan`.\r\n\r\n**Expected behavior**\r\nThe result should be `0`, as it was for pvlib <= 0.9.4.\r\n\r\n\r\n**Versions:**\r\n - ``pvlib.__version__``: '0.9.5'\r\n - ``pandas.__version__``:  '1.5.3'\r\n - python: 3.10.4\r\n\n", "hints_text": "", "created_at": "2023-03-24T10:46:42Z", "version": "0.9", "FAIL_TO_PASS": ["pvlib/tests/test_iam.py::test_physical_n1_L0"], "PASS_TO_PASS": ["pvlib/tests/test_iam.py::test_ashrae", "pvlib/tests/test_iam.py::test_ashrae_scalar", "pvlib/tests/test_iam.py::test_physical", "pvlib/tests/test_iam.py::test_physical_ar", "pvlib/tests/test_iam.py::test_physical_noar", "pvlib/tests/test_iam.py::test_physical_scalar", "pvlib/tests/test_iam.py::test_martin_ruiz", "pvlib/tests/test_iam.py::test_martin_ruiz_exception", "pvlib/tests/test_iam.py::test_martin_ruiz_diffuse", "pvlib/tests/test_iam.py::test_iam_interp", "pvlib/tests/test_iam.py::test_sapm[45-0.9975036250000002]", "pvlib/tests/test_iam.py::test_sapm[aoi1-expected1]", "pvlib/tests/test_iam.py::test_sapm[aoi2-expected2]", "pvlib/tests/test_iam.py::test_sapm_limits", "pvlib/tests/test_iam.py::test_marion_diffuse_model", "pvlib/tests/test_iam.py::test_marion_diffuse_kwargs", "pvlib/tests/test_iam.py::test_marion_diffuse_invalid", "pvlib/tests/test_iam.py::test_marion_integrate_scalar[sky-180-0.9596085829811408]", "pvlib/tests/test_iam.py::test_marion_integrate_scalar[horizon-1800-0.8329070417832541]", "pvlib/tests/test_iam.py::test_marion_integrate_scalar[ground-180-0.719823559106309]", "pvlib/tests/test_iam.py::test_marion_integrate_list[sky-180-expected0]", "pvlib/tests/test_iam.py::test_marion_integrate_list[horizon-1800-expected1]", "pvlib/tests/test_iam.py::test_marion_integrate_list[ground-180-expected2]", "pvlib/tests/test_iam.py::test_marion_integrate_series[sky-180-expected0]", "pvlib/tests/test_iam.py::test_marion_integrate_series[horizon-1800-expected1]", "pvlib/tests/test_iam.py::test_marion_integrate_series[ground-180-expected2]", "pvlib/tests/test_iam.py::test_marion_integrate_ground_flat", "pvlib/tests/test_iam.py::test_marion_integrate_invalid", "pvlib/tests/test_iam.py::test_schlick", "pvlib/tests/test_iam.py::test_schlick_diffuse"], "environment_setup_commit": "6072e0982c3c0236f532ddfa48fbf461180d834e", "query": "regression: iam.physical returns nan for aoi > 90\u00b0 when n = 1\n**Describe the bug**\r\nFor pvlib==0.9.5, when n = 1 (no reflection) and aoi > 90\u00b0, we get nan as result.\r\n\r\n**To Reproduce**\r\n```python\r\nimport pvlib\r\npvlib.iam.physical(aoi=100, n=1)\r\n```\r\nreturns `nan`.\r\n\r\n**Expected behavior**\r\nThe result should be `0`, as it was for pvlib <= 0.9.4.\r\n\r\n\r\n**Versions:**\r\n - ``pvlib.__version__``: '0.9.5'\r\n - ``pandas.__version__``:  '1.5.3'\r\n - python: 3.10.4\r\n\n", "task_id": "pvlib__pvlib-python-1707"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-980", "base_commit": "75369dcabacb6c6c38790cc23825f33f155ad1a9", "patch": "diff --git a/pvlib/soiling.py b/pvlib/soiling.py\n--- a/pvlib/soiling.py\n+++ b/pvlib/soiling.py\n@@ -12,8 +12,8 @@\n def hsu(rainfall, cleaning_threshold, tilt, pm2_5, pm10,\n         depo_veloc=None, rain_accum_period=pd.Timedelta('1h')):\n     \"\"\"\n-    Calculates soiling ratio given particulate and rain data using the model\n-    from Humboldt State University (HSU).\n+    Calculates soiling ratio given particulate and rain data using the\n+    Fixed Velocity model from Humboldt State University (HSU).\n \n     The HSU soiling model [1]_ returns the soiling ratio, a value between zero\n     and one which is equivalent to (1 - transmission loss). Therefore a soiling\n@@ -76,8 +76,17 @@ def hsu(rainfall, cleaning_threshold, tilt, pm2_5, pm10,\n     # cleaning is True for intervals with rainfall greater than threshold\n     cleaning_times = accum_rain.index[accum_rain >= cleaning_threshold]\n \n-    horiz_mass_rate = pm2_5 * depo_veloc['2_5']\\\n-        + np.maximum(pm10 - pm2_5, 0.) * depo_veloc['10'] * 3600\n+    # determine the time intervals in seconds (dt_sec)\n+    dt = rainfall.index\n+    # subtract shifted values from original and convert to seconds\n+    dt_diff = (dt[1:] - dt[:-1]).total_seconds()\n+    # ensure same number of elements in the array, assuming that the interval\n+    # prior to the first value is equal in length to the first interval\n+    dt_sec = np.append(dt_diff[0], dt_diff).astype('float64')\n+\n+    horiz_mass_rate = (\n+        pm2_5 * depo_veloc['2_5'] + np.maximum(pm10 - pm2_5, 0.)\n+        * depo_veloc['10']) * dt_sec\n     tilted_mass_rate = horiz_mass_rate * cosd(tilt)  # assuming no rain\n \n     # tms -> tilt_mass_rate\n", "test_patch": "diff --git a/pvlib/tests/test_soiling.py b/pvlib/tests/test_soiling.py\n--- a/pvlib/tests/test_soiling.py\n+++ b/pvlib/tests/test_soiling.py\n@@ -18,24 +18,24 @@ def expected_output():\n                        end=pd.Timestamp(2019, 1, 1, 23, 59, 0), freq='1h')\n \n     expected_no_cleaning = pd.Series(\n-        data=[0.97230454, 0.95036146, 0.93039061, 0.91177978, 0.89427556,\n-              0.8777455 , 0.86211038, 0.84731759, 0.83332881, 0.82011354,\n-              0.80764549, 0.79590056, 0.78485556, 0.77448749, 0.76477312,\n-              0.75568883, 0.74721046, 0.73931338, 0.73197253, 0.72516253,\n-              0.7188578 , 0.71303268, 0.7076616 , 0.70271919],\n+        data=[0.96998483, 0.94623958, 0.92468139, 0.90465654, 0.88589707,\n+              0.86826366, 0.85167258, 0.83606715, 0.82140458, 0.80764919,\n+              0.79476875, 0.78273241, 0.77150951, 0.76106905, 0.75137932,\n+              0.74240789, 0.73412165, 0.72648695, 0.71946981, 0.7130361,\n+              0.70715176, 0.70178307, 0.69689677, 0.69246034],\n         index=dt)\n     return expected_no_cleaning\n \n @pytest.fixture\n def expected_output_1():\n     dt = pd.date_range(start=pd.Timestamp(2019, 1, 1, 0, 0, 0),\n-        end=pd.Timestamp(2019, 1, 1, 23, 59, 0), freq='1h')\n+                       end=pd.Timestamp(2019, 1, 1, 23, 59, 0), freq='1h')\n     expected_output_1 = pd.Series(\n-        data=[0.9872406 , 0.97706269, 0.96769693, 0.95884032, 1.,\n-              0.9872406 , 0.97706269, 0.96769693, 1.        , 1.        ,\n-              0.9872406 , 0.97706269, 0.96769693, 0.95884032, 0.95036001,\n-              0.94218263, 0.93426236, 0.92656836, 0.91907873, 0.91177728,\n-              0.9046517 , 0.89769238, 0.89089165, 0.88424329],\n+        data=[0.98484972, 0.97277367, 0.96167471, 0.95119603, 1.,\n+              0.98484972, 0.97277367, 0.96167471, 1., 1.,\n+              0.98484972, 0.97277367, 0.96167471, 0.95119603, 0.94118234,\n+              0.93154854, 0.922242, 0.91322759, 0.90448058, 0.89598283,\n+              0.88772062, 0.87968325, 0.8718622, 0.86425049],\n         index=dt)\n     return expected_output_1\n \n@@ -44,15 +44,31 @@ def expected_output_2():\n     dt = pd.date_range(start=pd.Timestamp(2019, 1, 1, 0, 0, 0),\n                        end=pd.Timestamp(2019, 1, 1, 23, 59, 0), freq='1h')\n     expected_output_2 = pd.Series(\n-        data=[0.97229869, 0.95035106, 0.93037619, 0.91176175, 1.,\n-              1.        , 1.        , 0.97229869, 1.        , 1.        ,\n-              1.        , 1.        , 0.97229869, 0.95035106, 0.93037619,\n-              0.91176175, 0.89425431, 1.        , 1.        , 1.        ,\n-              1.        , 0.97229869, 0.95035106, 0.93037619],\n+        data=[0.95036261, 0.91178179, 0.87774818, 0.84732079, 1.,\n+              1., 1., 0.95036261, 1., 1.,\n+              1., 1., 0.95036261, 0.91178179, 0.87774818,\n+              0.84732079, 0.8201171, 1., 1., 1.,\n+              1., 0.95036261, 0.91178179, 0.87774818],\n         index=dt)\n-\n     return expected_output_2\n \n+\n+@pytest.fixture\n+def expected_output_3():\n+    dt = pd.date_range(start=pd.Timestamp(2019, 1, 1, 0, 0, 0),\n+                       end=pd.Timestamp(2019, 1, 1, 23, 59, 0), freq='1h')\n+    timedelta = [0, 0, 0, 0, 0, 30, 0, 30, 0, 30, 0, -30,\n+                 -30, -30, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]\n+    dt_new = dt + pd.to_timedelta(timedelta, 'm')\n+    expected_output_3 = pd.Series(\n+        data=[0.96576705, 0.9387675, 0.91437615, 0.89186852, 1.,\n+              1., 0.98093819, 0.9387675, 1., 1.,\n+              1., 1., 0.96576705, 0.9387675, 0.90291005,\n+              0.88122293, 0.86104089, 1., 1., 1.,\n+              0.96576705, 0.9387675, 0.91437615, 0.89186852],\n+        index=dt_new)\n+    return expected_output_3\n+\n @pytest.fixture\n def rainfall_input():\n \n@@ -105,12 +121,30 @@ def test_hsu_defaults(rainfall_input, expected_output_1):\n     Test Soiling HSU function with default deposition velocity and default rain\n     accumulation period.\n     \"\"\"\n-    result = hsu(\n-        rainfall=rainfall_input, cleaning_threshold=0.5, tilt=0.0,\n-        pm2_5=1.0e-2,pm10=2.0e-2)\n+    result = hsu(rainfall=rainfall_input, cleaning_threshold=0.5, tilt=0.0,\n+                 pm2_5=1.0e-2, pm10=2.0e-2)\n     assert np.allclose(result.values, expected_output_1)\n \n \n+@requires_scipy\n+def test_hsu_variable_time_intervals(rainfall_input, expected_output_3):\n+    \"\"\"\n+    Test Soiling HSU function with variable time intervals.\n+    \"\"\"\n+    depo_veloc = {'2_5': 1.0e-4, '10': 1.0e-4}\n+    rain = pd.DataFrame(data=rainfall_input)\n+    # define time deltas in minutes\n+    timedelta = [0, 0, 0, 0, 0, 30, 0, 30, 0, 30, 0, -30,\n+                 -30, -30, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]\n+    rain['mins_added'] = pd.to_timedelta(timedelta, 'm')\n+    rain['new_time'] = rain.index + rain['mins_added']\n+    rain_var_times = rain.set_index('new_time').iloc[:, 0]\n+    result = hsu(\n+        rainfall=rain_var_times, cleaning_threshold=0.5, tilt=50.0,\n+        pm2_5=1, pm10=2, depo_veloc=depo_veloc,\n+        rain_accum_period=pd.Timedelta('2h'))\n+    assert np.allclose(result, expected_output_3)\n+\n @pytest.fixture\n def greensboro_rain():\n     # get TMY3 data with rain\n", "problem_statement": "pvlib.soiling.hsu model implementation errors\n**Describe the bug**\r\nI ran an example run using the Matlab version of the HSU soiling function and found that the python version did not give anywhere near the same results.  The Matlab results matched the results in the original JPV paper.  As a result of this test, I found two errors in the python implementation, which are listed below:\r\n\r\n1.  depo_veloc = {'2_5': 0.004, '10': 0.0009} has the wrong default values.  They are reversed.\r\nThe proper dictionary should be: {'2_5': 0.0009, '10': 0.004}.  This is confirmed in the JPV paper and the Matlab version of the function.\r\n\r\n2. The horiz_mass_rate is in g/(m^2*hr) but should be in g/(m^2*s).  The line needs to be multiplied by 60x60 or 3600.\r\nThe proper line of code should be: \r\nhoriz_mass_rate = (pm2_5 * depo_veloc['2_5']+ np.maximum(pm10 - pm2_5, 0.) * depo_veloc['10'])*3600\r\n\r\nWhen I made these changes I was able to match the validation dataset from the JPV paper, as shown below.\r\n![image](https://user-images.githubusercontent.com/5392756/82380831-61c43d80-99e6-11ea-9ee3-2368fa71e580.png)\r\n\r\n\n", "hints_text": "nice sleuthing Josh! Is a PR forthcoming? \ud83c\udf89 \nHi Mark,\r\n                Yes, a PR is in the works.  I need to improve the testing first.\r\n\r\n-Josh\r\n\r\nFrom: Mark Mikofski <notifications@github.com>\r\nReply-To: pvlib/pvlib-python <reply@reply.github.com>\r\nDate: Tuesday, May 19, 2020 at 3:51 PM\r\nTo: pvlib/pvlib-python <pvlib-python@noreply.github.com>\r\nCc: Joshua Stein <jsstein@sandia.gov>, Author <author@noreply.github.com>\r\nSubject: [EXTERNAL] Re: [pvlib/pvlib-python] pvlib.soiling.hsu model implementation errors (#970)\r\n\r\n\r\nnice sleuthing Josh! Is a PR forthcoming? \ud83c\udf89\r\n\r\n\u2014\r\nYou are receiving this because you authored the thread.\r\nReply to this email directly, view it on GitHub<https://github.com/pvlib/pvlib-python/issues/970#issuecomment-631102921>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/ABJES5C2CRTZFF7ROT2EPOTRSL5ORANCNFSM4NFL4K3Q>.\r\n\nNow I need to go back and figure out where I missed these errors in the review.", "created_at": "2020-06-12T17:45:46Z", "version": "0.7", "FAIL_TO_PASS": ["pvlib/tests/test_soiling.py::test_hsu_no_cleaning", "pvlib/tests/test_soiling.py::test_hsu", "pvlib/tests/test_soiling.py::test_hsu_defaults", "pvlib/tests/test_soiling.py::test_hsu_variable_time_intervals"], "PASS_TO_PASS": ["pvlib/tests/test_soiling.py::test_kimber_nowash", "pvlib/tests/test_soiling.py::test_kimber_manwash", "pvlib/tests/test_soiling.py::test_kimber_norain", "pvlib/tests/test_soiling.py::test_kimber_initial_soil"], "environment_setup_commit": "6e5148f59c5050e8f7a0084b7ae39e93b80f72e6", "query": "pvlib.soiling.hsu model implementation errors\n**Describe the bug**\r\nI ran an example run using the Matlab version of the HSU soiling function and found that the python version did not give anywhere near the same results.  The Matlab results matched the results in the original JPV paper.  As a result of this test, I found two errors in the python implementation, which are listed below:\r\n\r\n1.  depo_veloc = {'2_5': 0.004, '10': 0.0009} has the wrong default values.  They are reversed.\r\nThe proper dictionary should be: {'2_5': 0.0009, '10': 0.004}.  This is confirmed in the JPV paper and the Matlab version of the function.\r\n\r\n2. The horiz_mass_rate is in g/(m^2*hr) but should be in g/(m^2*s).  The line needs to be multiplied by 60x60 or 3600.\r\nThe proper line of code should be: \r\nhoriz_mass_rate = (pm2_5 * depo_veloc['2_5']+ np.maximum(pm10 - pm2_5, 0.) * depo_veloc['10'])*3600\r\n\r\nWhen I made these changes I was able to match the validation dataset from the JPV paper, as shown below.\r\n![image](https://user-images.githubusercontent.com/5392756/82380831-61c43d80-99e6-11ea-9ee3-2368fa71e580.png)\r\n\r\n\n", "task_id": "pvlib__pvlib-python-980"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1224", "base_commit": "50dcc7fe412d9e27fe06670b8057e3d8e9ce5b19", "patch": "diff --git a/pvlib/pvsystem.py b/pvlib/pvsystem.py\n--- a/pvlib/pvsystem.py\n+++ b/pvlib/pvsystem.py\n@@ -98,8 +98,9 @@ class PVSystem:\n     arrays : iterable of Array, optional\n         List of arrays that are part of the system. If not specified\n         a single array is created from the other parameters (e.g.\n-        `surface_tilt`, `surface_azimuth`). If `arrays` is specified\n-        the following parameters are ignored:\n+        `surface_tilt`, `surface_azimuth`). Must contain at least one Array,\n+        if length of arrays is 0 a ValueError is raised. If `arrays` is\n+        specified the following parameters are ignored:\n \n         - `surface_tilt`\n         - `surface_azimuth`\n@@ -173,6 +174,11 @@ class PVSystem:\n         Arbitrary keyword arguments.\n         Included for compatibility, but not used.\n \n+    Raises\n+    ------\n+    ValueError\n+        If `arrays` is not None and has length 0.\n+\n     See also\n     --------\n     pvlib.location.Location\n@@ -210,6 +216,12 @@ def __init__(self,\n                 racking_model,\n                 array_losses_parameters,\n             ),)\n+        elif len(arrays) == 0:\n+            raise ValueError(\"PVSystem must have at least one Array. \"\n+                             \"If you want to create a PVSystem instance \"\n+                             \"with a single Array pass `arrays=None` and pass \"\n+                             \"values directly to PVSystem attributes, e.g., \"\n+                             \"`surface_tilt=30`\")\n         else:\n             self.arrays = tuple(arrays)\n \n", "test_patch": "diff --git a/pvlib/tests/test_pvsystem.py b/pvlib/tests/test_pvsystem.py\n--- a/pvlib/tests/test_pvsystem.py\n+++ b/pvlib/tests/test_pvsystem.py\n@@ -2084,6 +2084,12 @@ def test_PVSystem_num_arrays():\n     assert system_two.num_arrays == 2\n \n \n+def test_PVSystem_at_least_one_array():\n+    with pytest.raises(ValueError,\n+                       match=\"PVSystem must have at least one Array\"):\n+        pvsystem.PVSystem(arrays=[])\n+\n+\n def test_combine_loss_factors():\n     test_index = pd.date_range(start='1990/01/01T12:00', periods=365, freq='D')\n     loss_1 = pd.Series(.10, index=test_index)\n", "problem_statement": "It should be impossible to instantiate a PVSystem with no Arrays\n**Describe the bug**\r\nIt should be impossible to instantiate a `PVSystem` with no `Arrays`. Currently this is possible via `PVSystem(arrays=[])`.\r\n\r\n**To Reproduce**\r\nSteps to reproduce the behavior:\r\n```python\r\nfrom pvlib import pvsystem\r\npvsystem.PVSystem(arrays=[])\r\n```\r\nresults in this PVSystem:\r\n```\r\nPVSystem:\r\n  name: None\r\n  inverter: None\r\n```\r\n**Expected behavior**\r\nA `ValueError` should be raised indicating that a PVSystem must have at least one `Array` and suggesting that a system with an arbitrary default array can be constructed by passing `arrays=None` or not passing the `arrays` parameter at all.\r\n\r\n**Versions:**\r\n - ``pvlib.__version__``: 0.8.1+\r\n\r\n\n", "hints_text": "", "created_at": "2021-05-10T15:35:18Z", "version": "0.8", "FAIL_TO_PASS": ["pvlib/tests/test_pvsystem.py::test_PVSystem_at_least_one_array"], "PASS_TO_PASS": ["pvlib/tests/test_pvsystem.py::test_PVSystem_get_iam[ashrae-model_params0]", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_iam[physical-model_params1]", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_iam[martin_ruiz-model_params2]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_get_iam", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_iam_sapm", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_iam_interp", "pvlib/tests/test_pvsystem.py::test__normalize_sam_product_names", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_iam_invalid", "pvlib/tests/test_pvsystem.py::test_retrieve_sam_raise_no_parameters", "pvlib/tests/test_pvsystem.py::test_retrieve_sam_cecmod", "pvlib/tests/test_pvsystem.py::test_retrieve_sam_cecinverter", "pvlib/tests/test_pvsystem.py::test_sapm", "pvlib/tests/test_pvsystem.py::test_PVSystem_sapm", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_sapm", "pvlib/tests/test_pvsystem.py::test_sapm_spectral_loss[1.5-1.00028714375]", "pvlib/tests/test_pvsystem.py::test_sapm_spectral_loss[airmass1-expected1]", "pvlib/tests/test_pvsystem.py::test_sapm_spectral_loss[airmass2-expected2]", "pvlib/tests/test_pvsystem.py::test_PVSystem_sapm_spectral_loss", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_sapm_spectral_loss", "pvlib/tests/test_pvsystem.py::test_PVSystem_first_solar_spectral_loss[module_parameters0-multisi-None]", "pvlib/tests/test_pvsystem.py::test_PVSystem_first_solar_spectral_loss[module_parameters1-multisi-None]", "pvlib/tests/test_pvsystem.py::test_PVSystem_first_solar_spectral_loss[module_parameters2-None-coefficients2]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_first_solar_spectral_loss", "pvlib/tests/test_pvsystem.py::test_sapm_effective_irradiance[test_input0-1140.0510967821876]", "pvlib/tests/test_pvsystem.py::test_sapm_effective_irradiance[test_input1-expected1]", "pvlib/tests/test_pvsystem.py::test_sapm_effective_irradiance[test_input2-expected2]", "pvlib/tests/test_pvsystem.py::test_PVSystem_sapm_effective_irradiance", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_sapm_effective_irradiance", "pvlib/tests/test_pvsystem.py::test_PVSystem_sapm_effective_irradiance_value_error[20-poa_diffuse0-aoi0]", "pvlib/tests/test_pvsystem.py::test_PVSystem_sapm_effective_irradiance_value_error[poa_direct1-poa_diffuse1-aoi1]", "pvlib/tests/test_pvsystem.py::test_PVSystem_sapm_effective_irradiance_value_error[poa_direct2-poa_diffuse2-20]", "pvlib/tests/test_pvsystem.py::test_PVSystem_sapm_celltemp", "pvlib/tests/test_pvsystem.py::test_PVSystem_sapm_celltemp_kwargs", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_sapm_celltemp_different_arrays", "pvlib/tests/test_pvsystem.py::test_PVSystem_pvsyst_celltemp", "pvlib/tests/test_pvsystem.py::test_PVSystem_faiman_celltemp", "pvlib/tests/test_pvsystem.py::test_PVSystem_noct_celltemp", "pvlib/tests/test_pvsystem.py::test_PVSystem_noct_celltemp_error", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_functions[faiman_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_functions[pvsyst_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_functions[sapm_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_functions[fuentes_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_functions[noct_sam_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_temp[faiman_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_temp[pvsyst_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_temp[sapm_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_temp[fuentes_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_temp[noct_sam_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_wind[faiman_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_wind[pvsyst_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_wind[sapm_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_wind[fuentes_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_multi_wind[noct_sam_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_short[faiman_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_short[pvsyst_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_short[sapm_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_short[fuentes_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_short[noct_sam_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_long[faiman_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_long[pvsyst_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_long[sapm_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_long[fuentes_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_temp_too_long[noct_sam_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_short[faiman_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_short[pvsyst_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_short[sapm_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_short[fuentes_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_short[noct_sam_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_long[faiman_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_long[pvsyst_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_long[sapm_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_long[fuentes_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_wind_too_long[noct_sam_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_poa_length_mismatch[faiman_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_poa_length_mismatch[pvsyst_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_poa_length_mismatch[sapm_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_poa_length_mismatch[fuentes_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_celltemp_poa_length_mismatch[noct_sam_celltemp]", "pvlib/tests/test_pvsystem.py::test_PVSystem_fuentes_celltemp", "pvlib/tests/test_pvsystem.py::test_PVSystem_fuentes_celltemp_override", "pvlib/tests/test_pvsystem.py::test_Array__infer_temperature_model_params", "pvlib/tests/test_pvsystem.py::test_Array__infer_cell_type", "pvlib/tests/test_pvsystem.py::test_calcparams_desoto", "pvlib/tests/test_pvsystem.py::test_calcparams_cec", "pvlib/tests/test_pvsystem.py::test_calcparams_pvsyst", "pvlib/tests/test_pvsystem.py::test_PVSystem_calcparams_desoto", "pvlib/tests/test_pvsystem.py::test_PVSystem_calcparams_pvsyst", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_calcparams[calcparams_pvsyst]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_calcparams[calcparams_desoto]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_calcparams[calcparams_cec]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_calcparams_value_error[calcparams_desoto-1-celltemp0]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_calcparams_value_error[calcparams_desoto-irrad1-1]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_calcparams_value_error[calcparams_cec-1-celltemp2]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_calcparams_value_error[calcparams_cec-irrad3-1]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_calcparams_value_error[calcparams_pvsyst-1-celltemp4]", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_calcparams_value_error[calcparams_pvsyst-irrad5-1]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i0-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i0-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i0-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i1-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i1-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i1-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i2-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i2-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i2-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i3-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i3-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i3-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i4-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i4-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i4-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i5-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i5-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i5-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i6-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i6-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i6-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i7-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i7-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i7-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i8-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i8-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i8-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i9-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i9-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i9-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i10-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i10-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_v_from_i[fixture_v_from_i10-newton-1e-08]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i0]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i1]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i2]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i3]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i4]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i5]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i6]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i7]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i8]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i9]", "pvlib/tests/test_pvsystem.py::test_i_from_v_from_i[fixture_v_from_i10]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v0-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v0-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v0-newton-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v1-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v1-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v1-newton-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v2-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v2-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v2-newton-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v3-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v3-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v3-newton-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v4-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v4-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v4-newton-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v5-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v5-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v5-newton-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v6-lambertw-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v6-brentq-1e-11]", "pvlib/tests/test_pvsystem.py::test_i_from_v[fixture_i_from_v6-newton-1e-11]", "pvlib/tests/test_pvsystem.py::test_PVSystem_i_from_v", "pvlib/tests/test_pvsystem.py::test_i_from_v_size", "pvlib/tests/test_pvsystem.py::test_v_from_i_size", "pvlib/tests/test_pvsystem.py::test_mpp_floats", "pvlib/tests/test_pvsystem.py::test_mpp_array", "pvlib/tests/test_pvsystem.py::test_mpp_series", "pvlib/tests/test_pvsystem.py::test_singlediode_series", "pvlib/tests/test_pvsystem.py::test_singlediode_array", "pvlib/tests/test_pvsystem.py::test_singlediode_floats", "pvlib/tests/test_pvsystem.py::test_singlediode_floats_ivcurve", "pvlib/tests/test_pvsystem.py::test_singlediode_series_ivcurve", "pvlib/tests/test_pvsystem.py::test_scale_voltage_current_power", "pvlib/tests/test_pvsystem.py::test_PVSystem_scale_voltage_current_power", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_scale_voltage_current_power", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_sandia", "pvlib/tests/test_pvsystem.py::test_PVSystem_snlinverter", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_sandia_multi", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_pvwatts", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_pvwatts_kwargs", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_pvwatts_multi", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_single_array_tuple_input[sandia]", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_single_array_tuple_input[adr]", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_single_array_tuple_input[pvwatts]", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_adr", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_adr_multi", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_ac_invalid", "pvlib/tests/test_pvsystem.py::test_PVSystem_creation", "pvlib/tests/test_pvsystem.py::test_PVSystem_multiple_array_creation", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_aoi", "pvlib/tests/test_pvsystem.py::test_PVSystem_multiple_array_get_aoi", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_irradiance", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_irradiance_model", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_get_irradiance", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array_get_irradiance_multi_irrad", "pvlib/tests/test_pvsystem.py::test_PVSystem_change_surface_azimuth", "pvlib/tests/test_pvsystem.py::test_PVSystem_get_albedo", "pvlib/tests/test_pvsystem.py::test_PVSystem_modules_per_string", "pvlib/tests/test_pvsystem.py::test_PVSystem_strings_per_inverter", "pvlib/tests/test_pvsystem.py::test_PVSystem___repr__", "pvlib/tests/test_pvsystem.py::test_PVSystem_multi_array___repr__", "pvlib/tests/test_pvsystem.py::test_Array___repr__", "pvlib/tests/test_pvsystem.py::test_pvwatts_dc_scalars", "pvlib/tests/test_pvsystem.py::test_pvwatts_dc_arrays", "pvlib/tests/test_pvsystem.py::test_pvwatts_dc_series", "pvlib/tests/test_pvsystem.py::test_pvwatts_losses_default", "pvlib/tests/test_pvsystem.py::test_pvwatts_losses_arrays", "pvlib/tests/test_pvsystem.py::test_pvwatts_losses_series", "pvlib/tests/test_pvsystem.py::test_PVSystem_pvwatts_dc", "pvlib/tests/test_pvsystem.py::test_PVSystem_pvwatts_dc_kwargs", "pvlib/tests/test_pvsystem.py::test_PVSystem_multiple_array_pvwatts_dc", "pvlib/tests/test_pvsystem.py::test_PVSystem_multiple_array_pvwatts_dc_value_error", "pvlib/tests/test_pvsystem.py::test_PVSystem_pvwatts_losses", "pvlib/tests/test_pvsystem.py::test_PVSystem_pvwatts_ac", "pvlib/tests/test_pvsystem.py::test_PVSystem_pvwatts_ac_kwargs", "pvlib/tests/test_pvsystem.py::test_PVSystem_num_arrays", "pvlib/tests/test_pvsystem.py::test_combine_loss_factors", "pvlib/tests/test_pvsystem.py::test_no_extra_kwargs", "pvlib/tests/test_pvsystem.py::test_dc_ohms_from_percent", "pvlib/tests/test_pvsystem.py::test_PVSystem_dc_ohms_from_percent", "pvlib/tests/test_pvsystem.py::test_dc_ohmic_losses", "pvlib/tests/test_pvsystem.py::test_Array_dc_ohms_from_percent"], "environment_setup_commit": "ef8ad2fee9840a77d14b0dfd17fc489dd85c9b91", "query": "It should be impossible to instantiate a PVSystem with no Arrays\n**Describe the bug**\r\nIt should be impossible to instantiate a `PVSystem` with no `Arrays`. Currently this is possible via `PVSystem(arrays=[])`.\r\n\r\n**To Reproduce**\r\nSteps to reproduce the behavior:\r\n```python\r\nfrom pvlib import pvsystem\r\npvsystem.PVSystem(arrays=[])\r\n```\r\nresults in this PVSystem:\r\n```\r\nPVSystem:\r\n  name: None\r\n  inverter: None\r\n```\r\n**Expected behavior**\r\nA `ValueError` should be raised indicating that a PVSystem must have at least one `Array` and suggesting that a system with an arbitrary default array can be constructed by passing `arrays=None` or not passing the `arrays` parameter at all.\r\n\r\n**Versions:**\r\n - ``pvlib.__version__``: 0.8.1+\r\n\r\n\n", "task_id": "pvlib__pvlib-python-1224"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1239", "base_commit": "276a30de72a392ff59f798b8850229e9527ff03e", "patch": "diff --git a/pvlib/irradiance.py b/pvlib/irradiance.py\n--- a/pvlib/irradiance.py\n+++ b/pvlib/irradiance.py\n@@ -1126,7 +1126,6 @@ def perez(surface_tilt, surface_azimuth, dhi, dni, dni_extra,\n     F1 = np.maximum(F1, 0)\n \n     F2 = (F2c[ebin, 0] + F2c[ebin, 1] * delta + F2c[ebin, 2] * z)\n-    F2 = np.maximum(F2, 0)\n \n     A = aoi_projection(surface_tilt, surface_azimuth,\n                        solar_zenith, solar_azimuth)\n", "test_patch": "diff --git a/pvlib/tests/test_irradiance.py b/pvlib/tests/test_irradiance.py\n--- a/pvlib/tests/test_irradiance.py\n+++ b/pvlib/tests/test_irradiance.py\n@@ -248,6 +248,52 @@ def test_perez_components(irrad_data, ephem_data, dni_et, relative_airmass):\n     assert_series_equal(sum_components, expected_for_sum, check_less_precise=2)\n \n \n+def test_perez_negative_horizon():\n+    times = pd.date_range(start='20190101 11:30:00', freq='1H',\n+                          periods=5, tz='US/Central')\n+\n+    # Avoid test dependencies on functionality not being tested by hard-coding\n+    # the inputs. This data corresponds to Goodwin Creek in the afternoon on\n+    # 1/1/2019.\n+    # dni_e is slightly rounded from irradiance.get_extra_radiation\n+    # airmass from atmosphere.get_relative_airmas\n+    inputs = pd.DataFrame(np.array(\n+        [[ 158,         19,          1,          0,          0],\n+         [ 249,        165,        136,         93,         50],\n+         [  57.746951,  57.564205,  60.813841,  66.989435,  75.353368],\n+         [ 171.003315, 187.346924, 202.974357, 216.725599, 228.317233],\n+         [1414,       1414,       1414,       1414,       1414],\n+         [   1.869315,   1.859981,   2.044429,   2.544943,   3.900136]]).T,\n+        columns=['dni', 'dhi', 'solar_zenith',\n+                 'solar_azimuth', 'dni_extra', 'airmass'],\n+        index=times\n+    )\n+\n+    out = irradiance.perez(34, 180, inputs['dhi'], inputs['dni'],\n+                           inputs['dni_extra'], inputs['solar_zenith'],\n+                           inputs['solar_azimuth'], inputs['airmass'],\n+                           model='allsitescomposite1990',\n+                           return_components=True)\n+\n+    # sky_diffuse can be less than isotropic under certain conditions as\n+    # horizon goes negative\n+    expected = pd.DataFrame(np.array(\n+        [[281.410185, 152.20879, 123.867898, 82.836412, 43.517015],\n+         [166.785419, 142.24475, 119.173875, 83.525150, 45.725931],\n+         [113.548755,  16.09757,   9.956174,  3.142467,  0],\n+         [  1.076010,  -6.13353,  -5.262151, -3.831230, -2.208923]]).T,\n+        columns=['sky_diffuse', 'isotropic', 'circumsolar', 'horizon'],\n+        index=times\n+    )\n+\n+    expected_for_sum = expected['sky_diffuse'].copy()\n+    sum_components = out.iloc[:, 1:].sum(axis=1)\n+    sum_components.name = 'sky_diffuse'\n+\n+    assert_frame_equal(out, expected, check_less_precise=2)\n+    assert_series_equal(sum_components, expected_for_sum, check_less_precise=2)\n+\n+\n def test_perez_arrays(irrad_data, ephem_data, dni_et, relative_airmass):\n     dni = irrad_data['dni'].copy()\n     dni.iloc[2] = np.nan\n@@ -608,7 +654,7 @@ def test_gti_dirint():\n     expected_col_order = ['ghi', 'dni', 'dhi']\n     expected = pd.DataFrame(array(\n         [[  21.05796198,    0.        ,   21.05796198],\n-         [ 288.22574368,   60.59964218,  245.37532576],\n+         [ 291.40037163,   63.41290679,  246.56067523],\n          [ 931.04078010,  695.94965324,  277.06172442]]),\n         columns=expected_col_order, index=times)\n \n@@ -632,7 +678,7 @@ def test_gti_dirint():\n \n     expected = pd.DataFrame(array(\n         [[  21.05796198,    0.        ,   21.05796198],\n-         [ 289.81109139,   60.52460392,  247.01373353],\n+         [ 293.21310935,   63.27500913,  248.47092131],\n          [ 932.46756378,  648.05001357,  323.49974813]]),\n         columns=expected_col_order, index=times)\n \n@@ -646,8 +692,8 @@ def test_gti_dirint():\n \n     expected = pd.DataFrame(array(\n         [[  21.3592591,    0.        ,   21.3592591 ],\n-         [ 292.5162373,   64.42628826,  246.95997198],\n-         [ 941.6753031,  727.16311901,  258.36548605]]),\n+         [ 294.4985420,   66.25848451,  247.64671830],\n+         [ 941.7943404,  727.50552952,  258.16276278]]),\n         columns=expected_col_order, index=times)\n \n     assert_frame_equal(output, expected)\n@@ -659,8 +705,8 @@ def test_gti_dirint():\n         temp_dew=temp_dew)\n \n     expected = pd.DataFrame(array(\n-        [[  21.05796198,    0.        ,   21.05796198],\n-         [ 292.40468994,   36.79559287,  266.3862767 ],\n+        [[  21.05796198,    0.,           21.05796198],\n+         [ 295.06070190,   38.20346345,  268.0467738],\n          [ 931.79627208,  689.81549269,  283.5817439]]),\n         columns=expected_col_order, index=times)\n \n", "problem_statement": "The Perez diffuse model should not be forcing the horizon coefficient up to zero\nThe perez model in irradiance.py forces F2, and thus the horizon component of diffuse, to be non-negative.  This restriction should not happen.  F2 and the horizon coefficient should be allowed to be negative and to reduce overall diffuse.\r\n\r\nAccording to the original paper at https://www.osti.gov/servlets/purl/7024029\r\nSection III.2 states this explicitly for the horizon component:\r\n\"(2) The horizon brightening coefficient, F2, is negative for overcast and low E occurrences -- indicative of brightening of the zenithal region of the sky for these conditions. This becomes positive past intermediate conditions and increases substantially with clearness.\"\r\n\r\nWe observed a higher than expected POAI, coming from poa diffuse, on cloudy days at certain sites.\r\nExpected:\r\nHorizon (burgundy) can be less than zero and sky diffuse (green) is less than isotropic (blue)\r\n![image](https://user-images.githubusercontent.com/81724637/119172295-9ebc7900-ba1a-11eb-8e1a-3a170e1f995a.png)\r\n\r\nObserved from PVLib:\r\nHorizon is prevented from being negative and sky diffuse ends up higher than isotropic.\r\n![image](https://user-images.githubusercontent.com/81724637/119172410-c4498280-ba1a-11eb-8e91-540db0ddc609.png)\r\n\r\nRepro'd on PVLib 0.8.1\r\n\r\nSee added test case in the PR for this repro case.\r\n\n", "hints_text": "", "created_at": "2021-05-21T17:47:47Z", "version": "0.8", "FAIL_TO_PASS": ["pvlib/tests/test_irradiance.py::test_perez_negative_horizon", "pvlib/tests/test_irradiance.py::test_gti_dirint"], "PASS_TO_PASS": ["pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-300-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-300.0-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval2-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval3-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval4-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval5-expected5]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval6-expected6]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval7-expected7]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval8-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-300-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-300.0-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval2-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval3-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval4-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval5-expected5]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval6-expected6]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval7-expected7]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval8-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-300-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-300.0-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval2-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval3-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval4-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval5-expected5]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval6-expected6]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval7-expected7]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval8-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-300-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-300.0-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval2-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval3-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval4-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval5-expected5]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval6-expected6]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval7-expected7]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval8-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation_epoch_year", "pvlib/tests/test_irradiance.py::test_get_extra_radiation_nrel_numba", "pvlib/tests/test_irradiance.py::test_get_extra_radiation_invalid", "pvlib/tests/test_irradiance.py::test_grounddiffuse_simple_float", "pvlib/tests/test_irradiance.py::test_grounddiffuse_simple_series", "pvlib/tests/test_irradiance.py::test_grounddiffuse_albedo_0", "pvlib/tests/test_irradiance.py::test_grounddiffuse_albedo_invalid_surface", "pvlib/tests/test_irradiance.py::test_grounddiffuse_albedo_surface", "pvlib/tests/test_irradiance.py::test_isotropic_float", "pvlib/tests/test_irradiance.py::test_isotropic_series", "pvlib/tests/test_irradiance.py::test_klucher_series_float", "pvlib/tests/test_irradiance.py::test_klucher_series", "pvlib/tests/test_irradiance.py::test_haydavies", "pvlib/tests/test_irradiance.py::test_reindl", "pvlib/tests/test_irradiance.py::test_king", "pvlib/tests/test_irradiance.py::test_perez", "pvlib/tests/test_irradiance.py::test_perez_components", "pvlib/tests/test_irradiance.py::test_perez_arrays", "pvlib/tests/test_irradiance.py::test_perez_scalar", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[isotropic]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[klucher]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[haydavies]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[reindl]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[king]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[perez]", "pvlib/tests/test_irradiance.py::test_get_sky_diffuse_model_invalid", "pvlib/tests/test_irradiance.py::test_get_sky_diffuse_missing_dni_extra", "pvlib/tests/test_irradiance.py::test_get_sky_diffuse_missing_airmass", "pvlib/tests/test_irradiance.py::test_campbell_norman", "pvlib/tests/test_irradiance.py::test_get_total_irradiance", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[isotropic]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[klucher]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[haydavies]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[reindl]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[king]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[perez]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_missing_dni_extra", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_missing_airmass", "pvlib/tests/test_irradiance.py::test_poa_components", "pvlib/tests/test_irradiance.py::test_disc_value[93193-expected0]", "pvlib/tests/test_irradiance.py::test_disc_value[None-expected1]", "pvlib/tests/test_irradiance.py::test_disc_value[101325-expected2]", "pvlib/tests/test_irradiance.py::test_disc_overirradiance", "pvlib/tests/test_irradiance.py::test_disc_min_cos_zenith_max_zenith", "pvlib/tests/test_irradiance.py::test_dirint_value", "pvlib/tests/test_irradiance.py::test_dirint_nans", "pvlib/tests/test_irradiance.py::test_dirint_tdew", "pvlib/tests/test_irradiance.py::test_dirint_no_delta_kt", "pvlib/tests/test_irradiance.py::test_dirint_coeffs", "pvlib/tests/test_irradiance.py::test_dirint_min_cos_zenith_max_zenith", "pvlib/tests/test_irradiance.py::test_erbs", "pvlib/tests/test_irradiance.py::test_erbs_min_cos_zenith_max_zenith", "pvlib/tests/test_irradiance.py::test_erbs_all_scalar", "pvlib/tests/test_irradiance.py::test_dirindex", "pvlib/tests/test_irradiance.py::test_dirindex_min_cos_zenith_max_zenith", "pvlib/tests/test_irradiance.py::test_dni", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[0-0-0-0-0-1]", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[30-180-30-180-0-1]", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[30-180-150-0-180--1]", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[90-0-30-60-75.5224878-0.25]", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[90-0-30-170-119.4987042--0.4924038]", "pvlib/tests/test_irradiance.py::test_aoi_projection_precision", "pvlib/tests/test_irradiance.py::test_kt_kt_prime_factor", "pvlib/tests/test_irradiance.py::test_clearsky_index", "pvlib/tests/test_irradiance.py::test_clearness_index", "pvlib/tests/test_irradiance.py::test_clearness_index_zenith_independent"], "environment_setup_commit": "ef8ad2fee9840a77d14b0dfd17fc489dd85c9b91", "query": "The Perez diffuse model should not be forcing the horizon coefficient up to zero\nThe perez model in irradiance.py forces F2, and thus the horizon component of diffuse, to be non-negative.  This restriction should not happen.  F2 and the horizon coefficient should be allowed to be negative and to reduce overall diffuse.\r\n\r\nAccording to the original paper at https://www.osti.gov/servlets/purl/7024029\r\nSection III.2 states this explicitly for the horizon component:\r\n\"(2) The horizon brightening coefficient, F2, is negative for overcast and low E occurrences -- indicative of brightening of the zenithal region of the sky for these conditions. This becomes positive past intermediate conditions and increases substantially with clearness.\"\r\n\r\nWe observed a higher than expected POAI, coming from poa diffuse, on cloudy days at certain sites.\r\nExpected:\r\nHorizon (burgundy) can be less than zero and sky diffuse (green) is less than isotropic (blue)\r\n![image](https://user-images.githubusercontent.com/81724637/119172295-9ebc7900-ba1a-11eb-8e1a-3a170e1f995a.png)\r\n\r\nObserved from PVLib:\r\nHorizon is prevented from being negative and sky diffuse ends up higher than isotropic.\r\n![image](https://user-images.githubusercontent.com/81724637/119172410-c4498280-ba1a-11eb-8e91-540db0ddc609.png)\r\n\r\nRepro'd on PVLib 0.8.1\r\n\r\nSee added test case in the PR for this repro case.\r\n\n", "task_id": "pvlib__pvlib-python-1239"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1154", "base_commit": "0b8f24c265d76320067a5ee908a57d475cd1bb24", "patch": "diff --git a/pvlib/irradiance.py b/pvlib/irradiance.py\n--- a/pvlib/irradiance.py\n+++ b/pvlib/irradiance.py\n@@ -886,8 +886,9 @@ def reindl(surface_tilt, surface_azimuth, dhi, dni, ghi, dni_extra,\n     # these are the () and [] sub-terms of the second term of eqn 8\n     term1 = 1 - AI\n     term2 = 0.5 * (1 + tools.cosd(surface_tilt))\n-    term3 = 1 + np.sqrt(HB / ghi) * (tools.sind(0.5 * surface_tilt) ** 3)\n-\n+    with np.errstate(invalid='ignore', divide='ignore'):\n+        hb_to_ghi = np.where(ghi == 0, 0, np.divide(HB, ghi))\n+    term3 = 1 + np.sqrt(hb_to_ghi) * (tools.sind(0.5 * surface_tilt)**3)\n     sky_diffuse = dhi * (AI * Rb + term1 * term2 * term3)\n     sky_diffuse = np.maximum(sky_diffuse, 0)\n \n", "test_patch": "diff --git a/pvlib/tests/test_irradiance.py b/pvlib/tests/test_irradiance.py\n--- a/pvlib/tests/test_irradiance.py\n+++ b/pvlib/tests/test_irradiance.py\n@@ -203,7 +203,7 @@ def test_reindl(irrad_data, ephem_data, dni_et):\n         40, 180, irrad_data['dhi'], irrad_data['dni'], irrad_data['ghi'],\n         dni_et, ephem_data['apparent_zenith'], ephem_data['azimuth'])\n     # values from matlab 1.4 code\n-    assert_allclose(result, [np.nan, 27.9412, 104.1317, 34.1663], atol=1e-4)\n+    assert_allclose(result, [0., 27.9412, 104.1317, 34.1663], atol=1e-4)\n \n \n def test_king(irrad_data, ephem_data):\n", "problem_statement": "pvlib.irradiance.reindl() model generates NaNs when GHI = 0\n**Describe the bug**\r\nThe reindl function should give zero sky diffuse when GHI is zero. Instead it generates NaN or Inf values due to \"term3\" having a quotient that divides by GHI.  \r\n\r\n**Expected behavior**\r\nThe reindl function should result in zero sky diffuse when GHI is zero.\r\n\r\n\npvlib.irradiance.reindl() model generates NaNs when GHI = 0\n**Describe the bug**\r\nThe reindl function should give zero sky diffuse when GHI is zero. Instead it generates NaN or Inf values due to \"term3\" having a quotient that divides by GHI.  \r\n\r\n**Expected behavior**\r\nThe reindl function should result in zero sky diffuse when GHI is zero.\r\n\r\n\n", "hints_text": "Verified. Looks like an easy fix.\nVerified. Looks like an easy fix.", "created_at": "2021-01-29T20:53:24Z", "version": "0.8", "FAIL_TO_PASS": ["pvlib/tests/test_irradiance.py::test_reindl"], "PASS_TO_PASS": ["pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-300-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-300.0-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval2-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval3-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval4-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval5-expected5]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval6-expected6]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval7-expected7]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[asce-testval8-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-300-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-300.0-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval2-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval3-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval4-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval5-expected5]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval6-expected6]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval7-expected7]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[spencer-testval8-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-300-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-300.0-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval2-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval3-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval4-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval5-expected5]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval6-expected6]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval7-expected7]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[nrel-testval8-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-300-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-300.0-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval2-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval3-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval4-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval5-expected5]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval6-expected6]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval7-expected7]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation[pyephem-testval8-1383.636203]", "pvlib/tests/test_irradiance.py::test_get_extra_radiation_epoch_year", "pvlib/tests/test_irradiance.py::test_get_extra_radiation_nrel_numba", "pvlib/tests/test_irradiance.py::test_get_extra_radiation_invalid", "pvlib/tests/test_irradiance.py::test_grounddiffuse_simple_float", "pvlib/tests/test_irradiance.py::test_grounddiffuse_simple_series", "pvlib/tests/test_irradiance.py::test_grounddiffuse_albedo_0", "pvlib/tests/test_irradiance.py::test_grounddiffuse_albedo_invalid_surface", "pvlib/tests/test_irradiance.py::test_grounddiffuse_albedo_surface", "pvlib/tests/test_irradiance.py::test_isotropic_float", "pvlib/tests/test_irradiance.py::test_isotropic_series", "pvlib/tests/test_irradiance.py::test_klucher_series_float", "pvlib/tests/test_irradiance.py::test_klucher_series", "pvlib/tests/test_irradiance.py::test_haydavies", "pvlib/tests/test_irradiance.py::test_king", "pvlib/tests/test_irradiance.py::test_perez", "pvlib/tests/test_irradiance.py::test_perez_components", "pvlib/tests/test_irradiance.py::test_perez_arrays", "pvlib/tests/test_irradiance.py::test_perez_scalar", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[isotropic]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[klucher]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[haydavies]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[reindl]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[king]", "pvlib/tests/test_irradiance.py::test_sky_diffuse_zenith_close_to_90[perez]", "pvlib/tests/test_irradiance.py::test_get_sky_diffuse_invalid", "pvlib/tests/test_irradiance.py::test_campbell_norman", "pvlib/tests/test_irradiance.py::test_get_total_irradiance", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[isotropic]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[klucher]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[haydavies]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[reindl]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[king]", "pvlib/tests/test_irradiance.py::test_get_total_irradiance_scalars[perez]", "pvlib/tests/test_irradiance.py::test_poa_components", "pvlib/tests/test_irradiance.py::test_disc_value[93193-expected0]", "pvlib/tests/test_irradiance.py::test_disc_value[None-expected1]", "pvlib/tests/test_irradiance.py::test_disc_value[101325-expected2]", "pvlib/tests/test_irradiance.py::test_disc_overirradiance", "pvlib/tests/test_irradiance.py::test_disc_min_cos_zenith_max_zenith", "pvlib/tests/test_irradiance.py::test_dirint_value", "pvlib/tests/test_irradiance.py::test_dirint_nans", "pvlib/tests/test_irradiance.py::test_dirint_tdew", "pvlib/tests/test_irradiance.py::test_dirint_no_delta_kt", "pvlib/tests/test_irradiance.py::test_dirint_coeffs", "pvlib/tests/test_irradiance.py::test_dirint_min_cos_zenith_max_zenith", "pvlib/tests/test_irradiance.py::test_gti_dirint", "pvlib/tests/test_irradiance.py::test_erbs", "pvlib/tests/test_irradiance.py::test_erbs_min_cos_zenith_max_zenith", "pvlib/tests/test_irradiance.py::test_erbs_all_scalar", "pvlib/tests/test_irradiance.py::test_dirindex", "pvlib/tests/test_irradiance.py::test_dirindex_min_cos_zenith_max_zenith", "pvlib/tests/test_irradiance.py::test_dni", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[0-0-0-0-0-1]", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[30-180-30-180-0-1]", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[30-180-150-0-180--1]", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[90-0-30-60-75.5224878-0.25]", "pvlib/tests/test_irradiance.py::test_aoi_and_aoi_projection[90-0-30-170-119.4987042--0.4924038]", "pvlib/tests/test_irradiance.py::test_kt_kt_prime_factor", "pvlib/tests/test_irradiance.py::test_clearsky_index", "pvlib/tests/test_irradiance.py::test_clearness_index", "pvlib/tests/test_irradiance.py::test_clearness_index_zenith_independent"], "environment_setup_commit": "ef8ad2fee9840a77d14b0dfd17fc489dd85c9b91", "query": "pvlib.irradiance.reindl() model generates NaNs when GHI = 0\n**Describe the bug**\r\nThe reindl function should give zero sky diffuse when GHI is zero. Instead it generates NaN or Inf values due to \"term3\" having a quotient that divides by GHI.  \r\n\r\n**Expected behavior**\r\nThe reindl function should result in zero sky diffuse when GHI is zero.\r\n\r\n\npvlib.irradiance.reindl() model generates NaNs when GHI = 0\n**Describe the bug**\r\nThe reindl function should give zero sky diffuse when GHI is zero. Instead it generates NaN or Inf values due to \"term3\" having a quotient that divides by GHI.  \r\n\r\n**Expected behavior**\r\nThe reindl function should result in zero sky diffuse when GHI is zero.\r\n\r\n\n", "task_id": "pvlib__pvlib-python-1154"}, {"repo": "pylint-dev/astroid", "instance_id": "pylint-dev__astroid-934", "base_commit": "4cfd9b6d1003b9912ab94538e1dfa5d734f55251", "patch": "diff --git a/astroid/inference.py b/astroid/inference.py\n--- a/astroid/inference.py\n+++ b/astroid/inference.py\n@@ -309,6 +309,7 @@ def infer_attribute(self, context=None):\n         elif not context:\n             context = contextmod.InferenceContext()\n \n+        old_boundnode = context.boundnode\n         try:\n             context.boundnode = owner\n             yield from owner.igetattr(self.attrname, context)\n@@ -319,7 +320,7 @@ def infer_attribute(self, context=None):\n         ):\n             pass\n         finally:\n-            context.boundnode = None\n+            context.boundnode = old_boundnode\n     return dict(node=self, context=context)\n \n \n", "test_patch": "diff --git a/tests/unittest_inference.py b/tests/unittest_inference.py\n--- a/tests/unittest_inference.py\n+++ b/tests/unittest_inference.py\n@@ -3894,6 +3894,65 @@ class Clazz(metaclass=_Meta):\n         ).inferred()[0]\n         assert isinstance(cls, nodes.ClassDef) and cls.name == \"Clazz\"\n \n+    def test_infer_subclass_attr_outer_class(self):\n+        node = extract_node(\n+            \"\"\"\n+        class Outer:\n+            data = 123\n+\n+        class Test(Outer):\n+            pass\n+        Test.data\n+        \"\"\"\n+        )\n+        inferred = next(node.infer())\n+        assert isinstance(inferred, nodes.Const)\n+        assert inferred.value == 123\n+\n+    def test_infer_subclass_attr_inner_class_works_indirectly(self):\n+        node = extract_node(\n+            \"\"\"\n+        class Outer:\n+            class Inner:\n+                data = 123\n+        Inner = Outer.Inner\n+\n+        class Test(Inner):\n+            pass\n+        Test.data\n+        \"\"\"\n+        )\n+        inferred = next(node.infer())\n+        assert isinstance(inferred, nodes.Const)\n+        assert inferred.value == 123\n+\n+    def test_infer_subclass_attr_inner_class(self):\n+        clsdef_node, attr_node = extract_node(\n+            \"\"\"\n+        class Outer:\n+            class Inner:\n+                data = 123\n+\n+        class Test(Outer.Inner):\n+            pass\n+        Test  #@\n+        Test.data  #@\n+            \"\"\"\n+        )\n+        clsdef = next(clsdef_node.infer())\n+        assert isinstance(clsdef, nodes.ClassDef)\n+        inferred = next(clsdef.igetattr(\"data\"))\n+        assert isinstance(inferred, nodes.Const)\n+        assert inferred.value == 123\n+        # Inferring the value of .data via igetattr() worked before the\n+        # old_boundnode fixes in infer_subscript, so it should have been\n+        # possible to infer the subscript directly. It is the difference\n+        # between these two cases that led to the discovery of the cause of the\n+        # bug in https://github.com/PyCQA/astroid/issues/904\n+        inferred = next(attr_node.infer())\n+        assert isinstance(inferred, nodes.Const)\n+        assert inferred.value == 123\n+\n     def test_delayed_attributes_without_slots(self):\n         ast_node = extract_node(\n             \"\"\"\n", "problem_statement": "error during inference of class inheriting from another with `mod.Type` format\nConsider package a `level` with a class `Model` defined in `level`'s `__init__.py` file.\r\n\r\n```\r\nclass Model:\r\n    data: int = 1\r\n```\r\n\r\nIf a class `Test` inherits from `Model` as `class Test(Model)`, and `Model` comes from `from level import Model`,  then inferring `Test.data` works fine (below, A is an alias for astroid).\r\n\r\n<img width=\"248\" alt=\"Screen Shot 2021-02-19 at 09 41 09\" src=\"https://user-images.githubusercontent.com/2905588/108505730-9b3c1900-7296-11eb-8bb8-5b66b7253cf4.png\">\r\n\r\nHowever, if a `Test` inherits from `Model` as `class Test(level.Model)` and `level` comes from `import level`, then inference triggers an exception.\r\n\r\n<img width=\"784\" alt=\"Screen Shot 2021-02-19 at 09 42 09\" src=\"https://user-images.githubusercontent.com/2905588/108505815-beff5f00-7296-11eb-92a2-641be827e1f0.png\">\r\n\r\n\r\n\r\n\r\n\n", "hints_text": "", "created_at": "2021-04-07T23:44:25Z", "version": "2.5", "FAIL_TO_PASS": ["tests/unittest_inference.py::InferenceTest::test_infer_subclass_attr_inner_class"], "PASS_TO_PASS": ["tests/unittest_inference.py::InferenceUtilsTest::test_path_wrapper", "tests/unittest_inference.py::InferenceTest::test__new__", "tests/unittest_inference.py::InferenceTest::test__new__bound_methods", "tests/unittest_inference.py::InferenceTest::test_advanced_tupleassign_name_inference1", "tests/unittest_inference.py::InferenceTest::test_advanced_tupleassign_name_inference2", "tests/unittest_inference.py::InferenceTest::test_ancestors_inference", "tests/unittest_inference.py::InferenceTest::test_ancestors_inference2", "tests/unittest_inference.py::InferenceTest::test_args_default_inference1", "tests/unittest_inference.py::InferenceTest::test_args_default_inference2", "tests/unittest_inference.py::InferenceTest::test_aug_different_types_aug_not_implemented", "tests/unittest_inference.py::InferenceTest::test_aug_different_types_aug_not_implemented_rop_fallback", "tests/unittest_inference.py::InferenceTest::test_aug_different_types_augop_implemented", "tests/unittest_inference.py::InferenceTest::test_aug_different_types_no_method_implemented", "tests/unittest_inference.py::InferenceTest::test_aug_op_same_type_aug_implemented", "tests/unittest_inference.py::InferenceTest::test_aug_op_same_type_aug_not_implemented_normal_implemented", "tests/unittest_inference.py::InferenceTest::test_aug_op_same_type_not_implemented", "tests/unittest_inference.py::InferenceTest::test_aug_op_subtype_aug_op_is_implemented", "tests/unittest_inference.py::InferenceTest::test_aug_op_subtype_both_not_implemented", "tests/unittest_inference.py::InferenceTest::test_aug_op_subtype_normal_op_is_implemented", "tests/unittest_inference.py::InferenceTest::test_augassign", "tests/unittest_inference.py::InferenceTest::test_augop_supertypes_augop_implemented", "tests/unittest_inference.py::InferenceTest::test_augop_supertypes_none_implemented", "tests/unittest_inference.py::InferenceTest::test_augop_supertypes_normal_binop_implemented", "tests/unittest_inference.py::InferenceTest::test_augop_supertypes_not_implemented_returned_for_all", "tests/unittest_inference.py::InferenceTest::test_augop_supertypes_reflected_binop_implemented", "tests/unittest_inference.py::InferenceTest::test_bin_op_classes", "tests/unittest_inference.py::InferenceTest::test_bin_op_supertype_more_complicated_example", "tests/unittest_inference.py::InferenceTest::test_binary_op_custom_class", "tests/unittest_inference.py::InferenceTest::test_binary_op_float_div", "tests/unittest_inference.py::InferenceTest::test_binary_op_int_add", "tests/unittest_inference.py::InferenceTest::test_binary_op_int_bitand", "tests/unittest_inference.py::InferenceTest::test_binary_op_int_bitor", "tests/unittest_inference.py::InferenceTest::test_binary_op_int_bitxor", "tests/unittest_inference.py::InferenceTest::test_binary_op_int_shiftleft", "tests/unittest_inference.py::InferenceTest::test_binary_op_int_shiftright", "tests/unittest_inference.py::InferenceTest::test_binary_op_int_sub", "tests/unittest_inference.py::InferenceTest::test_binary_op_list_mul", "tests/unittest_inference.py::InferenceTest::test_binary_op_list_mul_int", "tests/unittest_inference.py::InferenceTest::test_binary_op_list_mul_none", "tests/unittest_inference.py::InferenceTest::test_binary_op_on_self", "tests/unittest_inference.py::InferenceTest::test_binary_op_other_type", "tests/unittest_inference.py::InferenceTest::test_binary_op_other_type_using_reflected_operands", "tests/unittest_inference.py::InferenceTest::test_binary_op_reflected_and_not_implemented_is_type_error", "tests/unittest_inference.py::InferenceTest::test_binary_op_str_mul", "tests/unittest_inference.py::InferenceTest::test_binary_op_tuple_add", "tests/unittest_inference.py::InferenceTest::test_binary_op_type_errors", "tests/unittest_inference.py::InferenceTest::test_binop_ambiguity", "tests/unittest_inference.py::InferenceTest::test_binop_different_types_no_method_implemented", "tests/unittest_inference.py::InferenceTest::test_binop_different_types_normal_not_implemented_and_reflected", "tests/unittest_inference.py::InferenceTest::test_binop_different_types_reflected_and_normal_not_implemented", "tests/unittest_inference.py::InferenceTest::test_binop_different_types_reflected_only", "tests/unittest_inference.py::InferenceTest::test_binop_different_types_unknown_bases", "tests/unittest_inference.py::InferenceTest::test_binop_inference_errors", "tests/unittest_inference.py::InferenceTest::test_binop_list_with_elts", "tests/unittest_inference.py::InferenceTest::test_binop_same_types", "tests/unittest_inference.py::InferenceTest::test_binop_subtype", "tests/unittest_inference.py::InferenceTest::test_binop_subtype_implemented_in_parent", "tests/unittest_inference.py::InferenceTest::test_binop_subtype_not_implemented", "tests/unittest_inference.py::InferenceTest::test_binop_supertype", "tests/unittest_inference.py::InferenceTest::test_binop_supertype_both_not_implemented", "tests/unittest_inference.py::InferenceTest::test_binop_supertype_rop_not_implemented", "tests/unittest_inference.py::InferenceTest::test_bool_value", "tests/unittest_inference.py::InferenceTest::test_bool_value_instances", "tests/unittest_inference.py::InferenceTest::test_bool_value_recursive", "tests/unittest_inference.py::InferenceTest::test_bool_value_variable", "tests/unittest_inference.py::InferenceTest::test_bound_method_inference", "tests/unittest_inference.py::InferenceTest::test_bt_ancestor_crash", "tests/unittest_inference.py::InferenceTest::test_builtin_help", "tests/unittest_inference.py::InferenceTest::test_builtin_inference_py3k", "tests/unittest_inference.py::InferenceTest::test_builtin_name_inference", "tests/unittest_inference.py::InferenceTest::test_builtin_open", "tests/unittest_inference.py::InferenceTest::test_builtin_types", "tests/unittest_inference.py::InferenceTest::test_bytes_subscript", "tests/unittest_inference.py::InferenceTest::test_callfunc_context_func", "tests/unittest_inference.py::InferenceTest::test_callfunc_context_lambda", "tests/unittest_inference.py::InferenceTest::test_callfunc_inference", "tests/unittest_inference.py::InferenceTest::test_class_inference", "tests/unittest_inference.py::InferenceTest::test_classmethod_inferred_by_context", "tests/unittest_inference.py::InferenceTest::test_context_call_for_context_managers", "tests/unittest_inference.py::InferenceTest::test_conversion_of_dict_methods", "tests/unittest_inference.py::InferenceTest::test_del1", "tests/unittest_inference.py::InferenceTest::test_del2", "tests/unittest_inference.py::InferenceTest::test_delayed_attributes_without_slots", "tests/unittest_inference.py::InferenceTest::test_dict_inference", "tests/unittest_inference.py::InferenceTest::test_dict_inference_for_multiple_starred", "tests/unittest_inference.py::InferenceTest::test_dict_inference_kwargs", "tests/unittest_inference.py::InferenceTest::test_dict_inference_unpack_repeated_key", "tests/unittest_inference.py::InferenceTest::test_dict_invalid_args", "tests/unittest_inference.py::InferenceTest::test_exc_ancestors", "tests/unittest_inference.py::InferenceTest::test_except_inference", "tests/unittest_inference.py::InferenceTest::test_f_arg_f", "tests/unittest_inference.py::InferenceTest::test_factory_method", "tests/unittest_inference.py::InferenceTest::test_factory_methods_cls_call", "tests/unittest_inference.py::InferenceTest::test_factory_methods_object_new_call", "tests/unittest_inference.py::InferenceTest::test_float_complex_ambiguity", "tests/unittest_inference.py::InferenceTest::test_frozenset_builtin_inference", "tests/unittest_inference.py::InferenceTest::test_function_inference", "tests/unittest_inference.py::InferenceTest::test_genexpr_bool_value", "tests/unittest_inference.py::InferenceTest::test_getattr_inference1", "tests/unittest_inference.py::InferenceTest::test_getattr_inference2", "tests/unittest_inference.py::InferenceTest::test_getattr_inference3", "tests/unittest_inference.py::InferenceTest::test_getattr_inference4", "tests/unittest_inference.py::InferenceTest::test_getitem_of_class_raised_type_error", "tests/unittest_inference.py::InferenceTest::test_im_func_unwrap", "tests/unittest_inference.py::InferenceTest::test_import_as", "tests/unittest_inference.py::InferenceTest::test_infer_abstract_property_return_values", "tests/unittest_inference.py::InferenceTest::test_infer_arg_called_object_when_used_as_index_is_uninferable", "tests/unittest_inference.py::InferenceTest::test_infer_arg_called_type_defined_in_outer_scope_is_uninferable", "tests/unittest_inference.py::InferenceTest::test_infer_arg_called_type_is_uninferable", "tests/unittest_inference.py::InferenceTest::test_infer_arg_called_type_when_used_as_index_is_uninferable", "tests/unittest_inference.py::InferenceTest::test_infer_arg_called_type_when_used_as_subscript_is_uninferable", "tests/unittest_inference.py::InferenceTest::test_infer_arguments", "tests/unittest_inference.py::InferenceTest::test_infer_call_result_crash", "tests/unittest_inference.py::InferenceTest::test_infer_call_result_invalid_dunder_call_on_instance", "tests/unittest_inference.py::InferenceTest::test_infer_cls_in_class_methods", "tests/unittest_inference.py::InferenceTest::test_infer_coercion_rules_for_floats_complex", "tests/unittest_inference.py::InferenceTest::test_infer_empty_nodes", "tests/unittest_inference.py::InferenceTest::test_infer_nested", "tests/unittest_inference.py::InferenceTest::test_infer_subclass_attr_inner_class_works_indirectly", "tests/unittest_inference.py::InferenceTest::test_infer_subclass_attr_instance_attr", "tests/unittest_inference.py::InferenceTest::test_infer_subclass_attr_instance_attr_indirect", "tests/unittest_inference.py::InferenceTest::test_infer_subclass_attr_outer_class", "tests/unittest_inference.py::InferenceTest::test_infer_variable_arguments", "tests/unittest_inference.py::InferenceTest::test_inference_restrictions", "tests/unittest_inference.py::InferenceTest::test_inferring_context_manager_skip_index_error", "tests/unittest_inference.py::InferenceTest::test_inferring_context_manager_unpacking_inference_error", "tests/unittest_inference.py::InferenceTest::test_inferring_with_contextlib_contextmanager", "tests/unittest_inference.py::InferenceTest::test_inferring_with_contextlib_contextmanager_failures", "tests/unittest_inference.py::InferenceTest::test_inferring_with_statement", "tests/unittest_inference.py::InferenceTest::test_inferring_with_statement_failures", "tests/unittest_inference.py::InferenceTest::test_infinite_loop_for_decorators", "tests/unittest_inference.py::InferenceTest::test_inner_value_redefined_by_subclass", "tests/unittest_inference.py::InferenceTest::test_instance_binary_operations", "tests/unittest_inference.py::InferenceTest::test_instance_binary_operations_multiple_methods", "tests/unittest_inference.py::InferenceTest::test_instance_binary_operations_parent", "tests/unittest_inference.py::InferenceTest::test_instance_slicing", "tests/unittest_inference.py::InferenceTest::test_instance_slicing_fails", "tests/unittest_inference.py::InferenceTest::test_instance_slicing_slices", "tests/unittest_inference.py::InferenceTest::test_invalid_slicing_primaries", "tests/unittest_inference.py::InferenceTest::test_invalid_subscripts", "tests/unittest_inference.py::InferenceTest::test_lambda_as_methods", "tests/unittest_inference.py::InferenceTest::test_list_builtin_inference", "tests/unittest_inference.py::InferenceTest::test_list_inference", "tests/unittest_inference.py::InferenceTest::test_listassign_name_inference", "tests/unittest_inference.py::InferenceTest::test_lookup_cond_branches", "tests/unittest_inference.py::InferenceTest::test_matmul", "tests/unittest_inference.py::InferenceTest::test_metaclass__getitem__", "tests/unittest_inference.py::InferenceTest::test_metaclass_custom_dunder_call", "tests/unittest_inference.py::InferenceTest::test_metaclass_custom_dunder_call_boundnode", "tests/unittest_inference.py::InferenceTest::test_metaclass_subclasses_arguments_are_classes_not_instances", "tests/unittest_inference.py::InferenceTest::test_metaclass_with_keyword_args", "tests/unittest_inference.py::InferenceTest::test_method_argument", "tests/unittest_inference.py::InferenceTest::test_module_inference", "tests/unittest_inference.py::InferenceTest::test_mul_list_supports__index__", "tests/unittest_inference.py::InferenceTest::test_mulassign_inference", "tests/unittest_inference.py::InferenceTest::test_name_bool_value", "tests/unittest_inference.py::InferenceTest::test_nested_contextmanager", "tests/unittest_inference.py::InferenceTest::test_no_infinite_ancestor_loop", "tests/unittest_inference.py::InferenceTest::test_no_runtime_error_in_repeat_inference", "tests/unittest_inference.py::InferenceTest::test_nonregr_absolute_import", "tests/unittest_inference.py::InferenceTest::test_nonregr_func_arg", "tests/unittest_inference.py::InferenceTest::test_nonregr_func_global", "tests/unittest_inference.py::InferenceTest::test_nonregr_getitem_empty_tuple", "tests/unittest_inference.py::InferenceTest::test_nonregr_inference_modifying_col_offset", "tests/unittest_inference.py::InferenceTest::test_nonregr_instance_attrs", "tests/unittest_inference.py::InferenceTest::test_nonregr_lambda_arg", "tests/unittest_inference.py::InferenceTest::test_nonregr_layed_dictunpack", "tests/unittest_inference.py::InferenceTest::test_nonregr_multi_referential_addition", "tests/unittest_inference.py::InferenceTest::test_pluggable_inference", "tests/unittest_inference.py::InferenceTest::test_property", "tests/unittest_inference.py::InferenceTest::test_python25_no_relative_import", "tests/unittest_inference.py::InferenceTest::test_scope_lookup_same_attributes", "tests/unittest_inference.py::InferenceTest::test_set_builtin_inference", "tests/unittest_inference.py::InferenceTest::test_simple_for", "tests/unittest_inference.py::InferenceTest::test_simple_for_genexpr", "tests/unittest_inference.py::InferenceTest::test_simple_subscript", "tests/unittest_inference.py::InferenceTest::test_simple_tuple", "tests/unittest_inference.py::InferenceTest::test_slicing_list", "tests/unittest_inference.py::InferenceTest::test_slicing_str", "tests/unittest_inference.py::InferenceTest::test_slicing_tuple", "tests/unittest_inference.py::InferenceTest::test_special_method_masquerading_as_another", "tests/unittest_inference.py::InferenceTest::test_starred_in_list_literal", "tests/unittest_inference.py::InferenceTest::test_starred_in_literals_inference_issues", "tests/unittest_inference.py::InferenceTest::test_starred_in_mapping_inference_issues", "tests/unittest_inference.py::InferenceTest::test_starred_in_mapping_literal", "tests/unittest_inference.py::InferenceTest::test_starred_in_mapping_literal_no_inference_possible", "tests/unittest_inference.py::InferenceTest::test_starred_in_mapping_literal_non_const_keys_values", "tests/unittest_inference.py::InferenceTest::test_starred_in_set_literal", "tests/unittest_inference.py::InferenceTest::test_starred_in_tuple_literal", "tests/unittest_inference.py::InferenceTest::test_stop_iteration_leak", "tests/unittest_inference.py::InferenceTest::test_str_methods", "tests/unittest_inference.py::InferenceTest::test_subscript_inference_error", "tests/unittest_inference.py::InferenceTest::test_subscript_multi_slice", "tests/unittest_inference.py::InferenceTest::test_subscript_multi_value", "tests/unittest_inference.py::InferenceTest::test_subscript_supports__index__", "tests/unittest_inference.py::InferenceTest::test_swap_assign_inference", "tests/unittest_inference.py::InferenceTest::test_tuple_builtin_inference", "tests/unittest_inference.py::InferenceTest::test_tuple_then_list", "tests/unittest_inference.py::InferenceTest::test_tupleassign_name_inference", "tests/unittest_inference.py::InferenceTest::test_two_parents_from_same_module", "tests/unittest_inference.py::InferenceTest::test_type__new__invalid_attrs", "tests/unittest_inference.py::InferenceTest::test_type__new__invalid_bases", "tests/unittest_inference.py::InferenceTest::test_type__new__invalid_mcs_argument", "tests/unittest_inference.py::InferenceTest::test_type__new__invalid_name", "tests/unittest_inference.py::InferenceTest::test_type__new__metaclass_and_ancestors_lookup", "tests/unittest_inference.py::InferenceTest::test_type__new__metaclass_lookup", "tests/unittest_inference.py::InferenceTest::test_type__new__not_enough_arguments", "tests/unittest_inference.py::InferenceTest::test_type__new__with_metaclass", "tests/unittest_inference.py::InferenceTest::test_unary_empty_type_errors", "tests/unittest_inference.py::InferenceTest::test_unary_not", "tests/unittest_inference.py::InferenceTest::test_unary_op_assignment", "tests/unittest_inference.py::InferenceTest::test_unary_op_classes", "tests/unittest_inference.py::InferenceTest::test_unary_op_instance_method_not_callable", "tests/unittest_inference.py::InferenceTest::test_unary_op_leaks_stop_iteration", "tests/unittest_inference.py::InferenceTest::test_unary_op_numbers", "tests/unittest_inference.py::InferenceTest::test_unary_operands", "tests/unittest_inference.py::InferenceTest::test_unary_type_errors", "tests/unittest_inference.py::InferenceTest::test_unary_type_errors_for_non_instance_objects", "tests/unittest_inference.py::InferenceTest::test_unbound_method_inference", "tests/unittest_inference.py::InferenceTest::test_unicode_methods", "tests/unittest_inference.py::GetattrTest::test_attribute_missing", "tests/unittest_inference.py::GetattrTest::test_attrname_not_string", "tests/unittest_inference.py::GetattrTest::test_default", "tests/unittest_inference.py::GetattrTest::test_lambda", "tests/unittest_inference.py::GetattrTest::test_lookup", "tests/unittest_inference.py::GetattrTest::test_yes_when_unknown", "tests/unittest_inference.py::HasattrTest::test_attribute_is_missing", "tests/unittest_inference.py::HasattrTest::test_attribute_is_not_missing", "tests/unittest_inference.py::HasattrTest::test_inference_errors", "tests/unittest_inference.py::HasattrTest::test_lambda", "tests/unittest_inference.py::BoolOpTest::test_bool_ops", "tests/unittest_inference.py::BoolOpTest::test_other_nodes", "tests/unittest_inference.py::BoolOpTest::test_yes_when_unknown", "tests/unittest_inference.py::TestCallable::test_callable", "tests/unittest_inference.py::TestCallable::test_callable_methods", "tests/unittest_inference.py::TestCallable::test_inference_errors", "tests/unittest_inference.py::TestCallable::test_not_callable", "tests/unittest_inference.py::TestBool::test_bool", "tests/unittest_inference.py::TestBool::test_bool_bool_special_method", "tests/unittest_inference.py::TestBool::test_bool_instance_not_callable", "tests/unittest_inference.py::TestType::test_type", "tests/unittest_inference.py::ArgumentsTest::test_args", "tests/unittest_inference.py::ArgumentsTest::test_defaults", "tests/unittest_inference.py::ArgumentsTest::test_fail_to_infer_args", "tests/unittest_inference.py::ArgumentsTest::test_kwargs", "tests/unittest_inference.py::ArgumentsTest::test_kwargs_access_by_name", "tests/unittest_inference.py::ArgumentsTest::test_kwargs_and_other_named_parameters", "tests/unittest_inference.py::ArgumentsTest::test_kwargs_are_overridden", "tests/unittest_inference.py::ArgumentsTest::test_kwonly_args", "tests/unittest_inference.py::ArgumentsTest::test_multiple_kwargs", "tests/unittest_inference.py::ArgumentsTest::test_multiple_starred_args", "tests/unittest_inference.py::SliceTest::test_slice", "tests/unittest_inference.py::SliceTest::test_slice_attributes", "tests/unittest_inference.py::SliceTest::test_slice_inference_error", "tests/unittest_inference.py::SliceTest::test_slice_type", "tests/unittest_inference.py::CallSiteTest::test_call_site", "tests/unittest_inference.py::CallSiteTest::test_call_site_starred_args", "tests/unittest_inference.py::CallSiteTest::test_call_site_valid_arguments", "tests/unittest_inference.py::CallSiteTest::test_duplicated_keyword_arguments", "tests/unittest_inference.py::ObjectDunderNewTest::test_object_dunder_new_is_inferred_if_decorator", "tests/unittest_inference.py::test_augassign_recursion", "tests/unittest_inference.py::test_infer_custom_inherit_from_property", "tests/unittest_inference.py::test_cannot_infer_call_result_for_builtin_methods", "tests/unittest_inference.py::test_unpack_dicts_in_assignment", "tests/unittest_inference.py::test_slice_inference_in_for_loops", "tests/unittest_inference.py::test_slice_inference_in_for_loops_not_working", "tests/unittest_inference.py::test_unpacking_starred_and_dicts_in_assignment", "tests/unittest_inference.py::test_unpacking_starred_empty_list_in_assignment", "tests/unittest_inference.py::test_regression_infinite_loop_decorator", "tests/unittest_inference.py::test_stop_iteration_in_int", "tests/unittest_inference.py::test_call_on_instance_with_inherited_dunder_call_method", "tests/unittest_inference.py::TestInferencePropagation::test_call_starargs_propagation", "tests/unittest_inference.py::TestInferencePropagation::test_call_kwargs_propagation", "tests/unittest_inference.py::test_limit_inference_result_amount", "tests/unittest_inference.py::test_attribute_inference_should_not_access_base_classes", "tests/unittest_inference.py::test_attribute_mro_object_inference", "tests/unittest_inference.py::test_inferred_sequence_unpacking_works", "tests/unittest_inference.py::test_recursion_error_inferring_slice", "tests/unittest_inference.py::test_exception_lookup_last_except_handler_wins", "tests/unittest_inference.py::test_exception_lookup_name_bound_in_except_handler", "tests/unittest_inference.py::test_builtin_inference_list_of_exceptions", "tests/unittest_inference.py::test_cannot_getattr_ann_assigns", "tests/unittest_inference.py::test_prevent_recursion_error_in_igetattr_and_context_manager_inference", "tests/unittest_inference.py::test_infer_context_manager_with_unknown_args", "tests/unittest_inference.py::test_subclass_of_exception[\\n", "tests/unittest_inference.py::test_ifexp_inference", "tests/unittest_inference.py::test_assert_last_function_returns_none_on_inference", "tests/unittest_inference.py::test_posonlyargs_inference", "tests/unittest_inference.py::test_infer_args_unpacking_of_self", "tests/unittest_inference.py::test_infer_exception_instance_attributes", "tests/unittest_inference.py::test_inference_is_limited_to_the_boundnode[\\n", "tests/unittest_inference.py::test_property_inference", "tests/unittest_inference.py::test_property_as_string", "tests/unittest_inference.py::test_property_callable_inference", "tests/unittest_inference.py::test_recursion_error_inferring_builtin_containers", "tests/unittest_inference.py::test_inferaugassign_picking_parent_instead_of_stmt", "tests/unittest_inference.py::test_classmethod_from_builtins_inferred_as_bound", "tests/unittest_inference.py::test_infer_dict_passes_context", "tests/unittest_inference.py::test_custom_decorators_for_classmethod_and_staticmethods[\\n", "tests/unittest_inference.py::test_dataclasses_subscript_inference_recursion_error_39", "tests/unittest_inference.py::test_self_reference_infer_does_not_trigger_recursion_error", "tests/unittest_inference.py::test_inferring_properties_multiple_time_does_not_mutate_locals_multiple_times", "tests/unittest_inference.py::test_getattr_fails_on_empty_values", "tests/unittest_inference.py::test_infer_first_argument_of_static_method_in_metaclass", "tests/unittest_inference.py::test_recursion_error_metaclass_monkeypatching", "tests/unittest_inference.py::test_allow_retrieving_instance_attrs_and_special_attrs_for_functions", "tests/unittest_inference.py::test_implicit_parameters_bound_method", "tests/unittest_inference.py::test_super_inference_of_abstract_property", "tests/unittest_inference.py::test_infer_generated_setter", "tests/unittest_inference.py::test_infer_list_of_uninferables_does_not_crash", "tests/unittest_inference.py::test_issue926_infer_stmts_referencing_same_name_is_not_uninferable", "tests/unittest_inference.py::test_issue926_binop_referencing_same_name_is_not_uninferable"], "environment_setup_commit": "d2ae3940a1a374253cc95d8fe83cb96f7a57e843", "query": "error during inference of class inheriting from another with `mod.Type` format\nConsider package a `level` with a class `Model` defined in `level`'s `__init__.py` file.\r\n\r\n```\r\nclass Model:\r\n    data: int = 1\r\n```\r\n\r\nIf a class `Test` inherits from `Model` as `class Test(Model)`, and `Model` comes from `from level import Model`,  then inferring `Test.data` works fine (below, A is an alias for astroid).\r\n\r\n<img width=\"248\" alt=\"Screen Shot 2021-02-19 at 09 41 09\" src=\"https://user-images.githubusercontent.com/2905588/108505730-9b3c1900-7296-11eb-8bb8-5b66b7253cf4.png\">\r\n\r\nHowever, if a `Test` inherits from `Model` as `class Test(level.Model)` and `level` comes from `import level`, then inference triggers an exception.\r\n\r\n<img width=\"784\" alt=\"Screen Shot 2021-02-19 at 09 42 09\" src=\"https://user-images.githubusercontent.com/2905588/108505815-beff5f00-7296-11eb-92a2-641be827e1f0.png\">\r\n\r\n\r\n\r\n\r\n\n", "task_id": "pylint-dev__astroid-934"}, {"repo": "pylint-dev/astroid", "instance_id": "pylint-dev__astroid-1268", "base_commit": "ce5cbce5ba11cdc2f8139ade66feea1e181a7944", "patch": "diff --git a/astroid/nodes/as_string.py b/astroid/nodes/as_string.py\n--- a/astroid/nodes/as_string.py\n+++ b/astroid/nodes/as_string.py\n@@ -36,6 +36,7 @@\n         MatchSingleton,\n         MatchStar,\n         MatchValue,\n+        Unknown,\n     )\n \n # pylint: disable=unused-argument\n@@ -643,6 +644,9 @@ def visit_property(self, node):\n     def visit_evaluatedobject(self, node):\n         return node.original.accept(self)\n \n+    def visit_unknown(self, node: \"Unknown\") -> str:\n+        return str(node)\n+\n \n def _import_string(names):\n     \"\"\"return a list of (name, asname) formatted as a string\"\"\"\n", "test_patch": "diff --git a/tests/unittest_nodes.py b/tests/unittest_nodes.py\n--- a/tests/unittest_nodes.py\n+++ b/tests/unittest_nodes.py\n@@ -306,6 +306,11 @@ def test_f_strings(self):\n         ast = abuilder.string_build(code)\n         self.assertEqual(ast.as_string().strip(), code.strip())\n \n+    @staticmethod\n+    def test_as_string_unknown() -> None:\n+        assert nodes.Unknown().as_string() == \"Unknown.Unknown()\"\n+        assert nodes.Unknown(lineno=1, col_offset=0).as_string() == \"Unknown.Unknown()\"\n+\n \n class _NodeTest(unittest.TestCase):\n     \"\"\"test transformation of If Node\"\"\"\n", "problem_statement": "'AsStringVisitor' object has no attribute 'visit_unknown'\n```python\r\n>>> import astroid\r\n>>> astroid.nodes.Unknown().as_string()\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv/lib/python3.9/site-packages/astroid/nodes/node_ng.py\", line 609, in as_string\r\n    return AsStringVisitor()(self)\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv/lib/python3.9/site-packages/astroid/nodes/as_string.py\", line 56, in __call__\r\n    return node.accept(self).replace(DOC_NEWLINE, \"\\n\")\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv/lib/python3.9/site-packages/astroid/nodes/node_ng.py\", line 220, in accept\r\n    func = getattr(visitor, \"visit_\" + self.__class__.__name__.lower())\r\nAttributeError: 'AsStringVisitor' object has no attribute 'visit_unknown'\r\n>>> \r\n```\r\n### `python -c \"from astroid import __pkginfo__; print(__pkginfo__.version)\"` output\r\n\r\n2.8.6-dev0\n", "hints_text": "Thank you for opening the issue.\nI don't believe `Unknown().as_string()` is ever called regularly. AFAIK it's only used during inference. What should the string representation of an `Unknown` node be? So not sure this needs to be addressed.\nProbably just `'Unknown'`.\nIt's mostly only a problem when we do something like this:\n\n```python\ninferred = infer(node)\nif inferred is not Uninferable:\n    if inferred.as_string().contains(some_value):\n        ...\n```\nSo for the most part, as long as it doesn't crash we're good.", "created_at": "2021-11-21T16:15:23Z", "version": "2.9", "FAIL_TO_PASS": ["tests/unittest_nodes.py::AsStringTest::test_as_string_unknown"], "PASS_TO_PASS": ["tests/unittest_nodes.py::AsStringTest::test_3k_annotations_and_metaclass", "tests/unittest_nodes.py::AsStringTest::test_3k_as_string", "tests/unittest_nodes.py::AsStringTest::test_as_string", "tests/unittest_nodes.py::AsStringTest::test_as_string_for_list_containing_uninferable", "tests/unittest_nodes.py::AsStringTest::test_class_def", "tests/unittest_nodes.py::AsStringTest::test_ellipsis", "tests/unittest_nodes.py::AsStringTest::test_f_strings", "tests/unittest_nodes.py::AsStringTest::test_frozenset_as_string", "tests/unittest_nodes.py::AsStringTest::test_func_signature_issue_185", "tests/unittest_nodes.py::AsStringTest::test_int_attribute", "tests/unittest_nodes.py::AsStringTest::test_module2_as_string", "tests/unittest_nodes.py::AsStringTest::test_module_as_string", "tests/unittest_nodes.py::AsStringTest::test_operator_precedence", "tests/unittest_nodes.py::AsStringTest::test_slice_and_subscripts", "tests/unittest_nodes.py::AsStringTest::test_slices", "tests/unittest_nodes.py::AsStringTest::test_tuple_as_string", "tests/unittest_nodes.py::AsStringTest::test_varargs_kwargs_as_string", "tests/unittest_nodes.py::IfNodeTest::test_block_range", "tests/unittest_nodes.py::IfNodeTest::test_if_elif_else_node", "tests/unittest_nodes.py::IfNodeTest::test_if_sys_guard", "tests/unittest_nodes.py::IfNodeTest::test_if_typing_guard", "tests/unittest_nodes.py::TryExceptNodeTest::test_block_range", "tests/unittest_nodes.py::TryFinallyNodeTest::test_block_range", "tests/unittest_nodes.py::TryExceptFinallyNodeTest::test_block_range", "tests/unittest_nodes.py::ImportNodeTest::test_absolute_import", "tests/unittest_nodes.py::ImportNodeTest::test_as_string", "tests/unittest_nodes.py::ImportNodeTest::test_bad_import_inference", "tests/unittest_nodes.py::ImportNodeTest::test_conditional", "tests/unittest_nodes.py::ImportNodeTest::test_conditional_import", "tests/unittest_nodes.py::ImportNodeTest::test_from_self_resolve", "tests/unittest_nodes.py::ImportNodeTest::test_import_self_resolve", "tests/unittest_nodes.py::ImportNodeTest::test_more_absolute_import", "tests/unittest_nodes.py::ImportNodeTest::test_real_name", "tests/unittest_nodes.py::CmpNodeTest::test_as_string", "tests/unittest_nodes.py::ConstNodeTest::test_bool", "tests/unittest_nodes.py::ConstNodeTest::test_complex", "tests/unittest_nodes.py::ConstNodeTest::test_copy", "tests/unittest_nodes.py::ConstNodeTest::test_float", "tests/unittest_nodes.py::ConstNodeTest::test_int", "tests/unittest_nodes.py::ConstNodeTest::test_none", "tests/unittest_nodes.py::ConstNodeTest::test_str", "tests/unittest_nodes.py::ConstNodeTest::test_str_kind", "tests/unittest_nodes.py::ConstNodeTest::test_unicode", "tests/unittest_nodes.py::NameNodeTest::test_assign_to_true", "tests/unittest_nodes.py::TestNamedExprNode::test_frame", "tests/unittest_nodes.py::TestNamedExprNode::test_scope", "tests/unittest_nodes.py::AnnAssignNodeTest::test_as_string", "tests/unittest_nodes.py::AnnAssignNodeTest::test_complex", "tests/unittest_nodes.py::AnnAssignNodeTest::test_primitive", "tests/unittest_nodes.py::AnnAssignNodeTest::test_primitive_without_initial_value", "tests/unittest_nodes.py::ArgumentsNodeTC::test_kwoargs", "tests/unittest_nodes.py::ArgumentsNodeTC::test_positional_only", "tests/unittest_nodes.py::UnboundMethodNodeTest::test_no_super_getattr", "tests/unittest_nodes.py::BoundMethodNodeTest::test_is_property", "tests/unittest_nodes.py::AliasesTest::test_aliases", "tests/unittest_nodes.py::Python35AsyncTest::test_async_await_keywords", "tests/unittest_nodes.py::Python35AsyncTest::test_asyncfor_as_string", "tests/unittest_nodes.py::Python35AsyncTest::test_asyncwith_as_string", "tests/unittest_nodes.py::Python35AsyncTest::test_await_as_string", "tests/unittest_nodes.py::Python35AsyncTest::test_decorated_async_def_as_string", "tests/unittest_nodes.py::ContextTest::test_list_del", "tests/unittest_nodes.py::ContextTest::test_list_load", "tests/unittest_nodes.py::ContextTest::test_list_store", "tests/unittest_nodes.py::ContextTest::test_starred_load", "tests/unittest_nodes.py::ContextTest::test_starred_store", "tests/unittest_nodes.py::ContextTest::test_subscript_del", "tests/unittest_nodes.py::ContextTest::test_subscript_load", "tests/unittest_nodes.py::ContextTest::test_subscript_store", "tests/unittest_nodes.py::ContextTest::test_tuple_load", "tests/unittest_nodes.py::ContextTest::test_tuple_store", "tests/unittest_nodes.py::test_unknown", "tests/unittest_nodes.py::test_type_comments_with", "tests/unittest_nodes.py::test_type_comments_for", "tests/unittest_nodes.py::test_type_coments_assign", "tests/unittest_nodes.py::test_type_comments_invalid_expression", "tests/unittest_nodes.py::test_type_comments_invalid_function_comments", "tests/unittest_nodes.py::test_type_comments_function", "tests/unittest_nodes.py::test_type_comments_arguments", "tests/unittest_nodes.py::test_type_comments_posonly_arguments", "tests/unittest_nodes.py::test_correct_function_type_comment_parent", "tests/unittest_nodes.py::test_is_generator_for_yield_assignments", "tests/unittest_nodes.py::test_f_string_correct_line_numbering", "tests/unittest_nodes.py::test_assignment_expression", "tests/unittest_nodes.py::test_assignment_expression_in_functiondef", "tests/unittest_nodes.py::test_get_doc", "tests/unittest_nodes.py::test_parse_fstring_debug_mode", "tests/unittest_nodes.py::test_parse_type_comments_with_proper_parent", "tests/unittest_nodes.py::test_const_itered", "tests/unittest_nodes.py::test_is_generator_for_yield_in_while", "tests/unittest_nodes.py::test_is_generator_for_yield_in_if", "tests/unittest_nodes.py::test_is_generator_for_yield_in_aug_assign"], "environment_setup_commit": "0d1211558670cfefd95b39984b8d5f7f34837f32", "query": "'AsStringVisitor' object has no attribute 'visit_unknown'\n```python\r\n>>> import astroid\r\n>>> astroid.nodes.Unknown().as_string()\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv/lib/python3.9/site-packages/astroid/nodes/node_ng.py\", line 609, in as_string\r\n    return AsStringVisitor()(self)\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv/lib/python3.9/site-packages/astroid/nodes/as_string.py\", line 56, in __call__\r\n    return node.accept(self).replace(DOC_NEWLINE, \"\\n\")\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv/lib/python3.9/site-packages/astroid/nodes/node_ng.py\", line 220, in accept\r\n    func = getattr(visitor, \"visit_\" + self.__class__.__name__.lower())\r\nAttributeError: 'AsStringVisitor' object has no attribute 'visit_unknown'\r\n>>> \r\n```\r\n### `python -c \"from astroid import __pkginfo__; print(__pkginfo__.version)\"` output\r\n\r\n2.8.6-dev0\n", "task_id": "pylint-dev__astroid-1268"}, {"repo": "pylint-dev/astroid", "instance_id": "pylint-dev__astroid-946", "base_commit": "2c109eec6fe3f972c6e8c637fe956431a0d7685c", "patch": "diff --git a/astroid/builder.py b/astroid/builder.py\n--- a/astroid/builder.py\n+++ b/astroid/builder.py\n@@ -67,7 +67,7 @@ def _can_assign_attr(node, attrname):\n     else:\n         if slots and attrname not in {slot.value for slot in slots}:\n             return False\n-    return True\n+    return node.qname() != \"builtins.object\"\n \n \n class AstroidBuilder(raw_building.InspectBuilder):\n", "test_patch": "diff --git a/tests/unittest_builder.py b/tests/unittest_builder.py\n--- a/tests/unittest_builder.py\n+++ b/tests/unittest_builder.py\n@@ -28,7 +28,7 @@\n \n import pytest\n \n-from astroid import builder, exceptions, manager, nodes, test_utils, util\n+from astroid import Instance, builder, exceptions, manager, nodes, test_utils, util\n \n from . import resources\n \n@@ -476,6 +476,53 @@ def A_assign_type(self):\n         self.assertIn(\"assign_type\", lclass.locals)\n         self.assertIn(\"type\", lclass.locals)\n \n+    def test_infer_can_assign_regular_object(self):\n+        mod = builder.parse(\n+            \"\"\"\n+            class A:\n+                pass\n+            a = A()\n+            a.value = \"is set\"\n+            a.other = \"is set\"\n+        \"\"\"\n+        )\n+        obj = list(mod.igetattr(\"a\"))\n+        self.assertEqual(len(obj), 1)\n+        obj = obj[0]\n+        self.assertIsInstance(obj, Instance)\n+        self.assertIn(\"value\", obj.instance_attrs)\n+        self.assertIn(\"other\", obj.instance_attrs)\n+\n+    def test_infer_can_assign_has_slots(self):\n+        mod = builder.parse(\n+            \"\"\"\n+            class A:\n+                __slots__ = ('value',)\n+            a = A()\n+            a.value = \"is set\"\n+            a.other = \"not set\"\n+        \"\"\"\n+        )\n+        obj = list(mod.igetattr(\"a\"))\n+        self.assertEqual(len(obj), 1)\n+        obj = obj[0]\n+        self.assertIsInstance(obj, Instance)\n+        self.assertIn(\"value\", obj.instance_attrs)\n+        self.assertNotIn(\"other\", obj.instance_attrs)\n+\n+    def test_infer_can_assign_no_classdict(self):\n+        mod = builder.parse(\n+            \"\"\"\n+            a = object()\n+            a.value = \"not set\"\n+        \"\"\"\n+        )\n+        obj = list(mod.igetattr(\"a\"))\n+        self.assertEqual(len(obj), 1)\n+        obj = obj[0]\n+        self.assertIsInstance(obj, Instance)\n+        self.assertNotIn(\"value\", obj.instance_attrs)\n+\n     def test_augassign_attr(self):\n         builder.parse(\n             \"\"\"\ndiff --git a/tests/unittest_scoped_nodes.py b/tests/unittest_scoped_nodes.py\n--- a/tests/unittest_scoped_nodes.py\n+++ b/tests/unittest_scoped_nodes.py\n@@ -1430,7 +1430,9 @@ class A:\n             pass\n         class B:\n             pass\n-        scope = object()\n+        class Scope:\n+            pass\n+        scope = Scope()\n         scope.A = A\n         scope.B = B\n         class C(scope.A, scope.B):\n", "problem_statement": "Delayed attribute assignment to object() may cause incorrect inference of instance attributes\n@cdce8p: `aiohttp` and `VLCTelnet` turned out to be red herrings. This case fails on current stable versions:\r\n\r\n```python\r\nclass Example:\r\n    def prev(self):\r\n        pass\r\n    def next(self):\r\n        pass\r\n    def other(self):\r\n        pass\r\n\r\n\r\nex = Example()\r\nex.other()  # no warning\r\nex.prev()   # no warning\r\nex.next()   # no warning\r\n\r\nimport typing\r\n\r\nex.other()  # no warning\r\nex.prev()   # false-positive: not-callable\r\nex.next()   # false-positive: not-callable\r\n```\r\n\r\n_Originally posted by @nelfin in https://github.com/PyCQA/astroid/issues/927#issuecomment-818626368_\r\n\r\nI've bisected this down to 78d5537. Pylint 2.3.1 passes this case with 20a7ae5 and fails with 78d5537\n", "hints_text": "Minimal case:\r\n\r\n```python\r\nclass Example:\r\n    def func(self):\r\n        pass\r\n\r\n\r\nwhatthe = object()\r\nwhatthe.func = None\r\n\r\nex = Example()\r\nex.func()   # false-positive: not-callable\r\n```\nNot caused by 78d5537, just revealed by it. `typing` imported `collections`, `collections.OrderedDict` had an ambiguously inferred case that was previously broken by failure with positional-only arguments which was fixed in 78d5537.", "created_at": "2021-04-13T12:30:06Z", "version": "2.5", "FAIL_TO_PASS": ["tests/unittest_builder.py::BuilderTest::test_infer_can_assign_no_classdict"], "PASS_TO_PASS": ["tests/unittest_builder.py::FromToLineNoTest::test_callfunc_lineno", "tests/unittest_builder.py::FromToLineNoTest::test_class_lineno", "tests/unittest_builder.py::FromToLineNoTest::test_decorated_function_lineno", "tests/unittest_builder.py::FromToLineNoTest::test_for_while_lineno", "tests/unittest_builder.py::FromToLineNoTest::test_if_lineno", "tests/unittest_builder.py::FromToLineNoTest::test_try_except_lineno", "tests/unittest_builder.py::FromToLineNoTest::test_try_finally_25_lineno", "tests/unittest_builder.py::FromToLineNoTest::test_try_finally_lineno", "tests/unittest_builder.py::FromToLineNoTest::test_with_lineno", "tests/unittest_builder.py::BuilderTest::test_asstuple", "tests/unittest_builder.py::BuilderTest::test_augassign_attr", "tests/unittest_builder.py::BuilderTest::test_build_constants", "tests/unittest_builder.py::BuilderTest::test_data_build_invalid_x_escape", "tests/unittest_builder.py::BuilderTest::test_data_build_null_bytes", "tests/unittest_builder.py::BuilderTest::test_future_imports", "tests/unittest_builder.py::BuilderTest::test_gen_expr_var_scope", "tests/unittest_builder.py::BuilderTest::test_globals", "tests/unittest_builder.py::BuilderTest::test_infer_can_assign_has_slots", "tests/unittest_builder.py::BuilderTest::test_infer_can_assign_regular_object", "tests/unittest_builder.py::BuilderTest::test_inferred_build", "tests/unittest_builder.py::BuilderTest::test_inferred_dont_pollute", "tests/unittest_builder.py::BuilderTest::test_inspect_build0", "tests/unittest_builder.py::BuilderTest::test_inspect_build1", "tests/unittest_builder.py::BuilderTest::test_inspect_build3", "tests/unittest_builder.py::BuilderTest::test_inspect_build_type_object", "tests/unittest_builder.py::BuilderTest::test_inspect_transform_module", "tests/unittest_builder.py::BuilderTest::test_missing_file", "tests/unittest_builder.py::BuilderTest::test_missing_newline", "tests/unittest_builder.py::BuilderTest::test_newstyle_detection", "tests/unittest_builder.py::BuilderTest::test_no_future_imports", "tests/unittest_builder.py::BuilderTest::test_not_implemented", "tests/unittest_builder.py::BuilderTest::test_object", "tests/unittest_builder.py::BuilderTest::test_package_name", "tests/unittest_builder.py::BuilderTest::test_socket_build", "tests/unittest_builder.py::BuilderTest::test_two_future_imports", "tests/unittest_builder.py::BuilderTest::test_yield_parent", "tests/unittest_builder.py::FileBuildTest::test_class_base_props", "tests/unittest_builder.py::FileBuildTest::test_class_basenames", "tests/unittest_builder.py::FileBuildTest::test_class_instance_attrs", "tests/unittest_builder.py::FileBuildTest::test_class_locals", "tests/unittest_builder.py::FileBuildTest::test_function_base_props", "tests/unittest_builder.py::FileBuildTest::test_function_locals", "tests/unittest_builder.py::FileBuildTest::test_method_base_props", "tests/unittest_builder.py::FileBuildTest::test_method_locals", "tests/unittest_builder.py::FileBuildTest::test_module_base_props", "tests/unittest_builder.py::FileBuildTest::test_module_locals", "tests/unittest_builder.py::FileBuildTest::test_unknown_encoding", "tests/unittest_builder.py::test_module_build_dunder_file", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_dict_interface", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_file_stream_api", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_file_stream_in_memory", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_file_stream_physical", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_getattr", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_import_1", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_import_2", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_module_getattr", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_public_names", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_relative_to_absolute_name", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_relative_to_absolute_name_beyond_top_level", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_special_attributes", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_stream_api", "tests/unittest_scoped_nodes.py::ModuleNodeTest::test_wildcard_import_names", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_argnames", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_decorator_builtin_descriptors", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_default_value", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_dict_interface", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_dunder_class_local_to_classmethod", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_dunder_class_local_to_function", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_dunder_class_local_to_method", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_format_args", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_format_args_keyword_only_args", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_four_args", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_func_instance_attr", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_igetattr", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_is_abstract", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_is_abstract_decorated", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_is_generator", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_is_method", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_lambda_pytype", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_lambda_qname", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_method_init_subclass", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_navigation", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_return_annotation_is_not_the_last", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_return_nothing", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_special_attributes", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_type_builtin_descriptor_subclasses", "tests/unittest_scoped_nodes.py::ClassNodeTest::test__bases__attribute", "tests/unittest_scoped_nodes.py::ClassNodeTest::test__mro__attribute", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_add_metaclass", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_all_ancestors_need_slots", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_ancestors", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_class_extra_decorators", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_class_extra_decorators_frame_is_not_class", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_class_extra_decorators_only_assignment_names_are_considered", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_class_extra_decorators_only_callfunc_are_considered", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_class_extra_decorators_only_same_name_considered", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_class_getattr", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_class_keywords", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_classmethod_attributes", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_cls_special_attributes_1", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_cls_special_attributes_2", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_dict_interface", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_duplicate_bases_namedtuple", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_extra_decorators_only_class_level_assignments", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_function_with_decorator_lineno", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_generator_from_infer_call_result_parent", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_getattr_from_grandpa", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_getattr_method_transform", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_has_dynamic_getattr", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_implicit_metaclass", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_implicit_metaclass_lookup", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_inner_classes", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_instance_attr_ancestors", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_instance_bound_method_lambdas", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_instance_bound_method_lambdas_2", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_instance_getattr", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_instance_getattr_with_class_attr", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_instance_special_attributes", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_kite_graph", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_local_attr_ancestors", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_local_attr_invalid_mro", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_local_attr_mro", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_metaclass_error", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_metaclass_lookup", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_metaclass_lookup_inference_errors", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_metaclass_lookup_using_same_class", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_metaclass_type", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_metaclass_yes_leak", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_methods", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_generic_1", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_generic_2", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_generic_3", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_generic_4", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_generic_5", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_generic_6", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_generic_7", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_generic_error_1", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_generic_error_2", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_with_attribute_classes", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_mro_with_factories", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_navigation", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_no_infinite_metaclass_loop", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_no_infinite_metaclass_loop_with_redefine", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_nonregr_infer_callresult", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_slots", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_slots_added_dynamically_still_inferred", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_slots_empty_list_of_slots", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_slots_for_dict_keys", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_slots_taken_from_parents", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_type", "tests/unittest_scoped_nodes.py::ClassNodeTest::test_type_three_arguments", "tests/unittest_scoped_nodes.py::test_metaclass_cannot_infer_call_yields_an_instance", "tests/unittest_scoped_nodes.py::test_posonlyargs_python_38[\\ndef", "tests/unittest_scoped_nodes.py::test_posonlyargs_default_value"], "environment_setup_commit": "d2ae3940a1a374253cc95d8fe83cb96f7a57e843", "query": "Delayed attribute assignment to object() may cause incorrect inference of instance attributes\n@cdce8p: `aiohttp` and `VLCTelnet` turned out to be red herrings. This case fails on current stable versions:\r\n\r\n```python\r\nclass Example:\r\n    def prev(self):\r\n        pass\r\n    def next(self):\r\n        pass\r\n    def other(self):\r\n        pass\r\n\r\n\r\nex = Example()\r\nex.other()  # no warning\r\nex.prev()   # no warning\r\nex.next()   # no warning\r\n\r\nimport typing\r\n\r\nex.other()  # no warning\r\nex.prev()   # false-positive: not-callable\r\nex.next()   # false-positive: not-callable\r\n```\r\n\r\n_Originally posted by @nelfin in https://github.com/PyCQA/astroid/issues/927#issuecomment-818626368_\r\n\r\nI've bisected this down to 78d5537. Pylint 2.3.1 passes this case with 20a7ae5 and fails with 78d5537\n", "task_id": "pylint-dev__astroid-946"}, {"repo": "pylint-dev/astroid", "instance_id": "pylint-dev__astroid-1262", "base_commit": "e840a7c54d3d8b5be2db1e66f34a5368c64fc3f7", "patch": "diff --git a/astroid/nodes/scoped_nodes.py b/astroid/nodes/scoped_nodes.py\n--- a/astroid/nodes/scoped_nodes.py\n+++ b/astroid/nodes/scoped_nodes.py\n@@ -389,10 +389,8 @@ class Module(LocalsDictNodeNG):\n \n     :type: int or None\n     \"\"\"\n-    lineno = 0\n+    lineno: Literal[0] = 0\n     \"\"\"The line that this node appears on in the source code.\n-\n-    :type: int or None\n     \"\"\"\n \n     # attributes below are set by the builder module or by raw factories\n@@ -469,7 +467,6 @@ class Module(LocalsDictNodeNG):\n     )\n     _other_other_fields = (\"locals\", \"globals\")\n \n-    lineno: None\n     col_offset: None\n     end_lineno: None\n     end_col_offset: None\n@@ -512,7 +509,6 @@ def __init__(\n         self.file = file\n         self.path = path\n         self.package = package\n-        self.parent = parent\n         self.pure_python = pure_python\n         self.locals = self.globals = {}\n         \"\"\"A map of the name of a local variable to the node defining the local.\n@@ -526,6 +522,8 @@ def __init__(\n         \"\"\"\n         self.future_imports = set()\n \n+        super().__init__(lineno=0, parent=parent)\n+\n     # pylint: enable=redefined-builtin\n \n     def postinit(self, body=None):\n", "test_patch": "diff --git a/tests/unittest_nodes_lineno.py b/tests/unittest_nodes_lineno.py\n--- a/tests/unittest_nodes_lineno.py\n+++ b/tests/unittest_nodes_lineno.py\n@@ -2,6 +2,7 @@\n \n import pytest\n \n+import astroid\n from astroid import builder, nodes\n from astroid.const import PY38_PLUS, PY39_PLUS, PY310_PLUS\n \n@@ -1221,3 +1222,14 @@ class X(Parent, var=42):\n         assert (c1.body[0].lineno, c1.body[0].col_offset) == (4, 4)\n         assert (c1.body[0].end_lineno, c1.body[0].end_col_offset) == (4, 8)\n         # fmt: on\n+\n+    @staticmethod\n+    def test_end_lineno_module() -> None:\n+        \"\"\"Tests for Module\"\"\"\n+        code = \"\"\"print()\"\"\"\n+        module = astroid.parse(code)\n+        assert isinstance(module, nodes.Module)\n+        assert module.lineno == 0\n+        assert module.col_offset is None\n+        assert module.end_lineno is None\n+        assert module.end_col_offset is None\n", "problem_statement": "``nodes.Module`` don't have a ``end_lineno`` and ``end_col_offset``\n### Steps to reproduce\r\n\r\n```python\r\nimport astroid\r\n\r\ncode = \"\"\"\r\n    print(\"a module\")\r\n    \"\"\"\r\n\r\nmodule = astroid.parse(code)\r\nprint(module.end_lineno)\r\nprint(module.end_col_offset)\r\n```\r\n\r\n### Current behavior\r\n\r\n`AttributeError` on both of the last lines.\r\n\r\n### Expected behavior\r\n\r\n@cdce8p Let me know if I misunderstood you, but I thought we wanted these to be accessible on all nodes, just initialised as `None`.\r\nIf that was not the case, I would make the case to do so as it allows you to do `node.end_lineno` without running in to `AttributeError`'s.\r\n\r\n### Version\r\n\r\nLatest `main`.\r\n\n", "hints_text": "", "created_at": "2021-11-19T16:46:31Z", "version": "2.9", "FAIL_TO_PASS": ["tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_module"], "PASS_TO_PASS": ["tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_container", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_name", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_attribute", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_call", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_assignment", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_mix_stmts", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_mix_nodes", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_ops", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_if", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_for", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_const", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_function", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_dict", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_try", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_subscript", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_import", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_with", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_while", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_string", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_comprehension", "tests/unittest_nodes_lineno.py::TestLinenoColOffset::test_end_lineno_class"], "environment_setup_commit": "0d1211558670cfefd95b39984b8d5f7f34837f32", "query": "``nodes.Module`` don't have a ``end_lineno`` and ``end_col_offset``\n### Steps to reproduce\r\n\r\n```python\r\nimport astroid\r\n\r\ncode = \"\"\"\r\n    print(\"a module\")\r\n    \"\"\"\r\n\r\nmodule = astroid.parse(code)\r\nprint(module.end_lineno)\r\nprint(module.end_col_offset)\r\n```\r\n\r\n### Current behavior\r\n\r\n`AttributeError` on both of the last lines.\r\n\r\n### Expected behavior\r\n\r\n@cdce8p Let me know if I misunderstood you, but I thought we wanted these to be accessible on all nodes, just initialised as `None`.\r\nIf that was not the case, I would make the case to do so as it allows you to do `node.end_lineno` without running in to `AttributeError`'s.\r\n\r\n### Version\r\n\r\nLatest `main`.\r\n\n", "task_id": "pylint-dev__astroid-1262"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-866", "base_commit": "b4b44acbf1ddcaf03df16210aac46cb3a8acd6b9", "patch": "diff --git a/pydicom/pixel_data_handlers/numpy_handler.py b/pydicom/pixel_data_handlers/numpy_handler.py\n--- a/pydicom/pixel_data_handlers/numpy_handler.py\n+++ b/pydicom/pixel_data_handlers/numpy_handler.py\n@@ -242,14 +242,20 @@ def get_pixeldata(ds, read_only=False):\n     # Check that the actual length of the pixel data is as expected\n     actual_length = len(ds.PixelData)\n     # Correct for the trailing NULL byte padding for odd length data\n+\n     padded_expected_len = expected_len + expected_len % 2\n     if actual_length < padded_expected_len:\n-        raise ValueError(\n-            \"The length of the pixel data in the dataset doesn't match the \"\n-            \"expected amount ({0} vs. {1} bytes). The dataset may be \"\n-            \"corrupted or there may be an issue with the pixel data handler.\"\n-            .format(actual_length, padded_expected_len)\n-        )\n+        if actual_length == expected_len:\n+            warnings.warn(\n+                \"The pixel data length is odd and misses a padding byte.\")\n+        else:\n+            raise ValueError(\n+                \"The length of the pixel data in the dataset ({} bytes) \"\n+                \"doesn't match the expected length ({} bytes). \"\n+                \"The dataset may be corrupted or there may be an issue \"\n+                \"with the pixel data handler.\"\n+                .format(actual_length, padded_expected_len)\n+            )\n     elif actual_length > padded_expected_len:\n         # PS 3.5, Section 8.1.1\n         msg = (\n", "test_patch": "diff --git a/pydicom/tests/test_numpy_pixel_data.py b/pydicom/tests/test_numpy_pixel_data.py\n--- a/pydicom/tests/test_numpy_pixel_data.py\n+++ b/pydicom/tests/test_numpy_pixel_data.py\n@@ -986,13 +986,23 @@ def test_bad_length_raises(self):\n         # Too short\n         ds.PixelData = ds.PixelData[:-1]\n         msg = (\n-            r\"The length of the pixel data in the dataset doesn't match the \"\n-            r\"expected amount \\(479999 vs. 480000 bytes\\). The dataset may be \"\n-            r\"corrupted or there may be an issue with the pixel data handler.\"\n+            r\"The length of the pixel data in the dataset \\(479999 bytes\\) \"\n+            r\"doesn't match the expected length \\(480000 bytes\\). \"\n+            r\"The dataset may be corrupted or there may be an issue \"\n+            r\"with the pixel data handler.\"\n         )\n         with pytest.raises(ValueError, match=msg):\n             get_pixeldata(ds)\n \n+    def test_missing_padding_warns(self):\n+        \"\"\"A warning shall be issued if the padding for odd data is missing.\"\"\"\n+        ds = dcmread(EXPL_8_3_1F_ODD)\n+        # remove the padding byte\n+        ds.PixelData = ds.PixelData[:-1]\n+        msg = \"The pixel data length is odd and misses a padding byte.\"\n+        with pytest.warns(UserWarning, match=msg):\n+            get_pixeldata(ds)\n+\n     def test_change_photometric_interpretation(self):\n         \"\"\"Test get_pixeldata changes PhotometricInterpretation if required.\"\"\"\n         def to_rgb(ds):\n", "problem_statement": "Handle odd-sized dicoms with warning\n<!-- Instructions For Filing a Bug: https://github.com/pydicom/pydicom/blob/master/CONTRIBUTING.md#filing-bugs -->\r\n\r\n#### Description\r\n<!-- Example: Attribute Error thrown when printing (0x0010, 0x0020) patient Id> 0-->\r\n\r\nWe have some uncompressed dicoms with an odd number of pixel bytes (saved by older versions of pydicom actually). \r\n\r\nWhen we re-open with pydicom 1.2.2, we're now unable to extract the image, due to the change made by https://github.com/pydicom/pydicom/pull/601\r\n\r\nWould it be possible to emit a warning instead of rejecting the dicom for such cases?\r\n\r\n#### Version\r\n1.2.2\n", "hints_text": "I agree that this would be sensible. Checking the mentioned PR, I also found that we had [discussed this briefly](https://github.com/pydicom/pydicom/pull/601#issuecomment-374710953) (with no result, obviously).\r\n@darcymason - I think this is another case of \"try to handle broken DICOM, only raise in 'strict' mode\", especially as these images have been written by pydicom itself...\nunsponsored plug: I like reviewable.io to keep track of what comments are resolved/unresolved/just-a-nit before merging. Looks like its free for open source repos.\n> @darcymason - I think this is another case of \"try to handle broken DICOM, only raise in 'strict' mode\", especially as these images have been written by pydicom itself...\r\n\r\nYes, I agree, for sure.  Even without it being written by pydicom, it is better to be tolerant on reading.", "created_at": "2019-06-21T12:02:05Z", "version": "1.2", "FAIL_TO_PASS": ["pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_bad_length_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_missing_padding_warns"], "PASS_TO_PASS": ["pydicom/tests/test_numpy_pixel_data.py::test_unsupported_syntaxes", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_environment", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_supported_dataset", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_jpeg_dcmtk.dcm-data0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/JPEG-lossy.dcm-data1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_jpeg_gdcm.dcm-data2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/MR_small_jpeg_ls_lossless.dcm-data3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/emri_small_jpeg_2k_lossless.dcm-data4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/JPEG2000.dcm-data5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/MR_small_RLE.dcm-data6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_pixel_array_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_environment", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_unsupported_syntax_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_dataset_pixel_array_handler_needs_convert", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_jpeg_dcmtk.dcm-data0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/JPEG-lossy.dcm-data1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_jpeg_gdcm.dcm-data2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/MR_small_jpeg_ls_lossless.dcm-data3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/emri_small_jpeg_2k_lossless.dcm-data4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/JPEG2000.dcm-data5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/MR_small_RLE.dcm-data6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_pixel_array_8bit_un_signed", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_pixel_array_16bit_un_signed", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_pixel_array_32bit_un_signed", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_1sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_1sample_2frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_3sample_1frame_odd_size", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_3sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_3sample_2frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/liver_1frame.dcm-data0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/liver.dcm-data1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/OBXXXX1A.dcm-data2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_small_odd.dcm-data3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/OBXXXX1A_2frame.dcm-data4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb.dcm-data5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_2frame.dcm-data6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/MR_small.dcm-data7]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/emri_small.dcm-data8]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_16bit.dcm-data9]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_16bit_2frame.dcm-data10]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/rtdose_1frame.dcm-data11]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/rtdose.dcm-data12]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_32bit.dcm-data13]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_32bit_2frame.dcm-data14]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_1bit_1sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_1bit_1sample_3frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_1sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_1sample_1frame_padded", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_1sample_10frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_3sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_3sample_2frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_1sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_1sample_15frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_3sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_3sample_2frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/liver_1frame.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/liver_expb_1frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/liver.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/liver_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/OBXXXX1A.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/OBXXXX1A_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/OBXXXX1A_2frame.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/OBXXXX1A_expb_2frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_2frame.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_expb_2frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/MR_small.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/MR_small_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/emri_small.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/emri_small_big_endian.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_16bit.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_expb_16bit.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_16bit_2frame.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_expb_16bit_2frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/rtdose_1frame.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/rtdose_expb_1frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/rtdose.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/rtdose_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_32bit.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_expb_32bit.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_32bit_2frame.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__1.2/pydicom/data/test_files/SC_rgb_expb_32bit_2frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_endianness_not_set", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_read_only", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_no_pixel_data_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_unknown_pixel_representation_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_unsupported_syntaxes_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_change_photometric_interpretation", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_array_read_only", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_array_read_only_bit_packed", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[-output0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00-output1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x01-output2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x02-output3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x04-output4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x08-output5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x10-output6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[@-output8]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x80-output9]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\xaa-output10]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\xf0-output11]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x0f-output12]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\xff-output13]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00\\x00-output14]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00\\x01-output15]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00\\x80-output16]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00\\xff-output17]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x01\\x80-output18]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x80\\x80-output19]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\xff\\x80-output20]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[-input0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00-input1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x01-input2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x02-input3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x04-input4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x08-input5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x10-input6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[@-input8]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x80-input9]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\xaa-input10]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\xf0-input11]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x0f-input12]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\xff-input13]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00\\x00-input14]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00\\x01-input15]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00\\x80-input16]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00\\xff-input17]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x01\\x80-input18]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x80\\x80-input19]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\xff\\x80-input20]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_non_binary_input", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_non_array_input", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00@-input0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x10-input2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x08-input3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x04-input4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x02-input5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x01-input6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x80-input7]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[@-input8]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x10-input10]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x08-input11]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x04-input12]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x02-input13]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x01-input14]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[-input15]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_functional"], "environment_setup_commit": "b4b44acbf1ddcaf03df16210aac46cb3a8acd6b9", "query": "Handle odd-sized dicoms with warning\n<!-- Instructions For Filing a Bug: https://github.com/pydicom/pydicom/blob/master/CONTRIBUTING.md#filing-bugs -->\r\n\r\n#### Description\r\n<!-- Example: Attribute Error thrown when printing (0x0010, 0x0020) patient Id> 0-->\r\n\r\nWe have some uncompressed dicoms with an odd number of pixel bytes (saved by older versions of pydicom actually). \r\n\r\nWhen we re-open with pydicom 1.2.2, we're now unable to extract the image, due to the change made by https://github.com/pydicom/pydicom/pull/601\r\n\r\nWould it be possible to emit a warning instead of rejecting the dicom for such cases?\r\n\r\n#### Version\r\n1.2.2\n", "task_id": "pydicom__pydicom-866"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-1069", "base_commit": "30ac743bcaedbc06f0e0d5cef590cb173756eb2d", "patch": "diff --git a/pydicom/pixel_data_handlers/util.py b/pydicom/pixel_data_handlers/util.py\n--- a/pydicom/pixel_data_handlers/util.py\n+++ b/pydicom/pixel_data_handlers/util.py\n@@ -112,6 +112,9 @@ def apply_color_lut(arr, ds=None, palette=None):\n             \"Table Module is not currently supported\"\n         )\n \n+    if 'RedPaletteColorLookupTableDescriptor' not in ds:\n+        raise ValueError(\"No suitable Palette Color Lookup Table Module found\")\n+\n     # All channels are supposed to be identical\n     lut_desc = ds.RedPaletteColorLookupTableDescriptor\n     # A value of 0 = 2^16 entries\n", "test_patch": "diff --git a/pydicom/tests/test_handler_util.py b/pydicom/tests/test_handler_util.py\n--- a/pydicom/tests/test_handler_util.py\n+++ b/pydicom/tests/test_handler_util.py\n@@ -1150,6 +1150,15 @@ def test_first_map_negative(self):\n         assert [60160, 25600, 37376] == list(rgb[arr == 130][0])\n         assert ([60160, 25600, 37376] == rgb[arr == 130]).all()\n \n+    def test_unchanged(self):\n+        \"\"\"Test dataset with no LUT is unchanged.\"\"\"\n+        # Regression test for #1068\n+        ds = dcmread(MOD_16, force=True)\n+        assert 'RedPaletteColorLookupTableDescriptor' not in ds\n+        msg = r\"No suitable Palette Color Lookup Table Module found\"\n+        with pytest.raises(ValueError, match=msg):\n+            apply_color_lut(ds.pixel_array, ds)\n+\n \n @pytest.mark.skipif(not HAVE_NP, reason=\"Numpy is not available\")\n class TestNumpy_ExpandSegmentedLUT(object):\n", "problem_statement": "apply_color_lut() incorrect exception when missing RedPaletteColorLUTDescriptor\n**Describe the bug**\r\n`AttributeError` when used on a dataset without `RedPaletteColorLookupTableDescriptor `\r\n\r\n**Expected behavior**\r\nShould raise `ValueError` for consistency with later exceptions\r\n\r\n**Steps To Reproduce**\r\n```python\r\nfrom pydicom.pixel_data_handlers.util import apply_color_lut\r\nds = dcmread(\"CT_small.dcm\")\r\narr = ds.apply_color_lut(arr, ds)\r\n```\r\n```\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \".../pydicom/pixel_data_handlers/util.py\", line 116, in apply_color_lut\r\n    lut_desc = ds.RedPaletteColorLookupTableDescriptor\r\n  File \".../pydicom/dataset.py\", line 768, in __getattr__\r\n    return object.__getattribute__(self, name)\r\nAttributeError: 'FileDataset' object has no attribute 'RedPaletteColorLookupTableDescriptor'\r\n```\n", "hints_text": "", "created_at": "2020-03-14T00:02:52Z", "version": "1.4", "FAIL_TO_PASS": ["pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_unchanged"], "PASS_TO_PASS": ["pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_unknown_pixel_representation_raises", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_unknown_bits_allocated_raises", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_unsupported_dtypes", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[1-0-False-uint8]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[1-1-False-uint8]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[8-0-False-uint8]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[8-1-False-int8]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[16-0-False-uint16]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[16-1-False-int16]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[32-0-False-uint32]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[32-1-False-int32]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[32-0-True-float32]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_supported_dtypes[64-0-True-float64]", "pydicom/tests/test_handler_util.py::TestNumpy_PixelDtype::test_byte_swapping", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_reference_1frame_1sample", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_reference_1frame_3sample", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_reference_2frame_1sample", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_reference_2frame_3sample", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_1frame_1sample", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_1frame_3sample_0conf", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_1frame_3sample_1conf", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_2frame_1sample", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_2frame_3sample_0conf", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_2frame_3sample_1conf", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_compressed_syntaxes_0conf", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_compressed_syntaxes_1conf", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_uncompressed_syntaxes", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_invalid_nr_frames_raises", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_invalid_samples_raises", "pydicom/tests/test_handler_util.py::TestNumpy_ReshapePixelArray::test_invalid_planar_conf_raises", "pydicom/tests/test_handler_util.py::TestNumpy_ConvertColourSpace::test_unknown_current_raises", "pydicom/tests/test_handler_util.py::TestNumpy_ConvertColourSpace::test_unknown_desired_raises", "pydicom/tests/test_handler_util.py::TestNumpy_ConvertColourSpace::test_current_is_desired[RGB-RGB]", "pydicom/tests/test_handler_util.py::TestNumpy_ConvertColourSpace::test_current_is_desired[YBR_FULL-YBR_FULL]", "pydicom/tests/test_handler_util.py::TestNumpy_ConvertColourSpace::test_current_is_desired[YBR_FULL-YBR_FULL_422]", "pydicom/tests/test_handler_util.py::TestNumpy_ConvertColourSpace::test_current_is_desired[YBR_FULL_422-YBR_FULL_422]", "pydicom/tests/test_handler_util.py::TestNumpy_ConvertColourSpace::test_current_is_desired[YBR_FULL_422-YBR_FULL]", "pydicom/tests/test_handler_util.py::TestNumpy_ConvertColourSpace::test_rgb_ybr_rgb_single_frame", "pydicom/tests/test_handler_util.py::TestNumpy_ConvertColourSpace::test_rgb_ybr_rgb_multi_frame", "pydicom/tests/test_handler_util.py::TestNumpy_DtypeCorrectedForEndianness::test_byte_swapping", "pydicom/tests/test_handler_util.py::TestNumpy_DtypeCorrectedForEndianness::test_no_endian_raises", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape0-1-length0]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape1-1-length1]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape2-1-length2]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape3-1-length3]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape4-1-length4]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape5-1-length5]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape6-1-length6]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape7-1-length7]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape8-1-length8]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape9-8-length9]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape10-8-length10]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape11-8-length11]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape12-8-length12]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape13-8-length13]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape14-8-length14]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape15-16-length15]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape16-16-length16]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape17-16-length17]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape18-16-length18]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape19-16-length19]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape20-32-length20]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape21-32-length21]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape22-32-length22]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape23-32-length23]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape24-32-length24]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape25-1-length25]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape26-1-length26]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape27-1-length27]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape28-1-length28]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape29-1-length29]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape30-1-length30]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape31-1-length31]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape32-1-length32]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape33-1-length33]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape34-8-length34]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape35-8-length35]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape36-8-length36]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape37-8-length37]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape38-8-length38]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape39-8-length39]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape40-16-length40]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape41-16-length41]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape42-16-length42]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape43-32-length43]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape44-32-length44]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape45-32-length45]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape46-1-length46]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape47-1-length47]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape48-1-length48]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape49-1-length49]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape50-1-length50]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape51-1-length51]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape52-1-length52]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape53-1-length53]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape54-1-length54]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape55-8-length55]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape56-8-length56]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape57-8-length57]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape58-16-length58]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape59-16-length59]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape60-16-length60]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape61-32-length61]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape62-32-length62]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_bytes[shape63-32-length63]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape0-1-length0]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape1-1-length1]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape2-1-length2]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape3-1-length3]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape4-1-length4]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape5-1-length5]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape6-1-length6]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape7-1-length7]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape8-1-length8]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape9-8-length9]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape10-8-length10]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape11-8-length11]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape12-8-length12]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape13-8-length13]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape14-8-length14]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape15-16-length15]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape16-16-length16]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape17-16-length17]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape18-16-length18]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape19-16-length19]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape20-32-length20]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape21-32-length21]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape22-32-length22]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape23-32-length23]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape24-32-length24]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape25-1-length25]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape26-1-length26]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape27-1-length27]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape28-1-length28]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape29-1-length29]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape30-1-length30]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape31-1-length31]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape32-1-length32]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape33-1-length33]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape34-8-length34]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape35-8-length35]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape36-8-length36]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape37-8-length37]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape38-8-length38]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape39-8-length39]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape40-16-length40]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape41-16-length41]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape42-16-length42]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape43-32-length43]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape44-32-length44]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape45-32-length45]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape46-1-length46]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape47-1-length47]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape48-1-length48]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape49-1-length49]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape50-1-length50]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape51-1-length51]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape52-1-length52]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape53-1-length53]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape54-1-length54]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape55-8-length55]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape56-8-length56]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape57-8-length57]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape58-16-length58]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape59-16-length59]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape60-16-length60]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape61-32-length61]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape62-32-length62]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_in_pixels[shape63-32-length63]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape0-1-length0]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape1-1-length1]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape2-1-length2]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape3-1-length3]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape4-1-length4]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape5-1-length5]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape6-1-length6]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape7-1-length7]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape8-1-length8]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape9-8-length9]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape10-8-length10]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape11-8-length11]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape12-8-length12]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape13-8-length13]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape14-8-length14]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape15-16-length15]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape16-16-length16]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape17-16-length17]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape18-16-length18]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape19-16-length19]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape20-32-length20]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape21-32-length21]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape22-32-length22]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape23-32-length23]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape24-32-length24]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape25-1-length25]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape26-1-length26]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape27-1-length27]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape28-1-length28]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape29-1-length29]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape30-1-length30]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape31-1-length31]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape32-1-length32]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape33-1-length33]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape34-8-length34]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape35-8-length35]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape36-8-length36]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape37-8-length37]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape38-8-length38]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape39-8-length39]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape40-16-length40]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape41-16-length41]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape42-16-length42]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape43-32-length43]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape44-32-length44]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape45-32-length45]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape46-1-length46]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape47-1-length47]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape48-1-length48]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape49-1-length49]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape50-1-length50]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape51-1-length51]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape52-1-length52]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape53-1-length53]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape54-1-length54]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape55-8-length55]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape56-8-length56]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape57-8-length57]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape58-16-length58]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape59-16-length59]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape60-16-length60]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape61-32-length61]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape62-32-length62]", "pydicom/tests/test_handler_util.py::TestGetExpectedLength::test_length_ybr_422[shape63-32-length63]", "pydicom/tests/test_handler_util.py::TestNumpy_ModalityLUT::test_slope_intercept", "pydicom/tests/test_handler_util.py::TestNumpy_ModalityLUT::test_lut_sequence", "pydicom/tests/test_handler_util.py::TestNumpy_ModalityLUT::test_lut_sequence_zero_entries", "pydicom/tests/test_handler_util.py::TestNumpy_ModalityLUT::test_unchanged", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_neither_ds_nor_palette_raises", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_palette_unknown_raises", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_palette_unavailable_raises", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_supplemental_raises", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_invalid_lut_bit_depth_raises", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_unequal_lut_length_raises", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_no_palette_color", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_uint08_16", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_uint08_16_2frame", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_uint16_16_segmented_litle", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_uint16_16_segmented_big", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_16_allocated_8_entries", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_alpha", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_well_known_palette", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_first_map_positive", "pydicom/tests/test_handler_util.py::TestNumpy_PaletteColor::test_first_map_negative", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_discrete", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_linear", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_indirect_08", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_indirect_16", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_palettes_spring", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_palettes_summer", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_palettes_fall", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_palettes_winter", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_first_linear_raises", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_first_indirect_raises", "pydicom/tests/test_handler_util.py::TestNumpy_ExpandSegmentedLUT::test_unknown_opcode_raises", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_voi_single_view", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_voi_multi_view", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_voi_multi_frame", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_voi_zero_entries", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_voi_uint8", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_voi_uint16", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_voi_int8", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_voi_int16", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_voi_bad_depth", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_single_view", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_multi_view", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_uint8", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_uint16", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_uint32", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_int8", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_int16", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_int32", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_multi_frame", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_rescale", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_modality_lut", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_bad_photometric_interp", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_bad_parameters", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_window_bad_index", "pydicom/tests/test_handler_util.py::TestNumpy_VOILUT::test_unchanged"], "environment_setup_commit": "5098c9147fadcb3e5918487036867931435adeb8", "query": "apply_color_lut() incorrect exception when missing RedPaletteColorLUTDescriptor\n**Describe the bug**\r\n`AttributeError` when used on a dataset without `RedPaletteColorLookupTableDescriptor `\r\n\r\n**Expected behavior**\r\nShould raise `ValueError` for consistency with later exceptions\r\n\r\n**Steps To Reproduce**\r\n```python\r\nfrom pydicom.pixel_data_handlers.util import apply_color_lut\r\nds = dcmread(\"CT_small.dcm\")\r\narr = ds.apply_color_lut(arr, ds)\r\n```\r\n```\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \".../pydicom/pixel_data_handlers/util.py\", line 116, in apply_color_lut\r\n    lut_desc = ds.RedPaletteColorLookupTableDescriptor\r\n  File \".../pydicom/dataset.py\", line 768, in __getattr__\r\n    return object.__getattribute__(self, name)\r\nAttributeError: 'FileDataset' object has no attribute 'RedPaletteColorLookupTableDescriptor'\r\n```\n", "task_id": "pydicom__pydicom-1069"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-1458", "base_commit": "8da0b9b215ebfad5756051c891def88e426787e7", "patch": "diff --git a/pydicom/pixel_data_handlers/numpy_handler.py b/pydicom/pixel_data_handlers/numpy_handler.py\n--- a/pydicom/pixel_data_handlers/numpy_handler.py\n+++ b/pydicom/pixel_data_handlers/numpy_handler.py\n@@ -43,7 +43,9 @@\n | (0028,0100) | BitsAllocated             | 1    | 1, 8, 16, 32, | Required |\n |             |                           |      | 64            |          |\n +-------------+---------------------------+------+---------------+----------+\n-| (0028,0103) | PixelRepresentation       | 1    | 0, 1          | Required |\n+| (0028,0101) | BitsStored                | 1    | 1, 8, 12, 16  | Optional |\n++-------------+---------------------------+------+---------------+----------+\n+| (0028,0103) | PixelRepresentation       | 1C   | 0, 1          | Optional |\n +-------------+---------------------------+------+---------------+----------+\n \n \"\"\"\n@@ -284,16 +286,28 @@ def get_pixeldata(ds: \"Dataset\", read_only: bool = False) -> \"np.ndarray\":\n             \"the dataset\"\n         )\n \n+    # Attributes required by both Floating Point Image Pixel Module Attributes\n+    # and Image Pixel Description Macro Attributes\n     required_elements = [\n-        'BitsAllocated', 'Rows', 'Columns', 'PixelRepresentation',\n+        'BitsAllocated', 'Rows', 'Columns',\n         'SamplesPerPixel', 'PhotometricInterpretation'\n     ]\n+    if px_keyword[0] == 'PixelData':\n+        # Attributess required by Image Pixel Description Macro Attributes\n+        required_elements.extend(['PixelRepresentation', 'BitsStored'])\n     missing = [elem for elem in required_elements if elem not in ds]\n     if missing:\n         raise AttributeError(\n             \"Unable to convert the pixel data as the following required \"\n             \"elements are missing from the dataset: \" + \", \".join(missing)\n         )\n+    if ds.SamplesPerPixel > 1:\n+        if not hasattr(ds, 'PlanarConfiguration'):\n+            raise AttributeError(\n+                \"Unable to convert the pixel data as the following \"\n+                \"conditionally required element is missing from the dataset: \"\n+                \"PlanarConfiguration\"\n+            )\n \n     # May be Pixel Data, Float Pixel Data or Double Float Pixel Data\n     pixel_data = getattr(ds, px_keyword[0])\n", "test_patch": "diff --git a/pydicom/tests/test_numpy_pixel_data.py b/pydicom/tests/test_numpy_pixel_data.py\n--- a/pydicom/tests/test_numpy_pixel_data.py\n+++ b/pydicom/tests/test_numpy_pixel_data.py\n@@ -26,6 +26,8 @@\n * PlanarConfiguration\n \"\"\"\n \n+from copy import deepcopy\n+\n import pytest\n \n from pydicom import config\n@@ -1068,6 +1070,7 @@ def test_endianness_not_set(self):\n         ds.Rows = 10\n         ds.Columns = 10\n         ds.BitsAllocated = 16\n+        ds.BitsStored = 16\n         ds.PixelRepresentation = 0\n         ds.SamplesPerPixel = 1\n         ds.PhotometricInterpretation = 'MONOCHROME2'\n@@ -1105,16 +1108,60 @@ def test_no_pixel_data_raises(self):\n         with pytest.raises(AttributeError, match=msg):\n             get_pixeldata(ds)\n \n-    def test_missing_required_elem(self):\n+    def test_missing_required_elem_pixel_data_monochrome(self):\n         \"\"\"Tet get_pixeldata raises if dataset missing required element.\"\"\"\n-        ds = dcmread(EXPL_16_1_1F)\n-        del ds.BitsAllocated\n+        required_attrs = (\n+            'BitsAllocated',\n+            'BitsStored',\n+            'Rows',\n+            'Columns',\n+            'SamplesPerPixel',\n+            'PhotometricInterpretation',\n+            'PixelRepresentation',\n+        )\n+        for attr in required_attrs:\n+            ds = dcmread(EXPL_16_1_1F)\n+            delattr(ds, attr)\n+            msg = (\n+                r\"Unable to convert the pixel data as the following required \"\n+                r\"elements are missing from the dataset: {}\".format(attr)\n+            )\n+            with pytest.raises(AttributeError, match=msg):\n+                get_pixeldata(ds)\n+\n+    def test_missing_required_elem_pixel_data_color(self):\n+        \"\"\"Tet get_pixeldata raises if dataset missing required element.\"\"\"\n+        ds = dcmread(EXPL_8_3_1F)\n+        del ds.Rows\n+        del ds.Columns\n+        msg = (\n+            r\"Unable to convert the pixel data as the following required \"\n+            r\"elements are missing from the dataset: Rows, Columns\"\n+        )\n+        with pytest.raises(AttributeError, match=msg):\n+            get_pixeldata(ds)\n+\n+    def test_missing_conditionally_required_elem_pixel_data_color(self):\n+        \"\"\"Tet get_pixeldata raises if dataset missing required element.\"\"\"\n+        ds = dcmread(EXPL_8_3_1F)\n+        del ds.PlanarConfiguration\n+        msg = (\n+            r\"Unable to convert the pixel data as the following conditionally \"\n+            r\"required element is missing from the dataset: \"\n+            r\"PlanarConfiguration\"\n+        )\n+        with pytest.raises(AttributeError, match=msg):\n+            get_pixeldata(ds)\n+\n+    def test_missing_required_elem_float_pixel_data_monochrome(self):\n+        \"\"\"Tet get_pixeldata raises if dataset missing required element.\"\"\"\n+        ds = dcmread(IMPL_32_1_1F)\n+        ds.FloatPixelData = ds.PixelData\n+        del ds.PixelData\n         del ds.Rows\n-        del ds.SamplesPerPixel\n         msg = (\n             r\"Unable to convert the pixel data as the following required \"\n-            r\"elements are missing from the dataset: BitsAllocated, Rows, \"\n-            r\"SamplesPerPixel\"\n+            r\"elements are missing from the dataset: Rows\"\n         )\n         with pytest.raises(AttributeError, match=msg):\n             get_pixeldata(ds)\n", "problem_statement": "Pixel Representation attribute should be optional for pixel data handler\n**Describe the bug**\r\nThe NumPy pixel data handler currently [requires the Pixel Representation attribute](https://github.com/pydicom/pydicom/blob/8da0b9b215ebfad5756051c891def88e426787e7/pydicom/pixel_data_handlers/numpy_handler.py#L46). This is problematic, because in case of Float Pixel Data or Double Float Pixel Data the attribute shall be absent. Compare [Floating Point Image Pixel Module Attributes](http://dicom.nema.org/medical/dicom/current/output/chtml/part03/sect_C.7.6.24.html) versus [Image Pixel Description Macro Attributes](http://dicom.nema.org/medical/dicom/current/output/chtml/part03/sect_C.7.6.3.html#table_C.7-11c)\r\n\r\n**Expected behavior**\r\nI would expect the `Dataset.pixel_array` property to be able to decode a Float Pixel Data or Double Float Pixel Data element without presence of the Pixel Representation element in the metadata.\r\n\r\n**Steps To Reproduce**\r\n```python\r\nimport numpy as np\r\nfrom pydicom.dataset import Dataset, FileMetaDataset\r\n\r\n\r\nds = Dataset()\r\nds.file_meta = FileMetaDataset()\r\nds.file_meta.TransferSyntaxUID = '1.2.840.10008.1.2.1'\r\n\r\nds.BitsAllocated = 32\r\nds.SamplesPerPixel = 1\r\nds.Rows = 5\r\nds.Columns = 5\r\nds.PhotometricInterpretation = 'MONOCHROME2'\r\n\r\npixel_array = np.zeros((ds.Rows, ds.Columns), dtype=np.float32)\r\nds.FloatPixelData = pixel_array.flatten().tobytes()\r\n\r\nnp.array_equal(ds.pixel_array, pixel_array)\r\n```\n", "hints_text": "", "created_at": "2021-08-04T15:22:07Z", "version": "2.2", "FAIL_TO_PASS": ["pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_missing_required_elem_pixel_data_monochrome", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_missing_conditionally_required_elem_pixel_data_color"], "PASS_TO_PASS": ["pydicom/tests/test_numpy_pixel_data.py::test_unsupported_syntaxes", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_environment", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_supported_dataset", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/SC_rgb_jpeg_dcmtk.dcm-data0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/JPEG-lossy.dcm-data1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/SC_rgb_jpeg_gdcm.dcm-data2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/MR_small_jpeg_ls_lossless.dcm-data3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/n/fs/.pydicom/data/emri_small_jpeg_2k_lossless.dcm-data4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/JPEG2000.dcm-data5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/MR_small_RLE.dcm-data6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NoNumpyHandler::test_pixel_array_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_environment", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_unsupported_syntax_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_dataset_pixel_array_handler_needs_convert", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_dataset_pixel_array_no_pixels", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/SC_rgb_jpeg_dcmtk.dcm-data0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/JPEG-lossy.dcm-data1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/SC_rgb_jpeg_gdcm.dcm-data2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/MR_small_jpeg_ls_lossless.dcm-data3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/n/fs/.pydicom/data/emri_small_jpeg_2k_lossless.dcm-data4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/JPEG2000.dcm-data5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_can_access_unsupported_dataset[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/MR_small_RLE.dcm-data6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_pixel_array_8bit_un_signed", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_decompress_using_handler[numpy]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_decompress_using_handler[NumPy]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_decompress_using_handler[np]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_decompress_using_handler[np_handler]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_decompress_using_handler[numpy_handler]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_pixel_array_16bit_un_signed", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_pixel_array_32bit_un_signed", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_1sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_1sample_2frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_3sample_1frame_odd_size", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_3sample_1frame_ybr422", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_3sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_8bit_3sample_2frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/liver_1frame.dcm-data0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/liver.dcm-data1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/OBXXXX1A.dcm-data2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/SC_rgb_small_odd.dcm-data3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/SC_ybr_full_422_uncompressed.dcm-data4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/OBXXXX1A_2frame.dcm-data5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/SC_rgb.dcm-data6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/SC_rgb_2frame.dcm-data7]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/MR_small.dcm-data8]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/emri_small.dcm-data9]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/SC_rgb_16bit.dcm-data10]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/SC_rgb_16bit_2frame.dcm-data11]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/rtdose_1frame.dcm-data12]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/rtdose.dcm-data13]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/SC_rgb_32bit.dcm-data14]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_properties[/n/fs/.pydicom/data/SC_rgb_32bit_2frame.dcm-data15]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_1bit_1sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_1bit_1sample_3frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_1sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_1sample_1frame_padded", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_1sample_10frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_3sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_16bit_3sample_2frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_1sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_1sample_15frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_3sample_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_3sample_2frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_float_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_32bit_float_15frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_64bit_float_1frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_little_64bit_float_15frame", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/liver_1frame.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/liver_expb_1frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/liver.dcm-/n/fs/.pydicom/data/liver_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/OBXXXX1A.dcm-/n/fs/.pydicom/data/OBXXXX1A_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/OBXXXX1A_2frame.dcm-/n/fs/.pydicom/data/OBXXXX1A_expb_2frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/SC_rgb.dcm-/n/fs/.pydicom/data/SC_rgb_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/SC_rgb_2frame.dcm-/n/fs/.pydicom/data/SC_rgb_expb_2frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/MR_small.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/MR_small_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/emri_small.dcm-/n/fs/.pydicom/data/emri_small_big_endian.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/SC_rgb_16bit.dcm-/n/fs/.pydicom/data/SC_rgb_expb_16bit.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/SC_rgb_16bit_2frame.dcm-/n/fs/.pydicom/data/SC_rgb_expb_16bit_2frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/rtdose_1frame.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/rtdose_expb_1frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/rtdose.dcm-/project/temp/tmpqcg17m39/pydicom__pydicom__2.2/pydicom/data/test_files/rtdose_expb.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/SC_rgb_32bit.dcm-/n/fs/.pydicom/data/SC_rgb_expb_32bit.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_big_endian_datasets[/n/fs/.pydicom/data/SC_rgb_32bit_2frame.dcm-/n/fs/.pydicom/data/SC_rgb_expb_32bit_2frame.dcm]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_endianness_not_set", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_NumpyHandler::test_read_only", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_no_pixel_data_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_missing_required_elem_pixel_data_color", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_missing_required_elem_float_pixel_data_monochrome", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_unknown_pixel_representation_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_unsupported_syntaxes_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_bad_length_raises", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_missing_padding_warns", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_change_photometric_interpretation", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_array_read_only", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_array_read_only_bit_packed", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_ybr422_excess_padding", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_ybr422_wrong_interpretation", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_float_pixel_data", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_GetPixelData::test_double_float_pixel_data", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[-output0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00-output1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x01-output2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x02-output3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x04-output4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x08-output5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x10-output6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[@-output8]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x80-output9]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\xaa-output10]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\xf0-output11]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x0f-output12]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\xff-output13]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00\\x00-output14]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00\\x01-output15]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00\\x80-output16]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x00\\xff-output17]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x01\\x80-output18]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\x80\\x80-output19]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_UnpackBits::test_unpack[\\xff\\x80-output20]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[-input0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00-input1]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x01-input2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x02-input3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x04-input4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x08-input5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x10-input6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[@-input8]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x80-input9]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\xaa-input10]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\xf0-input11]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x0f-input12]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\xff-input13]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00\\x00-input14]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00\\x01-input15]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00\\x80-input16]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x00\\xff-input17]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x01\\x80-input18]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\x80\\x80-input19]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack[\\xff\\x80-input20]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_non_binary_input", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_ndarray_input", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_padding", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00@-input0]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x10-input2]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x08-input3]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x04-input4]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x02-input5]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x00\\x01-input6]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x80-input7]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[@-input8]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x10-input10]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x08-input11]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x04-input12]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x02-input13]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[\\x01-input14]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_pack_partial[-input15]", "pydicom/tests/test_numpy_pixel_data.py::TestNumpy_PackBits::test_functional"], "environment_setup_commit": "0fa18d2a2179c92efc22200ed6b3689e66cecf92", "query": "Pixel Representation attribute should be optional for pixel data handler\n**Describe the bug**\r\nThe NumPy pixel data handler currently [requires the Pixel Representation attribute](https://github.com/pydicom/pydicom/blob/8da0b9b215ebfad5756051c891def88e426787e7/pydicom/pixel_data_handlers/numpy_handler.py#L46). This is problematic, because in case of Float Pixel Data or Double Float Pixel Data the attribute shall be absent. Compare [Floating Point Image Pixel Module Attributes](http://dicom.nema.org/medical/dicom/current/output/chtml/part03/sect_C.7.6.24.html) versus [Image Pixel Description Macro Attributes](http://dicom.nema.org/medical/dicom/current/output/chtml/part03/sect_C.7.6.3.html#table_C.7-11c)\r\n\r\n**Expected behavior**\r\nI would expect the `Dataset.pixel_array` property to be able to decode a Float Pixel Data or Double Float Pixel Data element without presence of the Pixel Representation element in the metadata.\r\n\r\n**Steps To Reproduce**\r\n```python\r\nimport numpy as np\r\nfrom pydicom.dataset import Dataset, FileMetaDataset\r\n\r\n\r\nds = Dataset()\r\nds.file_meta = FileMetaDataset()\r\nds.file_meta.TransferSyntaxUID = '1.2.840.10008.1.2.1'\r\n\r\nds.BitsAllocated = 32\r\nds.SamplesPerPixel = 1\r\nds.Rows = 5\r\nds.Columns = 5\r\nds.PhotometricInterpretation = 'MONOCHROME2'\r\n\r\npixel_array = np.zeros((ds.Rows, ds.Columns), dtype=np.float32)\r\nds.FloatPixelData = pixel_array.flatten().tobytes()\r\n\r\nnp.array_equal(ds.pixel_array, pixel_array)\r\n```\n", "task_id": "pydicom__pydicom-1458"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-1413", "base_commit": "f909c76e31f759246cec3708dadd173c5d6e84b1", "patch": "diff --git a/pydicom/dataelem.py b/pydicom/dataelem.py\n--- a/pydicom/dataelem.py\n+++ b/pydicom/dataelem.py\n@@ -433,13 +433,24 @@ def value(self) -> Any:\n     @value.setter\n     def value(self, val: Any) -> None:\n         \"\"\"Convert (if necessary) and set the value of the element.\"\"\"\n+        # Ignore backslash characters in these VRs, based on:\n+        # * Which str VRs can have backslashes in Part 5, Section 6.2\n+        # * All byte VRs\n+        exclusions = [\n+            'LT', 'OB', 'OD', 'OF', 'OL', 'OV', 'OW', 'ST', 'UN', 'UT',\n+            'OB/OW', 'OW/OB', 'OB or OW', 'OW or OB',\n+            # Probably not needed\n+            'AT', 'FD', 'FL', 'SQ', 'SS', 'SL', 'UL',\n+        ]\n+\n         # Check if is a string with multiple values separated by '\\'\n         # If so, turn them into a list of separate strings\n         #  Last condition covers 'US or SS' etc\n-        if isinstance(val, (str, bytes)) and self.VR not in \\\n-                ['UT', 'ST', 'LT', 'FL', 'FD', 'AT', 'OB', 'OW', 'OF', 'SL',\n-                 'SQ', 'SS', 'UL', 'OB/OW', 'OW/OB', 'OB or OW',\n-                 'OW or OB', 'UN'] and 'US' not in self.VR:\n+        if (\n+            isinstance(val, (str, bytes))\n+            and self.VR not in exclusions\n+            and 'US' not in self.VR\n+        ):\n             try:\n                 if _backslash_str in val:\n                     val = cast(str, val).split(_backslash_str)\n", "test_patch": "diff --git a/pydicom/tests/test_valuerep.py b/pydicom/tests/test_valuerep.py\n--- a/pydicom/tests/test_valuerep.py\n+++ b/pydicom/tests/test_valuerep.py\n@@ -1546,3 +1546,16 @@ def test_set_value(vr, pytype, vm0, vmN, keyword):\n     elem = ds[keyword]\n     assert elem.value == list(vmN)\n     assert list(vmN) == elem.value\n+\n+\n+@pytest.mark.parametrize(\"vr, pytype, vm0, vmN, keyword\", VALUE_REFERENCE)\n+def test_assigning_bytes(vr, pytype, vm0, vmN, keyword):\n+    \"\"\"Test that byte VRs are excluded from the backslash check.\"\"\"\n+    if pytype == bytes:\n+        ds = Dataset()\n+        value = b\"\\x00\\x01\" + b\"\\\\\" + b\"\\x02\\x03\"\n+        setattr(ds, keyword, value)\n+        elem = ds[keyword]\n+        assert elem.VR == vr\n+        assert elem.value == value\n+        assert elem.VM == 1\n", "problem_statement": "Error : a bytes-like object is required, not 'MultiValue'\nHello,\r\n\r\nI am getting following error while updating the tag LongTrianglePointIndexList (0066,0040),\r\n**TypeError: a bytes-like object is required, not 'MultiValue'**\r\n\r\nI noticed that the error  gets produced only when the VR is given as \"OL\" , works fine with \"OB\", \"OF\" etc.\r\n\r\nsample code (assume 'lineSeq' is the dicom dataset sequence):\r\n```python\r\nimport pydicom\r\nimport array\r\ndata=list(range(1,10))\r\ndata=array.array('H', indexData).tostring()  # to convert to unsigned short\r\nlineSeq.add_new(0x00660040, 'OL', data)   \r\nds.save_as(\"mydicom\")\r\n```\r\noutcome: **TypeError: a bytes-like object is required, not 'MultiValue'**\r\n\r\nusing version - 2.0.0.0\r\n\r\nAny help is appreciated.\r\n\r\nThank you\n", "hints_text": "Also tried following code to get the byte string, but same error.\r\n1. data=array.array('L', indexData).tostring()  # to convert to long -> same error\r\n2. data=array.array('Q', indexData).tostring()  # to convert to long long -> same error\r\n\r\n\nO* VRs should be `bytes`. Use `array.tobytes()` instead of `tostring()`?\r\n\r\nAlso, in the future if have an issue it's much more helpful if you post the full traceback rather than the error since we can look at it to figure out where in the code the exception is occurring.\r\n\r\nIt would also help if you posted the version of Python you're using. \r\n\r\nThis works fine for me with Python 3.9 and pydicom 2.1.2:\r\n```python\r\nfrom pydicom import Dataset\r\nimport array\r\n\r\narr = array.array('H', range(10))\r\nds = Dataset()\r\nds.is_little_endian = True\r\nds.is_implicit_VR = False\r\nds.LongTrianglePointIndexList = arr.tobytes()\r\nprint(ds[\"LongTrianglePointIndexList\"].VR)  # 'OL'\r\nds.save_as('temp.dcm')\r\n```\r\nThis also works fine:\r\n```python\r\nds = Dataset()\r\nds.add_new(0x00660040, 'OL', arr.tobytes())\r\n```\nThank you for the answer.\r\nUnfortunately the error still persists with above code.\r\nPlease find the attached detailed error.\r\n[error.txt](https://github.com/pydicom/pydicom/files/6661451/error.txt)\r\n\r\nOne more information is that the 'ds' is actually read from a file in the disk (ds=pydicom.read_file(filename)). \r\nand this byte array is stored under the following sequence\r\nds[0x0066,0x0002][0][0x0066,0x0013][0][0x0066,0x0028][0][0x0066,0x0040] = arr.tobytes()\r\n\r\npydicom - 2.0.0.0\r\npython - 3.6.4\r\n\r\nThank you.\nCould you post a minimal code sample that reproduces the issue please?\r\n\r\nIf you're using something like this:\r\n`ds[0x0066,0x0002][0][0x0066,0x0013][0][0x0066,0x0028][0][0x0066,0x0040] = arr.tobytes()`\r\n\r\nThen you're missing the `.value` assignment:\r\n`ds[0x0066,0x0002][0][0x0066,0x0013][0][0x0066,0x0028][0][0x0066,0x0040].value = arr.tobytes()`\nHello,\r\nabove code line I just mentioned to give an idea where the actual data is stored (tree level).\r\n\r\nPlease find the actual code used below,\r\n```python\r\nimport pydicom\r\nfrom pydicom.sequence import Sequence\r\nfrom pydicom.dataelem import DataElement\r\nfrom pydicom.dataset import Dataset\r\n\r\nds = pydicom.read_file(filename)\r\nsurfaceSeq= ds[0x0066,0x0002]\r\n\r\n#// read existing sequence items in the dataset\r\nseqlist=[]\r\nfor n in surfaceSeq:\r\n    seqlist.append(n)\r\n\r\nnewDs = Dataset()\r\n \r\nsurfaceMeshPrimitiveSq = Dataset()\r\nlineSeq = Dataset()\r\nindexData = list(range(1,100))\r\nindexData = array.array('H', indexData)\r\nindexData = indexData.tobytes()\r\nlineSeq.add_new(0x00660040, 'OL', indexData) \r\nsurfaceMeshPrimitiveSq.add_new(0x00660028, 'SQ', [lineSeq])\r\nnewDs.add_new(0x00660013, 'SQ', [surfaceMeshPrimitiveSq])\r\n\r\n#add the new sequnce item to the list\r\nseqlist.append(newDs)\r\nds[0x0066,0x0002] = DataElement(0x00660002,\"SQ\",seqlist)\r\nds.save_as(filename)\r\n```\nOK, I can reproduce with:\r\n```python\r\n\r\nimport array\r\n\r\nfrom pydicom import Dataset\r\nfrom pydicom.uid import ExplicitVRLittleEndian\r\n\r\nds = Dataset()\r\nds.file_meta = Dataset()\r\nds.file_meta.TransferSyntaxUID = ExplicitVRLittleEndian\r\n\r\nb = array.array('H', range(100)).tobytes()\r\n\r\nds.LongPrimitivePointIndexList = b\r\nds.save_as('1421.dcm')\r\n```\r\nAnd `print(ds)` gives:\r\n```\r\n(0066, 0040) Long Primitive Point Index List     OL: [b'\\x00\\x00\\x01\\x00\\x02\\x00\\x03\\x00\\x04\\x00\\x05\\x00\\x06\\x00\\x07\\x00\\x08\\x00\\t\\x00\\n\\x00\\x0b\\x00\\x0c\\x00\\r\\x00\\x0e\\x00\\x0f\\x00\\x10\\x00\\x11\\x00\\x12\\x00\\x13\\x00\\x14\\x00\\x15\\x00\\x16\\x00\\x17\\x00\\x18\\x00\\x19\\x00\\x1a\\x00\\x1b\\x00\\x1c\\x00\\x1d\\x00\\x1e\\x00\\x1f\\x00 \\x00!\\x00\"\\x00#\\x00$\\x00%\\x00&\\x00\\'\\x00(\\x00)\\x00*\\x00+\\x00,\\x00-\\x00.\\x00/\\x000\\x001\\x002\\x003\\x004\\x005\\x006\\x007\\x008\\x009\\x00:\\x00;\\x00<\\x00=\\x00>\\x00?\\x00@\\x00A\\x00B\\x00C\\x00D\\x00E\\x00F\\x00G\\x00H\\x00I\\x00J\\x00K\\x00L\\x00M\\x00N\\x00O\\x00P\\x00Q\\x00R\\x00S\\x00T\\x00U\\x00V\\x00W\\x00X\\x00Y\\x00Z\\x00[\\x00', b'\\x00]\\x00^\\x00_\\x00`\\x00a\\x00b\\x00c\\x00']\r\n```\r\nI think this is because the byte value is hitting the hex for the backslash character during assignment. Ouch, that's kinda nasty.", "created_at": "2021-06-16T09:47:08Z", "version": "2.1", "FAIL_TO_PASS": ["pydicom/tests/test_valuerep.py::test_assigning_bytes[OD-bytes-vm017-vmN17-DoubleFloatPixelData]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[OL-bytes-vm019-vmN19-TrackPointIndexList]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[OV-bytes-vm020-vmN20-SelectorOVValue]"], "PASS_TO_PASS": ["pydicom/tests/test_valuerep.py::TestTM::test_pickling", "pydicom/tests/test_valuerep.py::TestTM::test_pickling_tm_from_time", "pydicom/tests/test_valuerep.py::TestTM::test_str_and_repr", "pydicom/tests/test_valuerep.py::TestTM::test_new_empty_str", "pydicom/tests/test_valuerep.py::TestTM::test_new_str_conversion", "pydicom/tests/test_valuerep.py::TestTM::test_new_obj_conversion", "pydicom/tests/test_valuerep.py::TestTM::test_comparison", "pydicom/tests/test_valuerep.py::TestTM::test_time_behavior", "pydicom/tests/test_valuerep.py::TestDT::test_pickling", "pydicom/tests/test_valuerep.py::TestDT::test_pickling_with_timezone", "pydicom/tests/test_valuerep.py::TestDT::test_pickling_dt_from_datetime", "pydicom/tests/test_valuerep.py::TestDT::test_pickling_dt_from_datetime_with_timezone", "pydicom/tests/test_valuerep.py::TestDT::test_new_empty_str", "pydicom/tests/test_valuerep.py::TestDT::test_new_obj_conversion", "pydicom/tests/test_valuerep.py::TestDT::test_new_str_conversion", "pydicom/tests/test_valuerep.py::TestDT::test_str_and_repr", "pydicom/tests/test_valuerep.py::TestDT::test_comparison", "pydicom/tests/test_valuerep.py::TestDT::test_datetime_behavior", "pydicom/tests/test_valuerep.py::TestDA::test_pickling", "pydicom/tests/test_valuerep.py::TestDA::test_new_obj_conversion", "pydicom/tests/test_valuerep.py::TestDA::test_str_and_repr", "pydicom/tests/test_valuerep.py::TestDA::test_comparison", "pydicom/tests/test_valuerep.py::TestDA::test_date_behavior", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_valid[1]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_valid[3.14159265358979]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_valid[-1234.456e78]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_valid[1.234E-5]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_valid[1.234E+5]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_valid[+1]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_valid[", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_valid[42", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_invalid[nan]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_invalid[-inf]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_invalid[3.141592653589793]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_invalid[1,000]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_invalid[1", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_invalid[127.0.0.1]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_invalid[1.e]", "pydicom/tests/test_valuerep.py::TestIsValidDS::test_invalid[]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[1.0-1.0]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[0.0-0.0]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[-0.0--0.0]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[0.123-0.123]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[-0.321--0.321]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[1e-05-1e-05]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[3.141592653589793-3.14159265358979]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[-3.141592653589793--3.1415926535898]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[5.385940192876374e-07-5.3859401929e-07]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[-5.385940192876374e-07--5.385940193e-07]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[12342534378.125532-12342534378.1255]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[64070869985876.78-64070869985876.8]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_auto_format[1.7976931348623157e+308-1.797693135e+308]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-101]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-100]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[100]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[101]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-16]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-15]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-14]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-13]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-12]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-11]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-10]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-9]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-8]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-7]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-6]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-5]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-4]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-3]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-2]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[-1]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[0]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[1]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[2]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[3]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[4]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[5]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[6]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[7]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[8]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[9]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[10]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[11]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[12]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[13]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[14]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[15]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_pi[16]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-101]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-100]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[100]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[101]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-16]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-15]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-14]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-13]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-12]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-11]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-10]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-9]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-8]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-7]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-6]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-5]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-4]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-3]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-2]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[-1]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[0]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[1]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[2]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[3]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[4]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[5]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[6]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[7]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[8]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[9]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[10]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[11]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[12]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[13]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[14]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[15]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_powers_of_negative_pi[16]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_invalid[nan0]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_invalid[nan1]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_invalid[-inf]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_invalid[inf]", "pydicom/tests/test_valuerep.py::TestTruncateFloatForDS::test_wrong_type", "pydicom/tests/test_valuerep.py::TestDS::test_empty_value", "pydicom/tests/test_valuerep.py::TestDS::test_float_values", "pydicom/tests/test_valuerep.py::TestDSfloat::test_pickling", "pydicom/tests/test_valuerep.py::TestDSfloat::test_new_empty", "pydicom/tests/test_valuerep.py::TestDSfloat::test_str_value", "pydicom/tests/test_valuerep.py::TestDSfloat::test_str", "pydicom/tests/test_valuerep.py::TestDSfloat::test_repr", "pydicom/tests/test_valuerep.py::TestDSfloat::test_DSfloat", "pydicom/tests/test_valuerep.py::TestDSfloat::test_DSdecimal", "pydicom/tests/test_valuerep.py::TestDSfloat::test_auto_format[True]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_auto_format[False]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_auto_format_from_invalid_DS", "pydicom/tests/test_valuerep.py::TestDSfloat::test_auto_format_invalid_string[True]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_auto_format_invalid_string[False]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_auto_format_valid_string[True]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_auto_format_valid_string[False]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_enforce_valid_values_length", "pydicom/tests/test_valuerep.py::TestDSfloat::test_DSfloat_auto_format", "pydicom/tests/test_valuerep.py::TestDSfloat::test_enforce_valid_values_value[nan0]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_enforce_valid_values_value[-nan]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_enforce_valid_values_value[inf0]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_enforce_valid_values_value[-inf0]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_enforce_valid_values_value[nan1]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_enforce_valid_values_value[nan2]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_enforce_valid_values_value[-inf1]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_enforce_valid_values_value[inf1]", "pydicom/tests/test_valuerep.py::TestDSfloat::test_comparison_operators", "pydicom/tests/test_valuerep.py::TestDSfloat::test_hash", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_pickling", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_float_value", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_new_empty", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_str_value", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_DSfloat", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_DSdecimal", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_repr", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_auto_format[True]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_auto_format[False]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_auto_format_from_invalid_DS", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_auto_format_invalid_string[True]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_auto_format_invalid_string[False]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_enforce_valid_values_value[NaN]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_enforce_valid_values_value[-NaN]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_enforce_valid_values_value[Infinity]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_enforce_valid_values_value[-Infinity]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_enforce_valid_values_value[val4]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_enforce_valid_values_value[val5]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_enforce_valid_values_value[val6]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_enforce_valid_values_value[val7]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_auto_format_valid_string[True]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_auto_format_valid_string[False]", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_DSdecimal_auto_format", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_comparison_operators", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_hash", "pydicom/tests/test_valuerep.py::TestIS::test_empty_value", "pydicom/tests/test_valuerep.py::TestIS::test_str_value", "pydicom/tests/test_valuerep.py::TestIS::test_valid_value", "pydicom/tests/test_valuerep.py::TestIS::test_invalid_value", "pydicom/tests/test_valuerep.py::TestIS::test_pickling", "pydicom/tests/test_valuerep.py::TestIS::test_longint", "pydicom/tests/test_valuerep.py::TestIS::test_overflow", "pydicom/tests/test_valuerep.py::TestIS::test_str", "pydicom/tests/test_valuerep.py::TestIS::test_repr", "pydicom/tests/test_valuerep.py::TestIS::test_comparison_operators", "pydicom/tests/test_valuerep.py::TestIS::test_hash", "pydicom/tests/test_valuerep.py::TestBadValueRead::test_read_bad_value_in_VR_default", "pydicom/tests/test_valuerep.py::TestBadValueRead::test_read_bad_value_in_VR_enforce_valid_value", "pydicom/tests/test_valuerep.py::TestDecimalString::test_DS_decimal_set", "pydicom/tests/test_valuerep.py::TestDecimalString::test_valid_decimal_strings", "pydicom/tests/test_valuerep.py::TestDecimalString::test_invalid_decimal_strings", "pydicom/tests/test_valuerep.py::TestPersonName::test_last_first", "pydicom/tests/test_valuerep.py::TestPersonName::test_copy", "pydicom/tests/test_valuerep.py::TestPersonName::test_three_component", "pydicom/tests/test_valuerep.py::TestPersonName::test_formatting", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_kr", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_bytes", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_bytes_comp_delimiter", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_bytes_caret_delimiter", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_unicode", "pydicom/tests/test_valuerep.py::TestPersonName::test_not_equal", "pydicom/tests/test_valuerep.py::TestPersonName::test_encoding_carried", "pydicom/tests/test_valuerep.py::TestPersonName::test_hash", "pydicom/tests/test_valuerep.py::TestPersonName::test_next", "pydicom/tests/test_valuerep.py::TestPersonName::test_iterator", "pydicom/tests/test_valuerep.py::TestPersonName::test_contains", "pydicom/tests/test_valuerep.py::TestPersonName::test_length", "pydicom/tests/test_valuerep.py::TestPersonName::test_from_named_components", "pydicom/tests/test_valuerep.py::TestPersonName::test_from_named_components_kr_from_bytes", "pydicom/tests/test_valuerep.py::TestPersonName::test_from_named_components_kr_from_unicode", "pydicom/tests/test_valuerep.py::TestPersonName::test_from_named_components_jp_from_bytes", "pydicom/tests/test_valuerep.py::TestPersonName::test_from_named_components_jp_from_unicode", "pydicom/tests/test_valuerep.py::TestPersonName::test_from_named_components_veterinary", "pydicom/tests/test_valuerep.py::TestPersonName::test_from_named_components_with_separator", "pydicom/tests/test_valuerep.py::TestPersonName::test_from_named_components_with_separator_from_bytes", "pydicom/tests/test_valuerep.py::TestDateTime::test_date", "pydicom/tests/test_valuerep.py::TestDateTime::test_date_time", "pydicom/tests/test_valuerep.py::TestDateTime::test_time", "pydicom/tests/test_valuerep.py::test_person_name_unicode_warns", "pydicom/tests/test_valuerep.py::test_set_value[AE-str-vm00-vmN0-Receiver]", "pydicom/tests/test_valuerep.py::test_set_value[AS-str-vm01-vmN1-PatientAge]", "pydicom/tests/test_valuerep.py::test_set_value[AT-int-vm02-vmN2-OffendingElement]", "pydicom/tests/test_valuerep.py::test_set_value[CS-str-vm03-vmN3-QualityControlSubject]", "pydicom/tests/test_valuerep.py::test_set_value[DA-str-vm04-vmN4-PatientBirthDate]", "pydicom/tests/test_valuerep.py::test_set_value[DS-str-vm05-vmN5-PatientWeight]", "pydicom/tests/test_valuerep.py::test_set_value[DS-int-vm06-vmN6-PatientWeight]", "pydicom/tests/test_valuerep.py::test_set_value[DS-float-vm07-vmN7-PatientWeight]", "pydicom/tests/test_valuerep.py::test_set_value[DT-str-vm08-vmN8-AcquisitionDateTime]", "pydicom/tests/test_valuerep.py::test_set_value[FD-float-vm09-vmN9-RealWorldValueLUTData]", "pydicom/tests/test_valuerep.py::test_set_value[FL-float-vm010-vmN10-VectorAccuracy]", "pydicom/tests/test_valuerep.py::test_set_value[IS-str-vm011-vmN11-BeamNumber]", "pydicom/tests/test_valuerep.py::test_set_value[IS-int-vm012-vmN12-BeamNumber]", "pydicom/tests/test_valuerep.py::test_set_value[IS-float-vm013-vmN13-BeamNumber]", "pydicom/tests/test_valuerep.py::test_set_value[LO-str-vm014-vmN14-DataSetSubtype]", "pydicom/tests/test_valuerep.py::test_set_value[LT-str-vm015-vmN15-ExtendedCodeMeaning]", "pydicom/tests/test_valuerep.py::test_set_value[OB-bytes-vm016-vmN16-FillPattern]", "pydicom/tests/test_valuerep.py::test_set_value[OD-bytes-vm017-vmN17-DoubleFloatPixelData]", "pydicom/tests/test_valuerep.py::test_set_value[OF-bytes-vm018-vmN18-UValueData]", "pydicom/tests/test_valuerep.py::test_set_value[OL-bytes-vm019-vmN19-TrackPointIndexList]", "pydicom/tests/test_valuerep.py::test_set_value[OV-bytes-vm020-vmN20-SelectorOVValue]", "pydicom/tests/test_valuerep.py::test_set_value[OW-bytes-vm021-vmN21-TrianglePointIndexList]", "pydicom/tests/test_valuerep.py::test_set_value[PN-str-vm022-vmN22-PatientName]", "pydicom/tests/test_valuerep.py::test_set_value[SH-str-vm023-vmN23-CodeValue]", "pydicom/tests/test_valuerep.py::test_set_value[SL-int-vm024-vmN24-RationalNumeratorValue]", "pydicom/tests/test_valuerep.py::test_set_value[SQ-list-vm025-vmN25-BeamSequence]", "pydicom/tests/test_valuerep.py::test_set_value[SS-int-vm026-vmN26-SelectorSSValue]", "pydicom/tests/test_valuerep.py::test_set_value[ST-str-vm027-vmN27-InstitutionAddress]", "pydicom/tests/test_valuerep.py::test_set_value[SV-int-vm028-vmN28-SelectorSVValue]", "pydicom/tests/test_valuerep.py::test_set_value[TM-str-vm029-vmN29-StudyTime]", "pydicom/tests/test_valuerep.py::test_set_value[UC-str-vm030-vmN30-LongCodeValue]", "pydicom/tests/test_valuerep.py::test_set_value[UI-str-vm031-vmN31-SOPClassUID]", "pydicom/tests/test_valuerep.py::test_set_value[UL-int-vm032-vmN32-SimpleFrameList]", "pydicom/tests/test_valuerep.py::test_set_value[UN-bytes-vm033-vmN33-SelectorUNValue]", "pydicom/tests/test_valuerep.py::test_set_value[UR-str-vm034-vmN34-CodingSchemeURL]", "pydicom/tests/test_valuerep.py::test_set_value[US-int-vm035-vmN35-SourceAcquisitionBeamNumber]", "pydicom/tests/test_valuerep.py::test_set_value[UT-str-vm036-vmN36-StrainAdditionalInformation]", "pydicom/tests/test_valuerep.py::test_set_value[UV-int-vm037-vmN37-SelectorUVValue]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[AE-str-vm00-vmN0-Receiver]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[AS-str-vm01-vmN1-PatientAge]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[AT-int-vm02-vmN2-OffendingElement]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[CS-str-vm03-vmN3-QualityControlSubject]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[DA-str-vm04-vmN4-PatientBirthDate]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[DS-str-vm05-vmN5-PatientWeight]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[DS-int-vm06-vmN6-PatientWeight]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[DS-float-vm07-vmN7-PatientWeight]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[DT-str-vm08-vmN8-AcquisitionDateTime]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[FD-float-vm09-vmN9-RealWorldValueLUTData]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[FL-float-vm010-vmN10-VectorAccuracy]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[IS-str-vm011-vmN11-BeamNumber]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[IS-int-vm012-vmN12-BeamNumber]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[IS-float-vm013-vmN13-BeamNumber]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[LO-str-vm014-vmN14-DataSetSubtype]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[LT-str-vm015-vmN15-ExtendedCodeMeaning]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[OB-bytes-vm016-vmN16-FillPattern]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[OF-bytes-vm018-vmN18-UValueData]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[OW-bytes-vm021-vmN21-TrianglePointIndexList]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[PN-str-vm022-vmN22-PatientName]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[SH-str-vm023-vmN23-CodeValue]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[SL-int-vm024-vmN24-RationalNumeratorValue]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[SQ-list-vm025-vmN25-BeamSequence]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[SS-int-vm026-vmN26-SelectorSSValue]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[ST-str-vm027-vmN27-InstitutionAddress]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[SV-int-vm028-vmN28-SelectorSVValue]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[TM-str-vm029-vmN29-StudyTime]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[UC-str-vm030-vmN30-LongCodeValue]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[UI-str-vm031-vmN31-SOPClassUID]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[UL-int-vm032-vmN32-SimpleFrameList]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[UN-bytes-vm033-vmN33-SelectorUNValue]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[UR-str-vm034-vmN34-CodingSchemeURL]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[US-int-vm035-vmN35-SourceAcquisitionBeamNumber]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[UT-str-vm036-vmN36-StrainAdditionalInformation]", "pydicom/tests/test_valuerep.py::test_assigning_bytes[UV-int-vm037-vmN37-SelectorUVValue]"], "environment_setup_commit": "506ecea8f378dc687d5c504788fc78810a190b7a", "query": "Error : a bytes-like object is required, not 'MultiValue'\nHello,\r\n\r\nI am getting following error while updating the tag LongTrianglePointIndexList (0066,0040),\r\n**TypeError: a bytes-like object is required, not 'MultiValue'**\r\n\r\nI noticed that the error  gets produced only when the VR is given as \"OL\" , works fine with \"OB\", \"OF\" etc.\r\n\r\nsample code (assume 'lineSeq' is the dicom dataset sequence):\r\n```python\r\nimport pydicom\r\nimport array\r\ndata=list(range(1,10))\r\ndata=array.array('H', indexData).tostring()  # to convert to unsigned short\r\nlineSeq.add_new(0x00660040, 'OL', data)   \r\nds.save_as(\"mydicom\")\r\n```\r\noutcome: **TypeError: a bytes-like object is required, not 'MultiValue'**\r\n\r\nusing version - 2.0.0.0\r\n\r\nAny help is appreciated.\r\n\r\nThank you\n", "task_id": "pydicom__pydicom-1413"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-938", "base_commit": "6d8ef0bfcec983e5f8bd8a2e359ff318fe9fcf65", "patch": "diff --git a/pydicom/valuerep.py b/pydicom/valuerep.py\n--- a/pydicom/valuerep.py\n+++ b/pydicom/valuerep.py\n@@ -346,11 +346,12 @@ def __init__(self, val):\n     def __str__(self):\n         if hasattr(self, 'original_string'):\n             return self.original_string\n-        else:\n-            return super(DSfloat, self).__str__()\n+\n+        # Issue #937 (Python 3.8 compatibility)\n+        return repr(self)[1:-1]\n \n     def __repr__(self):\n-        return \"\\\"\" + str(self) + \"\\\"\"\n+        return '\"{}\"'.format(super(DSfloat, self).__repr__())\n \n \n class DSdecimal(Decimal):\n@@ -513,11 +514,15 @@ def __init__(self, val):\n         elif isinstance(val, IS) and hasattr(val, 'original_string'):\n             self.original_string = val.original_string\n \n-    def __repr__(self):\n+    def __str__(self):\n         if hasattr(self, 'original_string'):\n-            return \"\\\"\" + self.original_string + \"\\\"\"\n-        else:\n-            return \"\\\"\" + int.__str__(self) + \"\\\"\"\n+            return self.original_string\n+\n+        # Issue #937 (Python 3.8 compatibility)\n+        return repr(self)[1:-1]\n+\n+    def __repr__(self):\n+        return '\"{}\"'.format(super(IS, self).__repr__())\n \n \n def MultiString(val, valtype=str):\n", "test_patch": "diff --git a/pydicom/tests/test_valuerep.py b/pydicom/tests/test_valuerep.py\n--- a/pydicom/tests/test_valuerep.py\n+++ b/pydicom/tests/test_valuerep.py\n@@ -90,7 +90,6 @@ def test_pickling(self):\n \n class TestDS(object):\n     \"\"\"Unit tests for DS values\"\"\"\n-\n     def test_empty_value(self):\n         assert DS(None) is None\n         assert '' == DS('')\n@@ -106,7 +105,6 @@ def test_float_values(self):\n \n class TestDSfloat(object):\n     \"\"\"Unit tests for pickling DSfloat\"\"\"\n-\n     def test_pickling(self):\n         # Check that a pickled DSFloat is read back properly\n         x = pydicom.valuerep.DSfloat(9.0)\n@@ -116,10 +114,25 @@ def test_pickling(self):\n         assert x.real == x2.real\n         assert x.original_string == x2.original_string\n \n+    def test_str(self):\n+        \"\"\"Test DSfloat.__str__().\"\"\"\n+        val = pydicom.valuerep.DSfloat(1.1)\n+        assert '1.1' == str(val)\n+\n+        val = pydicom.valuerep.DSfloat('1.1')\n+        assert '1.1' == str(val)\n+\n+    def test_repr(self):\n+        \"\"\"Test DSfloat.__repr__().\"\"\"\n+        val = pydicom.valuerep.DSfloat(1.1)\n+        assert '\"1.1\"' == repr(val)\n+\n+        val = pydicom.valuerep.DSfloat('1.1')\n+        assert '\"1.1\"' == repr(val)\n+\n \n class TestDSdecimal(object):\n     \"\"\"Unit tests for pickling DSdecimal\"\"\"\n-\n     def test_pickling(self):\n         # Check that a pickled DSdecimal is read back properly\n         # DSdecimal actually prefers original_string when\n@@ -142,7 +155,6 @@ def test_float_value(self):\n \n class TestIS(object):\n     \"\"\"Unit tests for IS\"\"\"\n-\n     def test_empty_value(self):\n         assert IS(None) is None\n         assert '' == IS('')\n@@ -182,6 +194,22 @@ def test_overflow(self):\n             pydicom.valuerep.IS(3103050000)\n         config.enforce_valid_values = original_flag\n \n+    def test_str(self):\n+        \"\"\"Test IS.__str__().\"\"\"\n+        val = pydicom.valuerep.IS(1)\n+        assert '1' == str(val)\n+\n+        val = pydicom.valuerep.IS('1')\n+        assert '1' == str(val)\n+\n+    def test_repr(self):\n+        \"\"\"Test IS.__repr__().\"\"\"\n+        val = pydicom.valuerep.IS(1)\n+        assert '\"1\"' == repr(val)\n+\n+        val = pydicom.valuerep.IS('1')\n+        assert '\"1\"' == repr(val)\n+\n \n class TestBadValueRead(object):\n     \"\"\"Unit tests for handling a bad value for a VR\n", "problem_statement": "[python 3.8] failing tests: various issues but \"max recursion depth reached\" seems to be one\n#### Description\r\nFedora is beginning to test python packages against python 3.8. Pydicom builds but tests fail with errors.\r\n\r\n#### Steps/Code to Reproduce\r\n\r\n```\r\npython setup.py build\r\npython setup.py install\r\npytest\r\n```\r\n\r\nThe complete build log is attached. It includes the complete build process. The root log is also attached. These are the versions of other python libraries that are in use:\r\n\r\n```\r\npython3-dateutil-1:2.8.0-5.fc32.noarch\r\npython3-devel-3.8.0~b3-4.fc32.x86_64\r\npython3-numpy-1:1.17.0-3.fc32.x86_64\r\npython3-numpydoc-0.9.1-3.fc32.noarch\r\npython3-pytest-4.6.5-3.fc32.noarch\r\npython3-setuptools-41.0.1-8.fc32.noarch\r\npython3-six-1.12.0-5.fc32.noarch\r\n```\r\n\r\n[build-log.txt](https://github.com/pydicom/pydicom/files/3527558/build-log.txt)\r\n[root-log.txt](https://github.com/pydicom/pydicom/files/3527559/root-log.txt)\r\n\n", "hints_text": "Thanks, @sanjayankur31, we'll look into it.\nLooks like the [culprit](https://docs.python.org/3.8/whatsnew/3.8.html#changes-in-python-behavior) might be:\r\n\r\n> Removed `__str__` implementations from builtin types bool, int, float, complex and few classes from the standard library. They now inherit `__str__()` from object. As result, defining the `__repr__()` method in the subclass of these classes will affect they string representation.\r\n\r\nThe unit test results in the build log shows issues with `DSfloat.__str__()/DSfloat.__repr__()` and `IS.__repr__()` on lines [350](https://github.com/pydicom/pydicom/blob/6d8ef0bfcec983e5f8bd8a2e359ff318fe9fcf65/pydicom/valuerep.py#L353)/353 and [520](https://github.com/pydicom/pydicom/blob/6d8ef0bfcec983e5f8bd8a2e359ff318fe9fcf65/pydicom/valuerep.py#L520) of current master.\r\n", "created_at": "2019-08-22T05:03:01Z", "version": "1.3", "FAIL_TO_PASS": ["pydicom/tests/test_valuerep.py::TestDSfloat::test_str", "pydicom/tests/test_valuerep.py::TestDSfloat::test_repr", "pydicom/tests/test_valuerep.py::TestIS::test_str", "pydicom/tests/test_valuerep.py::TestIS::test_repr"], "PASS_TO_PASS": ["pydicom/tests/test_valuerep.py::TestTM::test_pickling", "pydicom/tests/test_valuerep.py::TestDT::test_pickling", "pydicom/tests/test_valuerep.py::TestDA::test_pickling", "pydicom/tests/test_valuerep.py::TestDS::test_empty_value", "pydicom/tests/test_valuerep.py::TestDS::test_float_values", "pydicom/tests/test_valuerep.py::TestDSfloat::test_pickling", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_pickling", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_float_value", "pydicom/tests/test_valuerep.py::TestIS::test_empty_value", "pydicom/tests/test_valuerep.py::TestIS::test_valid_value", "pydicom/tests/test_valuerep.py::TestIS::test_invalid_value", "pydicom/tests/test_valuerep.py::TestIS::test_pickling", "pydicom/tests/test_valuerep.py::TestIS::test_longint", "pydicom/tests/test_valuerep.py::TestIS::test_overflow", "pydicom/tests/test_valuerep.py::TestBadValueRead::test_read_bad_value_in_VR_default", "pydicom/tests/test_valuerep.py::TestBadValueRead::test_read_bad_value_in_VR_enforce_valid_value", "pydicom/tests/test_valuerep.py::TestDecimalString::test_valid_decimal_strings", "pydicom/tests/test_valuerep.py::TestDecimalString::test_invalid_decimal_strings", "pydicom/tests/test_valuerep.py::TestPersonName::test_last_first", "pydicom/tests/test_valuerep.py::TestPersonName::test_copy", "pydicom/tests/test_valuerep.py::TestPersonName::test_three_component", "pydicom/tests/test_valuerep.py::TestPersonName::test_formatting", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_kr", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_bytes", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_bytes_comp_delimiter", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_bytes_caret_delimiter", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_unicode", "pydicom/tests/test_valuerep.py::TestPersonName::test_not_equal", "pydicom/tests/test_valuerep.py::TestPersonName::test_encoding_carried", "pydicom/tests/test_valuerep.py::TestPersonName::test_hash", "pydicom/tests/test_valuerep.py::TestDateTime::test_date", "pydicom/tests/test_valuerep.py::TestDateTime::test_date_time", "pydicom/tests/test_valuerep.py::TestDateTime::test_time"], "environment_setup_commit": "7241f5d9db0de589b230bb84212fbb643a7c86c3", "query": "[python 3.8] failing tests: various issues but \"max recursion depth reached\" seems to be one\n#### Description\r\nFedora is beginning to test python packages against python 3.8. Pydicom builds but tests fail with errors.\r\n\r\n#### Steps/Code to Reproduce\r\n\r\n```\r\npython setup.py build\r\npython setup.py install\r\npytest\r\n```\r\n\r\nThe complete build log is attached. It includes the complete build process. The root log is also attached. These are the versions of other python libraries that are in use:\r\n\r\n```\r\npython3-dateutil-1:2.8.0-5.fc32.noarch\r\npython3-devel-3.8.0~b3-4.fc32.x86_64\r\npython3-numpy-1:1.17.0-3.fc32.x86_64\r\npython3-numpydoc-0.9.1-3.fc32.noarch\r\npython3-pytest-4.6.5-3.fc32.noarch\r\npython3-setuptools-41.0.1-8.fc32.noarch\r\npython3-six-1.12.0-5.fc32.noarch\r\n```\r\n\r\n[build-log.txt](https://github.com/pydicom/pydicom/files/3527558/build-log.txt)\r\n[root-log.txt](https://github.com/pydicom/pydicom/files/3527559/root-log.txt)\r\n\n", "task_id": "pydicom__pydicom-938"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-1194", "base_commit": "5e70c1dfe09820023fec519dac4c51bebcb7f60d", "patch": "diff --git a/pydicom/filewriter.py b/pydicom/filewriter.py\n--- a/pydicom/filewriter.py\n+++ b/pydicom/filewriter.py\n@@ -87,6 +87,9 @@ def _correct_ambiguous_vr_element(elem, ds, is_little_endian):\n             elem.VR = 'SS'\n             byte_type = 'h'\n \n+        if elem.VM == 0:\n+            return elem\n+\n         # Need to handle type check for elements with VM > 1\n         elem_value = elem.value if elem.VM == 1 else elem.value[0]\n         if not isinstance(elem_value, int):\n@@ -115,6 +118,9 @@ def _correct_ambiguous_vr_element(elem, ds, is_little_endian):\n         # As per PS3.3 C.11.1.1.1\n         if ds.LUTDescriptor[0] == 1:\n             elem.VR = 'US'\n+            if elem.VM == 0:\n+                return elem\n+\n             elem_value = elem.value if elem.VM == 1 else elem.value[0]\n             if not isinstance(elem_value, int):\n                 elem.value = convert_numbers(elem.value, is_little_endian, 'H')\n", "test_patch": "diff --git a/pydicom/tests/test_filewriter.py b/pydicom/tests/test_filewriter.py\n--- a/pydicom/tests/test_filewriter.py\n+++ b/pydicom/tests/test_filewriter.py\n@@ -1054,7 +1054,7 @@ def test_not_ambiguous_raw_data_element(self):\n         elem = RawDataElement(0x60003000, 'OB', 1, b'\\x00', 0, True, True)\n         out = correct_ambiguous_vr_element(elem, Dataset(), True)\n         assert out == elem\n-        assert type(out) == RawDataElement\n+        assert isinstance(out, RawDataElement)\n \n     def test_correct_ambiguous_data_element(self):\n         \"\"\"Test correct ambiguous US/SS element\"\"\"\n@@ -1086,10 +1086,28 @@ def test_correct_ambiguous_raw_data_element(self):\n         ds[0x00280120] = elem\n         ds.PixelRepresentation = 0\n         out = correct_ambiguous_vr_element(elem, ds, True)\n-        assert type(out) == DataElement\n+        assert isinstance(out, DataElement)\n         assert out.VR == 'US'\n         assert out.value == 0xfffe\n \n+    def test_empty_value(self):\n+        \"\"\"Regression test for #1193: empty value raises exception.\"\"\"\n+        ds = Dataset()\n+        elem = RawDataElement(0x00280106, 'US or SS', 0, None, 0, True, True)\n+        ds[0x00280106] = elem\n+        out = correct_ambiguous_vr_element(elem, ds, True)\n+        assert isinstance(out, DataElement)\n+        assert out.VR == 'US'\n+\n+        ds.LUTDescriptor = [1, 1, 1]\n+        elem = RawDataElement(0x00283006, 'US or SS', 0, None, 0, True, True)\n+        assert out.value is None\n+        ds[0x00283006] = elem\n+        out = correct_ambiguous_vr_element(elem, ds, True)\n+        assert isinstance(out, DataElement)\n+        assert out.VR == 'US'\n+        assert out.value is None\n+\n \n class TestWriteAmbiguousVR:\n     \"\"\"Attempt to write data elements with ambiguous VR.\"\"\"\n", "problem_statement": "Error decoding dataset with ambiguous VR element when the value is None\nHi all,\r\n    I used the storescu in pynetdicom 1.5.3 to send the dicom ct files(both on mac and ubuntu): \r\n**python storescu.py 192.168.1.120 9002 ~/Downloads/test/**\r\n(I also tried https://pydicom.github.io/pynetdicom/stable/examples/storage.html#storage-scu)\r\nbut it throwed errors: \r\n\r\n_E: Failed to encode the supplied Dataset\r\nE: Store failed: /Users/me/Downloads/test/CT_S1_118.dcm\r\nE: Failed to encode the supplied Dataset\r\nTraceback (most recent call last):\r\n  File \"storescu.py\", line 283, in main\r\n    status = assoc.send_c_store(ds, ii)\r\n  File \"/Users/me/.pyenv/versions/3.8.2/lib/python3.8/site-packages/pynetdicom/association.py\", line 1736, in send_c_store\r\n    raise ValueError('Failed to encode the supplied Dataset')\r\nValueError: Failed to encode the supplied Dataset_\r\n\r\nBut I used to send same files with storescu in dcm4che successfully.\r\nFile attached.\r\n\r\n[test.zip](https://github.com/pydicom/pynetdicom/files/5258867/test.zip)\r\n\n", "hints_text": "```python\r\n>>> from pydicom import dcmread\r\n>>> dcmread(\"CT_S1_001.dcm\")\r\nTraceback (most recent call last):\r\n  File \".../pydicom/tag.py\", line 30, in tag_in_exception\r\n    yield\r\n  File \".../pydicom/filewriter.py\", line 555, in write_dataset\r\n    write_data_element(fp, dataset.get_item(tag), dataset_encoding)\r\n  File \".../pydicom/dataset.py\", line 1060, in get_item\r\n    return self[key]\r\n  File \".../pydicom/dataset.py\", line 878, in __getitem__\r\n    self[tag] = correct_ambiguous_vr_element(\r\n  File \".../pydicom/filewriter.py\", line 160, in correct_ambiguous_vr_element\r\n    _correct_ambiguous_vr_element(elem, ds, is_little_endian)\r\n  File \".../pydicom/filewriter.py\", line 86, in _correct_ambiguous_vr_element\r\n    elem_value = elem.value if elem.VM == 1 else elem.value[0]\r\nTypeError: 'NoneType' object is not subscriptable\r\n```\r\nIssue occurs because the dataset is Implicit VR and the *Smallest Image Pixel Value* is ambiguous but empty,", "created_at": "2020-09-22T03:16:19Z", "version": "2.0", "FAIL_TO_PASS": ["pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVRElement::test_empty_value"], "PASS_TO_PASS": ["pydicom/tests/test_filewriter.py::TestWriteFile::testRTPlan", "pydicom/tests/test_filewriter.py::TestWriteFile::testRTDose", "pydicom/tests/test_filewriter.py::TestWriteFile::testCT", "pydicom/tests/test_filewriter.py::TestWriteFile::testMR", "pydicom/tests/test_filewriter.py::TestWriteFile::testUnicode", "pydicom/tests/test_filewriter.py::TestWriteFile::testMultiPN", "pydicom/tests/test_filewriter.py::TestWriteFile::testJPEG2000", "pydicom/tests/test_filewriter.py::TestWriteFile::test_pathlib_path_filename", "pydicom/tests/test_filewriter.py::TestWriteFile::testListItemWriteBack", "pydicom/tests/test_filewriter.py::TestWriteFile::testwrite_short_uid", "pydicom/tests/test_filewriter.py::TestWriteFile::test_write_no_ts", "pydicom/tests/test_filewriter.py::TestWriteFile::test_write_double_filemeta", "pydicom/tests/test_filewriter.py::TestWriteFile::test_write_ffff_ffff", "pydicom/tests/test_filewriter.py::TestWriteFile::test_write_removes_grouplength", "pydicom/tests/test_filewriter.py::TestWriteFile::test_write_empty_sequence", "pydicom/tests/test_filewriter.py::TestWriteFile::test_write_deflated_retains_elements", "pydicom/tests/test_filewriter.py::TestWriteFile::test_write_deflated_deflates_post_file_meta", "pydicom/tests/test_filewriter.py::TestWriteFile::test_write_dataset_without_encoding", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::testRTPlan", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::testRTDose", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::testCT", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::testMR", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::testUnicode", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::testMultiPN", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::testJPEG2000", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_pathlib_path_filename", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::testListItemWriteBack", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::testwrite_short_uid", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_write_no_ts", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_write_double_filemeta", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_write_ffff_ffff", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_write_removes_grouplength", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_write_empty_sequence", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_write_deflated_retains_elements", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_write_deflated_deflates_post_file_meta", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_write_dataset_without_encoding", "pydicom/tests/test_filewriter.py::TestScratchWriteDateTime::test_multivalue_DA", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_empty_AT", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_empty_LO", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_DA", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_multi_DA", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_TM", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_multi_TM", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_DT", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_multi_DT", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_ascii_vr_with_padding", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_OD_implicit_little", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_OD_explicit_little", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_OL_implicit_little", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_OL_explicit_little", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_UC_implicit_little", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_UC_explicit_little", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_UR_implicit_little", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_UR_explicit_little", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_UN_implicit_little", "pydicom/tests/test_filewriter.py::TestWriteDataElement::test_write_unknown_vr_raises", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_pixel_representation_vm_one", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_pixel_representation_vm_three", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_pixel_data", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_waveform_bits_allocated", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_lut_descriptor", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_overlay", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_sequence", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_write_new_ambiguous", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_ambiguous_element_in_sequence_explicit_using_attribute", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_ambiguous_element_in_sequence_explicit_using_index", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_ambiguous_element_in_sequence_implicit_using_attribute", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVR::test_ambiguous_element_in_sequence_implicit_using_index", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVRElement::test_not_ambiguous", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVRElement::test_not_ambiguous_raw_data_element", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVRElement::test_correct_ambiguous_data_element", "pydicom/tests/test_filewriter.py::TestCorrectAmbiguousVRElement::test_correct_ambiguous_raw_data_element", "pydicom/tests/test_filewriter.py::TestWriteAmbiguousVR::test_write_explicit_vr_raises", "pydicom/tests/test_filewriter.py::TestWriteAmbiguousVR::test_write_explicit_vr_little_endian", "pydicom/tests/test_filewriter.py::TestWriteAmbiguousVR::test_write_explicit_vr_big_endian", "pydicom/tests/test_filewriter.py::TestScratchWrite::testImpl_LE_deflen_write", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_preamble_default", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_preamble_custom", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_no_preamble", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_none_preamble", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_bad_preamble", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_bad_filename", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_prefix", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_prefix_none", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_ds_changed", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_raw_elements_preserved_implicit_vr", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_raw_elements_preserved_explicit_vr", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_convert_implicit_to_explicit_vr", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_write_dataset", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_write_dataset_with_explicit_vr", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_convert_implicit_to_explicit_vr_using_destination", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_convert_explicit_to_implicit_vr", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_convert_big_to_little_endian", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_convert_little_to_big_endian", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_changed_character_set", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_transfer_syntax_added", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_private_tag_vr_from_implicit_data", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_convert_rgb_from_implicit_to_explicit_vr", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_transfer_syntax_not_added", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_transfer_syntax_raises", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_media_storage_sop_class_uid_added", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_write_no_file_meta", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_raise_no_file_meta", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_add_file_meta", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_standard", "pydicom/tests/test_filewriter.py::TestWriteToStandard::test_commandset_no_written", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoToStandard::test_bad_elements", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoToStandard::test_missing_elements", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoToStandard::test_group_length", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoToStandard::test_group_length_updated", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoToStandard::test_version", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoToStandard::test_implementation_version_name_length", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoToStandard::test_implementation_class_uid_length", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoToStandard::test_filelike_position", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_preamble_default", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_preamble_custom", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_no_preamble", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_ds_unchanged", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_file_meta_unchanged", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_dataset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_preamble_dataset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_filemeta_dataset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_preamble_filemeta_dataset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_commandset_dataset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_preamble_commandset_dataset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_preamble_commandset_filemeta_dataset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_commandset_filemeta_dataset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_commandset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_commandset_filemeta", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_preamble_commandset", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_preamble_commandset_filemeta", "pydicom/tests/test_filewriter.py::TestWriteNonStandard::test_read_write_identical", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoNonStandard::test_transfer_syntax_not_added", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoNonStandard::test_bad_elements", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoNonStandard::test_missing_elements", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoNonStandard::test_group_length_updated", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoNonStandard::test_filelike_position", "pydicom/tests/test_filewriter.py::TestWriteFileMetaInfoNonStandard::test_meta_unchanged", "pydicom/tests/test_filewriter.py::TestWriteNumbers::test_write_empty_value", "pydicom/tests/test_filewriter.py::TestWriteNumbers::test_write_list", "pydicom/tests/test_filewriter.py::TestWriteNumbers::test_write_singleton", "pydicom/tests/test_filewriter.py::TestWriteNumbers::test_exception", "pydicom/tests/test_filewriter.py::TestWriteNumbers::test_write_big_endian", "pydicom/tests/test_filewriter.py::TestWriteOtherVRs::test_write_of", "pydicom/tests/test_filewriter.py::TestWriteOtherVRs::test_write_of_dataset", "pydicom/tests/test_filewriter.py::TestWritePN::test_no_encoding", "pydicom/tests/test_filewriter.py::TestWritePN::test_single_byte_multi_charset_groups", "pydicom/tests/test_filewriter.py::TestWritePN::test_single_byte_multi_charset_values", "pydicom/tests/test_filewriter.py::TestWriteText::test_no_encoding", "pydicom/tests/test_filewriter.py::TestWriteText::test_single_byte_multi_charset_text", "pydicom/tests/test_filewriter.py::TestWriteText::test_encode_mixed_charsets_text", "pydicom/tests/test_filewriter.py::TestWriteText::test_single_byte_multi_charset_text_multivalue", "pydicom/tests/test_filewriter.py::TestWriteText::test_invalid_encoding", "pydicom/tests/test_filewriter.py::TestWriteText::test_invalid_encoding_enforce_standard", "pydicom/tests/test_filewriter.py::TestWriteText::test_single_value_with_delimiters", "pydicom/tests/test_filewriter.py::TestWriteDT::test_format_dt", "pydicom/tests/test_filewriter.py::TestWriteUndefinedLengthPixelData::test_little_endian_correct_data", "pydicom/tests/test_filewriter.py::TestWriteUndefinedLengthPixelData::test_big_endian_correct_data", "pydicom/tests/test_filewriter.py::TestWriteUndefinedLengthPixelData::test_little_endian_incorrect_data", "pydicom/tests/test_filewriter.py::TestWriteUndefinedLengthPixelData::test_big_endian_incorrect_data", "pydicom/tests/test_filewriter.py::TestWriteUndefinedLengthPixelData::test_writing_to_gzip", "pydicom/tests/test_filewriter.py::TestWriteUndefinedLengthPixelData::test_writing_too_big_data_in_explicit_encoding"], "environment_setup_commit": "9d69811e539774f296c2f289839147e741251716", "query": "Error decoding dataset with ambiguous VR element when the value is None\nHi all,\r\n    I used the storescu in pynetdicom 1.5.3 to send the dicom ct files(both on mac and ubuntu): \r\n**python storescu.py 192.168.1.120 9002 ~/Downloads/test/**\r\n(I also tried https://pydicom.github.io/pynetdicom/stable/examples/storage.html#storage-scu)\r\nbut it throwed errors: \r\n\r\n_E: Failed to encode the supplied Dataset\r\nE: Store failed: /Users/me/Downloads/test/CT_S1_118.dcm\r\nE: Failed to encode the supplied Dataset\r\nTraceback (most recent call last):\r\n  File \"storescu.py\", line 283, in main\r\n    status = assoc.send_c_store(ds, ii)\r\n  File \"/Users/me/.pyenv/versions/3.8.2/lib/python3.8/site-packages/pynetdicom/association.py\", line 1736, in send_c_store\r\n    raise ValueError('Failed to encode the supplied Dataset')\r\nValueError: Failed to encode the supplied Dataset_\r\n\r\nBut I used to send same files with storescu in dcm4che successfully.\r\nFile attached.\r\n\r\n[test.zip](https://github.com/pydicom/pynetdicom/files/5258867/test.zip)\r\n\n", "task_id": "pydicom__pydicom-1194"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-1139", "base_commit": "b9fb05c177b685bf683f7f57b2d57374eb7d882d", "patch": "diff --git a/pydicom/valuerep.py b/pydicom/valuerep.py\n--- a/pydicom/valuerep.py\n+++ b/pydicom/valuerep.py\n@@ -1,6 +1,5 @@\n # Copyright 2008-2018 pydicom authors. See LICENSE file for details.\n \"\"\"Special classes for DICOM value representations (VR)\"\"\"\n-from copy import deepcopy\n from decimal import Decimal\n import re\n \n@@ -750,6 +749,25 @@ def __ne__(self, other):\n     def __str__(self):\n         return '='.join(self.components).__str__()\n \n+    def __next__(self):\n+        # Get next character or stop iteration\n+        if self._i < self._rep_len:\n+            c = self._str_rep[self._i]\n+            self._i += 1\n+            return c\n+        else:\n+            raise StopIteration\n+\n+    def __iter__(self):\n+        # Get string rep. and length, initialize index counter\n+        self._str_rep = self.__str__()\n+        self._rep_len = len(self._str_rep)\n+        self._i = 0\n+        return self\n+\n+    def __contains__(self, x):\n+        return x in self.__str__()\n+\n     def __repr__(self):\n         return '='.join(self.components).__repr__()\n \n", "test_patch": "diff --git a/pydicom/tests/test_valuerep.py b/pydicom/tests/test_valuerep.py\n--- a/pydicom/tests/test_valuerep.py\n+++ b/pydicom/tests/test_valuerep.py\n@@ -427,6 +427,62 @@ def test_hash(self):\n         )\n         assert hash(pn1) == hash(pn2)\n \n+    def test_next(self):\n+        \"\"\"Test that the next function works on it's own\"\"\"\n+        # Test getting the first character\n+        pn1 = PersonName(\"John^Doe^^Dr\", encodings=default_encoding)\n+        pn1_itr = iter(pn1)\n+        assert next(pn1_itr) == \"J\"\n+\n+        # Test getting multiple characters\n+        pn2 = PersonName(\n+            \"Yamada^Tarou=\u5c71\u7530^\u592a\u90ce=\u3084\u307e\u3060^\u305f\u308d\u3046\", [default_encoding, \"iso2022_jp\"]\n+        )\n+        pn2_itr = iter(pn2)\n+        assert next(pn2_itr) == \"Y\"\n+        assert next(pn2_itr) == \"a\"\n+\n+        # Test getting all characters\n+        pn3 = PersonName(\"SomeName\")\n+        pn3_itr = iter(pn3)\n+        assert next(pn3_itr) == \"S\"\n+        assert next(pn3_itr) == \"o\"\n+        assert next(pn3_itr) == \"m\"\n+        assert next(pn3_itr) == \"e\"\n+        assert next(pn3_itr) == \"N\"\n+        assert next(pn3_itr) == \"a\"\n+        assert next(pn3_itr) == \"m\"\n+        assert next(pn3_itr) == \"e\"\n+\n+        # Attempting to get next characeter should stop the iteration\n+        # I.e. next can only start once\n+        with pytest.raises(StopIteration):\n+            next(pn3_itr)\n+\n+        # Test that next() doesn't work without instantiating an iterator\n+        pn4 = PersonName(\"SomeName\")\n+        with pytest.raises(AttributeError):\n+            next(pn4)\n+\n+    def test_iterator(self):\n+        \"\"\"Test that iterators can be corretly constructed\"\"\"\n+        name_str = \"John^Doe^^Dr\"\n+        pn1 = PersonName(name_str)\n+        \n+        for i, c in enumerate(pn1):\n+            assert name_str[i] == c\n+\n+        # Ensure that multiple iterators can be created on the same variable\n+        for i, c in enumerate(pn1):\n+            assert name_str[i] == c\n+\n+    def test_contains(self):\n+        \"\"\"Test that characters can be check if they are within the name\"\"\"\n+        pn1 = PersonName(\"John^Doe\")\n+        assert (\"J\" in pn1) == True\n+        assert (\"o\" in pn1) == True\n+        assert (\"x\" in pn1) == False\n+\n \n class TestDateTime:\n     \"\"\"Unit tests for DA, DT, TM conversion to datetime objects\"\"\"\n", "problem_statement": "Make PersonName3 iterable\n```python\r\nfrom pydicom import Dataset\r\n\r\nds = Dataset()\r\nds.PatientName = 'SomeName'\r\n\r\n'S' in ds.PatientName\r\n```\r\n```\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\nTypeError: argument of type 'PersonName3' is not iterable\r\n```\r\n\r\nI'm not really sure if this is intentional or if PN elements should support `str` methods. And yes I know I can `str(ds.PatientName)` but it's a bit silly, especially when I keep having to write exceptions to my element iterators just for PN elements.\n", "hints_text": "I think it is reasonable to support at least some `str` methods (definitely `__contains__` for the example above), but there are many that don't make a lot of sense in this context though - e.g. `join`, `ljust`, `maketrans`, `splitlines` just to name a few, but I suppose each would either never be actually used or would have no effect.\r\n\r\nI have a vague memory that one or more of the `PersonName` classes was at one time subclassed from `str`, or at least that it was discussed... does anyone remember?  Maybe it would be easier now with only Python 3 supported.\n`PersonName` was derived from `str` or `unicode` in Python 2, but that caused a number of problems, which is why you switched to `PersonName3` in Python 3, I think. I agree though that it makes sense to implement `str` methods, either by implementing some of them, or generically by adding `__getattr__` that converts it to `str` and applies the attribute to that string. ", "created_at": "2020-06-26T11:47:17Z", "version": "2.0", "FAIL_TO_PASS": ["pydicom/tests/test_valuerep.py::TestPersonName::test_next", "pydicom/tests/test_valuerep.py::TestPersonName::test_iterator", "pydicom/tests/test_valuerep.py::TestPersonName::test_contains"], "PASS_TO_PASS": ["pydicom/tests/test_valuerep.py::TestTM::test_pickling", "pydicom/tests/test_valuerep.py::TestDT::test_pickling", "pydicom/tests/test_valuerep.py::TestDA::test_pickling", "pydicom/tests/test_valuerep.py::TestDS::test_empty_value", "pydicom/tests/test_valuerep.py::TestDS::test_float_values", "pydicom/tests/test_valuerep.py::TestDSfloat::test_pickling", "pydicom/tests/test_valuerep.py::TestDSfloat::test_str", "pydicom/tests/test_valuerep.py::TestDSfloat::test_repr", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_pickling", "pydicom/tests/test_valuerep.py::TestDSdecimal::test_float_value", "pydicom/tests/test_valuerep.py::TestIS::test_empty_value", "pydicom/tests/test_valuerep.py::TestIS::test_valid_value", "pydicom/tests/test_valuerep.py::TestIS::test_invalid_value", "pydicom/tests/test_valuerep.py::TestIS::test_pickling", "pydicom/tests/test_valuerep.py::TestIS::test_longint", "pydicom/tests/test_valuerep.py::TestIS::test_overflow", "pydicom/tests/test_valuerep.py::TestIS::test_str", "pydicom/tests/test_valuerep.py::TestIS::test_repr", "pydicom/tests/test_valuerep.py::TestBadValueRead::test_read_bad_value_in_VR_default", "pydicom/tests/test_valuerep.py::TestBadValueRead::test_read_bad_value_in_VR_enforce_valid_value", "pydicom/tests/test_valuerep.py::TestDecimalString::test_DS_decimal_set", "pydicom/tests/test_valuerep.py::TestDecimalString::test_valid_decimal_strings", "pydicom/tests/test_valuerep.py::TestDecimalString::test_invalid_decimal_strings", "pydicom/tests/test_valuerep.py::TestPersonName::test_last_first", "pydicom/tests/test_valuerep.py::TestPersonName::test_copy", "pydicom/tests/test_valuerep.py::TestPersonName::test_three_component", "pydicom/tests/test_valuerep.py::TestPersonName::test_formatting", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_kr", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_bytes", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_bytes_comp_delimiter", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_bytes_caret_delimiter", "pydicom/tests/test_valuerep.py::TestPersonName::test_unicode_jp_from_unicode", "pydicom/tests/test_valuerep.py::TestPersonName::test_not_equal", "pydicom/tests/test_valuerep.py::TestPersonName::test_encoding_carried", "pydicom/tests/test_valuerep.py::TestPersonName::test_hash", "pydicom/tests/test_valuerep.py::TestDateTime::test_date", "pydicom/tests/test_valuerep.py::TestDateTime::test_date_time", "pydicom/tests/test_valuerep.py::TestDateTime::test_time"], "environment_setup_commit": "9d69811e539774f296c2f289839147e741251716", "query": "Make PersonName3 iterable\n```python\r\nfrom pydicom import Dataset\r\n\r\nds = Dataset()\r\nds.PatientName = 'SomeName'\r\n\r\n'S' in ds.PatientName\r\n```\r\n```\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\nTypeError: argument of type 'PersonName3' is not iterable\r\n```\r\n\r\nI'm not really sure if this is intentional or if PN elements should support `str` methods. And yes I know I can `str(ds.PatientName)` but it's a bit silly, especially when I keep having to write exceptions to my element iterators just for PN elements.\n", "task_id": "pydicom__pydicom-1139"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-1256", "base_commit": "49a3da4a3d9c24d7e8427a25048a1c7d5c4f7724", "patch": "diff --git a/pydicom/jsonrep.py b/pydicom/jsonrep.py\n--- a/pydicom/jsonrep.py\n+++ b/pydicom/jsonrep.py\n@@ -226,7 +226,8 @@ def get_sequence_item(self, value):\n                     value_key = unique_value_keys[0]\n                     elem = DataElement.from_json(\n                         self.dataset_class, key, vr,\n-                        val[value_key], value_key\n+                        val[value_key], value_key,\n+                        self.bulk_data_element_handler\n                     )\n                 ds.add(elem)\n         return ds\n", "test_patch": "diff --git a/pydicom/tests/test_json.py b/pydicom/tests/test_json.py\n--- a/pydicom/tests/test_json.py\n+++ b/pydicom/tests/test_json.py\n@@ -354,3 +354,25 @@ def bulk_data_reader(tag, vr, value):\n         ds = Dataset().from_json(json.dumps(json_data), bulk_data_reader)\n \n         assert b'xyzzy' == ds[0x00091002].value\n+\n+    def test_bulk_data_reader_is_called_within_SQ(self):\n+        def bulk_data_reader(_):\n+            return b'xyzzy'\n+\n+        json_data = {\n+            \"003a0200\": {\n+                \"vr\": \"SQ\", \n+                \"Value\": [\n+                    {\n+                        \"54001010\": {\n+                            \"vr\": \"OW\",\n+                            \"BulkDataURI\": \"https://a.dummy.url\"\n+                        }\n+                    }\n+                ]\n+            }\n+        }\n+\n+        ds = Dataset().from_json(json.dumps(json_data), bulk_data_reader)\n+\n+        assert b'xyzzy' == ds[0x003a0200].value[0][0x54001010].value\n", "problem_statement": "from_json does not correctly convert BulkDataURI's in SQ data elements\n**Describe the bug**\r\nWhen a DICOM object contains large data elements in SQ elements and is converted to JSON, those elements are correctly turned into BulkDataURI's. However, when the JSON is converted back to DICOM using from_json, the BulkDataURI's in SQ data elements are not converted back and warnings are thrown.\r\n\r\n**Expected behavior**\r\nThe BulkDataURI's in SQ data elements get converted back correctly.\r\n\r\n**Steps To Reproduce**\r\nTake the `waveform_ecg.dcm` in the test data, convert it to JSON, and then convert the JSON to DICOM\r\n\r\n**Your environment**\r\nmodule       | version\r\n------       | -------\r\nplatform     | macOS-10.15.7-x86_64-i386-64bit\r\nPython       | 3.8.2 (v3.8.2:7b3ab5921f, Feb 24 2020, 17:52:18)  [Clang 6.0 (clang-600.0.57)]\r\npydicom      | 2.1.0\r\ngdcm         | _module not found_\r\njpeg_ls      | _module not found_\r\nnumpy        | _module not found_\r\nPIL          | _module not found_\r\n\r\nThe problem is in `jsonrep.py` at line 227. I plan on submitting a pull-request today for this.\n", "hints_text": "", "created_at": "2020-11-04T21:13:33Z", "version": "2.1", "FAIL_TO_PASS": ["pydicom/tests/test_json.py::TestBinary::test_bulk_data_reader_is_called_within_SQ"], "PASS_TO_PASS": ["pydicom/tests/test_json.py::TestPersonName::test_json_pn_from_file", "pydicom/tests/test_json.py::TestPersonName::test_pn_components_to_json", "pydicom/tests/test_json.py::TestPersonName::test_pn_components_from_json", "pydicom/tests/test_json.py::TestPersonName::test_empty_value", "pydicom/tests/test_json.py::TestPersonName::test_multi_value_to_json", "pydicom/tests/test_json.py::TestPersonName::test_dataelem_from_json", "pydicom/tests/test_json.py::TestAT::test_to_json", "pydicom/tests/test_json.py::TestAT::test_from_json", "pydicom/tests/test_json.py::TestAT::test_invalid_value_in_json", "pydicom/tests/test_json.py::TestAT::test_invalid_tag_in_json", "pydicom/tests/test_json.py::TestDataSetToJson::test_json_from_dicom_file", "pydicom/tests/test_json.py::TestDataSetToJson::test_roundtrip", "pydicom/tests/test_json.py::TestDataSetToJson::test_dataset_dumphandler", "pydicom/tests/test_json.py::TestDataSetToJson::test_dataelement_dumphandler", "pydicom/tests/test_json.py::TestDataSetToJson::test_sort_order", "pydicom/tests/test_json.py::TestSequence::test_nested_sequences", "pydicom/tests/test_json.py::TestBinary::test_inline_binary", "pydicom/tests/test_json.py::TestBinary::test_invalid_inline_binary", "pydicom/tests/test_json.py::TestBinary::test_valid_bulkdata_uri", "pydicom/tests/test_json.py::TestBinary::test_invalid_bulkdata_uri", "pydicom/tests/test_json.py::TestBinary::test_bulk_data_reader_is_called", "pydicom/tests/test_json.py::TestBinary::test_bulk_data_reader_is_called_2"], "environment_setup_commit": "506ecea8f378dc687d5c504788fc78810a190b7a", "query": "from_json does not correctly convert BulkDataURI's in SQ data elements\n**Describe the bug**\r\nWhen a DICOM object contains large data elements in SQ elements and is converted to JSON, those elements are correctly turned into BulkDataURI's. However, when the JSON is converted back to DICOM using from_json, the BulkDataURI's in SQ data elements are not converted back and warnings are thrown.\r\n\r\n**Expected behavior**\r\nThe BulkDataURI's in SQ data elements get converted back correctly.\r\n\r\n**Steps To Reproduce**\r\nTake the `waveform_ecg.dcm` in the test data, convert it to JSON, and then convert the JSON to DICOM\r\n\r\n**Your environment**\r\nmodule       | version\r\n------       | -------\r\nplatform     | macOS-10.15.7-x86_64-i386-64bit\r\nPython       | 3.8.2 (v3.8.2:7b3ab5921f, Feb 24 2020, 17:52:18)  [Clang 6.0 (clang-600.0.57)]\r\npydicom      | 2.1.0\r\ngdcm         | _module not found_\r\njpeg_ls      | _module not found_\r\nnumpy        | _module not found_\r\nPIL          | _module not found_\r\n\r\nThe problem is in `jsonrep.py` at line 227. I plan on submitting a pull-request today for this.\n", "task_id": "pydicom__pydicom-1256"}]