[{"repo": "sqlfluff/sqlfluff", "instance_id": "sqlfluff__sqlfluff-4051", "base_commit": "c3defb095b1aa7fe23c4bd430fdff2ce6ed6161d", "patch": "diff --git a/src/sqlfluff/cli/commands.py b/src/sqlfluff/cli/commands.py\n--- a/src/sqlfluff/cli/commands.py\n+++ b/src/sqlfluff/cli/commands.py\n@@ -137,24 +137,14 @@ def red_log_filter(record: logging.LogRecord) -> bool:\n class PathAndUserErrorHandler:\n     \"\"\"Make an API call but with error handling for the CLI.\"\"\"\n \n-    def __init__(self, formatter, paths):\n+    def __init__(self, formatter):\n         self.formatter = formatter\n-        self.paths = paths\n \n     def __enter__(self):\n         return self\n \n     def __exit__(self, exc_type, exc_val, exc_tb):\n-        if exc_type is OSError:\n-            click.echo(\n-                self.formatter.colorize(\n-                    f\"The path(s) { self.paths } could not be \"\n-                    \"accessed. Check it/they exist(s).\",\n-                    Color.red,\n-                )\n-            )\n-            sys.exit(EXIT_ERROR)\n-        elif exc_type is SQLFluffUserError:\n+        if exc_type is SQLFluffUserError:\n             click.echo(\n                 \"\\nUser Error: \"\n                 + self.formatter.colorize(\n@@ -584,7 +574,7 @@ def lint(\n     if verbose >= 1:\n         click.echo(format_linting_result_header())\n \n-    with PathAndUserErrorHandler(formatter, paths):\n+    with PathAndUserErrorHandler(formatter):\n         # add stdin if specified via lone '-'\n         if (\"-\",) == paths:\n             result = lnt.lint_string_wrapped(sys.stdin.read(), fname=\"stdin\")\n@@ -833,7 +823,7 @@ def fix(\n     # Lint the paths (not with the fix argument at this stage), outputting as we go.\n     click.echo(\"==== finding fixable violations ====\")\n \n-    with PathAndUserErrorHandler(formatter, paths):\n+    with PathAndUserErrorHandler(formatter):\n         result = lnt.lint_paths(\n             paths,\n             fix=True,\n@@ -1051,7 +1041,7 @@ def parse(\n     t0 = time.monotonic()\n \n     # handle stdin if specified via lone '-'\n-    with PathAndUserErrorHandler(formatter, path):\n+    with PathAndUserErrorHandler(formatter):\n         if \"-\" == path:\n             parsed_strings = [\n                 lnt.parse_string(\n@@ -1156,7 +1146,7 @@ def render(\n     )\n \n     # handle stdin if specified via lone '-'\n-    with PathAndUserErrorHandler(formatter, path):\n+    with PathAndUserErrorHandler(formatter):\n         if \"-\" == path:\n             raw_sql = sys.stdin.read()\n             fname = \"stdin\"\ndiff --git a/src/sqlfluff/core/linter/linter.py b/src/sqlfluff/core/linter/linter.py\n--- a/src/sqlfluff/core/linter/linter.py\n+++ b/src/sqlfluff/core/linter/linter.py\n@@ -27,6 +27,7 @@\n     SQLLintError,\n     SQLParseError,\n     SQLFluffSkipFile,\n+    SQLFluffUserError,\n )\n from sqlfluff.core.parser import Lexer, Parser, RegexLexer\n from sqlfluff.core.file_helpers import get_encoding\n@@ -969,7 +970,9 @@ def paths_from_path(\n             if ignore_non_existent_files:\n                 return []\n             else:\n-                raise OSError(\"Specified path does not exist\")\n+                raise SQLFluffUserError(\n+                    f\"Specified path does not exist. Check it/they exist(s): {path}.\"\n+                )\n \n         # Files referred to exactly are also ignored if\n         # matched, but we warn the users when that happens\n", "test_patch": "diff --git a/test/cli/commands_test.py b/test/cli/commands_test.py\n--- a/test/cli/commands_test.py\n+++ b/test/cli/commands_test.py\n@@ -1203,7 +1203,10 @@ def test__cli__command_lint_serialize_from_stdin(serialize, sql, expected, exit_\n def test__cli__command_fail_nice_not_found(command):\n     \"\"\"Check commands fail as expected when then don't find files.\"\"\"\n     result = invoke_assert_code(args=command, ret_code=2)\n-    assert \"could not be accessed\" in result.output\n+    assert (\n+        \"User Error: Specified path does not exist. Check it/they \"\n+        \"exist(s): this_file_does_not_exist.sql\"\n+    ) in result.output\n \n \n @patch(\"click.utils.should_strip_ansi\")\ndiff --git a/test/core/linter_test.py b/test/core/linter_test.py\n--- a/test/core/linter_test.py\n+++ b/test/core/linter_test.py\n@@ -16,6 +16,7 @@\n     SQLBaseError,\n     SQLLintError,\n     SQLParseError,\n+    SQLFluffUserError,\n )\n from sqlfluff.cli.formatters import OutputStreamFormatter\n from sqlfluff.cli.outputstream import make_output_stream\n@@ -120,9 +121,9 @@ def test__linter__skip_large_bytes(filesize, raises_skip):\n \n \n def test__linter__path_from_paths__not_exist():\n-    \"\"\"Test extracting paths from a file path.\"\"\"\n+    \"\"\"Test that the right errors are raise when a file doesn't exist.\"\"\"\n     lntr = Linter()\n-    with pytest.raises(IOError):\n+    with pytest.raises(SQLFluffUserError):\n         lntr.paths_from_path(\"asflekjfhsakuefhse\")\n \n \n", "problem_statement": "Misleading path does not exist message\nIt looks like if _at least one_ of the paths provided to sqlfluff do not exist, it will display an error message implying that _all_ of the supplied paths do not exist:\r\n\r\n```bash\r\ndbt@b54bee9ced88:/workspaces/dbt-dutchie$ sqlfluff fix models/shared/dispensaries.sql models/shares/dispensary_chains.sql\r\n==== finding fixable violations ====\r\n=== [dbt templater] Compiling dbt project...\r\n== [models/shared/dispensaries.sql] FAIL\r\nL:   6 | P:   2 | L003 | Indentation not consistent with line #376\r\nL:   8 | P:   2 | L003 | Indentation not consistent with line #376\r\nL:   9 | P:   3 | L003 | Line over-indented compared to line #376\r\nL:  10 | P:   2 | L003 | Indentation not consistent with line #376\r\nL:  12 | P:   2 | L003 | Indentation not consistent with line #376\r\nL:  13 | P:   3 | L003 | Line over-indented compared to line #376\r\nL:  14 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  15 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  16 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  17 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  18 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  19 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  20 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  21 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  22 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  23 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  24 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  25 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  26 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  27 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  28 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  29 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  30 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  31 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  32 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  33 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  34 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  58 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL:  35 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  36 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  37 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  38 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  39 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  40 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  41 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  42 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  43 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  44 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  45 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  46 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  47 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  48 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  49 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  50 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  51 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  52 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  53 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  54 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  55 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  56 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  57 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  58 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  59 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  60 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  61 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  62 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  63 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  64 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  65 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  66 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  67 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  68 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  69 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  70 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  71 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  72 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  73 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  74 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  75 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  76 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  77 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  78 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  79 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  80 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  81 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  82 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  83 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  84 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  85 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  86 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  87 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  88 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  89 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  90 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  91 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  92 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  92 | P:  44 | L001 | Unnecessary trailing whitespace.\r\nL:  93 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  94 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  95 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  96 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  97 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  98 | P:   4 | L003 | Line over-indented compared to line #376\r\nL:  99 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 100 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 101 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 102 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 103 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 104 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 105 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 106 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 107 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 108 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 109 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 110 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 111 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 112 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 113 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 114 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 115 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 116 | P:   3 | L003 | Line over-indented compared to line #376\r\nL: 235 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 117 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 118 | P:   3 | L003 | Line over-indented compared to line #376\r\nL: 119 | P:   4 | L003 | Line over-indented compared to line #376\r\nL: 120 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 121 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 122 | P:   2 | L003 | Indentation not consistent with line #376\r\nL: 339 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 343 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 347 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 351 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 355 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 358 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 361 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 364 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 367 | P:   1 | L004 | Incorrect indentation type found in file.\r\nL: 370 | P:   1 | L004 | Incorrect indentation type found in file.\r\nThe path(s) ('models/shared/dispensaries.sql', 'models/shares/dispensary_chains.sql') could not be accessed. Check it/they exist(s).\r\n```\r\n\r\n## Expected Behaviour\r\nI would expect only the unaccessible paths to be included in the error message.\r\n\r\n## Observed Behaviour\r\nSee above\r\n\r\n## Version\r\n```bash\r\ndbt@b54bee9ced88:/workspaces/dbt-dutchie$ sqlfluff --version\r\nsqlfluff, version 0.5.2\r\n```\r\n\r\n```bash\r\ndbt@b54bee9ced88:/workspaces/dbt-dutchie$ python --version\r\nPython 3.8.6\r\n```\r\n\r\n## Configuration\r\n```\r\n[sqlfluff]\r\ndialect = snowflake\r\ntemplater = dbt\r\nrules = L001,L002,L003,L004,L005,L006\r\nignore = parsing,templating\r\n\r\n[sqlfluff:rules]\r\nmax_line_length = 120\r\ncomma_style = trailing\r\n\r\n[sqlfluff:rules:L010]\r\ncapitalisation_policy = upper\r\n```\r\n\n", "hints_text": "", "created_at": "2022-11-09T18:11:06Z", "version": "1.3", "FAIL_TO_PASS": ["test/cli/commands_test.py::test__cli__command_fail_nice_not_found[command0]", "test/cli/commands_test.py::test__cli__command_fail_nice_not_found[command1]", "test/core/linter_test.py::test__linter__path_from_paths__not_exist"], "PASS_TO_PASS": ["test/cli/commands_test.py::test__cli__command_directed", "test/cli/commands_test.py::test__cli__command_dialect", "test/cli/commands_test.py::test__cli__command_no_dialect", "test/cli/commands_test.py::test__cli__command_parse_error_dialect_explicit_warning", "test/cli/commands_test.py::test__cli__command_parse_error_dialect_implicit_warning", "test/cli/commands_test.py::test__cli__command_dialect_legacy", "test/cli/commands_test.py::test__cli__command_extra_config_fail", "test/cli/commands_test.py::test__cli__command_lint_stdin[command0]", "test/cli/commands_test.py::test__cli__command_lint_stdin[command1]", "test/cli/commands_test.py::test__cli__command_lint_stdin[command2]", "test/cli/commands_test.py::test__cli__command_lint_stdin[command3]", "test/cli/commands_test.py::test__cli__command_render_stdin", "test/cli/commands_test.py::test__cli__command_lint_parse[command0]", "test/cli/commands_test.py::test__cli__command_lint_parse[command1]", "test/cli/commands_test.py::test__cli__command_lint_parse[command2]", "test/cli/commands_test.py::test__cli__command_lint_parse[command3]", "test/cli/commands_test.py::test__cli__command_lint_parse[command4]", "test/cli/commands_test.py::test__cli__command_lint_parse[command5]", "test/cli/commands_test.py::test__cli__command_lint_parse[command6]", "test/cli/commands_test.py::test__cli__command_lint_parse[command7]", "test/cli/commands_test.py::test__cli__command_lint_parse[command8]", "test/cli/commands_test.py::test__cli__command_lint_parse[command9]", "test/cli/commands_test.py::test__cli__command_lint_parse[command10]", "test/cli/commands_test.py::test__cli__command_lint_parse[command11]", "test/cli/commands_test.py::test__cli__command_lint_parse[command12]", "test/cli/commands_test.py::test__cli__command_lint_parse[command13]", "test/cli/commands_test.py::test__cli__command_lint_parse[command14]", "test/cli/commands_test.py::test__cli__command_lint_parse[command15]", "test/cli/commands_test.py::test__cli__command_lint_parse[command16]", "test/cli/commands_test.py::test__cli__command_lint_parse[command17]", "test/cli/commands_test.py::test__cli__command_lint_parse[command18]", "test/cli/commands_test.py::test__cli__command_lint_parse[command19]", "test/cli/commands_test.py::test__cli__command_lint_parse[command20]", "test/cli/commands_test.py::test__cli__command_lint_parse[command21]", "test/cli/commands_test.py::test__cli__command_lint_parse[command22]", "test/cli/commands_test.py::test__cli__command_lint_parse[command23]", "test/cli/commands_test.py::test__cli__command_lint_parse[command24]", "test/cli/commands_test.py::test__cli__command_lint_parse[command25]", "test/cli/commands_test.py::test__cli__command_lint_parse_with_retcode[command0-1]", "test/cli/commands_test.py::test__cli__command_lint_parse_with_retcode[command1-1]", "test/cli/commands_test.py::test__cli__command_lint_parse_with_retcode[command2-1]", "test/cli/commands_test.py::test__cli__command_lint_parse_with_retcode[command3-1]", "test/cli/commands_test.py::test__cli__command_lint_parse_with_retcode[command4-1]", "test/cli/commands_test.py::test__cli__command_lint_warning_explicit_file_ignored", "test/cli/commands_test.py::test__cli__command_lint_skip_ignore_files", "test/cli/commands_test.py::test__cli__command_lint_ignore_local_config", "test/cli/commands_test.py::test__cli__command_versioning", "test/cli/commands_test.py::test__cli__command_version", "test/cli/commands_test.py::test__cli__command_rules", "test/cli/commands_test.py::test__cli__command_dialects", "test/cli/commands_test.py::test__cli__command__fix[L001-test/fixtures/linter/indentation_errors.sql]", "test/cli/commands_test.py::test__cli__command__fix[L008-test/fixtures/linter/whitespace_errors.sql]", "test/cli/commands_test.py::test__cli__command__fix[L008-test/fixtures/linter/indentation_errors.sql]", "test/cli/commands_test.py::test__cli__command__fix[L003-test/fixtures/linter/indentation_error_hard.sql]", "test/cli/commands_test.py::test__cli__fix_error_handling_behavior[1_lint_error_1_unsuppressed_parse_error]", "test/cli/commands_test.py::test__cli__fix_error_handling_behavior[1_lint_error_1_unsuppressed_templating_error]", "test/cli/commands_test.py::test__cli__fix_error_handling_behavior[1_lint_error_1_suppressed_parse_error]", "test/cli/commands_test.py::test__cli__fix_error_handling_behavior[0_lint_errors_1_unsuppressed_parse_error]", "test/cli/commands_test.py::test__cli__fix_error_handling_behavior[0_lint_errors_1_suppressed_parse_error]", "test/cli/commands_test.py::test__cli__fix_error_handling_behavior[1_lint_error_1_unsuppressed_parse_error_FIX_EVEN_UNPARSABLE]", "test/cli/commands_test.py::test__cli__fix_error_handling_behavior[2_files_with_lint_errors_1_unsuppressed_parse_error]", "test/cli/commands_test.py::test_cli_fix_even_unparsable[command-line-False]", "test/cli/commands_test.py::test_cli_fix_even_unparsable[command-line-True]", "test/cli/commands_test.py::test_cli_fix_even_unparsable[config-file-False]", "test/cli/commands_test.py::test_cli_fix_even_unparsable[config-file-True]", "test/cli/commands_test.py::test__cli__fix_loop_limit_behavior[--", "test/cli/commands_test.py::test__cli__command_fix_stdin[select", "test/cli/commands_test.py::test__cli__command_fix_stdin[", "test/cli/commands_test.py::test__cli__command_fix_stdin[SELECT", "test/cli/commands_test.py::test__cli__command_fix_stdin_logging_to_stderr", "test/cli/commands_test.py::test__cli__command_fix_stdin_safety", "test/cli/commands_test.py::test__cli__command_fix_stdin_error_exit_code[create", "test/cli/commands_test.py::test__cli__command_fix_stdin_error_exit_code[select", "test/cli/commands_test.py::test__cli__command__fix_no_force[L001-test/fixtures/linter/indentation_errors.sql-y-0-0]", "test/cli/commands_test.py::test__cli__command__fix_no_force[L001-test/fixtures/linter/indentation_errors.sql-n-1-1]", "test/cli/commands_test.py::test__cli__command_parse_serialize_from_stdin[None-yaml]", "test/cli/commands_test.py::test__cli__command_parse_serialize_from_stdin[None-json]", "test/cli/commands_test.py::test__cli__command_parse_serialize_from_stdin[outfile-yaml]", "test/cli/commands_test.py::test__cli__command_parse_serialize_from_stdin[outfile-json]", "test/cli/commands_test.py::test__cli__command_lint_serialize_from_stdin[select", "test/cli/commands_test.py::test__cli__command_lint_serialize_from_stdin[SElect", "test/cli/commands_test.py::test__cli__command_lint_nocolor", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[None-human]", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[None-yaml]", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[None-json]", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[None-github-annotation]", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[None-github-annotation-native]", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[outfile-human]", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[outfile-yaml]", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[outfile-json]", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[outfile-github-annotation]", "test/cli/commands_test.py::test__cli__command_lint_serialize_multiple_files[outfile-github-annotation-native]", "test/cli/commands_test.py::test__cli__command_lint_serialize_github_annotation", "test/cli/commands_test.py::test__cli__command_lint_serialize_github_annotation_native", "test/cli/commands_test.py::test__cli__command_lint_serialize_annotation_level_error_failure_equivalent[github-annotation]", "test/cli/commands_test.py::test__cli__command_lint_serialize_annotation_level_error_failure_equivalent[github-annotation-native]", "test/cli/commands_test.py::test___main___help", "test/cli/commands_test.py::test_encoding[utf-8-ascii]", "test/cli/commands_test.py::test_encoding[utf-8-sig-UTF-8-SIG]", "test/cli/commands_test.py::test_encoding[utf-32-UTF-32]", "test/cli/commands_test.py::test_cli_encoding[utf-8-command-line-False]", "test/cli/commands_test.py::test_cli_encoding[utf-8-SIG-command-line-True]", "test/cli/commands_test.py::test_cli_encoding[utf-8-config-file-False]", "test/cli/commands_test.py::test_cli_encoding[utf-8-SIG-config-file-True]", "test/cli/commands_test.py::test_cli_no_disable_noqa_flag", "test/cli/commands_test.py::test_cli_disable_noqa_flag", "test/cli/commands_test.py::test_cli_get_default_config", "test/cli/commands_test.py::TestProgressBars::test_cli_lint_disabled_progress_bar", "test/cli/commands_test.py::TestProgressBars::test_cli_lint_disabled_progress_bar_deprecated_option", "test/cli/commands_test.py::TestProgressBars::test_cli_lint_enabled_progress_bar", "test/cli/commands_test.py::TestProgressBars::test_cli_lint_enabled_progress_bar_multiple_paths", "test/cli/commands_test.py::TestProgressBars::test_cli_lint_enabled_progress_bar_multiple_files", "test/cli/commands_test.py::test__cli__fix_multiple_errors_no_show_errors", "test/cli/commands_test.py::test__cli__fix_multiple_errors_show_errors", "test/cli/commands_test.py::test__cli__multiple_files__fix_multiple_errors_show_errors", "test/cli/commands_test.py::test__cli__render_fail", "test/cli/commands_test.py::test__cli__render_pass", "test/core/linter_test.py::test__linter__path_from_paths__dir", "test/core/linter_test.py::test__linter__path_from_paths__default", "test/core/linter_test.py::test__linter__path_from_paths__exts", "test/core/linter_test.py::test__linter__path_from_paths__file", "test/core/linter_test.py::test__linter__skip_large_bytes[0-False]", "test/core/linter_test.py::test__linter__skip_large_bytes[5-True]", "test/core/linter_test.py::test__linter__skip_large_bytes[2000-False]", "test/core/linter_test.py::test__linter__path_from_paths__not_exist_ignore", "test/core/linter_test.py::test__linter__path_from_paths__explicit_ignore", "test/core/linter_test.py::test__linter__path_from_paths__sqlfluffignore_current_directory", "test/core/linter_test.py::test__linter__path_from_paths__dot", "test/core/linter_test.py::test__linter__path_from_paths__ignore[test/fixtures/linter/sqlfluffignore]", "test/core/linter_test.py::test__linter__path_from_paths__ignore[test/fixtures/linter/sqlfluffignore/]", "test/core/linter_test.py::test__linter__path_from_paths__ignore[test/fixtures/linter/sqlfluffignore/.]", "test/core/linter_test.py::test__linter__lint_string_vs_file[test/fixtures/linter/indentation_errors.sql]", "test/core/linter_test.py::test__linter__lint_string_vs_file[test/fixtures/linter/whitespace_errors.sql]", "test/core/linter_test.py::test__linter__get_violations_filter_rules[None-7]", "test/core/linter_test.py::test__linter__get_violations_filter_rules[L010-2]", "test/core/linter_test.py::test__linter__get_violations_filter_rules[rules2-2]", "test/core/linter_test.py::test__linter__linting_result__sum_dicts", "test/core/linter_test.py::test__linter__linting_result__combine_dicts", "test/core/linter_test.py::test__linter__linting_result_check_tuples_by_path[False-list]", "test/core/linter_test.py::test__linter__linting_result_check_tuples_by_path[True-dict]", "test/core/linter_test.py::test__linter__linting_result_get_violations[1]", "test/core/linter_test.py::test__linter__linting_result_get_violations[2]", "test/core/linter_test.py::test__linter__linting_parallel_thread[False]", "test/core/linter_test.py::test__linter__linting_parallel_thread[True]", "test/core/linter_test.py::test_lint_path_parallel_wrapper_exception", "test/core/linter_test.py::test__linter__get_runner_processes[512-1-1]", "test/core/linter_test.py::test__linter__get_runner_processes[512-0-512]", "test/core/linter_test.py::test__linter__get_runner_processes[512--12-500]", "test/core/linter_test.py::test__linter__get_runner_processes[512-5-5]", "test/core/linter_test.py::test__linter__get_runner_processes[1--1-1]", "test/core/linter_test.py::test__linter__linting_unexpected_error_handled_gracefully", "test/core/linter_test.py::test__linter__raises_malformed_noqa", "test/core/linter_test.py::test__linter__empty_file", "test/core/linter_test.py::test__linter__mask_templated_violations[True-check_tuples0]", "test/core/linter_test.py::test__linter__mask_templated_violations[False-check_tuples1]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8.sql-autodetect-False]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8-sig.sql-autodetect-False]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8.sql-utf-8-False]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8-sig.sql-utf-8-True]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8.sql-utf-8-sig-False]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8-sig.sql-utf-8-sig-False]", "test/core/linter_test.py::test_parse_noqa[-None]", "test/core/linter_test.py::test_parse_noqa[noqa-expected1]", "test/core/linter_test.py::test_parse_noqa[noqa?-SQLParseError]", "test/core/linter_test.py::test_parse_noqa[noqa:-expected3]", "test/core/linter_test.py::test_parse_noqa[noqa:L001,L002-expected4]", "test/core/linter_test.py::test_parse_noqa[noqa:", "test/core/linter_test.py::test_parse_noqa[Inline", "test/core/linter_test.py::test_parse_noqa_no_dups", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_no_ignore]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_specific_line]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_different_specific_line]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_different_specific_rule]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_enable_this_range]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_disable_this_range]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_1_ignore_disable_specific_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_2_ignore_disable_specific_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_3_ignore_disable_specific_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_4_ignore_disable_specific_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_1_ignore_disable_all_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_2_ignore_disable_all_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_3_ignore_disable_all_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_4_ignore_disable_all_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[4_violations_two_types_disable_specific_enable_all]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[4_violations_two_types_disable_all_enable_specific]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violations_comment_inline_ignore]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[2_violations_comment_inline_ignore]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violations_comment_inline_glob_ignore]", "test/core/linter_test.py::test_linter_noqa", "test/core/linter_test.py::test_linter_noqa_with_templating", "test/core/linter_test.py::test_linter_noqa_template_errors", "test/core/linter_test.py::test_linter_noqa_prs", "test/core/linter_test.py::test_linter_noqa_tmp", "test/core/linter_test.py::test_linter_noqa_disable", "test/core/linter_test.py::test_delayed_exception", "test/core/linter_test.py::test__attempt_to_change_templater_warning", "test/core/linter_test.py::test_safe_create_replace_file[utf8_create]", "test/core/linter_test.py::test_safe_create_replace_file[utf8_update]", "test/core/linter_test.py::test_safe_create_replace_file[utf8_special_char]", "test/core/linter_test.py::test_safe_create_replace_file[incorrect_encoding]", "test/core/linter_test.py::test_advanced_api_methods", "test/core/linter_test.py::test_normalise_newlines", "test/core/linter_test.py::test_require_match_parse_grammar"], "environment_setup_commit": "dc59c2a5672aacedaf91f0e6129b467eefad331b"}, {"repo": "sqlfluff/sqlfluff", "instance_id": "sqlfluff__sqlfluff-1733", "base_commit": "a1579a16b1d8913d9d7c7d12add374a290bcc78c", "patch": "diff --git a/src/sqlfluff/rules/L039.py b/src/sqlfluff/rules/L039.py\n--- a/src/sqlfluff/rules/L039.py\n+++ b/src/sqlfluff/rules/L039.py\n@@ -44,7 +44,9 @@ def _eval(self, context: RuleContext) -> Optional[List[LintResult]]:\n                 # This is to avoid indents\n                 if not prev_newline:\n                     prev_whitespace = seg\n-                prev_newline = False\n+                # We won't set prev_newline to False, just for whitespace\n+                # in case there's multiple indents, inserted by other rule\n+                # fixes (see #1713)\n             elif seg.is_type(\"comment\"):\n                 prev_newline = False\n                 prev_whitespace = None\n", "test_patch": "diff --git a/test/rules/std_L003_L036_L039_combo_test.py b/test/rules/std_L003_L036_L039_combo_test.py\nnew file mode 100644\n--- /dev/null\n+++ b/test/rules/std_L003_L036_L039_combo_test.py\n@@ -0,0 +1,36 @@\n+\"\"\"Tests issue #1373 doesn't reoccur.\n+\n+The combination of L003 (incorrect indentation), L036 (select targets),\n+and L039 (unnecessary white space) can result in incorrect indentation.\n+\"\"\"\n+\n+import sqlfluff\n+\n+\n+def test__rules__std_L003_L036_L039():\n+    \"\"\"Verify that double indents don't flag L039.\"\"\"\n+    sql = \"\"\"\n+    WITH example AS (\n+        SELECT my_id,\n+            other_thing,\n+            one_more\n+        FROM\n+            my_table\n+    )\n+\n+    SELECT *\n+    FROM example\\n\"\"\"\n+    fixed_sql = \"\"\"\n+    WITH example AS (\n+        SELECT\n+            my_id,\n+            other_thing,\n+            one_more\n+        FROM\n+            my_table\n+    )\n+\n+    SELECT *\n+    FROM example\\n\"\"\"\n+    result = sqlfluff.fix(sql)\n+    assert result == fixed_sql\ndiff --git a/test/rules/std_L016_L36_combo.py b/test/rules/std_L016_L36_combo_test.py\nsimilarity index 100%\nrename from test/rules/std_L016_L36_combo.py\nrename to test/rules/std_L016_L36_combo_test.py\n", "problem_statement": "Extra space when first field moved to new line in a WITH statement\nNote, the query below uses a `WITH` statement. If I just try to fix the SQL within the CTE, this works fine.\r\n\r\nGiven the following SQL:\r\n\r\n```sql\r\nWITH example AS (\r\n    SELECT my_id,\r\n        other_thing,\r\n        one_more\r\n    FROM\r\n        my_table\r\n)\r\n\r\nSELECT *\r\nFROM example\r\n```\r\n\r\n## Expected Behaviour\r\n\r\nafter running `sqlfluff fix` I'd expect (`my_id` gets moved down and indented properly):\r\n\r\n```sql\r\nWITH example AS (\r\n    SELECT\r\n        my_id,\r\n        other_thing,\r\n        one_more\r\n    FROM\r\n        my_table\r\n)\r\n\r\nSELECT *\r\nFROM example\r\n```\r\n\r\n## Observed Behaviour\r\n\r\nafter running `sqlfluff fix` we get (notice that `my_id` is indented one extra space)\r\n\r\n```sql\r\nWITH example AS (\r\n    SELECT\r\n         my_id,\r\n        other_thing,\r\n        one_more\r\n    FROM\r\n        my_table\r\n)\r\n\r\nSELECT *\r\nFROM example\r\n```\r\n\r\n## Steps to Reproduce\r\n\r\nNoted above. Create a file with the initial SQL and fun `sqfluff fix` on it.\r\n\r\n## Dialect\r\n\r\nRunning with default config.\r\n\r\n## Version\r\nInclude the output of `sqlfluff --version` along with your Python version\r\n\r\nsqlfluff, version 0.7.0\r\nPython 3.7.5\r\n\r\n## Configuration\r\n\r\nDefault config.\r\n\n", "hints_text": "Does running `sqlfluff fix` again correct the SQL?\n@tunetheweb yes, yes it does. Is that something that the user is supposed to do (run it multiple times) or is this indeed a bug?\nIdeally not, but there are some circumstances where it\u2019s understandable that would happen. This however seems an easy enough example where it should not happen.\nThis appears to be a combination of rules L036, L003, and L039 not playing nicely together.\r\n\r\nThe original error is rule L036 and it produces this:\r\n\r\n```sql\r\nWITH example AS (\r\n    SELECT\r\nmy_id,\r\n        other_thing,\r\n        one_more\r\n    FROM\r\n        my_table\r\n)\r\n\r\nSELECT *\r\nFROM example\r\n```\r\n\r\nThat is, it moves the `my_id` down to the newline but does not even try to fix the indentation.\r\n\r\nThen we have another run through and L003 spots the lack of indentation and fixes it by adding the first set of whitespace:\r\n\r\n```sql\r\nWITH example AS (\r\n    SELECT\r\n    my_id,\r\n        other_thing,\r\n        one_more\r\n    FROM\r\n        my_table\r\n)\r\n\r\nSELECT *\r\nFROM example\r\n```\r\n\r\nThen we have another run through and L003 spots that there still isn't enough indentation and fixes it by adding the second set of whitespace:\r\n\r\n```sql\r\nWITH example AS (\r\n    SELECT\r\n        my_id,\r\n        other_thing,\r\n        one_more\r\n    FROM\r\n        my_table\r\n)\r\n\r\nSELECT *\r\nFROM example\r\n```\r\n\r\nAt this point we're all good.\r\n\r\nHowever then L039 has a look. It never expects two sets of whitespace following a new line and is specifically coded to only assume one set of spaces (which it normally would be if the other rules hadn't interfered as it would be parsed as one big space), so it think's the second set is too much indentation, so it replaces it with a single space.\r\n\r\nThen another run and L003 and the whitespace back in so we end up with two indents, and a single space.\r\n\r\nLuckily the fix is easier than that explanation. PR coming up...\r\n\r\n", "created_at": "2021-10-22T18:23:33Z", "version": "0.6", "FAIL_TO_PASS": ["test/rules/std_L003_L036_L039_combo_test.py::test__rules__std_L003_L036_L039"], "PASS_TO_PASS": ["test/rules/std_L016_L36_combo_test.py::test__rules__std_L016_L036_long_line_lint", "test/rules/std_L016_L36_combo_test.py::test__rules__std_L016_L036_long_line_fix", "test/rules/std_L016_L36_combo_test.py::test__rules__std_L016_L036_long_line_fix2"], "environment_setup_commit": "67023b85c41d23d6c6d69812a41b207c4f8a9331"}, {"repo": "sqlfluff/sqlfluff", "instance_id": "sqlfluff__sqlfluff-1577", "base_commit": "500505877769ab02504427284e4efdf832d299ea", "patch": "diff --git a/src/sqlfluff/core/templaters/base.py b/src/sqlfluff/core/templaters/base.py\n--- a/src/sqlfluff/core/templaters/base.py\n+++ b/src/sqlfluff/core/templaters/base.py\n@@ -84,7 +84,8 @@ def __init__(\n         is the same as the source view.\n         \"\"\"\n         self.source_str = source_str\n-        self.templated_str = templated_str or source_str\n+        # An empty string is still allowed as the templated string.\n+        self.templated_str = source_str if templated_str is None else templated_str\n         # If no fname, we assume this is from a string or stdin.\n         self.fname = fname\n         # Assume that no sliced_file, means the file is not templated\n@@ -297,7 +298,7 @@ def templated_slice_to_source_slice(\n                     break\n \n         subslices = self.sliced_file[\n-            # Ver inclusive slice\n+            # Very inclusive slice\n             min(ts_start_sf_start, ts_stop_sf_start) : max(\n                 ts_start_sf_stop, ts_stop_sf_stop\n             )\n", "test_patch": "diff --git a/test/core/templaters/jinja_test.py b/test/core/templaters/jinja_test.py\n--- a/test/core/templaters/jinja_test.py\n+++ b/test/core/templaters/jinja_test.py\n@@ -75,6 +75,18 @@ def test__templater_jinja_error_catatrophic():\n     assert len(vs) > 0\n \n \n+def test__templater_jinja_lint_empty():\n+    \"\"\"Check that parsing a file which renders to an empty string.\n+\n+    No exception should be raised, but the parsed tree should be None.\n+    \"\"\"\n+    lntr = Linter()\n+    parsed = lntr.parse_string(in_str='{{ \"\" }}')\n+    assert parsed.templated_file.source_str == '{{ \"\" }}'\n+    assert parsed.templated_file.templated_str == \"\"\n+    assert parsed.tree is None\n+\n+\n def assert_structure(yaml_loader, path, code_only=True, include_meta=False):\n     \"\"\"Check that a parsed sql file matches the yaml file with the same name.\"\"\"\n     lntr = Linter()\n", "problem_statement": "\"ValueError: Position Not Found\" with macro spanning entire file\n## Expected Behaviour\r\n\r\n`sqlfluff parse` should probably not fail with an exception and stack trace.\r\n\r\n## Observed Behaviour\r\n\r\n`sqlfluff parse` throws an exception, given an input file which is entirely spanned by a Jinja macro.\r\n\r\n## Steps to Reproduce\r\n\r\n```console\r\n$ echo -n '{% macro foo() %}{% endmacro %}' | sqlfluff parse -\r\nTraceback (most recent call last):\r\n  File \"/home/vladimir/work/extern/sqlfluff/venv/bin/sqlfluff\", line 33, in <module>\r\n    sys.exit(load_entry_point('sqlfluff', 'console_scripts', 'sqlfluff')())\r\n  File \"/home/vladimir/work/extern/sqlfluff/venv/lib/python3.9/site-packages/click/core.py\", line 1137, in __call__\r\n    return self.main(*args, **kwargs)\r\n  File \"/home/vladimir/work/extern/sqlfluff/venv/lib/python3.9/site-packages/click/core.py\", line 1062, in main\r\n    rv = self.invoke(ctx)\r\n  File \"/home/vladimir/work/extern/sqlfluff/venv/lib/python3.9/site-packages/click/core.py\", line 1668, in invoke\r\n    return _process_result(sub_ctx.command.invoke(sub_ctx))\r\n  File \"/home/vladimir/work/extern/sqlfluff/venv/lib/python3.9/site-packages/click/core.py\", line 1404, in invoke\r\n    return ctx.invoke(self.callback, **ctx.params)\r\n  File \"/home/vladimir/work/extern/sqlfluff/venv/lib/python3.9/site-packages/click/core.py\", line 763, in invoke\r\n    return __callback(*args, **kwargs)\r\n  File \"/home/vladimir/work/extern/sqlfluff/src/sqlfluff/cli/commands.py\", line 701, in parse\r\n    lnt.parse_string(\r\n  File \"/home/vladimir/work/extern/sqlfluff/src/sqlfluff/core/linter/linter.py\", line 596, in parse_string\r\n    return self.parse_rendered(rendered, recurse=recurse)\r\n  File \"/home/vladimir/work/extern/sqlfluff/src/sqlfluff/core/linter/linter.py\", line 294, in parse_rendered\r\n    tokens, lvs, config = cls._lex_templated_file(\r\n  File \"/home/vladimir/work/extern/sqlfluff/src/sqlfluff/core/linter/linter.py\", line 127, in _lex_templated_file\r\n    tokens, lex_vs = lexer.lex(templated_file)\r\n  File \"/home/vladimir/work/extern/sqlfluff/src/sqlfluff/core/parser/lexer.py\", line 319, in lex\r\n    segments: Tuple[RawSegment, ...] = self.elements_to_segments(\r\n  File \"/home/vladimir/work/extern/sqlfluff/src/sqlfluff/core/parser/lexer.py\", line 346, in elements_to_segments\r\n    source_slice = templated_file.templated_slice_to_source_slice(\r\n  File \"/home/vladimir/work/extern/sqlfluff/src/sqlfluff/core/templaters/base.py\", line 319, in templated_slice_to_source_slice\r\n    ts_stop_sf_start, ts_stop_sf_stop = self._find_slice_indices_of_templated_pos(\r\n  File \"/home/vladimir/work/extern/sqlfluff/src/sqlfluff/core/templaters/base.py\", line 214, in _find_slice_indices_of_templated_pos\r\n    raise ValueError(\"Position Not Found\")\r\nValueError: Position Not Found\r\n```\r\n\r\nNote: the issue does not occur if the file ends with a newline. \r\n\r\nThe contents of the macro also doesn't matter.\r\n\r\n## Dialect\r\n\r\nNone specified\r\n\r\n## Version\r\nSQLFluff 6011bdbe05669b075045e8127cdf18cc537686d4, Python 3.9.6\r\n\r\n## Configuration\r\n\r\nNone\n", "hints_text": "Hi @CyberShadow, @tunetheweb, what is expected output of\r\n```console\r\n$ echo -n '{% macro foo() %}{% endmacro %}' | sqlfluff parse -\r\n```\r\n?\r\n\nProbably the same as the input. Definitely not an exception, in any case.\r\n\r\nEdit: Whoops, forgot this was a `parse` case. What @tunetheweb said below, then.\nFor parse we don't return input.\r\n\r\nIf we add a newline we get this:\r\n\r\n```\r\n% echo -n '{% macro foo() %}{% endmacro %}\\n' | sqlfluff parse -\r\n[L:  1, P:  1]      |file:\r\n[L:  1, P:  1]      |    [META] placeholder:                                       [Type: 'compound', Raw: '{% macro foo() %}{% endmacro %}']\r\n[L:  1, P: 32]      |    newline:                                                  '\\n'\r\n```\r\n\r\nSo I'd expect the first two lines to be returned if newline isn't given.\r\n\r\nHere's some \"equivalent\" non-SQL that doesn't fail:\r\n\r\n```\r\n% echo \" \" | sqlfluff parse -     \r\n[L:  1, P:  1]      |file:\r\n[L:  1, P:  1]      |    whitespace:                                               ' '\r\n[L:  1, P:  2]      |    newline:                                                  '\\n'\r\n\r\n% echo \"\" | sqlfluff parse - \r\n[L:  1, P:  1]      |file:\r\n[L:  1, P:  1]      |    newline:                                                  '\\n'\r\n\r\n% echo \"--test\" | sqlfluff parse -\r\n[L:  1, P:  1]      |file:\r\n[L:  1, P:  1]      |    comment:                                                  '--test'\r\n[L:  1, P:  7]      |    newline:                                                  '\\n'\r\n``\r\n\r\n\r\n", "created_at": "2021-10-09T15:32:42Z", "version": "0.6", "FAIL_TO_PASS": ["test/core/templaters/jinja_test.py::test__templater_jinja_lint_empty"], "PASS_TO_PASS": ["test/core/templaters/jinja_test.py::test__templater_jinja[simple]", "test/core/templaters/jinja_test.py::test__templater_jinja[unboundlocal_bugfix]", "test/core/templaters/jinja_test.py::test__templater_jinja_error_variable", "test/core/templaters/jinja_test.py::test__templater_jinja_error_syntax", "test/core/templaters/jinja_test.py::test__templater_jinja_error_catatrophic", "test/core/templaters/jinja_test.py::test__templater_full[jinja_a/jinja-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_b/jinja-False-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_c_dbt/dbt_builtins-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_c_dbt/var_default-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_e/jinja-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_f/jinja-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_g_macros/jinja-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_h_macros/jinja-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_i_raw/raw_tag-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_i_raw/raw_tag_2-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_j_libraries/jinja-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_k_config_override_path_macros/jinja-True-False]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_l_metas/001-False-True]", "test/core/templaters/jinja_test.py::test__templater_full[jinja_l_metas/002-False-True]", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_template[-result0]", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_template[foo-result1]", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_template[foo", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_template[SELECT", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_template[{%", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_file[--result0]", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_file[foo-foo-result1]", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_file[SELECT", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_file[{{", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_file[SELECT\\n", "test/core/templaters/jinja_test.py::test__templater_jinja_slice_file[{%"], "environment_setup_commit": "67023b85c41d23d6c6d69812a41b207c4f8a9331"}, {"repo": "sqlfluff/sqlfluff", "instance_id": "sqlfluff__sqlfluff-2641", "base_commit": "b0ad239095b3cefb294c1b12c73c41e9f229aa81", "patch": "diff --git a/src/sqlfluff/core/rules/analysis/select_crawler.py b/src/sqlfluff/core/rules/analysis/select_crawler.py\n--- a/src/sqlfluff/core/rules/analysis/select_crawler.py\n+++ b/src/sqlfluff/core/rules/analysis/select_crawler.py\n@@ -129,6 +129,7 @@ class Query:\n     parent: Optional[\"Query\"] = field(default=None)\n     # Children (could be CTE, subselect, or other).\n     children: List[\"Query\"] = field(default_factory=list)\n+    cte_name_segment: Optional[BaseSegment] = field(default=None)\n \n     def lookup_cte(self, name: str, pop: bool = True) -> Optional[\"Query\"]:\n         \"\"\"Look up a CTE by name, in the current or any parent scope.\"\"\"\n@@ -233,7 +234,7 @@ def finish_segment():\n \n         # Stores the last CTE name we saw, so we can associate it with the\n         # corresponding Query.\n-        cte_name = None\n+        cte_name_segment: Optional[BaseSegment] = None\n \n         # Visit segment and all its children\n         for event, path in SelectCrawler.visit_segments(segment):\n@@ -273,10 +274,14 @@ def finish_segment():\n                                 append_query(query)\n                     else:\n                         # We're processing a \"with\" statement.\n-                        if cte_name:\n+                        if cte_name_segment:\n                             # If we have a CTE name, this is the Query for that\n                             # name.\n-                            query = self.query_class(QueryType.Simple, dialect)\n+                            query = self.query_class(\n+                                QueryType.Simple,\n+                                dialect,\n+                                cte_name_segment=cte_name_segment,\n+                            )\n                             if path[-1].is_type(\"select_statement\", \"values_clause\"):\n                                 # Add to the Query object we just created.\n                                 query.selectables.append(Selectable(path[-1], dialect))\n@@ -286,8 +291,8 @@ def finish_segment():\n                                 # to the Query later when we encounter those\n                                 # child segments.\n                                 pass\n-                            query_stack[-1].ctes[cte_name] = query\n-                            cte_name = None\n+                            query_stack[-1].ctes[cte_name_segment.raw] = query\n+                            cte_name_segment = None\n                             append_query(query)\n                         else:\n                             # There's no CTE name, so we're probably processing\n@@ -313,13 +318,13 @@ def finish_segment():\n                 elif path[-1].is_type(\"with_compound_statement\"):\n                     # Beginning a \"with\" statement, i.e. a block of CTEs.\n                     query = self.query_class(QueryType.WithCompound, dialect)\n-                    if cte_name:\n-                        query_stack[-1].ctes[cte_name] = query\n-                        cte_name = None\n+                    if cte_name_segment:\n+                        query_stack[-1].ctes[cte_name_segment.raw] = query\n+                        cte_name_segment = None\n                     append_query(query)\n                 elif path[-1].is_type(\"common_table_expression\"):\n                     # This is a \"<<cte name>> AS\". Grab the name for later.\n-                    cte_name = path[-1].segments[0].raw\n+                    cte_name_segment = path[-1].segments[0]\n             elif event == \"end\":\n                 finish_segment()\n \ndiff --git a/src/sqlfluff/rules/L045.py b/src/sqlfluff/rules/L045.py\n--- a/src/sqlfluff/rules/L045.py\n+++ b/src/sqlfluff/rules/L045.py\n@@ -1,7 +1,5 @@\n \"\"\"Implementation of Rule L045.\"\"\"\n-from typing import Optional\n-\n-from sqlfluff.core.rules.base import BaseRule, LintResult, RuleContext\n+from sqlfluff.core.rules.base import BaseRule, EvalResultType, LintResult, RuleContext\n from sqlfluff.core.rules.analysis.select_crawler import Query, SelectCrawler\n \n \n@@ -49,12 +47,21 @@ def _visit_sources(cls, query: Query):\n                 if isinstance(source, Query):\n                     cls._visit_sources(source)\n \n-    def _eval(self, context: RuleContext) -> Optional[LintResult]:\n+    def _eval(self, context: RuleContext) -> EvalResultType:\n         if context.segment.is_type(\"statement\"):\n             crawler = SelectCrawler(context.segment, context.dialect)\n             if crawler.query_tree:\n                 # Begin analysis at the final, outer query (key=None).\n                 self._visit_sources(crawler.query_tree)\n                 if crawler.query_tree.ctes:\n-                    return LintResult(anchor=context.segment)\n+                    return [\n+                        LintResult(\n+                            anchor=query.cte_name_segment,\n+                            description=f\"Query defines CTE \"\n+                            f'\"{query.cte_name_segment.raw}\" '\n+                            f\"but does not use it.\",\n+                        )\n+                        for query in crawler.query_tree.ctes.values()\n+                        if query.cte_name_segment\n+                    ]\n         return None\n", "test_patch": "diff --git a/test/fixtures/rules/std_rule_cases/L045.yml b/test/fixtures/rules/std_rule_cases/L045.yml\n--- a/test/fixtures/rules/std_rule_cases/L045.yml\n+++ b/test/fixtures/rules/std_rule_cases/L045.yml\n@@ -224,3 +224,13 @@ test_pass_spark3_values_clause_cte_2:\n   configs:\n     core:\n       dialect: spark3\n+\n+test_fail_query_uses_templating:\n+  fail_str: |\n+    WITH\n+    random_gibberish AS (\n+        SELECT 1\n+    )\n+\n+    SELECT var_bar\n+    FROM {{ ref('issue_2235') }}\ndiff --git a/test/rules/std_L045_test.py b/test/rules/std_L045_test.py\nnew file mode 100644\n--- /dev/null\n+++ b/test/rules/std_L045_test.py\n@@ -0,0 +1,46 @@\n+\"\"\"Tests the python routines within L045.\"\"\"\n+\n+import sqlfluff\n+\n+\n+def test__rules__std_L045_multiple_unused_ctes():\n+    \"\"\"Verify that L045 returns multiple lint issues, one per unused CTE.\"\"\"\n+    sql = \"\"\"\n+    WITH\n+    cte_1 AS (\n+        SELECT 1\n+    ),\n+    cte_2 AS (\n+        SELECT 2\n+    ),\n+    cte_3 AS (\n+        SELECT 3\n+    ),\n+    cte_4 AS (\n+        SELECT 4\n+    )\n+\n+    SELECT var_bar\n+    FROM cte_3\n+    \"\"\"\n+    result = sqlfluff.lint(sql, rules=[\"L045\"])\n+    assert result == [\n+        {\n+            \"code\": \"L045\",\n+            \"description\": 'Query defines CTE \"cte_1\" but does not use it.',\n+            \"line_no\": 3,\n+            \"line_pos\": 5,\n+        },\n+        {\n+            \"code\": \"L045\",\n+            \"description\": 'Query defines CTE \"cte_2\" but does not use it.',\n+            \"line_no\": 6,\n+            \"line_pos\": 5,\n+        },\n+        {\n+            \"code\": \"L045\",\n+            \"description\": 'Query defines CTE \"cte_4\" but does not use it.',\n+            \"line_no\": 12,\n+            \"line_pos\": 5,\n+        },\n+    ]\n", "problem_statement": "L045:  Unused CTEs are not automatically detected when using jinja/dbt as a templater\n## Expected Behaviour\r\nWhen unused CTEs are used with jinja or dbt as a templater, these are detected by L045. \r\n\r\n## Observed Behaviour\r\nWhen ref() statements are included in a SQL file and dbt is used as a templater, these seem to interfere with the ability for rule L045 to detect the unused CTEs.  The same behavior is observed when Jinja is included under the \"FROM\" statement of the relevant queries.\r\n\r\n## Steps to Reproduce\r\n(1). Generate a valid dbt project with at least two models with one variable each.  For the purposes of this reproduction example, I am going to assume that one model is 'foo' with variable 'var_foo' and one model is 'bar' with variable 'var_bar'.\r\n \r\n(2) Using DBT as a templater and BigQuery as a dialect, run dbt lint on the following SQL file:\r\n\r\n```sql\r\nWITH\r\nrandom_gibberish AS (\r\n    SELECT var_foo\r\n    FROM\r\n        {{ ref('foo') }}\r\n)\r\n\r\nSELECT var_bar\r\nFROM\r\n    {{ ref('bar') }}\r\n```\r\n\r\nIf the templater is switched to Jinja, L045 again doesn't produce any errors.\r\n\r\n## Dialect\r\nBigquery\r\n\r\n## Version\r\nSQLFluff version is 0.10.0.  Python version is 3.8.10.\r\nI'm using dbt 1.0.1 but the same issue occurs when Jinja is used as a templater.\r\n\r\n## Configuration\r\n```\r\n[sqlfluff]\r\ndialect = bigquery\r\nexclude_rules = L003,L008,L011,L014,L016,L029,L031,L034\r\n\r\n[sqlfluff:rules]\r\nmax_line_length = 120\r\ncomma_style = leading\r\n\r\n[sqlfluff:rules:L010]\r\ncapitalisation_policy = upper\r\n\r\n[sqlfluff:rules:L030]\r\ncapitalisation_policy = upper\r\n```\n", "hints_text": "", "created_at": "2022-02-14T20:13:17Z", "version": "0.9", "FAIL_TO_PASS": ["test/rules/std_L045_test.py::test__rules__std_L045_multiple_unused_ctes"], "PASS_TO_PASS": [], "environment_setup_commit": "a4dcf3f08d95cbde4efb39969b0ab8e33a791f21"}, {"repo": "sqlfluff/sqlfluff", "instance_id": "sqlfluff__sqlfluff-1517", "base_commit": "304a197829f98e7425a46d872ada73176137e5ae", "patch": "diff --git a/src/sqlfluff/core/parser/helpers.py b/src/sqlfluff/core/parser/helpers.py\n--- a/src/sqlfluff/core/parser/helpers.py\n+++ b/src/sqlfluff/core/parser/helpers.py\n@@ -2,6 +2,7 @@\n \n from typing import Tuple, List, Any, Iterator, TYPE_CHECKING\n \n+from sqlfluff.core.errors import SQLParseError\n from sqlfluff.core.string_helpers import curtail_string\n \n if TYPE_CHECKING:\n@@ -26,11 +27,11 @@ def check_still_complete(\n     \"\"\"Check that the segments in are the same as the segments out.\"\"\"\n     initial_str = join_segments_raw(segments_in)\n     current_str = join_segments_raw(matched_segments + unmatched_segments)\n-    if initial_str != current_str:  # pragma: no cover\n-        raise RuntimeError(\n-            \"Dropped elements in sequence matching! {!r} != {!r}\".format(\n-                initial_str, current_str\n-            )\n+\n+    if initial_str != current_str:\n+        raise SQLParseError(\n+            f\"Could not parse: {current_str}\",\n+            segment=unmatched_segments[0],\n         )\n     return True\n \n", "test_patch": "diff --git a/test/dialects/ansi_test.py b/test/dialects/ansi_test.py\n--- a/test/dialects/ansi_test.py\n+++ b/test/dialects/ansi_test.py\n@@ -3,7 +3,7 @@\n import pytest\n import logging\n \n-from sqlfluff.core import FluffConfig, Linter\n+from sqlfluff.core import FluffConfig, Linter, SQLParseError\n from sqlfluff.core.parser import Lexer\n \n \n@@ -214,3 +214,29 @@ def test__dialect__ansi_parse_indented_joins(sql_string, indented_joins, meta_lo\n         idx for idx, raw_seg in enumerate(parsed.tree.iter_raw_seg()) if raw_seg.is_meta\n     )\n     assert res_meta_locs == meta_loc\n+\n+\n+@pytest.mark.parametrize(\n+    \"raw,expected_message\",\n+    [\n+        (\";;\", \"Line 1, Position 1: Found unparsable section: ';;'\"),\n+        (\"select id from tbl;\", \"\"),\n+        (\"select id from tbl;;\", \"Could not parse: ;\"),\n+        (\"select id from tbl;;;;;;\", \"Could not parse: ;;;;;\"),\n+        (\"select id from tbl;select id2 from tbl2;\", \"\"),\n+        (\n+            \"select id from tbl;;select id2 from tbl2;\",\n+            \"Could not parse: ;select id2 from tbl2;\",\n+        ),\n+    ],\n+)\n+def test__dialect__ansi_multiple_semicolons(raw: str, expected_message: str) -> None:\n+    \"\"\"Multiple semicolons should be properly handled.\"\"\"\n+    lnt = Linter()\n+    parsed = lnt.parse_string(raw)\n+\n+    assert len(parsed.violations) == (1 if expected_message else 0)\n+    if expected_message:\n+        violation = parsed.violations[0]\n+        assert isinstance(violation, SQLParseError)\n+        assert violation.desc() == expected_message\n", "problem_statement": "\"Dropped elements in sequence matching\" when doubled semicolon\n## Expected Behaviour\r\nFrankly, I'm not sure whether it (doubled `;`) should be just ignored or rather some specific rule should be triggered.\r\n## Observed Behaviour\r\n```console\r\n(.venv) ?master ~/prod/_inne/sqlfluff> echo \"select id from tbl;;\" | sqlfluff lint -\r\nTraceback (most recent call last):\r\n  File \"/home/adam/prod/_inne/sqlfluff/.venv/bin/sqlfluff\", line 11, in <module>\r\n    load_entry_point('sqlfluff', 'console_scripts', 'sqlfluff')()\r\n  File \"/home/adam/prod/_inne/sqlfluff/.venv/lib/python3.9/site-packages/click/core.py\", line 1137, in __call__\r\n    return self.main(*args, **kwargs)\r\n  File \"/home/adam/prod/_inne/sqlfluff/.venv/lib/python3.9/site-packages/click/core.py\", line 1062, in main\r\n    rv = self.invoke(ctx)\r\n  File \"/home/adam/prod/_inne/sqlfluff/.venv/lib/python3.9/site-packages/click/core.py\", line 1668, in invoke\r\n    return _process_result(sub_ctx.command.invoke(sub_ctx))\r\n  File \"/home/adam/prod/_inne/sqlfluff/.venv/lib/python3.9/site-packages/click/core.py\", line 1404, in invoke\r\n    return ctx.invoke(self.callback, **ctx.params)\r\n  File \"/home/adam/prod/_inne/sqlfluff/.venv/lib/python3.9/site-packages/click/core.py\", line 763, in invoke\r\n    return __callback(*args, **kwargs)\r\n  File \"/home/adam/prod/_inne/sqlfluff/src/sqlfluff/cli/commands.py\", line 347, in lint\r\n    result = lnt.lint_string_wrapped(sys.stdin.read(), fname=\"stdin\")\r\n  File \"/home/adam/prod/_inne/sqlfluff/src/sqlfluff/core/linter/linter.py\", line 789, in lint_string_wrapped\r\n    linted_path.add(self.lint_string(string, fname=fname, fix=fix))\r\n  File \"/home/adam/prod/_inne/sqlfluff/src/sqlfluff/core/linter/linter.py\", line 668, in lint_string\r\n    parsed = self.parse_string(in_str=in_str, fname=fname, config=config)\r\n  File \"/home/adam/prod/_inne/sqlfluff/src/sqlfluff/core/linter/linter.py\", line 607, in parse_string\r\n    return self.parse_rendered(rendered, recurse=recurse)\r\n  File \"/home/adam/prod/_inne/sqlfluff/src/sqlfluff/core/linter/linter.py\", line 313, in parse_rendered\r\n    parsed, pvs = cls._parse_tokens(\r\n  File \"/home/adam/prod/_inne/sqlfluff/src/sqlfluff/core/linter/linter.py\", line 190, in _parse_tokens\r\n    parsed: Optional[BaseSegment] = parser.parse(\r\n  File \"/home/adam/prod/_inne/sqlfluff/src/sqlfluff/core/parser/parser.py\", line 32, in parse\r\n    parsed = root_segment.parse(parse_context=ctx)\r\n  File \"/home/adam/prod/_inne/sqlfluff/src/sqlfluff/core/parser/segments/base.py\", line 821, in parse\r\n    check_still_complete(segments, m.matched_segments, m.unmatched_segments)\r\n  File \"/home/adam/prod/_inne/sqlfluff/src/sqlfluff/core/parser/helpers.py\", line 30, in check_still_complete\r\n    raise RuntimeError(\r\nRuntimeError: Dropped elements in sequence matching! 'select id from tbl;;' != ';'\r\n\r\n```\r\n## Steps to Reproduce\r\nRun \r\n```console\r\necho \"select id from tbl;;\" | sqlfluff lint -\r\n```\r\n## Dialect\r\ndefault (ansi)\r\n## Version\r\n```\r\nsqlfluff, version 0.6.6\r\nPython 3.9.5\r\n```\r\n## Configuration\r\nNone\r\n\n", "hints_text": "Sounds similar to #1458 where we should handle \"empty\" statement/files better?\nNope, that's the different issue. I doubt that solving one of them would help in other one. I think both issues should stay, just in the case.\nBut what do you think @tunetheweb - should it just ignore these `;;` or raise something like `Found unparsable section:`? \nJust tested and in BigQuery it's an error.\r\nInterestingly Oracle is fine with it.\r\n\r\nI think it should be raised as `Found unparsable section`.", "created_at": "2021-10-06T07:57:35Z", "version": "0.6", "FAIL_TO_PASS": ["test/dialects/ansi_test.py::test__dialect__ansi_multiple_semicolons[select"], "PASS_TO_PASS": ["test/dialects/ansi_test.py::test__dialect__ansi__file_lex[a", "test/dialects/ansi_test.py::test__dialect__ansi__file_lex[b.c-res1]", "test/dialects/ansi_test.py::test__dialect__ansi__file_lex[abc", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectKeywordSegment-select]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[NakedIdentifierSegment-online_sales]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[BareFunctionSegment-current_timestamp]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[FunctionSegment-current_timestamp()]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[NumericLiteralSegment-1000.0]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-online_sales", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[IntervalExpressionSegment-INTERVAL", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-CASE", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-CAST(ROUND(online_sales", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-name", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment-MIN", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-DATE_ADD(CURRENT_DATE('America/New_York'),", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-my_array[1]]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-my_array[OFFSET(1)]]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-my_array[5:8]]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-4", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-bits[OFFSET(0)]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment-(count_18_24", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-count_18_24", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectStatementSegment-SELECT", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment-t.val/t.id]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment-CAST(num", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment-a.*]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment-a.b.*]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment-a.b.c.*]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ObjectReferenceSegment-a..c.*]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment--some_variable]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment--", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-concat(left(uaid,", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-c", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment-c", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[ExpressionSegment-NULL::INT]", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[SelectClauseElementSegment-NULL::INT", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_parses[TruncateStatementSegment-TRUNCATE", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_not_match[ObjectReferenceSegment-\\n", "test/dialects/ansi_test.py::test__dialect__ansi_specific_segment_not_parse[SELECT", "test/dialects/ansi_test.py::test__dialect__ansi_is_whitespace", "test/dialects/ansi_test.py::test__dialect__ansi_parse_indented_joins[select", "test/dialects/ansi_test.py::test__dialect__ansi_multiple_semicolons[;;-Line"], "environment_setup_commit": "67023b85c41d23d6c6d69812a41b207c4f8a9331"}, {"repo": "sqlfluff/sqlfluff", "instance_id": "sqlfluff__sqlfluff-1763", "base_commit": "a10057635e5b2559293a676486f0b730981f037a", "patch": "diff --git a/src/sqlfluff/core/linter/linted_file.py b/src/sqlfluff/core/linter/linted_file.py\n--- a/src/sqlfluff/core/linter/linted_file.py\n+++ b/src/sqlfluff/core/linter/linted_file.py\n@@ -7,6 +7,8 @@\n \n import os\n import logging\n+import shutil\n+import tempfile\n from typing import (\n     Any,\n     Iterable,\n@@ -493,7 +495,24 @@ def persist_tree(self, suffix: str = \"\") -> bool:\n             if suffix:\n                 root, ext = os.path.splitext(fname)\n                 fname = root + suffix + ext\n-            # Actually write the file.\n-            with open(fname, \"w\", encoding=self.encoding) as f:\n-                f.write(write_buff)\n+            self._safe_create_replace_file(fname, write_buff, self.encoding)\n         return success\n+\n+    @staticmethod\n+    def _safe_create_replace_file(fname, write_buff, encoding):\n+        # Write to a temporary file first, so in case of encoding or other\n+        # issues, we don't delete or corrupt the user's existing file.\n+        dirname, basename = os.path.split(fname)\n+        with tempfile.NamedTemporaryFile(\n+            mode=\"w\",\n+            encoding=encoding,\n+            prefix=basename,\n+            dir=dirname,\n+            suffix=os.path.splitext(fname)[1],\n+            delete=False,\n+        ) as tmp:\n+            tmp.file.write(write_buff)\n+            tmp.flush()\n+            os.fsync(tmp.fileno())\n+        # Once the temp file is safely written, replace the existing file.\n+        shutil.move(tmp.name, fname)\n", "test_patch": "diff --git a/test/core/linter_test.py b/test/core/linter_test.py\n--- a/test/core/linter_test.py\n+++ b/test/core/linter_test.py\n@@ -641,3 +641,56 @@ def test__attempt_to_change_templater_warning(caplog):\n         assert \"Attempt to set templater to \" in caplog.text\n     finally:\n         logger.propagate = original_propagate_value\n+\n+\n+@pytest.mark.parametrize(\n+    \"case\",\n+    [\n+        dict(\n+            name=\"utf8_create\",\n+            fname=\"test.sql\",\n+            encoding=\"utf-8\",\n+            existing=None,\n+            update=\"def\",\n+            expected=\"def\",\n+        ),\n+        dict(\n+            name=\"utf8_update\",\n+            fname=\"test.sql\",\n+            encoding=\"utf-8\",\n+            existing=\"abc\",\n+            update=\"def\",\n+            expected=\"def\",\n+        ),\n+        dict(\n+            name=\"utf8_special_char\",\n+            fname=\"test.sql\",\n+            encoding=\"utf-8\",\n+            existing=\"abc\",\n+            update=\"\u2192\",  # Special utf-8 character\n+            expected=\"\u2192\",\n+        ),\n+        dict(\n+            name=\"incorrect_encoding\",\n+            fname=\"test.sql\",\n+            encoding=\"Windows-1252\",\n+            existing=\"abc\",\n+            update=\"\u2192\",  # Not valid in Windows-1252\n+            expected=\"abc\",  # File should be unchanged\n+        ),\n+    ],\n+    ids=lambda case: case[\"name\"],\n+)\n+def test_safe_create_replace_file(case, tmp_path):\n+    \"\"\"Test creating or updating .sql files, various content and encoding.\"\"\"\n+    p = tmp_path / case[\"fname\"]\n+    if case[\"existing\"]:\n+        p.write_text(case[\"existing\"])\n+    try:\n+        linter.LintedFile._safe_create_replace_file(\n+            str(p), case[\"update\"], case[\"encoding\"]\n+        )\n+    except:  # noqa: E722\n+        pass\n+    actual = p.read_text(encoding=case[\"encoding\"])\n+    assert case[\"expected\"] == actual\n", "problem_statement": "dbt postgres fix command errors with UnicodeEncodeError and also wipes the .sql file\n_If this is a parsing or linting issue, please include a minimal SQL example which reproduces the issue, along with the `sqlfluff parse` output, `sqlfluff lint` output and `sqlfluff fix` output when relevant._\r\n\r\n## Expected Behaviour\r\nViolation failure notice at a minimum, without wiping the file. Would like a way to ignore the known error at a minimum as --noqa is not getting past this. Actually would expect --noqa to totally ignore this.\r\n\r\n## Observed Behaviour\r\nReported error: `UnicodeEncodeError: 'charmap' codec can't encode character '\\u2192' in position 120: character maps to <undefined>`\r\n\r\n## Steps to Reproduce\r\nSQL file:\r\n```sql\r\nSELECT\r\n    reacted_table_name_right.descendant_id AS category_id,\r\n    string_agg(redacted_table_name_left.name, ' \u2192 ' ORDER BY reacted_table_name_right.generations DESC) AS breadcrumbs -- noqa\r\nFROM {{ ref2('redacted_schema_name', 'redacted_table_name_left') }} AS redacted_table_name_left\r\nINNER JOIN {{ ref2('redacted_schema_name', 'reacted_table_name_right') }} AS reacted_table_name_right\r\n    ON redacted_table_name_left.id = order_issue_category_hierarchies.ancestor_id\r\nGROUP BY reacted_table_name_right.descendant_id\r\n```\r\nRunning `sqlfluff fix --ignore templating,parsing,lexing -vvvv` and accepting proposed fixes for linting violations.\r\n\r\n## Dialect\r\n`postgres`, with `dbt` templater\r\n\r\n## Version\r\n`python 3.7.12`\r\n`sqlfluff 0.7.0`\r\n`sqlfluff-templater-dbt 0.7.0`\r\n\r\n## Configuration\r\nI've tried a few, here's one:\r\n```\r\n[sqlfluff]\r\nverbose = 2\r\ndialect = postgres\r\ntemplater = dbt\r\nexclude_rules = None\r\noutput_line_length = 80\r\nrunaway_limit = 10\r\nignore_templated_areas = True\r\nprocesses = 3\r\n# Comma separated list of file extensions to lint.\r\n\r\n# NB: This config will only apply in the root folder.\r\nsql_file_exts = .sql\r\n\r\n[sqlfluff:indentation]\r\nindented_joins = False\r\nindented_using_on = True\r\ntemplate_blocks_indent = True\r\n\r\n[sqlfluff:templater]\r\nunwrap_wrapped_queries = True\r\n\r\n[sqlfluff:templater:jinja]\r\napply_dbt_builtins = True\r\n\r\n[sqlfluff:templater:jinja:macros]\r\n# Macros provided as builtins for dbt projects\r\ndbt_ref = {% macro ref(model_ref) %}{{model_ref}}{% endmacro %}\r\ndbt_source = {% macro source(source_name, table) %}{{source_name}}_{{table}}{% endmacro %}\r\ndbt_config = {% macro config() %}{% for k in kwargs %}{% endfor %}{% endmacro %}\r\ndbt_var = {% macro var(variable, default='') %}item{% endmacro %}\r\ndbt_is_incremental = {% macro is_incremental() %}True{% endmacro %}\r\n\r\n# Common config across rules\r\n[sqlfluff:rules]\r\ntab_space_size = 4\r\nindent_unit = space\r\nsingle_table_references = consistent\r\nunquoted_identifiers_policy = all\r\n\r\n# L001 - Remove trailing whitespace (fix)\r\n# L002 - Single section of whitespace should not contain both tabs and spaces (fix)\r\n# L003 - Keep consistent indentation (fix)\r\n# L004 - We use 4 spaces for indentation just for completeness (fix)\r\n# L005 - Remove space before commas (fix)\r\n# L006 - Operators (+, -, *, /) will be wrapped by a single space each side (fix)\r\n\r\n# L007 - Operators should not be at the end of a line\r\n[sqlfluff:rules:L007]  # Keywords\r\noperator_new_lines = after\r\n\r\n# L008 - Always use a single whitespace after a comma (fix)\r\n# L009 - Files will always end with a trailing newline\r\n\r\n# L010 - All keywords will use full upper case (fix)\r\n[sqlfluff:rules:L010]  # Keywords\r\ncapitalisation_policy = upper\r\n\r\n# L011 - Always explicitly alias tables (fix)\r\n[sqlfluff:rules:L011]  # Aliasing\r\naliasing = explicit\r\n\r\n# L012 - Do not have to explicitly alias all columns\r\n[sqlfluff:rules:L012]  # Aliasing\r\naliasing = explicit\r\n\r\n# L013 - Always explicitly alias a column with an expression in it (fix)\r\n[sqlfluff:rules:L013]  # Aliasing\r\nallow_scalar = False\r\n\r\n# L014 - Always user full lower case for 'quoted identifiers' -> column refs. without an alias (fix)\r\n[sqlfluff:rules:L014]  # Unquoted identifiers\r\nextended_capitalisation_policy = lower\r\n\r\n# L015 - Always remove parenthesis when using DISTINCT to be clear that DISTINCT applies to all columns (fix)\r\n\r\n# L016 - Lines should be 120 characters of less. Comment lines should not be ignored (fix)\r\n[sqlfluff:rules:L016]\r\nignore_comment_lines = False\r\nmax_line_length = 120\r\n\r\n# L017 - There should not be whitespace between function name and brackets (fix)\r\n# L018 - Always align closing bracket of WITH to the WITH keyword (fix)\r\n\r\n# L019 - Always use trailing commas / commas at the end of the line (fix)\r\n[sqlfluff:rules:L019]\r\ncomma_style = trailing\r\n\r\n# L020 - Table aliases will always be unique per statement\r\n# L021 - Remove any use of ambiguous DISTINCT and GROUP BY combinations. Lean on removing the GROUP BY.\r\n# L022 - Add blank lines after common table expressions (CTE) / WITH.\r\n# L023 - Always add a single whitespace after AS in a WITH clause (fix)\r\n\r\n[sqlfluff:rules:L026]\r\nforce_enable = False\r\n\r\n# L027 - Always add references if more than one referenced table or view is used\r\n\r\n[sqlfluff:rules:L028]\r\nforce_enable = False\r\n\r\n[sqlfluff:rules:L029]  # Keyword identifiers\r\nunquoted_identifiers_policy = aliases\r\n\r\n[sqlfluff:rules:L030]  # Function names\r\ncapitalisation_policy = upper\r\n\r\n# L032 - We prefer use of join keys rather than USING\r\n# L034 - We prefer ordering of columns in select statements as (fix):\r\n# 1. wildcards\r\n# 2. single identifiers\r\n# 3. calculations and aggregates\r\n\r\n# L035 - Omit 'else NULL'; it is redundant (fix)\r\n# L036 - Move select targets / identifiers onto new lines each (fix)\r\n# L037 - When using ORDER BY, make the direction explicit (fix)\r\n\r\n# L038 - Never use trailing commas at the end of the SELECT clause\r\n[sqlfluff:rules:L038]\r\nselect_clause_trailing_comma = forbid\r\n\r\n# L039 - Remove unnecessary whitespace (fix)\r\n\r\n[sqlfluff:rules:L040]  # Null & Boolean Literals\r\ncapitalisation_policy = upper\r\n\r\n# L042 - Join clauses should not contain subqueries. Use common tables expressions (CTE) instead.\r\n[sqlfluff:rules:L042]\r\n# By default, allow subqueries in from clauses, but not join clauses.\r\nforbid_subquery_in = join\r\n\r\n# L043 - Reduce CASE WHEN conditions to COALESCE (fix)\r\n# L044 - Prefer a known number of columns along the path to the source data\r\n# L045 - Remove unused common tables expressions (CTE) / WITH statements (fix)\r\n# L046 - Jinja tags should have a single whitespace on both sides\r\n\r\n# L047 - Use COUNT(*) instead of COUNT(0) or COUNT(1) alternatives (fix)\r\n[sqlfluff:rules:L047]  # Consistent syntax to count all rows\r\nprefer_count_1 = False\r\nprefer_count_0 = False\r\n\r\n# L048 - Quoted literals should be surrounded by a single whitespace (fix)\r\n# L049 - Always use IS or IS NOT for comparisons with NULL (fix)\r\n```\r\n\n", "hints_text": "I get a dbt-related error -- can you provide your project file as well? Also, what operating system are you running this on? I tested a simplified (non-dbt) version of your file on my Mac, and it worked okay.\r\n\r\n```\r\ndbt.exceptions.DbtProjectError: Runtime Error\r\n  no dbt_project.yml found at expected path /Users/bhart/dev/sqlfluff/dbt_project.yml\r\n```\nNever mind the questions above -- I managed to reproduce the error in a sample dbt project. Taking a look now...\n@Tumble17: Have you tried setting the `encoding` parameter in `.sqlfluff`? Do you know what encoding you're using? The default is `autodetect`, and SQLFluff \"thinks\" the file uses \"Windows-1252\" encoding, which I assume is incorrect -- that's why SQLFluff is unable to write out the updated file.\nI added this line to the first section of your `.sqlfluff`, and now it seems to work. I'll look into changing the behavior of `sqlfluff fix` so it doesn't erase the file when it fails.\r\n\r\n```\r\nencoding = utf-8\r\n```", "created_at": "2021-10-26T17:28:28Z", "version": "0.6", "FAIL_TO_PASS": ["test/core/linter_test.py::test_safe_create_replace_file[utf8_create]", "test/core/linter_test.py::test_safe_create_replace_file[utf8_update]", "test/core/linter_test.py::test_safe_create_replace_file[utf8_special_char]"], "PASS_TO_PASS": ["test/core/linter_test.py::test__linter__path_from_paths__dir", "test/core/linter_test.py::test__linter__path_from_paths__default", "test/core/linter_test.py::test__linter__path_from_paths__exts", "test/core/linter_test.py::test__linter__path_from_paths__file", "test/core/linter_test.py::test__linter__path_from_paths__not_exist", "test/core/linter_test.py::test__linter__path_from_paths__not_exist_ignore", "test/core/linter_test.py::test__linter__path_from_paths__explicit_ignore", "test/core/linter_test.py::test__linter__path_from_paths__dot", "test/core/linter_test.py::test__linter__path_from_paths__ignore[test/fixtures/linter/sqlfluffignore]", "test/core/linter_test.py::test__linter__path_from_paths__ignore[test/fixtures/linter/sqlfluffignore/]", "test/core/linter_test.py::test__linter__path_from_paths__ignore[test/fixtures/linter/sqlfluffignore/.]", "test/core/linter_test.py::test__linter__lint_string_vs_file[test/fixtures/linter/indentation_errors.sql]", "test/core/linter_test.py::test__linter__lint_string_vs_file[test/fixtures/linter/whitespace_errors.sql]", "test/core/linter_test.py::test__linter__get_violations_filter_rules[None-7]", "test/core/linter_test.py::test__linter__get_violations_filter_rules[L010-2]", "test/core/linter_test.py::test__linter__get_violations_filter_rules[rules2-2]", "test/core/linter_test.py::test__linter__linting_result__sum_dicts", "test/core/linter_test.py::test__linter__linting_result__combine_dicts", "test/core/linter_test.py::test__linter__linting_result_check_tuples_by_path[False-list]", "test/core/linter_test.py::test__linter__linting_result_check_tuples_by_path[True-dict]", "test/core/linter_test.py::test__linter__linting_result_get_violations[1]", "test/core/linter_test.py::test__linter__linting_result_get_violations[2]", "test/core/linter_test.py::test__linter__linting_parallel_thread[False]", "test/core/linter_test.py::test__linter__linting_parallel_thread[True]", "test/core/linter_test.py::test_lint_path_parallel_wrapper_exception", "test/core/linter_test.py::test__linter__linting_unexpected_error_handled_gracefully", "test/core/linter_test.py::test__linter__raises_malformed_noqa", "test/core/linter_test.py::test__linter__empty_file", "test/core/linter_test.py::test__linter__mask_templated_violations[True-check_tuples0]", "test/core/linter_test.py::test__linter__mask_templated_violations[False-check_tuples1]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8.sql-autodetect-False]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8-sig.sql-autodetect-False]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8.sql-utf-8-False]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8-sig.sql-utf-8-True]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8.sql-utf-8-sig-False]", "test/core/linter_test.py::test__linter__encoding[test/fixtures/linter/encoding-utf-8-sig.sql-utf-8-sig-False]", "test/core/linter_test.py::test_parse_noqa[-None]", "test/core/linter_test.py::test_parse_noqa[noqa-expected1]", "test/core/linter_test.py::test_parse_noqa[noqa?-SQLParseError]", "test/core/linter_test.py::test_parse_noqa[noqa:-expected3]", "test/core/linter_test.py::test_parse_noqa[noqa:L001,L002-expected4]", "test/core/linter_test.py::test_parse_noqa[noqa:", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_no_ignore]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_specific_line]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_different_specific_line]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_different_specific_rule]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_enable_this_range]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_ignore_disable_this_range]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_1_ignore_disable_specific_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_2_ignore_disable_specific_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_3_ignore_disable_specific_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_4_ignore_disable_specific_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_1_ignore_disable_all_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_2_ignore_disable_all_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_3_ignore_disable_all_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[1_violation_line_4_ignore_disable_all_2_3]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[4_violations_two_types_disable_specific_enable_all]", "test/core/linter_test.py::test_linted_file_ignore_masked_violations[4_violations_two_types_disable_all_enable_specific]", "test/core/linter_test.py::test_linter_noqa", "test/core/linter_test.py::test_linter_noqa_with_templating", "test/core/linter_test.py::test_delayed_exception", "test/core/linter_test.py::test__attempt_to_change_templater_warning", "test/core/linter_test.py::test_safe_create_replace_file[incorrect_encoding]"], "environment_setup_commit": "67023b85c41d23d6c6d69812a41b207c4f8a9331"}, {"repo": "marshmallow-code/marshmallow", "instance_id": "marshmallow-code__marshmallow-1359", "base_commit": "b40a0f4e33823e6d0f341f7e8684e359a99060d1", "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@@ -1114,7 +1114,7 @@ def _bind_to_schema(self, field_name, schema):\n         super()._bind_to_schema(field_name, schema)\n         self.format = (\n             self.format\n-            or getattr(schema.opts, self.SCHEMA_OPTS_VAR_NAME)\n+            or getattr(self.root.opts, self.SCHEMA_OPTS_VAR_NAME)\n             or self.DEFAULT_FORMAT\n         )\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@@ -169,6 +169,20 @@ class OtherSchema(MySchema):\n         assert schema2.fields[\"foo\"].key_field.root == schema2\n         assert schema2.fields[\"foo\"].value_field.root == schema2\n \n+    # Regression test for https://github.com/marshmallow-code/marshmallow/issues/1357\n+    def test_datetime_list_inner_format(self, schema):\n+        class MySchema(Schema):\n+            foo = fields.List(fields.DateTime())\n+            bar = fields.Tuple((fields.DateTime(),))\n+\n+            class Meta:\n+                datetimeformat = \"iso8601\"\n+                dateformat = \"iso8601\"\n+\n+        schema = MySchema()\n+        assert schema.fields[\"foo\"].inner.format == \"iso8601\"\n+        assert schema.fields[\"bar\"].tuple_fields[0].format == \"iso8601\"\n+\n \n class TestMetadata:\n     @pytest.mark.parametrize(\"FieldClass\", ALL_FIELDS)\n", "problem_statement": "3.0: DateTime fields cannot be used as inner field for List or Tuple fields\nBetween releases 3.0.0rc8 and 3.0.0rc9, `DateTime` fields have started throwing an error when being instantiated as inner fields of container fields like `List` or `Tuple`. The snippet below works in <=3.0.0rc8 and throws the error below in >=3.0.0rc9 (and, worryingly, 3.0.0):\r\n\r\n```python\r\nfrom marshmallow import fields, Schema\r\n\r\nclass MySchema(Schema):\r\n    times = fields.List(fields.DateTime())\r\n\r\ns = MySchema()\r\n```\r\n\r\nTraceback:\r\n```\r\nTraceback (most recent call last):\r\n  File \"test-mm.py\", line 8, in <module>\r\n    s = MySchema()\r\n  File \"/Users/victor/.pyenv/versions/marshmallow/lib/python3.6/site-packages/marshmallow/schema.py\", line 383, in __init__\r\n    self.fields = self._init_fields()\r\n  File \"/Users/victor/.pyenv/versions/marshmallow/lib/python3.6/site-packages/marshmallow/schema.py\", line 913, in _init_fields\r\n    self._bind_field(field_name, field_obj)\r\n  File \"/Users/victor/.pyenv/versions/marshmallow/lib/python3.6/site-packages/marshmallow/schema.py\", line 969, in _bind_field\r\n    field_obj._bind_to_schema(field_name, self)\r\n  File \"/Users/victor/.pyenv/versions/marshmallow/lib/python3.6/site-packages/marshmallow/fields.py\", line 636, in _bind_to_schema\r\n    self.inner._bind_to_schema(field_name, self)\r\n  File \"/Users/victor/.pyenv/versions/marshmallow/lib/python3.6/site-packages/marshmallow/fields.py\", line 1117, in _bind_to_schema\r\n    or getattr(schema.opts, self.SCHEMA_OPTS_VAR_NAME)\r\nAttributeError: 'List' object has no attribute 'opts'\r\n```\r\n\r\nIt seems like it's treating the parent field as a Schema without checking that it is indeed a schema, so the `schema.opts` statement fails as fields don't have an `opts` attribute.\n", "hints_text": "Thanks for reporting. I don't think I'll have time to look into this until the weekend. Would you like to send a PR? \nI'm afraid I don't have any time either, and I don't really have enough context on the `_bind_to_schema` process to make sure I'm not breaking stuff.\nOK, no problem. @lafrech Will you have a chance to look into this?\nI've found the patch below to fix the minimal example above, but I'm not really sure what it's missing out on or how to test it properly:\r\n```patch\r\ndiff --git a/src/marshmallow/fields.py b/src/marshmallow/fields.py\r\nindex 0b18e7d..700732e 100644\r\n--- a/src/marshmallow/fields.py\r\n+++ b/src/marshmallow/fields.py\r\n@@ -1114,7 +1114,7 @@ class DateTime(Field):\r\n         super()._bind_to_schema(field_name, schema)\r\n         self.format = (\r\n             self.format\r\n-            or getattr(schema.opts, self.SCHEMA_OPTS_VAR_NAME)\r\n+            or getattr(getattr(schema, \"opts\", None), self.SCHEMA_OPTS_VAR_NAME, None)\r\n             or self.DEFAULT_FORMAT\r\n         )\r\n```\n    git difftool 3.0.0rc8 3.0.0rc9 src/marshmallow/fields.py\r\n\r\nWhen reworking container stuff, I changed\r\n\r\n```py\r\n        self.inner.parent = self\r\n        self.inner.name = field_name\r\n```\r\ninto\r\n\r\n```py\r\n        self.inner._bind_to_schema(field_name, self)\r\n```\r\n\r\nAFAIR, I did this merely to avoid duplication. On second thought, I think it was the right thing to do, not only for duplication but to actually bind inner fields to the `Schema`.\r\n\r\nReverting this avoids the error but the inner field's `_bind_to_schema` method is not called so I'm not sure it is desirable.\r\n\r\nI think we really mean to call that method, not only in this case but also generally.\r\n\r\nChanging\r\n\r\n```py\r\n            or getattr(schema.opts, self.SCHEMA_OPTS_VAR_NAME)\r\n```\r\n\r\ninto\r\n\r\n```py\r\n            or getattr(self.root.opts, self.SCHEMA_OPTS_VAR_NAME)\r\n```\r\n\r\nmight be a better fix. Can anyone confirm (@sloria, @deckar01)?\r\n\r\nThe fix in https://github.com/marshmallow-code/marshmallow/issues/1357#issuecomment-523465528 removes the error but also the feature: `DateTime` fields buried into container fields won't respect the format set in the `Schema`.\r\n\r\nI didn't double-check that but AFAIU, the change I mentioned above (in container stuff rework) was the right thing to do. The feature was already broken (format set in `Schema` not respected if `DateTime` field in container field) and that's just one of the issues that may arise due to the inner field not being bound to the `Schema`. But I may be wrong.\nOn quick glance, your analysis and fix look correct @lafrech \nLet's do that, then.\r\n\r\nNot much time either. The first who gets the time can do it.\r\n\r\nFor the non-reg tests :\r\n\r\n1/ a test that checks the format set in the schema is respected if the `DateTime` field is in a container field\r\n\r\n2/ a set of tests asserting the `_bind_to_schema` method of inner fields `List`, `Dict`, `Tuple` is called from container fields (we can use `DateTime` with the same test case for that)\r\n\r\nPerhaps 1/ is useless if 2/ is done.", "created_at": "2019-08-21T15:45:13Z", "version": "3.0", "FAIL_TO_PASS": ["tests/test_fields.py::TestParentAndName::test_datetime_list_inner_format"], "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::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::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::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_only_and_exclude_merged_with_nested[only-expected0]", "tests/test_fields.py::TestListNested::test_list_nested_only_and_exclude_merged_with_nested[exclude-expected1]", "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": "8b3a32614fd4a74e93e9a63a042e74c1fea34466"}, {"repo": "marshmallow-code/marshmallow", "instance_id": "marshmallow-code__marshmallow-1343", "base_commit": "2be2d83a1a9a6d3d9b85804f3ab545cecc409bb0", "patch": "diff --git a/src/marshmallow/schema.py b/src/marshmallow/schema.py\n--- a/src/marshmallow/schema.py\n+++ b/src/marshmallow/schema.py\n@@ -877,7 +877,7 @@ def _invoke_field_validators(self, unmarshal, data, many):\n                 for idx, item in enumerate(data):\n                     try:\n                         value = item[field_obj.attribute or field_name]\n-                    except KeyError:\n+                    except (KeyError, TypeError):\n                         pass\n                     else:\n                         validated_value = unmarshal.call_and_store(\n@@ -892,7 +892,7 @@ def _invoke_field_validators(self, unmarshal, data, many):\n             else:\n                 try:\n                     value = data[field_obj.attribute or field_name]\n-                except KeyError:\n+                except (KeyError, TypeError):\n                     pass\n                 else:\n                     validated_value = unmarshal.call_and_store(\n", "test_patch": "diff --git a/tests/test_marshalling.py b/tests/test_marshalling.py\n--- a/tests/test_marshalling.py\n+++ b/tests/test_marshalling.py\n@@ -2,7 +2,7 @@\n \n import pytest\n \n-from marshmallow import fields, Schema\n+from marshmallow import fields, Schema, validates\n from marshmallow.marshalling import Marshaller, Unmarshaller, missing\n from marshmallow.exceptions import ValidationError\n \n@@ -283,3 +283,24 @@ class TestSchema(Schema):\n \n             assert result is None\n             assert excinfo.value.messages == {'foo': {'_schema': ['Invalid input type.']}}\n+\n+    # Regression test for https://github.com/marshmallow-code/marshmallow/issues/1342\n+    def test_deserialize_wrong_nested_type_with_validates_method(self, unmarshal):\n+        class TestSchema(Schema):\n+            value = fields.String()\n+\n+            @validates('value')\n+            def validate_value(self, value):\n+                pass\n+\n+        data = {\n+            'foo': 'not what we need'\n+        }\n+        fields_dict = {\n+            'foo': fields.Nested(TestSchema, required=True)\n+        }\n+        with pytest.raises(ValidationError) as excinfo:\n+            result = unmarshal.deserialize(data, fields_dict)\n+\n+            assert result is None\n+            assert excinfo.value.messages == {'foo': {'_schema': ['Invalid input type.']}}\n", "problem_statement": "[version 2.20.0] TypeError: 'NoneType' object is not subscriptable\nAfter update from version 2.19.5 to 2.20.0 I got error for code like:\r\n\r\n```python\r\nfrom marshmallow import Schema, fields, validates\r\n\r\n\r\nclass Bar(Schema):\r\n    value = fields.String()\r\n\r\n    @validates('value')  # <- issue here\r\n    def validate_value(self, value):\r\n        pass\r\n\r\n\r\nclass Foo(Schema):\r\n    bar = fields.Nested(Bar)\r\n\r\n\r\nsch = Foo()\r\n\r\nsch.validate({\r\n    'bar': 'invalid',\r\n})\r\n```\r\n\r\n```\r\nTraceback (most recent call last):\r\n  File \"/_/bug_mschema.py\", line 19, in <module>\r\n    'bar': 'invalid',\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/schema.py\", line 628, in validate\r\n    _, errors = self._do_load(data, many, partial=partial, postprocess=False)\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/schema.py\", line 670, in _do_load\r\n    index_errors=self.opts.index_errors,\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/marshalling.py\", line 292, in deserialize\r\n    index=(index if index_errors else None)\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/marshalling.py\", line 65, in call_and_store\r\n    value = getter_func(data)\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/marshalling.py\", line 285, in <lambda>\r\n    data\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/fields.py\", line 265, in deserialize\r\n    output = self._deserialize(value, attr, data)\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/fields.py\", line 465, in _deserialize\r\n    data, errors = self.schema.load(value)\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/schema.py\", line 588, in load\r\n    result, errors = self._do_load(data, many, partial=partial, postprocess=True)\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/schema.py\", line 674, in _do_load\r\n    self._invoke_field_validators(unmarshal, data=result, many=many)\r\n  File \"/_/env/lib/python3.7/site-packages/marshmallow/schema.py\", line 894, in _invoke_field_validators\r\n    value = data[field_obj.attribute or field_name]\r\nTypeError: 'NoneType' object is not subscriptable\r\n```\n", "hints_text": "Thanks for reporting. I was able to reproduce this on 2.20.0. This is likely a regression from https://github.com/marshmallow-code/marshmallow/pull/1323 . I don't have time to look into it now. Would appreciate a PR.", "created_at": "2019-08-13T04:36:01Z", "version": "2.20", "FAIL_TO_PASS": ["tests/test_marshalling.py::TestUnmarshaller::test_deserialize_wrong_nested_type_with_validates_method"], "PASS_TO_PASS": ["tests/test_marshalling.py::test_missing_is_falsy", "tests/test_marshalling.py::TestMarshaller::test_prefix", "tests/test_marshalling.py::TestMarshaller::test_marshalling_generator", "tests/test_marshalling.py::TestMarshaller::test_default_to_missing", "tests/test_marshalling.py::TestMarshaller::test_serialize_fields_with_load_only_param", "tests/test_marshalling.py::TestMarshaller::test_missing_data_are_skipped", "tests/test_marshalling.py::TestMarshaller::test_serialize_with_load_only_doesnt_validate", "tests/test_marshalling.py::TestMarshaller::test_serialize_fields_with_dump_to_param", "tests/test_marshalling.py::TestMarshaller::test_serialize_fields_with_dump_to_and_prefix_params", "tests/test_marshalling.py::TestMarshaller::test_stores_indices_of_errors_when_many_equals_true", "tests/test_marshalling.py::TestMarshaller::test_doesnt_store_errors_when_index_errors_equals_false", "tests/test_marshalling.py::TestUnmarshaller::test_extra_data_is_ignored", "tests/test_marshalling.py::TestUnmarshaller::test_stores_errors", "tests/test_marshalling.py::TestUnmarshaller::test_stores_indices_of_errors_when_many_equals_true", "tests/test_marshalling.py::TestUnmarshaller::test_doesnt_store_errors_when_index_errors_equals_false", "tests/test_marshalling.py::TestUnmarshaller::test_deserialize", "tests/test_marshalling.py::TestUnmarshaller::test_extra_fields", "tests/test_marshalling.py::TestUnmarshaller::test_deserialize_many", "tests/test_marshalling.py::TestUnmarshaller::test_deserialize_stores_errors", "tests/test_marshalling.py::TestUnmarshaller::test_deserialize_fields_with_attribute_param", "tests/test_marshalling.py::TestUnmarshaller::test_deserialize_fields_with_load_from_param", "tests/test_marshalling.py::TestUnmarshaller::test_deserialize_fields_with_dump_only_param", "tests/test_marshalling.py::TestUnmarshaller::test_deserialize_wrong_type_root_data", "tests/test_marshalling.py::TestUnmarshaller::test_deserialize_wrong_type_nested_data"], "environment_setup_commit": "7015fc4333a2f32cd58c3465296e834acd4496ff"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1160", "base_commit": "47654a073e0eb2b48b2ccdadb5cade9be0484b73", "patch": "diff --git a/pvlib/tracking.py b/pvlib/tracking.py\n--- a/pvlib/tracking.py\n+++ b/pvlib/tracking.py\n@@ -2,7 +2,7 @@\n import pandas as pd\n \n from pvlib.tools import cosd, sind, tand\n-from pvlib.pvsystem import PVSystem\n+from pvlib.pvsystem import PVSystem, _unwrap_single_value\n from pvlib import irradiance, atmosphere\n \n \n@@ -169,6 +169,7 @@ def get_aoi(self, surface_tilt, surface_azimuth, solar_zenith,\n                              solar_zenith, solar_azimuth)\n         return aoi\n \n+    @_unwrap_single_value\n     def get_irradiance(self, surface_tilt, surface_azimuth,\n                        solar_zenith, solar_azimuth, dni, ghi, dhi,\n                        dni_extra=None, airmass=None, model='haydavies',\n@@ -221,16 +222,29 @@ def get_irradiance(self, surface_tilt, surface_azimuth,\n         if airmass is None:\n             airmass = atmosphere.get_relative_airmass(solar_zenith)\n \n-        return irradiance.get_total_irradiance(surface_tilt,\n-                                               surface_azimuth,\n-                                               solar_zenith,\n-                                               solar_azimuth,\n-                                               dni, ghi, dhi,\n-                                               dni_extra=dni_extra,\n-                                               airmass=airmass,\n-                                               model=model,\n-                                               albedo=self.albedo,\n-                                               **kwargs)\n+        # SingleAxisTracker only supports a single Array, but we need the\n+        # validate/iterate machinery so that single length tuple input/output\n+        # is handled the same as PVSystem.get_irradiance. GH 1159\n+        dni = self._validate_per_array(dni, system_wide=True)\n+        ghi = self._validate_per_array(ghi, system_wide=True)\n+        dhi = self._validate_per_array(dhi, system_wide=True)\n+\n+        return tuple(\n+            irradiance.get_total_irradiance(\n+                surface_tilt,\n+                surface_azimuth,\n+                solar_zenith,\n+                solar_azimuth,\n+                dni, ghi, dhi,\n+                dni_extra=dni_extra,\n+                airmass=airmass,\n+                model=model,\n+                albedo=self.albedo,\n+                **kwargs)\n+            for array, dni, ghi, dhi in zip(\n+                self.arrays, dni, ghi, dhi\n+            )\n+        )\n \n \n def singleaxis(apparent_zenith, apparent_azimuth,\n", "test_patch": "diff --git a/pvlib/tests/test_modelchain.py b/pvlib/tests/test_modelchain.py\n--- a/pvlib/tests/test_modelchain.py\n+++ b/pvlib/tests/test_modelchain.py\n@@ -726,6 +726,29 @@ def test_run_model_tracker(sapm_dc_snl_ac_system, location, weather, mocker):\n                                             'surface_tilt']).all()\n     assert mc.results.ac[0] > 0\n     assert np.isnan(mc.results.ac[1])\n+    assert isinstance(mc.results.dc, pd.DataFrame)\n+\n+\n+def test_run_model_tracker_list(\n+        sapm_dc_snl_ac_system, location, weather, mocker):\n+    system = SingleAxisTracker(\n+        module_parameters=sapm_dc_snl_ac_system.module_parameters,\n+        temperature_model_parameters=(\n+            sapm_dc_snl_ac_system.temperature_model_parameters\n+        ),\n+        inverter_parameters=sapm_dc_snl_ac_system.inverter_parameters)\n+    mocker.spy(system, 'singleaxis')\n+    mc = ModelChain(system, location)\n+    mc.run_model([weather])\n+    assert system.singleaxis.call_count == 1\n+    assert (mc.results.tracking.columns == ['tracker_theta',\n+                                            'aoi',\n+                                            'surface_azimuth',\n+                                            'surface_tilt']).all()\n+    assert mc.results.ac[0] > 0\n+    assert np.isnan(mc.results.ac[1])\n+    assert isinstance(mc.results.dc, tuple)\n+    assert len(mc.results.dc) == 1\n \n \n def test__assign_total_irrad(sapm_dc_snl_ac_system, location, weather,\n", "problem_statement": "ValueError: SingleAxisTracker, Array, and running the model on a tuple/list of weather\n**Describe the bug**\r\nI know a refactoring of the Array with single axis tracking is in the works #1146. In the meantime, a `ValueError` is raised when trying to run a SingleAxisTracker defined with an array and supplying (ghi, dni, dhi) weather as a tuple/list. I would expect calling `run_model([weather])` would work similarly to a modelchain for a fixed system with an array singleton. The error stems from `pvlib.tracking.SingleAxisTracker.get_irradiance`  because most inputs are `pandas.Series`, but ghi, dhi, dni are `Tuple[Series]`.\r\n\r\n**To Reproduce**\r\n```python\r\nimport pandas as pd\r\nfrom pvlib.location import Location\r\nfrom pvlib.pvsystem import Array\r\nfrom pvlib.tracking import SingleAxisTracker\r\nfrom pvlib.modelchain import ModelChain\r\n\r\n\r\narray_params = {\r\n    \"surface_tilt\": None,\r\n    \"surface_azimuth\": None,\r\n    \"module\": \"Canadian_Solar_Inc__CS5P_220M\",\r\n    \"albedo\": 0.2,\r\n    \"temperature_model_parameters\": {\r\n        \"u_c\": 29.0,\r\n        \"u_v\": 0.0,\r\n        \"eta_m\": 0.1,\r\n        \"alpha_absorption\": 0.9,\r\n    },\r\n    \"strings\": 5,\r\n    \"modules_per_string\": 7,\r\n    \"module_parameters\": {\r\n        \"alpha_sc\": 0.004539,\r\n        \"gamma_ref\": 1.2,\r\n        \"mu_gamma\": -0.003,\r\n        \"I_L_ref\": 5.11426,\r\n        \"I_o_ref\": 8.10251e-10,\r\n        \"R_sh_ref\": 381.254,\r\n        \"R_sh_0\": 400.0,\r\n        \"R_s\": 1.06602,\r\n        \"cells_in_series\": 96,\r\n        \"R_sh_exp\": 5.5,\r\n        \"EgRef\": 1.121,\r\n    },\r\n}\r\ninverter_parameters = {\r\n    \"Paco\": 250.0,\r\n    \"Pdco\": 259.589,\r\n    \"Vdco\": 40.0,\r\n    \"Pso\": 2.08961,\r\n    \"C0\": -4.1e-05,\r\n    \"C1\": -9.1e-05,\r\n    \"C2\": 0.000494,\r\n    \"C3\": -0.013171,\r\n    \"Pnt\": 0.075,\r\n}\r\n\r\n\r\nlocation = Location(latitude=33.98, longitude=-115.323, altitude=2300)\r\n\r\n\r\ntracking = SingleAxisTracker(\r\n    arrays=[Array(**array_params, name=0)],\r\n    axis_tilt=0,\r\n    axis_azimuth=180,\r\n    gcr=0.1,\r\n    backtrack=True,\r\n    inverter_parameters=inverter_parameters,\r\n)\r\n\r\nweather = pd.DataFrame(\r\n    {\r\n        \"ghi\": [1100.0, 1101.0],\r\n        \"dni\": [1000.0, 1001],\r\n        \"dhi\": [100.0, 100],\r\n        \"module_temperature\": [25.0, 25],\r\n    },\r\n    index=pd.DatetimeIndex(\r\n        [pd.Timestamp(\"2021-01-20T12:00-05:00\"), pd.Timestamp(\"2021-01-20T12:05-05:00\")]\r\n    ),\r\n)\r\nmc = ModelChain(\r\n    tracking,\r\n    location,\r\n    aoi_model=\"no_loss\",\r\n    spectral_model=\"no_loss\",\r\n)\r\nmc.run_model(weather)  # OK\r\nmc.run_model([weather])  # ValueError\r\n\r\n```\r\n\r\n**Versions:**\r\n - ``pvlib.__version__``: 0.9.0-alpha.2+2.g47654a0\r\n\n", "hints_text": "", "created_at": "2021-02-05T03:27:29Z", "version": "0.8", "FAIL_TO_PASS": ["pvlib/tests/test_modelchain.py::test_run_model_tracker_list"], "PASS_TO_PASS": ["pvlib/tests/test_modelchain.py::test_ModelChain_creation", "pvlib/tests/test_modelchain.py::test_with_sapm", "pvlib/tests/test_modelchain.py::test_with_pvwatts", "pvlib/tests/test_modelchain.py::test_orientation_strategy[None-expected0]", "pvlib/tests/test_modelchain.py::test_orientation_strategy[None-expected1]", "pvlib/tests/test_modelchain.py::test_orientation_strategy[flat-expected2]", "pvlib/tests/test_modelchain.py::test_orientation_strategy[south_at_latitude_tilt-expected3]", "pvlib/tests/test_modelchain.py::test_run_model_with_irradiance", "pvlib/tests/test_modelchain.py::test_run_model_from_irradiance_arrays_no_loss", "pvlib/tests/test_modelchain.py::test_run_model_from_irradiance_arrays_no_loss_input_type[tuple]", "pvlib/tests/test_modelchain.py::test_run_model_from_irradiance_arrays_no_loss_input_type[list]", "pvlib/tests/test_modelchain.py::test_ModelChain_invalid_inverter_params_arrays[adr]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_multi_weather[tuple]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_multi_weather[list]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_no_irradiance", "pvlib/tests/test_modelchain.py::test_prepare_inputs_arrays_one_missing_irradiance", "pvlib/tests/test_modelchain.py::test_prepare_inputs_weather_wrong_length[tuple]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_weather_wrong_length[list]", "pvlib/tests/test_modelchain.py::test_ModelChain_times_error_arrays", "pvlib/tests/test_modelchain.py::test_ModelChain_times_arrays", "pvlib/tests/test_modelchain.py::test_prepare_inputs_missing_irrad_component[dhi]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_missing_irrad_component[ghi]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_missing_irrad_component[dni]", "pvlib/tests/test_modelchain.py::test_run_model_arrays_weather[tuple-sandia]", "pvlib/tests/test_modelchain.py::test_run_model_arrays_weather[tuple-pvwatts]", "pvlib/tests/test_modelchain.py::test_run_model_arrays_weather[list-sandia]", "pvlib/tests/test_modelchain.py::test_run_model_arrays_weather[list-pvwatts]", "pvlib/tests/test_modelchain.py::test_run_model_perez", "pvlib/tests/test_modelchain.py::test_run_model_gueymard_perez", "pvlib/tests/test_modelchain.py::test_run_model_with_weather_sapm_temp", "pvlib/tests/test_modelchain.py::test_run_model_with_weather_pvsyst_temp", "pvlib/tests/test_modelchain.py::test_run_model_with_weather_faiman_temp", "pvlib/tests/test_modelchain.py::test_run_model_with_weather_fuentes_temp", "pvlib/tests/test_modelchain.py::test_run_model_tracker", "pvlib/tests/test_modelchain.py::test__assign_total_irrad", "pvlib/tests/test_modelchain.py::test_prepare_inputs_from_poa", "pvlib/tests/test_modelchain.py::test_prepare_inputs_from_poa_multi_data[tuple]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_from_poa_multi_data[list]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_from_poa_wrong_number_arrays[tuple]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_from_poa_wrong_number_arrays[list]", "pvlib/tests/test_modelchain.py::test_prepare_inputs_from_poa_arrays_different_indices", "pvlib/tests/test_modelchain.py::test_prepare_inputs_from_poa_arrays_missing_column", "pvlib/tests/test_modelchain.py::test__prepare_temperature", "pvlib/tests/test_modelchain.py::test__prepare_temperature_arrays_weather", "pvlib/tests/test_modelchain.py::test_temperature_models_arrays_multi_weather[temp_params0-sapm_temp]", "pvlib/tests/test_modelchain.py::test_temperature_models_arrays_multi_weather[temp_params1-pvsyst_temp]", "pvlib/tests/test_modelchain.py::test_temperature_models_arrays_multi_weather[temp_params2-faiman_temp]", "pvlib/tests/test_modelchain.py::test_temperature_models_arrays_multi_weather[temp_params3-fuentes_temp]", "pvlib/tests/test_modelchain.py::test_run_model_solar_position_weather", "pvlib/tests/test_modelchain.py::test_run_model_from_poa", "pvlib/tests/test_modelchain.py::test_run_model_from_poa_arrays[tuple]", "pvlib/tests/test_modelchain.py::test_run_model_from_poa_arrays[list]", "pvlib/tests/test_modelchain.py::test_run_model_from_poa_arrays_solar_position_weather", "pvlib/tests/test_modelchain.py::test_run_model_from_poa_tracking", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance_no_poa_global", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance_poa_global_differs", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance_arrays_error[tuple]", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance_arrays_error[list]", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance_arrays[tuple]", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance_arrays[list]", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance_minimal_input", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance_missing_poa", "pvlib/tests/test_modelchain.py::test_run_model_singleton_weather_single_array", "pvlib/tests/test_modelchain.py::test_run_model_from_poa_singleton_weather_single_array", "pvlib/tests/test_modelchain.py::test_run_model_from_effective_irradiance_weather_single_array", "pvlib/tests/test_modelchain.py::test_infer_dc_model[sapm]", "pvlib/tests/test_modelchain.py::test_infer_dc_model[cec]", "pvlib/tests/test_modelchain.py::test_infer_dc_model[desoto]", "pvlib/tests/test_modelchain.py::test_infer_dc_model[pvsyst]", "pvlib/tests/test_modelchain.py::test_infer_dc_model[singlediode]", "pvlib/tests/test_modelchain.py::test_infer_dc_model[pvwatts_dc]", "pvlib/tests/test_modelchain.py::test_singlediode_dc_arrays[cec]", "pvlib/tests/test_modelchain.py::test_singlediode_dc_arrays[desoto]", "pvlib/tests/test_modelchain.py::test_singlediode_dc_arrays[pvsyst]", "pvlib/tests/test_modelchain.py::test_infer_spectral_model[sapm]", "pvlib/tests/test_modelchain.py::test_infer_spectral_model[cec]", "pvlib/tests/test_modelchain.py::test_infer_spectral_model[cec_native]", "pvlib/tests/test_modelchain.py::test_infer_temp_model[sapm_temp]", "pvlib/tests/test_modelchain.py::test_infer_temp_model[faiman_temp]", "pvlib/tests/test_modelchain.py::test_infer_temp_model[pvsyst_temp]", "pvlib/tests/test_modelchain.py::test_infer_temp_model[fuentes_temp]", "pvlib/tests/test_modelchain.py::test_infer_temp_model_invalid", "pvlib/tests/test_modelchain.py::test_temperature_model_inconsistent", "pvlib/tests/test_modelchain.py::test_dc_model_user_func", "pvlib/tests/test_modelchain.py::test_pvwatts_dc_multiple_strings", "pvlib/tests/test_modelchain.py::test_ac_models[sandia]", "pvlib/tests/test_modelchain.py::test_ac_models[adr]", "pvlib/tests/test_modelchain.py::test_ac_models[pvwatts]", "pvlib/tests/test_modelchain.py::test_ac_models[sandia_multi]", "pvlib/tests/test_modelchain.py::test_ac_models[pvwatts_multi]", "pvlib/tests/test_modelchain.py::test_ac_model_user_func", "pvlib/tests/test_modelchain.py::test_ac_model_not_a_model", "pvlib/tests/test_modelchain.py::test_infer_ac_model_invalid_params", "pvlib/tests/test_modelchain.py::test_aoi_models[sapm]", "pvlib/tests/test_modelchain.py::test_aoi_models[ashrae]", "pvlib/tests/test_modelchain.py::test_aoi_models[physical]", "pvlib/tests/test_modelchain.py::test_aoi_models[martin_ruiz]", "pvlib/tests/test_modelchain.py::test_aoi_models_singleon_weather_single_array[sapm]", "pvlib/tests/test_modelchain.py::test_aoi_models_singleon_weather_single_array[ashrae]", "pvlib/tests/test_modelchain.py::test_aoi_models_singleon_weather_single_array[physical]", "pvlib/tests/test_modelchain.py::test_aoi_models_singleon_weather_single_array[martin_ruiz]", "pvlib/tests/test_modelchain.py::test_aoi_model_no_loss", "pvlib/tests/test_modelchain.py::test_aoi_model_user_func", "pvlib/tests/test_modelchain.py::test_infer_aoi_model[sapm]", "pvlib/tests/test_modelchain.py::test_infer_aoi_model[ashrae]", "pvlib/tests/test_modelchain.py::test_infer_aoi_model[physical]", "pvlib/tests/test_modelchain.py::test_infer_aoi_model[martin_ruiz]", "pvlib/tests/test_modelchain.py::test_infer_aoi_model_invalid", "pvlib/tests/test_modelchain.py::test_spectral_models[sapm]", "pvlib/tests/test_modelchain.py::test_spectral_models[first_solar]", "pvlib/tests/test_modelchain.py::test_spectral_models[no_loss]", "pvlib/tests/test_modelchain.py::test_spectral_models[constant_spectral_loss]", "pvlib/tests/test_modelchain.py::test_spectral_models_singleton_weather_single_array[sapm]", "pvlib/tests/test_modelchain.py::test_spectral_models_singleton_weather_single_array[first_solar]", "pvlib/tests/test_modelchain.py::test_spectral_models_singleton_weather_single_array[no_loss]", "pvlib/tests/test_modelchain.py::test_spectral_models_singleton_weather_single_array[constant_spectral_loss]", "pvlib/tests/test_modelchain.py::test_losses_models_pvwatts", "pvlib/tests/test_modelchain.py::test_losses_models_pvwatts_arrays", "pvlib/tests/test_modelchain.py::test_losses_models_ext_def", "pvlib/tests/test_modelchain.py::test_losses_models_no_loss", "pvlib/tests/test_modelchain.py::test_invalid_dc_model_params", "pvlib/tests/test_modelchain.py::test_invalid_models[dc_model]", "pvlib/tests/test_modelchain.py::test_invalid_models[ac_model]", "pvlib/tests/test_modelchain.py::test_invalid_models[aoi_model]", "pvlib/tests/test_modelchain.py::test_invalid_models[spectral_model]", "pvlib/tests/test_modelchain.py::test_invalid_models[temperature_model]", "pvlib/tests/test_modelchain.py::test_invalid_models[losses_model]", "pvlib/tests/test_modelchain.py::test_bad_get_orientation", "pvlib/tests/test_modelchain.py::test_with_sapm_pvsystem_arrays", "pvlib/tests/test_modelchain.py::test_ModelChain_no_extra_kwargs", "pvlib/tests/test_modelchain.py::test_ModelChain_attributes_deprecated_10", "pvlib/tests/test_modelchain.py::test_basic_chain_required", "pvlib/tests/test_modelchain.py::test_basic_chain_alt_az", "pvlib/tests/test_modelchain.py::test_basic_chain_strategy", "pvlib/tests/test_modelchain.py::test_basic_chain_altitude_pressure", "pvlib/tests/test_modelchain.py::test_ModelChain___repr__[south_at_latitude_tilt-south_at_latitude_tilt]", "pvlib/tests/test_modelchain.py::test_ModelChain___repr__[None-None]", "pvlib/tests/test_modelchain.py::test_complete_irradiance_clean_run", "pvlib/tests/test_modelchain.py::test_complete_irradiance", "pvlib/tests/test_modelchain.py::test_complete_irradiance_arrays[tuple]", "pvlib/tests/test_modelchain.py::test_complete_irradiance_arrays[list]", "pvlib/tests/test_modelchain.py::test_complete_irradiance_arrays_wrong_length[tuple]", "pvlib/tests/test_modelchain.py::test_complete_irradiance_arrays_wrong_length[list]", "pvlib/tests/test_modelchain.py::test_unknown_attribute", "pvlib/tests/test_modelchain.py::test_inconsistent_array_params", "pvlib/tests/test_modelchain.py::test_modelchain__common_keys", "pvlib/tests/test_modelchain.py::test__irrad_for_celltemp"], "environment_setup_commit": "ef8ad2fee9840a77d14b0dfd17fc489dd85c9b91"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1191", "base_commit": "0415365031ca8d0b2867f2a2877e0ad9d7098ffc", "patch": "diff --git a/pvlib/irradiance.py b/pvlib/irradiance.py\n--- a/pvlib/irradiance.py\n+++ b/pvlib/irradiance.py\n@@ -182,6 +182,9 @@ def aoi_projection(surface_tilt, surface_azimuth, solar_zenith, solar_azimuth):\n         tools.sind(surface_tilt) * tools.sind(solar_zenith) *\n         tools.cosd(solar_azimuth - surface_azimuth))\n \n+    # GH 1185\n+    projection = np.clip(projection, -1, 1)\n+\n     try:\n         projection.name = 'aoi_projection'\n     except AttributeError:\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@@ -792,6 +792,27 @@ def test_aoi_and_aoi_projection(surface_tilt, surface_azimuth, solar_zenith,\n     assert_allclose(aoi_projection, aoi_proj_expected, atol=1e-6)\n \n \n+def test_aoi_projection_precision():\n+    # GH 1185 -- test that aoi_projection does not exceed 1.0, and when\n+    # given identical inputs, the returned projection is very close to 1.0\n+\n+    # scalars\n+    zenith = 89.26778228223463\n+    azimuth = 60.932028605997004\n+    projection = irradiance.aoi_projection(zenith, azimuth, zenith, azimuth)\n+    assert projection <= 1\n+    assert np.isclose(projection, 1)\n+\n+    # arrays\n+    zeniths = np.array([zenith])\n+    azimuths = np.array([azimuth])\n+    projections = irradiance.aoi_projection(zeniths, azimuths,\n+                                            zeniths, azimuths)\n+    assert all(projections <= 1)\n+    assert all(np.isclose(projections, 1))\n+    assert projections.dtype == np.dtype('float64')\n+\n+\n @pytest.fixture\n def airmass_kt():\n     # disc algorithm stopped at am=12. test am > 12 for out of range behavior\n", "problem_statement": "irradiance.aoi can return NaN when module orientation is perfectly aligned with solar position\n**Describe the bug**\r\nI was playing with a dual-axis tracking mount with #1176 and found that when the modules are perfectly aligned with the sun (i.e. AOI should be exactly zero), floating point round-off can result in aoi projection values slightly greater than one, resulting in NaN aoi.  This only happens for some perfectly-aligned inputs (for example tilt=zenith=20, azimuth=180 returns aoi=0 as expected).\r\n\r\n**To Reproduce**\r\n```python\r\nimport pvlib\r\nzenith = 89.26778228223463\r\nazimuth = 60.932028605997004\r\nprint(pvlib.irradiance.aoi_projection(zenith, azimuth, zenith, azimuth))\r\nprint(pvlib.irradiance.aoi(zenith, azimuth, zenith, azimuth))\r\n\r\n# output:\r\n1.0000000000000002\r\nRuntimeWarning: invalid value encountered in arccos:  aoi_value = np.rad2deg(np.arccos(projection))\r\nnan\r\n```\r\n\r\n**Expected behavior**\r\nI expect aoi=0 whenever module orientation and solar position angles are identical.\r\n\r\n**Versions:**\r\n - ``pvlib.__version__``: `0.9.0-alpha.4+14.g61650e9`\r\n - ``pandas.__version__``: `0.25.1`\r\n - ``numpy.__version__``: `1.17.0`\r\n - python: `3.7.7 (default, May  6 2020, 11:45:54) [MSC v.1916 64 bit (AMD64)]`\r\n\r\n**Additional context**\r\nSome ideas for fixes:\r\n1) In `irradiance.aoi_projection`, return a hard-coded `1.0` for inputs within some small tolerance\r\n2) In `irradiance.aoi_projection`, clamp return value to `[-1, +1]`\r\n3) In `irradiance.aoi`, clamp aoi_projection values to `[-1, +1`] before calling `arccos`\r\n4) Rework the `irradiance.aoi_projection` trig equations to not generate impossible values?\n", "hints_text": "", "created_at": "2021-03-10T01:05:50Z", "version": "0.8", "FAIL_TO_PASS": ["pvlib/tests/test_irradiance.py::test_aoi_projection_precision"], "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_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"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1589", "base_commit": "bd86597f62013f576670a452869ea88a47c58c01", "patch": "diff --git a/pvlib/bifacial/infinite_sheds.py b/pvlib/bifacial/infinite_sheds.py\n--- a/pvlib/bifacial/infinite_sheds.py\n+++ b/pvlib/bifacial/infinite_sheds.py\n@@ -216,8 +216,8 @@ def _ground_angle(x, surface_tilt, gcr):\n     #  :         \\  v      *-.\\\n     #  :          \\<-----P---->\\\n \n-    x1 = x * sind(surface_tilt)\n-    x2 = (x * cosd(surface_tilt) + 1 / gcr)\n+    x1 = gcr * x * sind(surface_tilt)\n+    x2 = gcr * x * cosd(surface_tilt) + 1\n     psi = np.arctan2(x1, x2)  # do this first because it handles 0 / 0\n     return np.rad2deg(psi)\n \ndiff --git a/pvlib/shading.py b/pvlib/shading.py\n--- a/pvlib/shading.py\n+++ b/pvlib/shading.py\n@@ -52,8 +52,8 @@ def masking_angle(surface_tilt, gcr, slant_height):\n     # The original equation (8 in [1]) requires pitch and collector width,\n     # but it's easy to non-dimensionalize it to make it a function of GCR\n     # by factoring out B from the argument to arctan.\n-    numerator = (1 - slant_height) * sind(surface_tilt)\n-    denominator = 1/gcr - (1 - slant_height) * cosd(surface_tilt)\n+    numerator = gcr * (1 - slant_height) * sind(surface_tilt)\n+    denominator = 1 - gcr * (1 - slant_height) * cosd(surface_tilt)\n     phi = np.arctan(numerator / denominator)\n     return np.degrees(phi)\n \n", "test_patch": "diff --git a/pvlib/tests/bifacial/test_infinite_sheds.py b/pvlib/tests/bifacial/test_infinite_sheds.py\n--- a/pvlib/tests/bifacial/test_infinite_sheds.py\n+++ b/pvlib/tests/bifacial/test_infinite_sheds.py\n@@ -106,6 +106,14 @@ def test__ground_angle(test_system):\n     assert np.allclose(angles, expected_angles)\n \n \n+def test__ground_angle_zero_gcr():\n+    surface_tilt = 30.0\n+    x = np.array([0.0, 0.5, 1.0])\n+    angles = infinite_sheds._ground_angle(x, surface_tilt, 0)\n+    expected_angles = np.array([0, 0, 0])\n+    assert np.allclose(angles, expected_angles)\n+\n+\n def test__vf_row_ground(test_system):\n     ts, _, _ = test_system\n     x = np.array([0., 0.5, 1.0])\ndiff --git a/pvlib/tests/test_shading.py b/pvlib/tests/test_shading.py\n--- a/pvlib/tests/test_shading.py\n+++ b/pvlib/tests/test_shading.py\n@@ -45,6 +45,13 @@ def test_masking_angle_scalar(surface_tilt, masking_angle):\n         assert np.isclose(masking_angle_actual, angle)\n \n \n+def test_masking_angle_zero_gcr(surface_tilt):\n+    # scalar inputs and outputs, including zero\n+    for tilt in surface_tilt:\n+        masking_angle_actual = shading.masking_angle(tilt, 0, 0.25)\n+        assert np.isclose(masking_angle_actual, 0)\n+\n+\n def test_masking_angle_passias_series(surface_tilt, average_masking_angle):\n     # pandas series inputs and outputs\n     masking_angle_actual = shading.masking_angle_passias(surface_tilt, 0.5)\n", "problem_statement": "ZeroDivisionError when gcr is zero\n**Describe the bug**\r\n\r\nThough maybe not intuitive, setting ground coverage ratio to zero is useful when a plant consists of a single shed, e.g. calculating the irradiance on the backside of the panels. However, e.g., `bifacial.infinite_sheds.get_irradiance_poa` fails with `ZeroDivisionError` whenever `gcr=0`.\r\n\r\n**To Reproduce**\r\n\r\n```python\r\nfrom pvlib.bifacial.infinite_sheds import get_irradiance_poa\r\n\r\nget_irradiance_poa(surface_tilt=160, surface_azimuth=180, solar_zenith=20, solar_azimuth=180, gcr=0, height=1, pitch=1000, ghi=200, dhi=200, dni=0, albedo=0.2)\r\n```\r\nreturns:\r\n```\r\nTraceback (most recent call last):\r\n  File \"C:\\Python\\Python310\\lib\\site-packages\\IPython\\core\\interactiveshell.py\", line 3398, in run_code\r\n    exec(code_obj, self.user_global_ns, self.user_ns)\r\n  File \"<ipython-input-7-0cb583b2b311>\", line 3, in <cell line: 3>\r\n    get_irradiance_poa(surface_tilt=160, surface_azimuth=180, solar_zenith=20, solar_azimuth=180, gcr=0, height=1, pitch=1, ghi=200, dhi=200, dni=0, albedo=0.2)\r\n  File \"C:\\Python\\Python310\\lib\\site-packages\\pvlib\\bifacial\\infinite_sheds.py\", line 522, in get_irradiance_poa\r\n    vf_shade_sky, vf_noshade_sky = _vf_row_sky_integ(\r\n  File \"C:\\Python\\Python310\\lib\\site-packages\\pvlib\\bifacial\\infinite_sheds.py\", line 145, in _vf_row_sky_integ\r\n    psi_t_shaded = masking_angle(surface_tilt, gcr, x)\r\n  File \"C:\\Python\\Python310\\lib\\site-packages\\pvlib\\shading.py\", line 56, in masking_angle\r\n    denominator = 1/gcr - (1 - slant_height) * cosd(surface_tilt)\r\nZeroDivisionError: division by zero\r\n```\r\n\r\n**Expected behavior**\r\n\r\nOne can easily solve this `ZeroDivisionError` by multiplying both numerator and denominator with `gcr` inside `shading.masking_angle` and the same inside `bifacial.infinite_sheds._ground_angle`.\r\n\r\n**Versions:**\r\n - ``pvlib.__version__``: '0.9.3'\r\n - ``pandas.__version__``: '1.4.4'\r\n - python: '3.10.4'\r\n\n", "hints_text": "@kdebrab thanks for investigating this case, which wasn't consider in the implementation. @pvlib/pvlib-core I think we should fix this. \r\n\r\nFor consistency we should also extend `shading.masking_angle_passias` for the limiting case of `gcr=0`. That may be more complicated and could be done in a second PR.\r\n\nI think `infinite_sheds.get_irradiance_poa(...)` converges to `irradiance.get_total_irradiance(..., model='isotropic')` as gcr approaches zero, so that's an option for modeling this situation in the meantime.  \nProbably close enough to be useful, but in theory the rear irradiance would be slightly less than GHI * 1/2 (1 - cos(tilt)), due to the row's shadow.\nWith a more realistic model (e.g. pvfactors) that considers shadows individually that's true, but `infinite_sheds` models ground-reflected irradiance using integrated averages which dilute the effect of the row's own shadow to nothing as gcr approaches zero.  By decreasing `gcr` and increasing `npoints` you can get `infinite_sheds` as close to `get_total_irradiance` as you like:\r\n\r\n![image](https://user-images.githubusercontent.com/57452607/198049857-0c844116-3bc0-48dd-b889-8b658f39b4a0.png)\r\n\r\n<details>\r\n  <summary>Source</summary>\r\n\r\n```python\r\nimport pvlib\r\nimport pandas as pd\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\ntimes = pd.date_range('2019-06-01', '2019-06-02', freq='T', tz='Etc/GMT+5')\r\nlocation = pvlib.location.Location(40, -80)\r\nsp = location.get_solarposition(times)\r\ncs = location.get_clearsky(times, solar_position=sp)\r\n\r\nkwargs = dict(\r\n    surface_tilt=20, surface_azimuth=180,\r\n    solar_zenith=sp.apparent_zenith, solar_azimuth=sp.azimuth,\r\n    ghi=cs.ghi, dhi=cs.dhi, dni=cs.dni, albedo=0.2\r\n)\r\n\r\nlimit = pvlib.irradiance.get_total_irradiance(**kwargs, model='isotropic')['poa_global']\r\n\r\nall_stats = []\r\n\r\nfor gcr in [0.3, 0.1, 1e-2, 1e-3, 1e-4, 1e-5, 1e-6, 1e-7]:\r\n    stats = dict(gcr=gcr)\r\n    for npoints in [100, 1000, 10000]:\r\n        out = pvlib.bifacial.infinite_sheds.get_irradiance_poa(gcr=gcr, height=1, pitch=1/gcr, npoints=npoints, **kwargs)\r\n        stats[f'npoints={npoints}'] = np.max(np.abs(out['poa_global'] - limit))\r\n\r\n    all_stats.append(stats)\r\n\r\npd.DataFrame(all_stats).set_index('gcr').plot(logx=True, logy=True)\r\nplt.ylabel('Max Absolute Difference [W/m2]')\r\n\r\n```\r\n</details>\n@kanderso-nrel Thanks for pointing this out!\r\n\r\nI think for a `surface_tilt` equal to 20\u00b0 (front side of the panel) this result would be fine, as there is no shadow on the front surface from the own row. However, changing `surface_tilt` to 160\u00b0 (back side of the panel) yields basically the same figure and that is indeed not ideal (and unexpected for me).\r\n\r\nIf I understand well, this is due to the calculation of the ground-reflected irradiance, where the infinite_sheds method uses (1) the **average** 'view factor from the ground to the sky' of the ground between the rows, and (2) the **average** 'fraction of ground between rows that is unshaded', both of which approach 1 as the pitch approaches infinity.\r\n\r\nI think an improved method would not take the average, but some kind of weighted average, considering that the reflection from the ground right in front of the surface is more important than the reflection from the ground further away from the surface. In that case, I would assume that the effect of the row's own shadow would no longer dilute when gcr approaches zero.\n> However, changing surface_tilt to 160\u00b0 (back side of the panel) yields basically the same figure and that is indeed not ideal (and unexpected for me).\r\n\r\nOops, I think I had originally started with rear-side, switched to front-side just to check it as well, and forgot to switch back to rear before posting here.  Good catch.\r\n\r\nFYI pvfactors (`pvlib.bifacial.pvfactors.pvfactors_timeseries`) can model irradiance for single rows (`n_pvrows=1, index_observed_pvrow=0`) and does not suffer from the averaging issues you mention. ", "created_at": "2022-11-11T14:19:29Z", "version": "0.8", "FAIL_TO_PASS": ["pvlib/tests/bifacial/test_infinite_sheds.py::test__ground_angle_zero_gcr", "pvlib/tests/test_shading.py::test_masking_angle_zero_gcr"], "PASS_TO_PASS": ["pvlib/tests/bifacial/test_infinite_sheds.py::test__vf_ground_sky_integ", "pvlib/tests/bifacial/test_infinite_sheds.py::test__vf_row_sky_integ", "pvlib/tests/bifacial/test_infinite_sheds.py::test__poa_sky_diffuse_pv", "pvlib/tests/bifacial/test_infinite_sheds.py::test__ground_angle", "pvlib/tests/bifacial/test_infinite_sheds.py::test__vf_row_ground", "pvlib/tests/bifacial/test_infinite_sheds.py::test__vf_row_ground_integ", "pvlib/tests/bifacial/test_infinite_sheds.py::test__poa_ground_shadows", "pvlib/tests/bifacial/test_infinite_sheds.py::test__shaded_fraction_floats", "pvlib/tests/bifacial/test_infinite_sheds.py::test__shaded_fraction_array", "pvlib/tests/bifacial/test_infinite_sheds.py::test_get_irradiance_poa", "pvlib/tests/bifacial/test_infinite_sheds.py::test__backside_tilt", "pvlib/tests/bifacial/test_infinite_sheds.py::test_get_irradiance", "pvlib/tests/bifacial/test_infinite_sheds.py::test_get_irradiance_limiting_gcr", "pvlib/tests/test_shading.py::test_masking_angle_series", "pvlib/tests/test_shading.py::test_masking_angle_scalar", "pvlib/tests/test_shading.py::test_masking_angle_passias_series", "pvlib/tests/test_shading.py::test_masking_angle_passias_scalar", "pvlib/tests/test_shading.py::test_sky_diffuse_passias_series", "pvlib/tests/test_shading.py::test_sky_diffuse_passias_scalar"], "environment_setup_commit": "ef8ad2fee9840a77d14b0dfd17fc489dd85c9b91"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1072", "base_commit": "04a523fafbd61bc2e49420963b84ed8e2bd1b3cf", "patch": "diff --git a/pvlib/temperature.py b/pvlib/temperature.py\n--- a/pvlib/temperature.py\n+++ b/pvlib/temperature.py\n@@ -599,8 +599,9 @@ def fuentes(poa_global, temp_air, wind_speed, noct_installed, module_height=5,\n     # n.b. the way Fuentes calculates the first timedelta makes it seem like\n     # the value doesn't matter -- rather than recreate it here, just assume\n     # it's the same as the second timedelta:\n-    timedelta_hours = np.diff(poa_global.index).astype(float) / 1e9 / 60 / 60\n-    timedelta_hours = np.append([timedelta_hours[0]], timedelta_hours)\n+    timedelta_seconds = poa_global.index.to_series().diff().dt.total_seconds()\n+    timedelta_hours = timedelta_seconds / 3600\n+    timedelta_hours.iloc[0] = timedelta_hours.iloc[1]\n \n     tamb_array = temp_air + 273.15\n     sun_array = poa_global * absorp\n", "test_patch": "diff --git a/pvlib/tests/test_temperature.py b/pvlib/tests/test_temperature.py\n--- a/pvlib/tests/test_temperature.py\n+++ b/pvlib/tests/test_temperature.py\n@@ -190,3 +190,17 @@ def test_fuentes(filename, inoct):\n     night_difference = expected_tcell[is_night] - actual_tcell[is_night]\n     assert night_difference.max() < 6\n     assert night_difference.min() > 0\n+\n+\n+@pytest.mark.parametrize('tz', [None, 'Etc/GMT+5'])\n+def test_fuentes_timezone(tz):\n+    index = pd.date_range('2019-01-01', freq='h', periods=3, tz=tz)\n+\n+    df = pd.DataFrame({'poa_global': 1000, 'temp_air': 20, 'wind_speed': 1},\n+                      index)\n+\n+    out = temperature.fuentes(df['poa_global'], df['temp_air'],\n+                              df['wind_speed'], noct_installed=45)\n+\n+    assert_series_equal(out, pd.Series([47.85, 50.85, 50.85], index=index,\n+                                       name='tmod'))\n", "problem_statement": "temperature.fuentes errors when given tz-aware inputs on pandas>=1.0.0\n**Describe the bug**\r\nWhen the weather timeseries inputs to `temperature.fuentes` have tz-aware index, an internal call to `np.diff(index)` returns an array of `Timedelta` objects instead of an array of nanosecond ints, throwing an error immediately after.  The error only happens when using pandas>=1.0.0; using 0.25.3 runs successfully, but emits the warning:\r\n\r\n```\r\n  /home/kevin/anaconda3/envs/pvlib-dev/lib/python3.7/site-packages/numpy/lib/function_base.py:1243: FutureWarning: Converting timezone-aware DatetimeArray to timezone-naive ndarray with 'datetime64[ns]' dtype. In the future, this will return an ndarray with 'object' dtype where each element is a 'pandas.Timestamp' with the correct 'tz'.\r\n  \tTo accept the future behavior, pass 'dtype=object'.\r\n  \tTo keep the old behavior, pass 'dtype=\"datetime64[ns]\"'.\r\n    a = asanyarray(a)\r\n```\r\n\r\n**To Reproduce**\r\n```python\r\nIn [1]: import pvlib\r\n   ...: import pandas as pd\r\n   ...: \r\n   ...: index_naive = pd.date_range('2019-01-01', freq='h', periods=3)\r\n   ...: \r\n   ...: kwargs = {\r\n   ...:     'poa_global': pd.Series(1000, index_naive),\r\n   ...:     'temp_air': pd.Series(20, index_naive),\r\n   ...:     'wind_speed': pd.Series(1, index_naive),\r\n   ...:     'noct_installed': 45\r\n   ...: }\r\n   ...: \r\n\r\nIn [2]: print(pvlib.temperature.fuentes(**kwargs))\r\n2019-01-01 00:00:00    47.85\r\n2019-01-01 01:00:00    50.85\r\n2019-01-01 02:00:00    50.85\r\nFreq: H, Name: tmod, dtype: float64\r\n\r\nIn [3]: kwargs['poa_global'].index = index_naive.tz_localize('UTC')\r\n   ...: print(pvlib.temperature.fuentes(**kwargs))\r\n   ...: \r\nTraceback (most recent call last):\r\n\r\n  File \"<ipython-input-3-ff99badadc91>\", line 2, in <module>\r\n    print(pvlib.temperature.fuentes(**kwargs))\r\n\r\n  File \"/home/kevin/anaconda3/lib/python3.7/site-packages/pvlib/temperature.py\", line 602, in fuentes\r\n    timedelta_hours = np.diff(poa_global.index).astype(float) / 1e9 / 60 / 60\r\n\r\nTypeError: float() argument must be a string or a number, not 'Timedelta'\r\n```\r\n\r\n**Expected behavior**\r\n`temperature.fuentes` should work with both tz-naive and tz-aware inputs.\r\n\r\n\r\n**Versions:**\r\n - ``pvlib.__version__``: 0.8.0\r\n - ``pandas.__version__``: 1.0.0+\r\n - python: 3.7.4 (default, Aug 13 2019, 20:35:49) \\n[GCC 7.3.0]\r\n\r\n\n", "hints_text": "", "created_at": "2020-10-01T00:53:14Z", "version": "0.7", "FAIL_TO_PASS": ["pvlib/tests/test_temperature.py::test_fuentes_timezone[Etc/GMT+5]"], "PASS_TO_PASS": ["pvlib/tests/test_temperature.py::test_sapm_cell", "pvlib/tests/test_temperature.py::test_sapm_module", "pvlib/tests/test_temperature.py::test_sapm_cell_from_module", "pvlib/tests/test_temperature.py::test_sapm_ndarray", "pvlib/tests/test_temperature.py::test_sapm_series", "pvlib/tests/test_temperature.py::test_pvsyst_cell_default", "pvlib/tests/test_temperature.py::test_pvsyst_cell_kwargs", "pvlib/tests/test_temperature.py::test_pvsyst_cell_ndarray", "pvlib/tests/test_temperature.py::test_pvsyst_cell_series", "pvlib/tests/test_temperature.py::test_faiman_default", "pvlib/tests/test_temperature.py::test_faiman_kwargs", "pvlib/tests/test_temperature.py::test_faiman_list", "pvlib/tests/test_temperature.py::test_faiman_ndarray", "pvlib/tests/test_temperature.py::test_faiman_series", "pvlib/tests/test_temperature.py::test__temperature_model_params", "pvlib/tests/test_temperature.py::test_fuentes[pvwatts_8760_rackmount.csv-45]", "pvlib/tests/test_temperature.py::test_fuentes[pvwatts_8760_roofmount.csv-49]", "pvlib/tests/test_temperature.py::test_fuentes_timezone[None]"], "environment_setup_commit": "6e5148f59c5050e8f7a0084b7ae39e93b80f72e6"}, {"repo": "pvlib/pvlib-python", "instance_id": "pvlib__pvlib-python-1606", "base_commit": "c78b50f4337ecbe536a961336ca91a1176efc0e8", "patch": "diff --git a/pvlib/tools.py b/pvlib/tools.py\n--- a/pvlib/tools.py\n+++ b/pvlib/tools.py\n@@ -341,6 +341,8 @@ def _golden_sect_DataFrame(params, lower, upper, func, atol=1e-8):\n     --------\n     pvlib.singlediode._pwr_optfcn\n     \"\"\"\n+    if np.any(upper - lower < 0.):\n+        raise ValueError('upper >= lower is required')\n \n     phim1 = (np.sqrt(5) - 1) / 2\n \n@@ -349,16 +351,8 @@ def _golden_sect_DataFrame(params, lower, upper, func, atol=1e-8):\n     df['VL'] = lower\n \n     converged = False\n-    iterations = 0\n \n-    # handle all NaN case gracefully\n-    with warnings.catch_warnings():\n-        warnings.filterwarnings(action='ignore',\n-                                message='All-NaN slice encountered')\n-        iterlimit = 1 + np.nanmax(\n-            np.trunc(np.log(atol / (df['VH'] - df['VL'])) / np.log(phim1)))\n-\n-    while not converged and (iterations <= iterlimit):\n+    while not converged:\n \n         phi = phim1 * (df['VH'] - df['VL'])\n         df['V1'] = df['VL'] + phi\n@@ -373,22 +367,16 @@ def _golden_sect_DataFrame(params, lower, upper, func, atol=1e-8):\n \n         err = abs(df['V2'] - df['V1'])\n \n-        # works with single value because err is np.float64\n-        converged = (err[~np.isnan(err)] < atol).all()\n-        # err will be less than atol before iterations hit the limit\n-        # but just to be safe\n-        iterations += 1\n-\n-    if iterations > iterlimit:\n-        raise Exception(\"Iterations exceeded maximum. Check that func\",\n-                        \" is not NaN in (lower, upper)\")  # pragma: no cover\n+        # handle all NaN case gracefully\n+        with warnings.catch_warnings():\n+            warnings.filterwarnings(action='ignore',\n+                                    message='All-NaN slice encountered')\n+            converged = np.all(err[~np.isnan(err)] < atol)\n \n-    try:\n-        func_result = func(df, 'V1')\n-        x = np.where(np.isnan(func_result), np.nan, df['V1'])\n-    except KeyError:\n-        func_result = np.full_like(upper, np.nan)\n-        x = func_result.copy()\n+    # best estimate of location of maximum\n+    df['max'] = 0.5 * (df['V1'] + df['V2'])\n+    func_result = func(df, 'max')\n+    x = np.where(np.isnan(func_result), np.nan, df['max'])\n \n     return func_result, x\n \n", "test_patch": "diff --git a/pvlib/tests/test_tools.py b/pvlib/tests/test_tools.py\n--- a/pvlib/tests/test_tools.py\n+++ b/pvlib/tests/test_tools.py\n@@ -45,6 +45,22 @@ def test__golden_sect_DataFrame_vector():\n     v, x = tools._golden_sect_DataFrame(params, lower, upper,\n                                         _obj_test_golden_sect)\n     assert np.allclose(x, expected, atol=1e-8)\n+    # some upper and lower bounds equal\n+    params = {'c': np.array([1., 2., 1.]), 'n': np.array([1., 1., 1.])}\n+    lower = np.array([0., 0.001, 1.])\n+    upper = np.array([1., 1.2, 1.])\n+    expected = np.array([0.5, 0.25, 1.0])  # x values for maxima\n+    v, x = tools._golden_sect_DataFrame(params, lower, upper,\n+                                        _obj_test_golden_sect)\n+    assert np.allclose(x, expected, atol=1e-8)\n+    # all upper and lower bounds equal, arrays of length 1\n+    params = {'c': np.array([1.]), 'n': np.array([1.])}\n+    lower = np.array([1.])\n+    upper = np.array([1.])\n+    expected = np.array([1.])  # x values for maxima\n+    v, x = tools._golden_sect_DataFrame(params, lower, upper,\n+                                        _obj_test_golden_sect)\n+    assert np.allclose(x, expected, atol=1e-8)\n \n \n def test__golden_sect_DataFrame_nans():\n", "problem_statement": "golden-section search fails when upper and lower bounds are equal\n**Describe the bug**\r\nI was using pvlib for sometime now and until now I was always passing a big dataframe containing readings of a long period. Because of some changes in our software architecture, I need to pass the weather readings as a single reading (a dataframe with only one row) and I noticed that for readings that GHI-DHI are zero pvlib fails to calculate the output and returns below error while the same code executes correctly with weather information that has non-zero GHI-DHI:\r\n```python\r\nimport os\r\nimport pathlib\r\nimport time\r\nimport json\r\nfrom datetime import datetime\r\nfrom time import mktime, gmtime\r\n\r\nimport pandas as pd\r\n\r\nfrom pvlib import pvsystem\r\nfrom pvlib import location as pvlocation\r\nfrom pvlib import modelchain\r\nfrom pvlib.temperature import TEMPERATURE_MODEL_PARAMETERS as PARAMS # not used -- to remove\r\nfrom pvlib.bifacial.pvfactors import pvfactors_timeseries\r\nfrom pvlib.temperature import TEMPERATURE_MODEL_PARAMETERS\r\n\r\nclass PV:\r\n    def pv_transform_time(self, val):\r\n        # tt = gmtime(val / 1000)\r\n        tt = gmtime(val)\r\n        dd = datetime.fromtimestamp(mktime(tt))\r\n        timestamp = pd.Timestamp(dd)\r\n        return timestamp\r\n\r\n    def __init__(self, model: str, inverter: str, latitude: float, longitude: float, **kwargs):\r\n        # super().__init__(**kwargs)\r\n\r\n        temperature_model_parameters = TEMPERATURE_MODEL_PARAMETERS[\"sapm\"][\r\n            \"open_rack_glass_glass\"\r\n        ]\r\n        # Load the database of CEC module model parameters\r\n        modules = pvsystem.retrieve_sam(\"cecmod\")\r\n        # Load the database of CEC inverter model parameters\r\n        inverters = pvsystem.retrieve_sam(\"cecinverter\")\r\n\r\n\r\n        # A bare bone PV simulator\r\n\r\n        # Load the database of CEC module model parameters\r\n        modules = pvsystem.retrieve_sam('cecmod')\r\n        inverters = pvsystem.retrieve_sam('cecinverter')\r\n        module_parameters = modules[model]\r\n        inverter_parameters = inverters[inverter]\r\n\r\n        location = pvlocation.Location(latitude=latitude, longitude=longitude)\r\n        system = pvsystem.PVSystem(module_parameters=module_parameters, inverter_parameters=inverter_parameters, temperature_model_parameters=temperature_model_parameters)\r\n        self.modelchain = modelchain.ModelChain(system, location, aoi_model='no_loss', spectral_model=\"no_loss\")\r\n\r\n    def process(self, data):\r\n        weather = pd.read_json(data)\r\n        # print(f\"raw_weather: {weather}\")\r\n        weather.drop('time.1', axis=1, inplace=True)\r\n        weather['time'] = pd.to_datetime(weather['time']).map(datetime.timestamp) # --> this works for the new process_weather code and also the old weather file\r\n        weather[\"time\"] = weather[\"time\"].apply(self.pv_transform_time)\r\n        weather.index = weather[\"time\"]\r\n        # print(f\"weather: {weather}\")\r\n        # print(weather.dtypes)\r\n        # print(weather['ghi'][0])\r\n        # print(type(weather['ghi'][0]))\r\n\r\n        # simulate\r\n        self.modelchain.run_model(weather)\r\n        # print(self.modelchain.results.ac.to_frame().to_json())\r\n        print(self.modelchain.results.ac)\r\n\r\n\r\n# good data\r\ngood_data = \"{\\\"time\\\":{\\\"12\\\":\\\"2010-01-01 13:30:00+00:00\\\"},\\\"ghi\\\":{\\\"12\\\":36},\\\"dhi\\\":{\\\"12\\\":36},\\\"dni\\\":{\\\"12\\\":0},\\\"Tamb\\\":{\\\"12\\\":8.0},\\\"WindVel\\\":{\\\"12\\\":5.0},\\\"WindDir\\\":{\\\"12\\\":270},\\\"time.1\\\":{\\\"12\\\":\\\"2010-01-01 13:30:00+00:00\\\"}}\"\r\n\r\n# data that causes error\r\ndata = \"{\\\"time\\\":{\\\"4\\\":\\\"2010-01-01 05:30:00+00:00\\\"},\\\"ghi\\\":{\\\"4\\\":0},\\\"dhi\\\":{\\\"4\\\":0},\\\"dni\\\":{\\\"4\\\":0},\\\"Tamb\\\":{\\\"4\\\":8.0},\\\"WindVel\\\":{\\\"4\\\":4.0},\\\"WindDir\\\":{\\\"4\\\":240},\\\"time.1\\\":{\\\"4\\\":\\\"2010-01-01 05:30:00+00:00\\\"}}\"\r\np1 = PV(model=\"Trina_Solar_TSM_300DEG5C_07_II_\", inverter=\"ABB__MICRO_0_25_I_OUTD_US_208__208V_\", latitude=51.204483, longitude=5.265472)\r\np1.process(good_data)\r\nprint(\"=====\")\r\np1.process(data)\r\n```\r\nError:\r\n```log\r\n$ python3 ./tmp-pv.py \r\ntime\r\n2010-01-01 13:30:00    7.825527\r\ndtype: float64\r\n=====\r\n/home/user/.local/lib/python3.10/site-packages/pvlib/tools.py:340: RuntimeWarning: divide by zero encountered in divide\r\n  np.trunc(np.log(atol / (df['VH'] - df['VL'])) / np.log(phim1)))\r\nTraceback (most recent call last):\r\n  File \"/home/user/workspace/enorch/simulator/simulator_processor/src/pv/./tmp-pv.py\", line 88, in <module>\r\n    p1.process(data)\r\n  File \"/home/user/workspace/enorch/simulator/simulator_processor/src/pv/./tmp-pv.py\", line 75, in process\r\n    self.modelchain.run_model(weather)\r\n  File \"/home/user/.local/lib/python3.10/site-packages/pvlib/modelchain.py\", line 1770, in run_model\r\n    self._run_from_effective_irrad(weather)\r\n  File \"/home/user/.local/lib/python3.10/site-packages/pvlib/modelchain.py\", line 1858, in _run_from_effective_irrad\r\n    self.dc_model()\r\n  File \"/home/user/.local/lib/python3.10/site-packages/pvlib/modelchain.py\", line 790, in cec\r\n    return self._singlediode(self.system.calcparams_cec)\r\n  File \"/home/user/.local/lib/python3.10/site-packages/pvlib/modelchain.py\", line 772, in _singlediode\r\n    self.results.dc = tuple(itertools.starmap(\r\n  File \"/home/user/.local/lib/python3.10/site-packages/pvlib/pvsystem.py\", line 931, in singlediode\r\n    return singlediode(photocurrent, saturation_current,\r\n  File \"/home/user/.local/lib/python3.10/site-packages/pvlib/pvsystem.py\", line 2826, in singlediode\r\n    out = _singlediode._lambertw(\r\n  File \"/home/user/.local/lib/python3.10/site-packages/pvlib/singlediode.py\", line 651, in _lambertw\r\n    p_mp, v_mp = _golden_sect_DataFrame(params, 0., v_oc * 1.14,\r\n  File \"/home/user/.local/lib/python3.10/site-packages/pvlib/tools.py\", line 364, in _golden_sect_DataFrame\r\n    raise Exception(\"Iterations exceeded maximum. Check that func\",\r\nException: ('Iterations exceeded maximum. Check that func', ' is not NaN in (lower, upper)')\r\n```\r\n\r\nI have to mention that for now the workaround that I am using is to pass the weather data as a dataframe with two rows, the first row is a good weather data that pvlib can process and the second row is the incoming weather reading (I can also post that code if you want).\r\n\r\n**Expected behavior**\r\nPVlib should have consistent behavior and regardless of GHI-DHI readings.\r\n\r\n**Versions:**\r\n```python\r\n>>> import pvlib\r\n>>> import pandas\r\n>>> pvlib.__version__\r\n'0.9.1'\r\n>>> pandas.__version__\r\n'1.4.3'\r\n``` \r\n - python: 3.10.6\r\n- OS: Ubuntu 22.04.1 LTS\n", "hints_text": "Confirmed. This appears to be an oversight in `pvlib.tools._golden_section_DataFrame` involving error messaging, likely introduced with #1089 .\r\n\r\nIn this code when processing the content of `data`, photocurrent is 0., hence the shunt resistance is infinite and v_oc is 0. That sets the range for the golden section search to be [0., 0.]. [iterlimit](https://github.com/pvlib/pvlib-python/blob/582b956c63c463e5178fbb7a88fa545fa5b1c257/pvlib/tools.py#L358) is then -infinity, which skips the loop (`iterations <= iterlimit`) but since `iterations > iterlimit` raises the \"Iterations exceeded...\" exception.\r\n", "created_at": "2022-12-07T21:12:08Z", "version": "0.8", "FAIL_TO_PASS": ["pvlib/tests/test_tools.py::test__golden_sect_DataFrame_vector"], "PASS_TO_PASS": ["pvlib/tests/test_tools.py::test_build_kwargs[keys0-input_dict0-expected0]", "pvlib/tests/test_tools.py::test_build_kwargs[keys1-input_dict1-expected1]", "pvlib/tests/test_tools.py::test_build_kwargs[keys2-input_dict2-expected2]", "pvlib/tests/test_tools.py::test_build_kwargs[keys3-input_dict3-expected3]", "pvlib/tests/test_tools.py::test__golden_sect_DataFrame[params0-0.0-1.0-0.5-_obj_test_golden_sect]", "pvlib/tests/test_tools.py::test__golden_sect_DataFrame[params1-0.0-1.0-0.07230200263994839-_obj_test_golden_sect]", "pvlib/tests/test_tools.py::test__golden_sect_DataFrame[params2-0.0-100.0-89.14332727531685-_obj_test_golden_sect]", "pvlib/tests/test_tools.py::test__golden_sect_DataFrame_atol", "pvlib/tests/test_tools.py::test__golden_sect_DataFrame_nans", "pvlib/tests/test_tools.py::test_degrees_to_index_1"], "environment_setup_commit": "ef8ad2fee9840a77d14b0dfd17fc489dd85c9b91"}, {"repo": "pylint-dev/astroid", "instance_id": "pylint-dev__astroid-1364", "base_commit": "9363c34934f94124f4867caf1bdf8f6755201ccd", "patch": "diff --git a/astroid/const.py b/astroid/const.py\n--- a/astroid/const.py\n+++ b/astroid/const.py\n@@ -8,6 +8,8 @@\n PY310_PLUS = sys.version_info >= (3, 10)\n BUILTINS = \"builtins\"  # TODO Remove in 2.8\n \n+WIN32 = sys.platform == \"win32\"\n+\n \n class Context(enum.Enum):\n     Load = 1\n", "test_patch": "diff --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@@ -43,9 +43,9 @@\n \n import pytest\n \n-from astroid import MANAGER, builder, nodes, objects, test_utils, util\n+from astroid import MANAGER, builder, nodes, objects, parse, test_utils, util\n from astroid.bases import BoundMethod, Generator, Instance, UnboundMethod\n-from astroid.const import PY38_PLUS\n+from astroid.const import PY38_PLUS, PY310_PLUS, WIN32\n from astroid.exceptions import (\n     AttributeInferenceError,\n     DuplicateBasesError,\n@@ -1670,6 +1670,49 @@ class B(A[T], A[T]): ...\n         with self.assertRaises(DuplicateBasesError):\n             cls.mro()\n \n+    @test_utils.require_version(minver=\"3.7\")\n+    def test_mro_typing_extensions(self):\n+        \"\"\"Regression test for mro() inference on typing_extesnions.\n+\n+        Regression reported in:\n+        https://github.com/PyCQA/astroid/issues/1124\n+        \"\"\"\n+        module = parse(\n+            \"\"\"\n+        import abc\n+        import typing\n+        import dataclasses\n+\n+        import typing_extensions\n+\n+        T = typing.TypeVar(\"T\")\n+\n+        class MyProtocol(typing_extensions.Protocol): pass\n+        class EarlyBase(typing.Generic[T], MyProtocol): pass\n+        class Base(EarlyBase[T], abc.ABC): pass\n+        class Final(Base[object]): pass\n+        \"\"\"\n+        )\n+        class_names = [\n+            \"ABC\",\n+            \"Base\",\n+            \"EarlyBase\",\n+            \"Final\",\n+            \"Generic\",\n+            \"MyProtocol\",\n+            \"Protocol\",\n+            \"object\",\n+        ]\n+        if not PY38_PLUS:\n+            class_names.pop(-2)\n+        # typing_extensions is not installed on this combination of version\n+        # and platform\n+        if PY310_PLUS and WIN32:\n+            class_names.pop(-2)\n+\n+        final_def = module.body[-1]\n+        self.assertEqual(class_names, sorted(i.name for i in final_def.mro()))\n+\n     def test_generator_from_infer_call_result_parent(self) -> None:\n         func = builder.extract_node(\n             \"\"\"\n", "problem_statement": "MRO failure on Python 3.7 with typing_extensions\n### Steps to reproduce\r\n\r\nRun the following script on Python 3.7:\r\n\r\n```python\r\nfrom astroid import parse\r\nmodule = parse(\"\"\"\r\nimport abc\r\nimport typing\r\nimport dataclasses\r\n\r\nimport typing_extensions\r\n\r\nT = typing.TypeVar(\"T\")\r\n\r\nclass MyProtocol(typing_extensions.Protocol): pass\r\nclass EarlyBase(typing.Generic[T], MyProtocol): pass\r\nclass Base(EarlyBase[T], abc.ABC): pass\r\nclass Final(Base[object]): pass\r\n\"\"\")\r\n\r\n#                    typing.Protocol\r\n#                          |\r\n# typing.Generic[T]    MyProtocol\r\n#              \\       /\r\n#              EarlyBase     abc.ABC\r\n#                       \\    /\r\n#                        Base\r\n#                         |\r\n#                        Final\r\n\r\nfinal_def = module.body[-1]\r\nfinal_def.mro()\r\n```\r\n\r\n### Current behavior\r\n\r\n```\r\nTraceback (most recent call last):\r\n  File \"xxx.py\", line 31, in <module>\r\n    print(\"mro:\", final_def.mro())\r\n  File \"/home/rturner/astroid/astroid/nodes/scoped_nodes.py\", line 3009, in mro\r\n    return self._compute_mro(context=context)\r\n  File \"/home/rturner/astroid/astroid/nodes/scoped_nodes.py\", line 2985, in _compute_mro\r\n    mro = base._compute_mro(context=context)\r\n  File \"/home/rturner/astroid/astroid/nodes/scoped_nodes.py\", line 2999, in _compute_mro\r\n    return _c3_merge(unmerged_mro, self, context)\r\n  File \"/home/rturner/astroid/astroid/nodes/scoped_nodes.py\", line 103, in _c3_merge\r\n    context=context,\r\nastroid.exceptions.InconsistentMroError: Cannot create a consistent method resolution order for MROs (tuple, object), (EarlyBase, tuple, Generic, object, MyProtocol), (ABC, object), (tuple, EarlyBase, ABC) of class <ClassDef.Base l.1347 at 0x7fa0efd52590>.\r\n```\r\n\r\n### Expected behavior\r\n\r\nNo MRO error is raised; Python 3.7 doesn't raise an error.\r\n\r\n### `python -c \"from astroid import __pkginfo__; print(__pkginfo__.version)\"` output\r\n\r\n2.6.7-dev0; the test case fails in pylint 2.9.6 and on the main branch at commit 6e8699cef0888631bd827b096533fc6e894d2fb2.\n", "hints_text": "", "created_at": "2022-01-20T10:00:25Z", "version": "2.10", "FAIL_TO_PASS": ["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_abstract_methods_are_not_implicitly_none", "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_no_returns_is_implicitly_none", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_only_raises_is_not_implicitly_none", "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_typing_extensions", "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_issue940_metaclass_subclass_property", "tests/unittest_scoped_nodes.py::test_issue940_property_grandchild", "tests/unittest_scoped_nodes.py::test_issue940_metaclass_property", "tests/unittest_scoped_nodes.py::test_issue940_with_metaclass_class_context_property", "tests/unittest_scoped_nodes.py::test_issue940_metaclass_values_funcdef", "tests/unittest_scoped_nodes.py::test_issue940_metaclass_derived_funcdef", "tests/unittest_scoped_nodes.py::test_issue940_metaclass_funcdef_is_not_datadescriptor", "tests/unittest_scoped_nodes.py::test_issue940_enums_as_a_real_world_usecase", "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", "tests/unittest_scoped_nodes.py::test_ancestor_with_generic", "tests/unittest_scoped_nodes.py::test_slots_duplicate_bases_issue_1089", "tests/unittest_scoped_nodes.py::TestFrameNodes::test_frame_node", "tests/unittest_scoped_nodes.py::TestFrameNodes::test_non_frame_node"], "PASS_TO_PASS": [], "environment_setup_commit": "da745538c7236028a22cdf0405f6829fcf6886bc"}, {"repo": "pylint-dev/astroid", "instance_id": "pylint-dev__astroid-1164", "base_commit": "40ea1a3b8e52bbfed43deb1725cde461f4bd8a96", "patch": "diff --git a/astroid/nodes/__init__.py b/astroid/nodes/__init__.py\n--- a/astroid/nodes/__init__.py\n+++ b/astroid/nodes/__init__.py\n@@ -89,6 +89,7 @@\n     Set,\n     Slice,\n     Starred,\n+    Statement,\n     Subscript,\n     TryExcept,\n     TryFinally,\n@@ -116,6 +117,7 @@\n     SetComp,\n     builtin_lookup,\n     function_to_method,\n+    get_wrapping_class,\n )\n \n _BaseContainer = BaseContainer  # TODO Remove for astroid 3.0\n@@ -254,6 +256,7 @@\n     \"FunctionDef\",\n     \"function_to_method\",\n     \"GeneratorExp\",\n+    \"get_wrapping_class\",\n     \"Global\",\n     \"If\",\n     \"IfExp\",\n@@ -287,6 +290,7 @@\n     \"SetComp\",\n     \"Slice\",\n     \"Starred\",\n+    \"Statement\",\n     \"Subscript\",\n     \"TryExcept\",\n     \"TryFinally\",\n", "test_patch": "diff --git a/tests/unittest_brain_ctypes.py b/tests/unittest_brain_ctypes.py\n--- a/tests/unittest_brain_ctypes.py\n+++ b/tests/unittest_brain_ctypes.py\n@@ -2,8 +2,7 @@\n \n import pytest\n \n-from astroid import extract_node\n-from astroid.nodes.node_classes import Const\n+from astroid import extract_node, nodes\n \n pytestmark = pytest.mark.skipif(\n     hasattr(sys, \"pypy_version_info\"),\n@@ -72,7 +71,7 @@ def test_ctypes_redefined_types_members(c_type, builtin_type, type_code):\n     \"\"\"\n     node = extract_node(src)\n     node_inf = node.inferred()[0]\n-    assert isinstance(node_inf, Const)\n+    assert isinstance(node_inf, nodes.Const)\n     assert node_inf.value == type_code\n \n \n@@ -102,5 +101,5 @@ def test_other_ctypes_member_untouched():\n     \"\"\"\n     node = extract_node(src)\n     node_inf = node.inferred()[0]\n-    assert isinstance(node_inf, Const)\n+    assert isinstance(node_inf, nodes.Const)\n     assert node_inf.value == 6\ndiff --git a/tests/unittest_lookup.py b/tests/unittest_lookup.py\n--- a/tests/unittest_lookup.py\n+++ b/tests/unittest_lookup.py\n@@ -24,7 +24,6 @@\n     InferenceError,\n     NameInferenceError,\n )\n-from astroid.nodes.scoped_nodes import builtin_lookup\n \n from . import resources\n \n@@ -389,8 +388,8 @@ def initialize(linter):\n         self.assertEqual(len(path.lookup(\"__path__\")[1]), 1)\n \n     def test_builtin_lookup(self):\n-        self.assertEqual(builtin_lookup(\"__dict__\")[1], ())\n-        intstmts = builtin_lookup(\"int\")[1]\n+        self.assertEqual(nodes.builtin_lookup(\"__dict__\")[1], ())\n+        intstmts = nodes.builtin_lookup(\"int\")[1]\n         self.assertEqual(len(intstmts), 1)\n         self.assertIsInstance(intstmts[0], nodes.ClassDef)\n         self.assertEqual(intstmts[0].name, \"int\")\n@@ -411,7 +410,10 @@ class foo:\n                 def test(self):\n                     pass\n         \"\"\"\n-        member = builder.extract_node(code, __name__).targets[0]\n+\n+        node = builder.extract_node(code, __name__)\n+        assert isinstance(node, nodes.Assign)\n+        member = node.targets[0]\n         it = member.infer()\n         obj = next(it)\n         self.assertIsInstance(obj, nodes.Const)\ndiff --git a/tests/unittest_protocols.py b/tests/unittest_protocols.py\n--- a/tests/unittest_protocols.py\n+++ b/tests/unittest_protocols.py\n@@ -22,7 +22,6 @@\n from astroid import extract_node, nodes, util\n from astroid.const import PY38_PLUS, PY310_PLUS\n from astroid.exceptions import InferenceError\n-from astroid.nodes.node_classes import AssignName, Const, Name, Starred\n \n \n @contextlib.contextmanager\n@@ -38,14 +37,14 @@ class ProtocolTests(unittest.TestCase):\n     def assertConstNodesEqual(self, nodes_list_expected, nodes_list_got):\n         self.assertEqual(len(nodes_list_expected), len(nodes_list_got))\n         for node in nodes_list_got:\n-            self.assertIsInstance(node, Const)\n+            self.assertIsInstance(node, nodes.Const)\n         for node, expected_value in zip(nodes_list_got, nodes_list_expected):\n             self.assertEqual(expected_value, node.value)\n \n     def assertNameNodesEqual(self, nodes_list_expected, nodes_list_got):\n         self.assertEqual(len(nodes_list_expected), len(nodes_list_got))\n         for node in nodes_list_got:\n-            self.assertIsInstance(node, Name)\n+            self.assertIsInstance(node, nodes.Name)\n         for node, expected_name in zip(nodes_list_got, nodes_list_expected):\n             self.assertEqual(expected_name, node.name)\n \n@@ -60,11 +59,11 @@ def test_assigned_stmts_simple_for(self):\n         \"\"\"\n         )\n \n-        for1_assnode = next(assign_stmts[0].nodes_of_class(AssignName))\n+        for1_assnode = next(assign_stmts[0].nodes_of_class(nodes.AssignName))\n         assigned = list(for1_assnode.assigned_stmts())\n         self.assertConstNodesEqual([1, 2, 3], assigned)\n \n-        for2_assnode = next(assign_stmts[1].nodes_of_class(AssignName))\n+        for2_assnode = next(assign_stmts[1].nodes_of_class(nodes.AssignName))\n         self.assertRaises(InferenceError, list, for2_assnode.assigned_stmts())\n \n     def test_assigned_stmts_starred_for(self):\n@@ -75,14 +74,14 @@ def test_assigned_stmts_starred_for(self):\n         \"\"\"\n         )\n \n-        for1_starred = next(assign_stmts.nodes_of_class(Starred))\n+        for1_starred = next(assign_stmts.nodes_of_class(nodes.Starred))\n         assigned = next(for1_starred.assigned_stmts())\n         assert isinstance(assigned, astroid.List)\n         assert assigned.as_string() == \"[1, 2]\"\n \n     def _get_starred_stmts(self, code):\n         assign_stmt = extract_node(f\"{code} #@\")\n-        starred = next(assign_stmt.nodes_of_class(Starred))\n+        starred = next(assign_stmt.nodes_of_class(nodes.Starred))\n         return next(starred.assigned_stmts())\n \n     def _helper_starred_expected_const(self, code, expected):\n@@ -97,7 +96,7 @@ def _helper_starred_expected(self, code, expected):\n \n     def _helper_starred_inference_error(self, code):\n         assign_stmt = extract_node(f\"{code} #@\")\n-        starred = next(assign_stmt.nodes_of_class(Starred))\n+        starred = next(assign_stmt.nodes_of_class(nodes.Starred))\n         self.assertRaises(InferenceError, list, starred.assigned_stmts())\n \n     def test_assigned_stmts_starred_assnames(self):\n@@ -143,11 +142,11 @@ def test_assigned_stmts_assignments(self):\n         \"\"\"\n         )\n \n-        simple_assnode = next(assign_stmts[0].nodes_of_class(AssignName))\n+        simple_assnode = next(assign_stmts[0].nodes_of_class(nodes.AssignName))\n         assigned = list(simple_assnode.assigned_stmts())\n         self.assertNameNodesEqual([\"a\"], assigned)\n \n-        assnames = assign_stmts[1].nodes_of_class(AssignName)\n+        assnames = assign_stmts[1].nodes_of_class(nodes.AssignName)\n         simple_mul_assnode_1 = next(assnames)\n         assigned = list(simple_mul_assnode_1.assigned_stmts())\n         self.assertNameNodesEqual([\"b\"], assigned)\n@@ -162,13 +161,15 @@ def test_assigned_stmts_annassignments(self):\n         b: str  #@\n         \"\"\"\n         )\n-        simple_annassign_node = next(annassign_stmts[0].nodes_of_class(AssignName))\n+        simple_annassign_node = next(\n+            annassign_stmts[0].nodes_of_class(nodes.AssignName)\n+        )\n         assigned = list(simple_annassign_node.assigned_stmts())\n         self.assertEqual(1, len(assigned))\n-        self.assertIsInstance(assigned[0], Const)\n+        self.assertIsInstance(assigned[0], nodes.Const)\n         self.assertEqual(assigned[0].value, \"abc\")\n \n-        empty_annassign_node = next(annassign_stmts[1].nodes_of_class(AssignName))\n+        empty_annassign_node = next(annassign_stmts[1].nodes_of_class(nodes.AssignName))\n         assigned = list(empty_annassign_node.assigned_stmts())\n         self.assertEqual(1, len(assigned))\n         self.assertIs(assigned[0], util.Uninferable)\ndiff --git a/tests/unittest_python3.py b/tests/unittest_python3.py\n--- a/tests/unittest_python3.py\n+++ b/tests/unittest_python3.py\n@@ -20,8 +20,6 @@\n \n from astroid import nodes\n from astroid.builder import AstroidBuilder, extract_node\n-from astroid.nodes.node_classes import Assign, Const, Expr, Name, YieldFrom\n-from astroid.nodes.scoped_nodes import ClassDef, FunctionDef\n from astroid.test_utils import require_version\n \n \n@@ -36,7 +34,7 @@ def test_starred_notation(self):\n         # Get the star node\n         node = next(next(next(astroid.get_children()).get_children()).get_children())\n \n-        self.assertTrue(isinstance(node.assign_type(), Assign))\n+        self.assertTrue(isinstance(node.assign_type(), nodes.Assign))\n \n     def test_yield_from(self):\n         body = dedent(\n@@ -47,11 +45,11 @@ def func():\n         )\n         astroid = self.builder.string_build(body)\n         func = astroid.body[0]\n-        self.assertIsInstance(func, FunctionDef)\n+        self.assertIsInstance(func, nodes.FunctionDef)\n         yieldfrom_stmt = func.body[0]\n \n-        self.assertIsInstance(yieldfrom_stmt, Expr)\n-        self.assertIsInstance(yieldfrom_stmt.value, YieldFrom)\n+        self.assertIsInstance(yieldfrom_stmt, nodes.Expr)\n+        self.assertIsInstance(yieldfrom_stmt.value, nodes.YieldFrom)\n         self.assertEqual(yieldfrom_stmt.as_string(), \"yield from iter([1, 2])\")\n \n     def test_yield_from_is_generator(self):\n@@ -63,7 +61,7 @@ def func():\n         )\n         astroid = self.builder.string_build(body)\n         func = astroid.body[0]\n-        self.assertIsInstance(func, FunctionDef)\n+        self.assertIsInstance(func, nodes.FunctionDef)\n         self.assertTrue(func.is_generator())\n \n     def test_yield_from_as_string(self):\n@@ -85,7 +83,7 @@ def test_simple_metaclass(self):\n         klass = astroid.body[0]\n \n         metaclass = klass.metaclass()\n-        self.assertIsInstance(metaclass, ClassDef)\n+        self.assertIsInstance(metaclass, nodes.ClassDef)\n         self.assertEqual(metaclass.name, \"type\")\n \n     def test_metaclass_error(self):\n@@ -104,7 +102,7 @@ class Test(metaclass=ABCMeta): pass\"\"\"\n         klass = astroid.body[1]\n \n         metaclass = klass.metaclass()\n-        self.assertIsInstance(metaclass, ClassDef)\n+        self.assertIsInstance(metaclass, nodes.ClassDef)\n         self.assertEqual(metaclass.name, \"ABCMeta\")\n \n     def test_metaclass_multiple_keywords(self):\n@@ -114,7 +112,7 @@ def test_metaclass_multiple_keywords(self):\n         klass = astroid.body[0]\n \n         metaclass = klass.metaclass()\n-        self.assertIsInstance(metaclass, ClassDef)\n+        self.assertIsInstance(metaclass, nodes.ClassDef)\n         self.assertEqual(metaclass.name, \"type\")\n \n     def test_as_string(self):\n@@ -171,7 +169,7 @@ class SubTest(Test): pass\n         klass = astroid[\"SubTest\"]\n         self.assertTrue(klass.newstyle)\n         metaclass = klass.metaclass()\n-        self.assertIsInstance(metaclass, ClassDef)\n+        self.assertIsInstance(metaclass, nodes.ClassDef)\n         self.assertEqual(metaclass.name, \"ABCMeta\")\n \n     def test_metaclass_ancestors(self):\n@@ -199,7 +197,7 @@ class ThirdImpl(Simple, SecondMeta):\n             for name in names:\n                 impl = astroid[name]\n                 meta = impl.metaclass()\n-                self.assertIsInstance(meta, ClassDef)\n+                self.assertIsInstance(meta, nodes.ClassDef)\n                 self.assertEqual(meta.name, metaclass)\n \n     def test_annotation_support(self):\n@@ -213,18 +211,18 @@ def test(a: int, b: str, c: None, d, e,\n             )\n         )\n         func = astroid[\"test\"]\n-        self.assertIsInstance(func.args.varargannotation, Name)\n+        self.assertIsInstance(func.args.varargannotation, nodes.Name)\n         self.assertEqual(func.args.varargannotation.name, \"float\")\n-        self.assertIsInstance(func.args.kwargannotation, Name)\n+        self.assertIsInstance(func.args.kwargannotation, nodes.Name)\n         self.assertEqual(func.args.kwargannotation.name, \"int\")\n-        self.assertIsInstance(func.returns, Name)\n+        self.assertIsInstance(func.returns, nodes.Name)\n         self.assertEqual(func.returns.name, \"int\")\n         arguments = func.args\n-        self.assertIsInstance(arguments.annotations[0], Name)\n+        self.assertIsInstance(arguments.annotations[0], nodes.Name)\n         self.assertEqual(arguments.annotations[0].name, \"int\")\n-        self.assertIsInstance(arguments.annotations[1], Name)\n+        self.assertIsInstance(arguments.annotations[1], nodes.Name)\n         self.assertEqual(arguments.annotations[1].name, \"str\")\n-        self.assertIsInstance(arguments.annotations[2], Const)\n+        self.assertIsInstance(arguments.annotations[2], nodes.Const)\n         self.assertIsNone(arguments.annotations[2].value)\n         self.assertIsNone(arguments.annotations[3])\n         self.assertIsNone(arguments.annotations[4])\n@@ -238,9 +236,9 @@ def test(a: int=1, b: str=2):\n             )\n         )\n         func = astroid[\"test\"]\n-        self.assertIsInstance(func.args.annotations[0], Name)\n+        self.assertIsInstance(func.args.annotations[0], nodes.Name)\n         self.assertEqual(func.args.annotations[0].name, \"int\")\n-        self.assertIsInstance(func.args.annotations[1], Name)\n+        self.assertIsInstance(func.args.annotations[1], nodes.Name)\n         self.assertEqual(func.args.annotations[1].name, \"str\")\n         self.assertIsNone(func.returns)\n \n@@ -255,11 +253,11 @@ def test(*, a: int, b: str, c: None, d, e):\n         )\n         func = node[\"test\"]\n         arguments = func.args\n-        self.assertIsInstance(arguments.kwonlyargs_annotations[0], Name)\n+        self.assertIsInstance(arguments.kwonlyargs_annotations[0], nodes.Name)\n         self.assertEqual(arguments.kwonlyargs_annotations[0].name, \"int\")\n-        self.assertIsInstance(arguments.kwonlyargs_annotations[1], Name)\n+        self.assertIsInstance(arguments.kwonlyargs_annotations[1], nodes.Name)\n         self.assertEqual(arguments.kwonlyargs_annotations[1].name, \"str\")\n-        self.assertIsInstance(arguments.kwonlyargs_annotations[2], Const)\n+        self.assertIsInstance(arguments.kwonlyargs_annotations[2], nodes.Const)\n         self.assertIsNone(arguments.kwonlyargs_annotations[2].value)\n         self.assertIsNone(arguments.kwonlyargs_annotations[3])\n         self.assertIsNone(arguments.kwonlyargs_annotations[4])\n@@ -283,6 +281,7 @@ def test_unpacking_in_dicts(self):\n         code = \"{'x': 1, **{'y': 2}}\"\n         node = extract_node(code)\n         self.assertEqual(node.as_string(), code)\n+        assert isinstance(node, nodes.Dict)\n         keys = [key for (key, _) in node.items]\n         self.assertIsInstance(keys[0], nodes.Const)\n         self.assertIsInstance(keys[1], nodes.DictUnpack)\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@@ -53,7 +53,7 @@\n     ResolveError,\n     TooManyLevelsError,\n )\n-from astroid.nodes import scoped_nodes\n+from astroid.nodes.scoped_nodes import _is_metaclass\n \n from . import resources\n \n@@ -1120,7 +1120,7 @@ class BBB(AAA.JJJ):\n                 pass\n         \"\"\"\n         )\n-        self.assertFalse(scoped_nodes._is_metaclass(klass))\n+        self.assertFalse(_is_metaclass(klass))\n         ancestors = [base.name for base in klass.ancestors()]\n         self.assertIn(\"object\", ancestors)\n         self.assertIn(\"JJJ\", ancestors)\n@@ -1169,7 +1169,7 @@ class WithMeta(object, metaclass=abc.ABCMeta):\n         )\n         inferred = next(klass.infer())\n         metaclass = inferred.metaclass()\n-        self.assertIsInstance(metaclass, scoped_nodes.ClassDef)\n+        self.assertIsInstance(metaclass, nodes.ClassDef)\n         self.assertIn(metaclass.qname(), (\"abc.ABCMeta\", \"_py_abc.ABCMeta\"))\n \n     @unittest.skipUnless(HAS_SIX, \"These tests require the six library\")\n@@ -1667,7 +1667,7 @@ class A(object):\n             pass\n         \"\"\"\n         )\n-        type_cls = scoped_nodes.builtin_lookup(\"type\")[1][0]\n+        type_cls = nodes.builtin_lookup(\"type\")[1][0]\n         self.assertEqual(cls.implicit_metaclass(), type_cls)\n \n     def test_implicit_metaclass_lookup(self):\n@@ -1743,7 +1743,7 @@ class A(object, metaclass=Metaclass):\n         #   of the property\n         property_meta = next(module[\"Metaclass\"].igetattr(\"meta_property\"))\n         self.assertIsInstance(property_meta, objects.Property)\n-        wrapping = scoped_nodes.get_wrapping_class(property_meta)\n+        wrapping = nodes.get_wrapping_class(property_meta)\n         self.assertEqual(wrapping, module[\"Metaclass\"])\n \n         property_class = next(acls.igetattr(\"meta_property\"))\n@@ -1751,7 +1751,7 @@ class A(object, metaclass=Metaclass):\n         self.assertEqual(property_class.value, 42)\n \n         static = next(acls.igetattr(\"static\"))\n-        self.assertIsInstance(static, scoped_nodes.FunctionDef)\n+        self.assertIsInstance(static, nodes.FunctionDef)\n \n     def test_local_attr_invalid_mro(self):\n         cls = builder.extract_node(\n@@ -1820,14 +1820,14 @@ class Test(object): #@\n         \"\"\"\n         )\n         cls = next(ast_nodes[0].infer())\n-        self.assertIsInstance(next(cls.igetattr(\"lam\")), scoped_nodes.Lambda)\n-        self.assertIsInstance(next(cls.igetattr(\"not_method\")), scoped_nodes.Lambda)\n+        self.assertIsInstance(next(cls.igetattr(\"lam\")), nodes.Lambda)\n+        self.assertIsInstance(next(cls.igetattr(\"not_method\")), nodes.Lambda)\n \n         instance = next(ast_nodes[1].infer())\n         lam = next(instance.igetattr(\"lam\"))\n         self.assertIsInstance(lam, BoundMethod)\n         not_method = next(instance.igetattr(\"not_method\"))\n-        self.assertIsInstance(not_method, scoped_nodes.Lambda)\n+        self.assertIsInstance(not_method, nodes.Lambda)\n \n     def test_instance_bound_method_lambdas_2(self):\n         \"\"\"\n@@ -1846,7 +1846,7 @@ class MyClass(object): #@\n         \"\"\"\n         )\n         cls = next(ast_nodes[0].infer())\n-        self.assertIsInstance(next(cls.igetattr(\"f2\")), scoped_nodes.Lambda)\n+        self.assertIsInstance(next(cls.igetattr(\"f2\")), nodes.Lambda)\n \n         instance = next(ast_nodes[1].infer())\n         f2 = next(instance.igetattr(\"f2\"))\ndiff --git a/tests/unittest_utils.py b/tests/unittest_utils.py\n--- a/tests/unittest_utils.py\n+++ b/tests/unittest_utils.py\n@@ -13,10 +13,8 @@\n \n import unittest\n \n-from astroid import builder, nodes\n-from astroid import util as astroid_util\n+from astroid import Uninferable, builder, nodes\n from astroid.exceptions import InferenceError\n-from astroid.nodes import node_classes\n \n \n class InferenceUtil(unittest.TestCase):\n@@ -38,8 +36,8 @@ def test_not_exclusive(self):\n         xnames = [n for n in module.nodes_of_class(nodes.Name) if n.name == \"x\"]\n         assert len(xnames) == 3\n         assert xnames[1].lineno == 6\n-        self.assertEqual(node_classes.are_exclusive(xass1, xnames[1]), False)\n-        self.assertEqual(node_classes.are_exclusive(xass1, xnames[2]), False)\n+        self.assertEqual(nodes.are_exclusive(xass1, xnames[1]), False)\n+        self.assertEqual(nodes.are_exclusive(xass1, xnames[2]), False)\n \n     def test_if(self):\n         module = builder.parse(\n@@ -61,12 +59,12 @@ def test_if(self):\n         a4 = module.locals[\"a\"][3]\n         a5 = module.locals[\"a\"][4]\n         a6 = module.locals[\"a\"][5]\n-        self.assertEqual(node_classes.are_exclusive(a1, a2), False)\n-        self.assertEqual(node_classes.are_exclusive(a1, a3), True)\n-        self.assertEqual(node_classes.are_exclusive(a1, a5), True)\n-        self.assertEqual(node_classes.are_exclusive(a3, a5), True)\n-        self.assertEqual(node_classes.are_exclusive(a3, a4), False)\n-        self.assertEqual(node_classes.are_exclusive(a5, a6), False)\n+        self.assertEqual(nodes.are_exclusive(a1, a2), False)\n+        self.assertEqual(nodes.are_exclusive(a1, a3), True)\n+        self.assertEqual(nodes.are_exclusive(a1, a5), True)\n+        self.assertEqual(nodes.are_exclusive(a3, a5), True)\n+        self.assertEqual(nodes.are_exclusive(a3, a4), False)\n+        self.assertEqual(nodes.are_exclusive(a5, a6), False)\n \n     def test_try_except(self):\n         module = builder.parse(\n@@ -89,16 +87,16 @@ def exclusive_func2():\n         f2 = module.locals[\"exclusive_func2\"][1]\n         f3 = module.locals[\"exclusive_func2\"][2]\n         f4 = module.locals[\"exclusive_func2\"][3]\n-        self.assertEqual(node_classes.are_exclusive(f1, f2), True)\n-        self.assertEqual(node_classes.are_exclusive(f1, f3), True)\n-        self.assertEqual(node_classes.are_exclusive(f1, f4), False)\n-        self.assertEqual(node_classes.are_exclusive(f2, f4), True)\n-        self.assertEqual(node_classes.are_exclusive(f3, f4), True)\n-        self.assertEqual(node_classes.are_exclusive(f3, f2), True)\n+        self.assertEqual(nodes.are_exclusive(f1, f2), True)\n+        self.assertEqual(nodes.are_exclusive(f1, f3), True)\n+        self.assertEqual(nodes.are_exclusive(f1, f4), False)\n+        self.assertEqual(nodes.are_exclusive(f2, f4), True)\n+        self.assertEqual(nodes.are_exclusive(f3, f4), True)\n+        self.assertEqual(nodes.are_exclusive(f3, f2), True)\n \n-        self.assertEqual(node_classes.are_exclusive(f2, f1), True)\n-        self.assertEqual(node_classes.are_exclusive(f4, f1), False)\n-        self.assertEqual(node_classes.are_exclusive(f4, f2), True)\n+        self.assertEqual(nodes.are_exclusive(f2, f1), True)\n+        self.assertEqual(nodes.are_exclusive(f4, f1), False)\n+        self.assertEqual(nodes.are_exclusive(f4, f2), True)\n \n     def test_unpack_infer_uninferable_nodes(self):\n         node = builder.extract_node(\n@@ -109,9 +107,9 @@ def test_unpack_infer_uninferable_nodes(self):\n         \"\"\"\n         )\n         inferred = next(node.infer())\n-        unpacked = list(node_classes.unpack_infer(inferred))\n+        unpacked = list(nodes.unpack_infer(inferred))\n         self.assertEqual(len(unpacked), 3)\n-        self.assertTrue(all(elt is astroid_util.Uninferable for elt in unpacked))\n+        self.assertTrue(all(elt is Uninferable for elt in unpacked))\n \n     def test_unpack_infer_empty_tuple(self):\n         node = builder.extract_node(\n@@ -121,7 +119,7 @@ def test_unpack_infer_empty_tuple(self):\n         )\n         inferred = next(node.infer())\n         with self.assertRaises(InferenceError):\n-            list(node_classes.unpack_infer(inferred))\n+            list(nodes.unpack_infer(inferred))\n \n \n if __name__ == \"__main__\":\n", "problem_statement": "ImportError: cannot import name 'Statement' from 'astroid.node_classes' \n### Steps to reproduce\r\n\r\n1. run pylint <some_file>\r\n\r\n\r\n### Current behavior\r\n\r\n```python\r\nexception: Traceback (most recent call last):\r\n  File \"/usr/lib/python3.9/runpy.py\", line 197, in _run_module_as_main\r\n    return _run_code(code, main_globals, None,\r\n  File \"/usr/lib/python3.9/runpy.py\", line 87, in _run_code\r\n    exec(code, run_globals)\r\n  File \"/home/user/folder/check_mk/.venv/lib/python3.9/site-packages/pylint/__main__.py\", line 9, in <module>\r\n    pylint.run_pylint()\r\n  File \"/home/user/folder/check_mk/.venv/lib/python3.9/site-packages/pylint/__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"/home/user/folder/check_mk/.venv/lib/python3.9/site-packages/pylint/lint/run.py\", line 331, in __init__\r\n    linter.load_plugin_modules(plugins)\r\n  File \"/home/user/folder/check_mk/.venv/lib/python3.9/site-packages/pylint/lint/pylinter.py\", line 551, in load_plugin_modules\r\n    module = astroid.modutils.load_module_from_name(modname)\r\n  File \"/home/user/folder/check_mk/.venv/lib/python3.9/site-packages/astroid/modutils.py\", line 218, in load_module_from_name\r\n    return importlib.import_module(dotted_name)\r\n  File \"/usr/lib/python3.9/importlib/__init__.py\", line 127, in import_module\r\n    return _bootstrap._gcd_import(name[level:], package, level)\r\n  File \"<frozen importlib._bootstrap>\", line 1030, in _gcd_import\r\n  File \"<frozen importlib._bootstrap>\", line 1007, in _find_and_load\r\n  File \"<frozen importlib._bootstrap>\", line 986, in _find_and_load_unlocked\r\n  File \"<frozen importlib._bootstrap>\", line 680, in _load_unlocked\r\n  File \"<frozen importlib._bootstrap_external>\", line 855, in exec_module\r\n  File \"<frozen importlib._bootstrap>\", line 228, in _call_with_frames_removed\r\n  File \"/home/user/folder/check_mk/tests/testlib/pylint_checker_cmk_module_layers.py\", line 14, in <module>\r\n    from astroid.node_classes import Import, ImportFrom, Statement  # type: ignore[import]\r\nImportError: cannot import name 'Statement' from 'astroid.node_classes' (/home/user/folder/check_mk/.venv/lib/python3.9/site-packages/astroid/node_classes.py)\r\n```\r\n\r\n### Expected behavior\r\nNo exception\r\n\r\n### `python -c \"from astroid import __pkginfo__; print(__pkginfo__.version)\"` output\r\n2.7.3\r\npylint 2.10.2\r\nastroid 2.7.3\r\nPython 3.9.5 (default, May 11 2021, 08:20:37) \n", "hints_text": "This is caused by our local plugin.\r\n\r\nHas probably nothing to do with upstream. \nThis is caused by a bad refactor from us, we deprecated `astroid.node_classes` and `astroid.scoped_nodes` in favor of `astroid.nodes` but nothing should break before astroid 3.0.\n@Pierre-Sassoulas I see.\r\nAlso Statement is not available in astroid.nodes it is in astroid.nodes.node_classes\r\n\r\nWas the Statement also deprecated? Or called something else now?\nIt seems we're not using it ourselves or not by using `astroid.nodes` API so we did not realize it was not importable easily. But it should, I'm going to add it.", "created_at": "2021-09-04T15:03:02Z", "version": "2.7", "FAIL_TO_PASS": ["tests/unittest_scoped_nodes.py::ClassNodeTest::test_metaclass_lookup"], "PASS_TO_PASS": ["tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_bool-bool-?]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_byte-int-b]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_char-bytes-c]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_double-float-d]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_float-float-f]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_int-int-i]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_int16-int-h]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_int32-int-i]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_int64-int-l]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_int8-int-b]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_long-int-l]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_longdouble-float-g]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_longlong-int-l]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_short-int-h]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_size_t-int-L]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_ssize_t-int-l]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_ubyte-int-B]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_uint-int-I]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_uint16-int-H]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_uint32-int-I]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_uint64-int-L]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_uint8-int-B]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_ulong-int-L]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_ulonglong-int-L]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_ushort-int-H]", "tests/unittest_brain_ctypes.py::test_ctypes_redefined_types_members[c_wchar-str-u]", "tests/unittest_brain_ctypes.py::test_cdata_member_access", "tests/unittest_brain_ctypes.py::test_other_ctypes_member_untouched", "tests/unittest_lookup.py::LookupTest::test_builtin_lookup", "tests/unittest_lookup.py::LookupTest::test_class", "tests/unittest_lookup.py::LookupTest::test_class_ancestor_name", "tests/unittest_lookup.py::LookupTest::test_class_in_function", "tests/unittest_lookup.py::LookupTest::test_class_variables", "tests/unittest_lookup.py::LookupTest::test_decorator_arguments_lookup", "tests/unittest_lookup.py::LookupTest::test_dict_comp_nested", "tests/unittest_lookup.py::LookupTest::test_dict_comps", "tests/unittest_lookup.py::LookupTest::test_explicit___name__", "tests/unittest_lookup.py::LookupTest::test_function_argument_with_default", "tests/unittest_lookup.py::LookupTest::test_function_module_special", "tests/unittest_lookup.py::LookupTest::test_function_nested", "tests/unittest_lookup.py::LookupTest::test_generator_attributes", "tests/unittest_lookup.py::LookupTest::test_global_delete", "tests/unittest_lookup.py::LookupTest::test_inner_classes", "tests/unittest_lookup.py::LookupTest::test_inner_decorator_member_lookup", "tests/unittest_lookup.py::LookupTest::test_lambda_nested", "tests/unittest_lookup.py::LookupTest::test_limit", "tests/unittest_lookup.py::LookupTest::test_list_comp_nested", "tests/unittest_lookup.py::LookupTest::test_list_comp_target", "tests/unittest_lookup.py::LookupTest::test_list_comps", "tests/unittest_lookup.py::LookupTest::test_loopvar_hiding", "tests/unittest_lookup.py::LookupTest::test_method", "tests/unittest_lookup.py::LookupTest::test_module", "tests/unittest_lookup.py::LookupTest::test_set_comp_closure", "tests/unittest_lookup.py::LookupTest::test_set_comp_nested", "tests/unittest_lookup.py::LookupTest::test_set_comps", "tests/unittest_lookup.py::LookupTest::test_static_method_lookup", "tests/unittest_lookup.py::LookupControlFlowTest::test_assign_after_args_param", "tests/unittest_lookup.py::LookupControlFlowTest::test_assign_after_kwonly_param", "tests/unittest_lookup.py::LookupControlFlowTest::test_assign_after_param", "tests/unittest_lookup.py::LookupControlFlowTest::test_assign_after_posonly_param", "tests/unittest_lookup.py::LookupControlFlowTest::test_assign_after_use", "tests/unittest_lookup.py::LookupControlFlowTest::test_assign_exclusive", "tests/unittest_lookup.py::LookupControlFlowTest::test_assign_not_exclusive", "tests/unittest_lookup.py::LookupControlFlowTest::test_consecutive_assign", "tests/unittest_lookup.py::LookupControlFlowTest::test_del_exclusive", "tests/unittest_lookup.py::LookupControlFlowTest::test_del_no_effect_after", "tests/unittest_lookup.py::LookupControlFlowTest::test_del_not_exclusive", "tests/unittest_lookup.py::LookupControlFlowTest::test_del_removes_prior", "tests/unittest_lookup.py::LookupControlFlowTest::test_except_assign_after_block", "tests/unittest_lookup.py::LookupControlFlowTest::test_except_assign_after_block_overwritten", "tests/unittest_lookup.py::LookupControlFlowTest::test_except_assign_in_block", "tests/unittest_lookup.py::LookupControlFlowTest::test_except_assign_in_block_multiple", "tests/unittest_lookup.py::LookupControlFlowTest::test_except_var_after_block_multiple", "tests/unittest_lookup.py::LookupControlFlowTest::test_except_var_after_block_single", "tests/unittest_lookup.py::LookupControlFlowTest::test_except_var_in_block", "tests/unittest_lookup.py::LookupControlFlowTest::test_except_var_in_block_overwrites", "tests/unittest_lookup.py::LookupControlFlowTest::test_except_var_in_multiple_blocks", "tests/unittest_lookup.py::LookupControlFlowTest::test_if_assign", "tests/unittest_lookup.py::LookupControlFlowTest::test_if_assigns_different_branch", "tests/unittest_lookup.py::LookupControlFlowTest::test_if_assigns_same_branch", "tests/unittest_lookup.py::LookupControlFlowTest::test_if_else", "tests/unittest_lookup.py::LookupControlFlowTest::test_if_variable_in_condition_1", "tests/unittest_lookup.py::LookupControlFlowTest::test_if_variable_in_condition_2", "tests/unittest_protocols.py::ProtocolTests::test_assign_stmts_starred_fails", "tests/unittest_protocols.py::ProtocolTests::test_assigned_stmts_annassignments", "tests/unittest_protocols.py::ProtocolTests::test_assigned_stmts_assignments", "tests/unittest_protocols.py::ProtocolTests::test_assigned_stmts_simple_for", "tests/unittest_protocols.py::ProtocolTests::test_assigned_stmts_starred_assnames", "tests/unittest_protocols.py::ProtocolTests::test_assigned_stmts_starred_for", "tests/unittest_protocols.py::ProtocolTests::test_assigned_stmts_starred_yes", "tests/unittest_protocols.py::ProtocolTests::test_not_passing_uninferable_in_seq_inference", "tests/unittest_protocols.py::ProtocolTests::test_sequence_assigned_stmts_not_accepting_empty_node", "tests/unittest_protocols.py::test_named_expr_inference", "tests/unittest_python3.py::Python3TC::test_annotation_as_string", "tests/unittest_python3.py::Python3TC::test_annotation_support", "tests/unittest_python3.py::Python3TC::test_as_string", "tests/unittest_python3.py::Python3TC::test_async_comprehensions", "tests/unittest_python3.py::Python3TC::test_async_comprehensions_as_string", "tests/unittest_python3.py::Python3TC::test_async_comprehensions_outside_coroutine", "tests/unittest_python3.py::Python3TC::test_format_string", "tests/unittest_python3.py::Python3TC::test_kwonlyargs_annotations_supper", "tests/unittest_python3.py::Python3TC::test_metaclass_ancestors", "tests/unittest_python3.py::Python3TC::test_metaclass_error", "tests/unittest_python3.py::Python3TC::test_metaclass_imported", "tests/unittest_python3.py::Python3TC::test_metaclass_multiple_keywords", "tests/unittest_python3.py::Python3TC::test_metaclass_yes_leak", "tests/unittest_python3.py::Python3TC::test_nested_unpacking_in_dicts", "tests/unittest_python3.py::Python3TC::test_old_syntax_works", "tests/unittest_python3.py::Python3TC::test_parent_metaclass", "tests/unittest_python3.py::Python3TC::test_simple_metaclass", "tests/unittest_python3.py::Python3TC::test_starred_notation", "tests/unittest_python3.py::Python3TC::test_underscores_in_numeral_literal", "tests/unittest_python3.py::Python3TC::test_unpacking_in_dict_getitem", "tests/unittest_python3.py::Python3TC::test_unpacking_in_dicts", "tests/unittest_python3.py::Python3TC::test_yield_from", "tests/unittest_python3.py::Python3TC::test_yield_from_as_string", "tests/unittest_python3.py::Python3TC::test_yield_from_is_generator", "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_abstract_methods_are_not_implicitly_none", "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_no_returns_is_implicitly_none", "tests/unittest_scoped_nodes.py::FunctionNodeTest::test_only_raises_is_not_implicitly_none", "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_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_issue940_metaclass_subclass_property", "tests/unittest_scoped_nodes.py::test_issue940_property_grandchild", "tests/unittest_scoped_nodes.py::test_issue940_metaclass_property", "tests/unittest_scoped_nodes.py::test_issue940_with_metaclass_class_context_property", "tests/unittest_scoped_nodes.py::test_issue940_metaclass_values_funcdef", "tests/unittest_scoped_nodes.py::test_issue940_metaclass_derived_funcdef", "tests/unittest_scoped_nodes.py::test_issue940_metaclass_funcdef_is_not_datadescriptor", "tests/unittest_scoped_nodes.py::test_issue940_enums_as_a_real_world_usecase", "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", "tests/unittest_scoped_nodes.py::test_ancestor_with_generic", "tests/unittest_scoped_nodes.py::test_slots_duplicate_bases_issue_1089", "tests/unittest_utils.py::InferenceUtil::test_if", "tests/unittest_utils.py::InferenceUtil::test_not_exclusive", "tests/unittest_utils.py::InferenceUtil::test_try_except", "tests/unittest_utils.py::InferenceUtil::test_unpack_infer_empty_tuple", "tests/unittest_utils.py::InferenceUtil::test_unpack_infer_uninferable_nodes"], "environment_setup_commit": "40ea1a3b8e52bbfed43deb1725cde461f4bd8a96"}, {"repo": "pylint-dev/astroid", "instance_id": "pylint-dev__astroid-1333", "base_commit": "d2a5b3c7b1e203fec3c7ca73c30eb1785d3d4d0a", "patch": "diff --git a/astroid/modutils.py b/astroid/modutils.py\n--- a/astroid/modutils.py\n+++ b/astroid/modutils.py\n@@ -297,6 +297,9 @@ def _get_relative_base_path(filename, path_to_check):\n     if os.path.normcase(real_filename).startswith(path_to_check):\n         importable_path = real_filename\n \n+    # if \"var\" in path_to_check:\n+    #     breakpoint()\n+\n     if importable_path:\n         base_path = os.path.splitext(importable_path)[0]\n         relative_base_path = base_path[len(path_to_check) :]\n@@ -307,8 +310,11 @@ def _get_relative_base_path(filename, path_to_check):\n \n def modpath_from_file_with_callback(filename, path=None, is_package_cb=None):\n     filename = os.path.expanduser(_path_from_filename(filename))\n+    paths_to_check = sys.path.copy()\n+    if path:\n+        paths_to_check += path\n     for pathname in itertools.chain(\n-        path or [], map(_cache_normalize_path, sys.path), sys.path\n+        paths_to_check, map(_cache_normalize_path, paths_to_check)\n     ):\n         if not pathname:\n             continue\n", "test_patch": "diff --git a/tests/unittest_modutils.py b/tests/unittest_modutils.py\n--- a/tests/unittest_modutils.py\n+++ b/tests/unittest_modutils.py\n@@ -30,6 +30,7 @@\n import tempfile\n import unittest\n import xml\n+from pathlib import Path\n from xml import etree\n from xml.etree import ElementTree\n \n@@ -189,6 +190,30 @@ def test_load_from_module_symlink_on_symlinked_paths_in_syspath(self) -> None:\n         # this should be equivalent to: import secret\n         self.assertEqual(modutils.modpath_from_file(symlink_secret_path), [\"secret\"])\n \n+    def test_load_packages_without_init(self) -> None:\n+        \"\"\"Test that we correctly find packages with an __init__.py file.\n+\n+        Regression test for issue reported in:\n+        https://github.com/PyCQA/astroid/issues/1327\n+        \"\"\"\n+        tmp_dir = Path(tempfile.gettempdir())\n+        self.addCleanup(os.chdir, os.curdir)\n+        os.chdir(tmp_dir)\n+\n+        self.addCleanup(shutil.rmtree, tmp_dir / \"src\")\n+        os.mkdir(tmp_dir / \"src\")\n+        os.mkdir(tmp_dir / \"src\" / \"package\")\n+        with open(tmp_dir / \"src\" / \"__init__.py\", \"w\", encoding=\"utf-8\"):\n+            pass\n+        with open(tmp_dir / \"src\" / \"package\" / \"file.py\", \"w\", encoding=\"utf-8\"):\n+            pass\n+\n+        # this should be equivalent to: import secret\n+        self.assertEqual(\n+            modutils.modpath_from_file(str(Path(\"src\") / \"package\"), [\".\"]),\n+            [\"src\", \"package\"],\n+        )\n+\n \n class LoadModuleFromPathTest(resources.SysPathSetup, unittest.TestCase):\n     def test_do_not_load_twice(self) -> None:\n", "problem_statement": "astroid 2.9.1 breaks pylint with missing __init__.py: F0010: error while code parsing: Unable to load file __init__.py\n### Steps to reproduce\r\n> Steps provided are for Windows 11, but initial problem found in Ubuntu 20.04\r\n\r\n> Update 2022-01-04: Corrected repro steps and added more environment details\r\n\r\n1. Set up simple repo with following structure (all files can be empty):\r\n```\r\nroot_dir/\r\n|--src/\r\n|----project/ # Notice the missing __init__.py\r\n|------file.py # It can be empty, but I added `import os` at the top\r\n|----__init__.py\r\n```\r\n2. Open a command prompt\r\n3. `cd root_dir`\r\n4. `python -m venv venv`\r\n5. `venv/Scripts/activate`\r\n6. `pip install pylint astroid==2.9.1` # I also repro'd on the latest, 2.9.2\r\n7. `pylint src/project` # Updated from `pylint src`\r\n8. Observe failure:\r\n```\r\nsrc\\project\\__init__.py:1:0: F0010: error while code parsing: Unable to load file src\\project\\__init__.py:\r\n```\r\n\r\n### Current behavior\r\nFails with `src\\project\\__init__.py:1:0: F0010: error while code parsing: Unable to load file src\\project\\__init__.py:`\r\n\r\n### Expected behavior\r\nDoes not fail with error.\r\n> If you replace step 6 with `pip install pylint astroid==2.9.0`, you get no failure with an empty output - since no files have content\r\n\r\n### `python -c \"from astroid import __pkginfo__; print(__pkginfo__.version)\"` output\r\n2.9.1\r\n\r\n`python 3.9.1`\r\n`pylint 2.12.2 `\r\n\r\n\r\n\r\nThis issue has been observed with astroid `2.9.1` and `2.9.2`\n", "hints_text": "I can't seem to reproduce this in my `virtualenv`. This might be specific to `venv`? Needs some further investigation.\n@interifter Which version of `pylint` are you using?\nRight, ``pip install pylint astroid==2.9.0``, will keep the local version if you already have one, so I thought it was ``2.12.2`` but that could be false. In fact it probably isn't 2.12.2. For the record, you're not supposed to set the version of ``astroid`` yourself, pylint does, and bad thing will happen if you try to set the version of an incompatible astroid. We might want to update the issue's template to have this information next.\nMy apologies... I updated the repro steps with a critical missed detail: `pylint src/project`, instead of `pylint src`\r\n\r\nBut I verified that either with, or without, `venv`, the issue is reproduced.\r\n\r\nAlso, I never have specified the `astroid` version, before. \r\n\r\nHowever, this isn't the first time the issue has been observed.\r\nBack in early 2019, a [similar issue](https://stackoverflow.com/questions/48024049/pylint-raises-error-if-directory-doesnt-contain-init-py-file) was observed with either `astroid 2.2.0` or `isort 4.3.5`, which led me to try pinning `astroid==2.9.0`, which worked.\n> @interifter Which version of `pylint` are you using?\r\n\r\n`2.12.2`\r\n\r\nFull env info:\r\n\r\n```\r\nPackage           Version\r\n----------------- -------\r\nastroid           2.9.2\r\ncolorama          0.4.4\r\nisort             5.10.1\r\nlazy-object-proxy 1.7.1\r\nmccabe            0.6.1\r\npip               20.2.3\r\nplatformdirs      2.4.1\r\npylint            2.12.2\r\nsetuptools        49.2.1\r\ntoml              0.10.2\r\ntyping-extensions 4.0.1\r\nwrapt             1.13.3\r\n```\r\n\nI confirm the bug and i'm able to reproduce it with `python 3.9.1`. \r\n```\r\n$> pip freeze\r\nastroid==2.9.2\r\nisort==5.10.1\r\nlazy-object-proxy==1.7.1\r\nmccabe==0.6.1\r\nplatformdirs==2.4.1\r\npylint==2.12.2\r\ntoml==0.10.2\r\ntyping-extensions==4.0.1\r\nwrapt==1.13.3\r\n```\nBisected and this is the faulty commit:\r\nhttps://github.com/PyCQA/astroid/commit/2ee20ccdf62450db611acc4a1a7e42f407ce8a14\nFix in #1333, no time to write tests yet so if somebody has any good ideas: please let me know!", "created_at": "2022-01-08T19:36:45Z", "version": "2.10", "FAIL_TO_PASS": ["tests/unittest_modutils.py::ModPathFromFileTest::test_load_packages_without_init"], "PASS_TO_PASS": ["tests/unittest_modutils.py::ModuleFileTest::test_find_egg_module", "tests/unittest_modutils.py::ModuleFileTest::test_find_zipped_module", "tests/unittest_modutils.py::LoadModuleFromNameTest::test_known_values_load_module_from_name_1", "tests/unittest_modutils.py::LoadModuleFromNameTest::test_known_values_load_module_from_name_2", "tests/unittest_modutils.py::LoadModuleFromNameTest::test_raise_load_module_from_name_1", "tests/unittest_modutils.py::GetModulePartTest::test_get_module_part_exception", "tests/unittest_modutils.py::GetModulePartTest::test_known_values_get_builtin_module_part", "tests/unittest_modutils.py::GetModulePartTest::test_known_values_get_compiled_module_part", "tests/unittest_modutils.py::GetModulePartTest::test_known_values_get_module_part_1", "tests/unittest_modutils.py::GetModulePartTest::test_known_values_get_module_part_2", "tests/unittest_modutils.py::GetModulePartTest::test_known_values_get_module_part_3", "tests/unittest_modutils.py::ModPathFromFileTest::test_import_symlink_both_outside_of_path", "tests/unittest_modutils.py::ModPathFromFileTest::test_import_symlink_with_source_outside_of_path", "tests/unittest_modutils.py::ModPathFromFileTest::test_known_values_modpath_from_file_1", "tests/unittest_modutils.py::ModPathFromFileTest::test_load_from_module_symlink_on_symlinked_paths_in_syspath", "tests/unittest_modutils.py::ModPathFromFileTest::test_raise_modpath_from_file_exception", "tests/unittest_modutils.py::LoadModuleFromPathTest::test_do_not_load_twice", "tests/unittest_modutils.py::FileFromModPathTest::test_builtin", "tests/unittest_modutils.py::FileFromModPathTest::test_site_packages", "tests/unittest_modutils.py::FileFromModPathTest::test_std_lib", "tests/unittest_modutils.py::FileFromModPathTest::test_unexisting", "tests/unittest_modutils.py::FileFromModPathTest::test_unicode_in_package_init", "tests/unittest_modutils.py::GetSourceFileTest::test", "tests/unittest_modutils.py::GetSourceFileTest::test_raise", "tests/unittest_modutils.py::StandardLibModuleTest::test_4", "tests/unittest_modutils.py::StandardLibModuleTest::test_builtin", "tests/unittest_modutils.py::StandardLibModuleTest::test_builtins", "tests/unittest_modutils.py::StandardLibModuleTest::test_custom_path", "tests/unittest_modutils.py::StandardLibModuleTest::test_datetime", "tests/unittest_modutils.py::StandardLibModuleTest::test_failing_edge_cases", "tests/unittest_modutils.py::StandardLibModuleTest::test_nonstandard", "tests/unittest_modutils.py::StandardLibModuleTest::test_unknown", "tests/unittest_modutils.py::IsRelativeTest::test_deep_relative", "tests/unittest_modutils.py::IsRelativeTest::test_deep_relative2", "tests/unittest_modutils.py::IsRelativeTest::test_deep_relative3", "tests/unittest_modutils.py::IsRelativeTest::test_deep_relative4", "tests/unittest_modutils.py::IsRelativeTest::test_is_relative_bad_path", "tests/unittest_modutils.py::IsRelativeTest::test_known_values_is_relative_1", "tests/unittest_modutils.py::IsRelativeTest::test_known_values_is_relative_3", "tests/unittest_modutils.py::IsRelativeTest::test_known_values_is_relative_4", "tests/unittest_modutils.py::IsRelativeTest::test_known_values_is_relative_5", "tests/unittest_modutils.py::GetModuleFilesTest::test_get_all_files", "tests/unittest_modutils.py::GetModuleFilesTest::test_get_module_files_1", "tests/unittest_modutils.py::GetModuleFilesTest::test_load_module_set_attribute", "tests/unittest_modutils.py::ExtensionPackageWhitelistTest::test_is_module_name_part_of_extension_package_whitelist_success", "tests/unittest_modutils.py::ExtensionPackageWhitelistTest::test_is_module_name_part_of_extension_package_whitelist_true"], "environment_setup_commit": "da745538c7236028a22cdf0405f6829fcf6886bc"}, {"repo": "pylint-dev/astroid", "instance_id": "pylint-dev__astroid-1196", "base_commit": "39c2a9805970ca57093d32bbaf0e6a63e05041d8", "patch": "diff --git a/astroid/nodes/node_classes.py b/astroid/nodes/node_classes.py\n--- a/astroid/nodes/node_classes.py\n+++ b/astroid/nodes/node_classes.py\n@@ -2346,24 +2346,33 @@ def itered(self):\n         \"\"\"\n         return [key for (key, _) in self.items]\n \n-    def getitem(self, index, context=None):\n+    def getitem(\n+        self, index: Const | Slice, context: InferenceContext | None = None\n+    ) -> NodeNG:\n         \"\"\"Get an item from this node.\n \n         :param index: The node to use as a subscript index.\n-        :type index: Const or Slice\n \n         :raises AstroidTypeError: When the given index cannot be used as a\n             subscript index, or if this node is not subscriptable.\n         :raises AstroidIndexError: If the given index does not exist in the\n             dictionary.\n         \"\"\"\n+        # pylint: disable-next=import-outside-toplevel; circular import\n+        from astroid.helpers import safe_infer\n+\n         for key, value in self.items:\n             # TODO(cpopa): no support for overriding yet, {1:2, **{1: 3}}.\n             if isinstance(key, DictUnpack):\n+                inferred_value = safe_infer(value, context)\n+                if not isinstance(inferred_value, Dict):\n+                    continue\n+\n                 try:\n-                    return value.getitem(index, context)\n+                    return inferred_value.getitem(index, context)\n                 except (AstroidTypeError, AstroidIndexError):\n                     continue\n+\n             for inferredkey in key.infer(context):\n                 if inferredkey is util.Uninferable:\n                     continue\n", "test_patch": "diff --git a/tests/unittest_python3.py b/tests/unittest_python3.py\n--- a/tests/unittest_python3.py\n+++ b/tests/unittest_python3.py\n@@ -5,7 +5,9 @@\n import unittest\n from textwrap import dedent\n \n-from astroid import nodes\n+import pytest\n+\n+from astroid import exceptions, nodes\n from astroid.builder import AstroidBuilder, extract_node\n from astroid.test_utils import require_version\n \n@@ -285,6 +287,33 @@ def test_unpacking_in_dict_getitem(self) -> None:\n             self.assertIsInstance(value, nodes.Const)\n             self.assertEqual(value.value, expected)\n \n+    @staticmethod\n+    def test_unpacking_in_dict_getitem_with_ref() -> None:\n+        node = extract_node(\n+            \"\"\"\n+        a = {1: 2}\n+        {**a, 2: 3}  #@\n+        \"\"\"\n+        )\n+        assert isinstance(node, nodes.Dict)\n+\n+        for key, expected in ((1, 2), (2, 3)):\n+            value = node.getitem(nodes.Const(key))\n+            assert isinstance(value, nodes.Const)\n+            assert value.value == expected\n+\n+    @staticmethod\n+    def test_unpacking_in_dict_getitem_uninferable() -> None:\n+        node = extract_node(\"{**a, 2: 3}\")\n+        assert isinstance(node, nodes.Dict)\n+\n+        with pytest.raises(exceptions.AstroidIndexError):\n+            node.getitem(nodes.Const(1))\n+\n+        value = node.getitem(nodes.Const(2))\n+        assert isinstance(value, nodes.Const)\n+        assert value.value == 3\n+\n     def test_format_string(self) -> None:\n         code = \"f'{greetings} {person}'\"\n         node = extract_node(code)\n", "problem_statement": "getitem does not infer the actual unpacked value\nWhen trying to call `Dict.getitem()` on a context where we have a dict unpacking of anything beside a real dict, astroid currently raises an `AttributeError: 'getitem'`, which has 2 problems:\r\n\r\n- The object might be a reference against something constant, this pattern is usually seen when we have different sets of dicts that extend each other, and all of their values are inferrable. \r\n- We can have something that is uninferable, but in that case instead of an `AttributeError` I think it makes sense to raise the usual `AstroidIndexError` which is supposed to be already handled by the downstream.\r\n\r\n\r\nHere is a short reproducer;\r\n\r\n```py\r\nfrom astroid import parse\r\n\r\n\r\nsource = \"\"\"\r\nX = {\r\n    'A': 'B'\r\n}\r\n\r\nY = {\r\n    **X\r\n}\r\n\r\nKEY = 'A'\r\n\"\"\"\r\n\r\ntree = parse(source)\r\n\r\nfirst_dict = tree.body[0].value\r\nsecond_dict = tree.body[1].value\r\nkey = tree.body[2].value\r\n\r\nprint(f'{first_dict.getitem(key).value = }')\r\nprint(f'{second_dict.getitem(key).value = }')\r\n\r\n\r\n```\r\n\r\nThe current output;\r\n\r\n```\r\n $ python t1.py                                                                                                 3ms\r\nfirst_dict.getitem(key).value = 'B'\r\nTraceback (most recent call last):\r\n  File \"/home/isidentical/projects/astroid/t1.py\", line 23, in <module>\r\n    print(f'{second_dict.getitem(key).value = }')\r\n  File \"/home/isidentical/projects/astroid/astroid/nodes/node_classes.py\", line 2254, in getitem\r\n    return value.getitem(index, context)\r\nAttributeError: 'Name' object has no attribute 'getitem'\r\n```\r\n\r\nExpeceted output;\r\n```\r\n $ python t1.py                                                                                                 4ms\r\nfirst_dict.getitem(key).value = 'B'\r\nsecond_dict.getitem(key).value = 'B'\r\n\r\n```\r\n\n", "hints_text": "", "created_at": "2021-10-03T15:58:07Z", "version": "2.12", "FAIL_TO_PASS": ["tests/unittest_python3.py::Python3TC::test_unpacking_in_dict_getitem_uninferable", "tests/unittest_python3.py::Python3TC::test_unpacking_in_dict_getitem_with_ref"], "PASS_TO_PASS": ["tests/unittest_python3.py::Python3TC::test_annotation_as_string", "tests/unittest_python3.py::Python3TC::test_annotation_support", "tests/unittest_python3.py::Python3TC::test_as_string", "tests/unittest_python3.py::Python3TC::test_async_comprehensions", "tests/unittest_python3.py::Python3TC::test_async_comprehensions_as_string", "tests/unittest_python3.py::Python3TC::test_async_comprehensions_outside_coroutine", "tests/unittest_python3.py::Python3TC::test_format_string", "tests/unittest_python3.py::Python3TC::test_kwonlyargs_annotations_supper", "tests/unittest_python3.py::Python3TC::test_metaclass_ancestors", "tests/unittest_python3.py::Python3TC::test_metaclass_error", "tests/unittest_python3.py::Python3TC::test_metaclass_imported", "tests/unittest_python3.py::Python3TC::test_metaclass_multiple_keywords", "tests/unittest_python3.py::Python3TC::test_metaclass_yes_leak", "tests/unittest_python3.py::Python3TC::test_nested_unpacking_in_dicts", "tests/unittest_python3.py::Python3TC::test_old_syntax_works", "tests/unittest_python3.py::Python3TC::test_parent_metaclass", "tests/unittest_python3.py::Python3TC::test_simple_metaclass", "tests/unittest_python3.py::Python3TC::test_starred_notation", "tests/unittest_python3.py::Python3TC::test_underscores_in_numeral_literal", "tests/unittest_python3.py::Python3TC::test_unpacking_in_dict_getitem", "tests/unittest_python3.py::Python3TC::test_unpacking_in_dicts", "tests/unittest_python3.py::Python3TC::test_yield_from", "tests/unittest_python3.py::Python3TC::test_yield_from_as_string", "tests/unittest_python3.py::Python3TC::test_yield_from_is_generator"], "environment_setup_commit": "52f6d2d7722db383af035be929f18af5e9fe8cd5"}, {"repo": "pylint-dev/astroid", "instance_id": "pylint-dev__astroid-927", "base_commit": "cd8b6a43192724128af68605ef22aabf3254f495", "patch": "diff --git a/astroid/context.py b/astroid/context.py\n--- a/astroid/context.py\n+++ b/astroid/context.py\n@@ -102,7 +102,7 @@ def clone(self):\n         starts with the same context but diverge as each side is inferred\n         so the InferenceContext will need be cloned\"\"\"\n         # XXX copy lookupname/callcontext ?\n-        clone = InferenceContext(self.path, inferred=self.inferred)\n+        clone = InferenceContext(self.path.copy(), inferred=self.inferred.copy())\n         clone.callcontext = self.callcontext\n         clone.boundnode = self.boundnode\n         clone.extra_context = self.extra_context\n", "test_patch": "diff --git a/tests/unittest_brain_numpy_core_umath.py b/tests/unittest_brain_numpy_core_umath.py\n--- a/tests/unittest_brain_numpy_core_umath.py\n+++ b/tests/unittest_brain_numpy_core_umath.py\n@@ -14,7 +14,7 @@\n except ImportError:\n     HAS_NUMPY = False\n \n-from astroid import bases, builder, nodes, util\n+from astroid import bases, builder, nodes\n \n \n @unittest.skipUnless(HAS_NUMPY, \"This test requires the numpy library.\")\n@@ -220,9 +220,7 @@ def test_numpy_core_umath_functions_return_type(self):\n             with self.subTest(typ=func_):\n                 inferred_values = list(self._inferred_numpy_func_call(func_))\n                 self.assertTrue(\n-                    len(inferred_values) == 1\n-                    or len(inferred_values) == 2\n-                    and inferred_values[-1].pytype() is util.Uninferable,\n+                    len(inferred_values) == 1,\n                     msg=\"Too much inferred values ({}) for {:s}\".format(\n                         inferred_values[-1].pytype(), func_\n                     ),\ndiff --git a/tests/unittest_inference.py b/tests/unittest_inference.py\n--- a/tests/unittest_inference.py\n+++ b/tests/unittest_inference.py\n@@ -1704,7 +1704,8 @@ def __init__(self):\n         \"\"\"\n         ast = extract_node(code, __name__)\n         expr = ast.func.expr\n-        self.assertIs(next(expr.infer()), util.Uninferable)\n+        with pytest.raises(exceptions.InferenceError):\n+            next(expr.infer())\n \n     def test_tuple_builtin_inference(self):\n         code = \"\"\"\n@@ -6032,5 +6033,37 @@ def test_infer_list_of_uninferables_does_not_crash():\n     assert not inferred.elts\n \n \n+# https://github.com/PyCQA/astroid/issues/926\n+def test_issue926_infer_stmts_referencing_same_name_is_not_uninferable():\n+    code = \"\"\"\n+    pair = [1, 2]\n+    ex = pair[0]\n+    if 1 + 1 == 2:\n+        ex = pair[1]\n+    ex\n+    \"\"\"\n+    node = extract_node(code)\n+    inferred = list(node.infer())\n+    assert len(inferred) == 2\n+    assert isinstance(inferred[0], nodes.Const)\n+    assert inferred[0].value == 1\n+    assert isinstance(inferred[1], nodes.Const)\n+    assert inferred[1].value == 2\n+\n+\n+# https://github.com/PyCQA/astroid/issues/926\n+def test_issue926_binop_referencing_same_name_is_not_uninferable():\n+    code = \"\"\"\n+    pair = [1, 2]\n+    ex = pair[0] + pair[1]\n+    ex\n+    \"\"\"\n+    node = extract_node(code)\n+    inferred = list(node.infer())\n+    assert len(inferred) == 1\n+    assert isinstance(inferred[0], nodes.Const)\n+    assert inferred[0].value == 3\n+\n+\n if __name__ == \"__main__\":\n     unittest.main()\ndiff --git a/tests/unittest_regrtest.py b/tests/unittest_regrtest.py\n--- a/tests/unittest_regrtest.py\n+++ b/tests/unittest_regrtest.py\n@@ -99,7 +99,7 @@ def test_numpy_crash(self):\n         astroid = builder.string_build(data, __name__, __file__)\n         callfunc = astroid.body[1].value.func\n         inferred = callfunc.inferred()\n-        self.assertEqual(len(inferred), 2)\n+        self.assertEqual(len(inferred), 1)\n \n     def test_nameconstant(self):\n         # used to fail for Python 3.4\n", "problem_statement": "infer_stmts cannot infer multiple uses of the same AssignName\nGiven multiple assignments to the same target which both reference the same AssignName, infer_stmts fails for subsequent attempts after the first.\r\n\r\n### Steps to reproduce\r\n\r\nThis appears to be a minimum working example, removing any part removes the effect:\r\n\r\n```python\r\nfails = astroid.extract_node(\"\"\"\r\n    pair = [1, 2]\r\n    ex = pair[0]\r\n    if 1 + 1 == 2:\r\n        ex = pair[1]\r\n    ex\r\n\"\"\")\r\nprint(list(fails.infer()))\r\n# [<Const.int l.2 at 0x...>, Uninferable]\r\n```\r\n\r\nFor some context, I originally saw this with attributes on an imported module, i.e.\r\n\r\n```python\r\nimport mod\r\nex = mod.One()\r\n# later ... or in some branch\r\nex = mod.Two()\r\n```\r\n\r\n### Current behavior\r\n\r\nSee above.\r\n\r\n### Expected behavior\r\n\r\nInlining the variable or switching to a different name works fine:\r\n\r\n```python\r\nworks = astroid.extract_node(\"\"\"\r\n    # pair = [1, 2]\r\n    ex = [1, 2][0]\r\n    if 1 + 1 == 2:\r\n        ex = [1, 2][1]\r\n    ex\r\n\"\"\")\r\nprint(list(works.infer()))\r\n# [<Const.int l.3 at 0x...>, <Const.int l.5 at 0x...>]\r\n\r\nworks = astroid.extract_node(\"\"\"\r\n    first = [1, 2]\r\n    second = [1, 2]\r\n    ex = first[0]\r\n    if 1 + 1 == 2:\r\n        ex = second[1]\r\n    ex\r\n\"\"\")\r\nprint(list(works.infer()))\r\n# [<Const.int l.2 at 0x...>, <Const.int l.3 at 0x...>]\r\n```\r\n\r\nI would expect that the first failing example would work similarly. This (only) worked\r\nin astroid 2.5 and appears to have been \"broken\" by the revert of cc3bfc5 in 03d15b0 (astroid 2.5.1 and above).\r\n\r\n### ``python -c \"from astroid import __pkginfo__; print(__pkginfo__.version)\"`` output\r\n\r\n```\r\n$ python -c \"from astroid import __pkginfo__; print(__pkginfo__.version)\"\r\n2.5-dev\r\n$ git rev-parse HEAD\r\n03d15b0f32f7d7c9b2cb062b9321e531bd954344\r\n```\r\n\n", "hints_text": "It appears that this is caused by `InferenceContext` maintaining a strong reference to the mutable set that is shared between clones, see this simplified example:\r\n\r\n```python\r\nclass Context:\r\n    def __init__(self, path=None):\r\n        self.path = path or set()\r\n    def clone(self):\r\n        return Context(path=self.path)\r\n\r\na = Context()\r\na.path.add('hello')\r\nb = a.clone()\r\nb.path.add('world')\r\nprint(a.path, b.path)\r\n# (set(['world', 'hello']), set(['world', 'hello']))\r\nprint(a.path is b.path)\r\n# True\r\n```", "created_at": "2021-03-29T12:55:48Z", "version": "2.5", "FAIL_TO_PASS": ["tests/unittest_inference.py::InferenceTest::test_stop_iteration_leak", "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"], "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_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_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_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_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_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_regrtest.py::NonRegressionTests::test_ancestors_missing_from_function", "tests/unittest_regrtest.py::NonRegressionTests::test_ancestors_patching_class_recursion", "tests/unittest_regrtest.py::NonRegressionTests::test_ancestors_yes_in_bases", "tests/unittest_regrtest.py::NonRegressionTests::test_binop_generates_nodes_with_parents", "tests/unittest_regrtest.py::NonRegressionTests::test_decorator_callchain_issue42", "tests/unittest_regrtest.py::NonRegressionTests::test_decorator_names_inference_error_leaking", "tests/unittest_regrtest.py::NonRegressionTests::test_filter_stmts_scoping", "tests/unittest_regrtest.py::NonRegressionTests::test_living_property", "tests/unittest_regrtest.py::NonRegressionTests::test_module_path", "tests/unittest_regrtest.py::NonRegressionTests::test_nameconstant", "tests/unittest_regrtest.py::NonRegressionTests::test_package_sidepackage", "tests/unittest_regrtest.py::NonRegressionTests::test_recursion_regression_issue25", "tests/unittest_regrtest.py::NonRegressionTests::test_recursive_property_method", "tests/unittest_regrtest.py::NonRegressionTests::test_regression_inference_of_self_in_lambda", "tests/unittest_regrtest.py::NonRegressionTests::test_ssl_protocol", "tests/unittest_regrtest.py::NonRegressionTests::test_unicode_in_docstring", "tests/unittest_regrtest.py::NonRegressionTests::test_uninferable_string_argument_of_namedtuple", "tests/unittest_regrtest.py::test_ancestor_looking_up_redefined_function", "tests/unittest_regrtest.py::test_crash_in_dunder_inference_prevented"], "environment_setup_commit": "d2ae3940a1a374253cc95d8fe83cb96f7a57e843"}, {"repo": "pyvista/pyvista", "instance_id": "pyvista__pyvista-4406", "base_commit": "461bb5ed5be8c9dda6e9ed765fab3224149d9c62", "patch": "diff --git a/pyvista/core/filters/rectilinear_grid.py b/pyvista/core/filters/rectilinear_grid.py\n--- a/pyvista/core/filters/rectilinear_grid.py\n+++ b/pyvista/core/filters/rectilinear_grid.py\n@@ -2,24 +2,29 @@\n \n import collections\n from typing import Sequence, Union\n+import warnings\n \n import numpy as np\n \n from pyvista import _vtk, abstract_class\n from pyvista.core.filters import _get_output, _update_alg\n+from pyvista.utilities import assert_empty_kwargs\n+from pyvista.utilities.misc import PyVistaDeprecationWarning\n \n \n @abstract_class\n class RectilinearGridFilters:\n     \"\"\"An internal class to manage filters/algorithms for rectilinear grid datasets.\"\"\"\n \n+    # Note remove kwargs when removing deprecation for pass_cell_data\n     def to_tetrahedra(\n         self,\n         tetra_per_cell: int = 5,\n         mixed: Union[Sequence[int], bool] = False,\n         pass_cell_ids: bool = True,\n-        pass_cell_data: bool = True,\n+        pass_data: bool = True,\n         progress_bar: bool = False,\n+        **kwargs,\n     ):\n         \"\"\"Create a tetrahedral mesh structured grid.\n \n@@ -46,7 +51,7 @@ def to_tetrahedra(\n             :class:`pyvista.RectilinearGrid`. The name of this array is\n             ``'vtkOriginalCellIds'`` within the ``cell_data``.\n \n-        pass_cell_data : bool, default: True\n+        pass_data : bool, default: True\n             Set to ``True`` to make the tetrahedra mesh have the cell data from\n             the original :class:`pyvista.RectilinearGrid`.  This uses\n             ``pass_cell_ids=True`` internally. If ``True``, ``pass_cell_ids``\n@@ -55,6 +60,9 @@ def to_tetrahedra(\n         progress_bar : bool, default: False\n             Display a progress bar to indicate progress.\n \n+        **kwargs : dict, optional\n+            Deprecated keyword argument ``pass_cell_data``.\n+\n         Returns\n         -------\n         pyvista.UnstructuredGrid\n@@ -87,8 +95,17 @@ def to_tetrahedra(\n         >>> tet_grid.explode(factor=0.5).plot(show_edges=True)\n \n         \"\"\"\n+        # Note remove this section when deprecation is done\n+        pass_cell_data = kwargs.pop(\"pass_cell_data\", None)\n+        assert_empty_kwargs(**kwargs)\n+        if pass_cell_data is not None:\n+            warnings.warn(\n+                \"pass_cell_data is a deprecated option, use pass_data\", PyVistaDeprecationWarning\n+            )\n+            pass_data = pass_cell_data\n+\n         alg = _vtk.vtkRectilinearGridToTetrahedra()\n-        alg.SetRememberVoxelId(pass_cell_ids or pass_cell_data)\n+        alg.SetRememberVoxelId(pass_cell_ids or pass_data)\n         if mixed is not False:\n             if isinstance(mixed, str):\n                 self.cell_data.active_scalars_name = mixed\n@@ -116,16 +133,27 @@ def to_tetrahedra(\n         alg.SetInputData(self)\n         _update_alg(alg, progress_bar, 'Converting to tetrahedra')\n         out = _get_output(alg)\n-        if pass_cell_data:\n+\n+        if pass_data:\n             # algorithm stores original cell ids in active scalars\n+            # this does not preserve active scalars, but we need to\n+            # keep active scalars until they are renamed\n             for name in self.cell_data:  # type: ignore\n                 if name != out.cell_data.active_scalars_name:\n                     out[name] = self.cell_data[name][out.cell_data.active_scalars]  # type: ignore\n \n+            for name in self.point_data:  # type: ignore\n+                out[name] = self.point_data[name]  # type: ignore\n+\n         if alg.GetRememberVoxelId():\n             # original cell_ids are not named and are the active scalars\n             out.cell_data.set_array(\n                 out.cell_data.pop(out.cell_data.active_scalars_name), 'vtkOriginalCellIds'\n             )\n \n+        if pass_data:\n+            # Now reset active scalars in cast the original mesh had data with active scalars\n+            association, name = self.active_scalars_info  # type: ignore\n+            out.set_active_scalars(name, preference=association)\n+\n         return out\n", "test_patch": "diff --git a/tests/filters/test_rectilinear_grid.py b/tests/filters/test_rectilinear_grid.py\n--- a/tests/filters/test_rectilinear_grid.py\n+++ b/tests/filters/test_rectilinear_grid.py\n@@ -2,6 +2,7 @@\n import pytest\n \n import pyvista as pv\n+from pyvista.utilities.misc import PyVistaDeprecationWarning\n \n \n @pytest.fixture\n@@ -48,22 +49,39 @@ def test_to_tetrahedral_edge_case():\n \n \n def test_to_tetrahedral_pass_cell_ids(tiny_rectilinear):\n-    tet_grid = tiny_rectilinear.to_tetrahedra(pass_cell_ids=False, pass_cell_data=False)\n+    tet_grid = tiny_rectilinear.to_tetrahedra(pass_cell_ids=False, pass_data=False)\n     assert not tet_grid.cell_data\n-    tet_grid = tiny_rectilinear.to_tetrahedra(pass_cell_ids=True, pass_cell_data=False)\n+    tet_grid = tiny_rectilinear.to_tetrahedra(pass_cell_ids=True, pass_data=False)\n     assert 'vtkOriginalCellIds' in tet_grid.cell_data\n     assert np.issubdtype(tet_grid.cell_data['vtkOriginalCellIds'].dtype, np.integer)\n \n \n def test_to_tetrahedral_pass_cell_data(tiny_rectilinear):\n+    # test that data isn't passed\n     tiny_rectilinear[\"cell_data\"] = np.ones(tiny_rectilinear.n_cells)\n-\n-    tet_grid = tiny_rectilinear.to_tetrahedra(pass_cell_ids=False, pass_cell_data=False)\n+    tiny_rectilinear[\"point_data\"] = np.arange(tiny_rectilinear.n_points)\n+    tiny_rectilinear.set_active_scalars(\"cell_data\")\n+    tet_grid = tiny_rectilinear.to_tetrahedra(pass_cell_ids=False, pass_data=False)\n     assert not tet_grid.cell_data\n+    assert not tet_grid.point_data\n \n-    tet_grid = tiny_rectilinear.to_tetrahedra(pass_cell_ids=False, pass_cell_data=True)\n+    # test with cell data\n+    tet_grid = tiny_rectilinear.to_tetrahedra(pass_cell_ids=False, pass_data=True)\n     assert tet_grid.cell_data\n     assert \"cell_data\" in tet_grid.cell_data\n+    assert \"point_data\" in tet_grid.point_data\n+    assert tet_grid.active_scalars_name == \"cell_data\"\n \n     # automatically added\n     assert 'vtkOriginalCellIds' in tet_grid.cell_data\n+\n+    with pytest.warns(PyVistaDeprecationWarning):\n+        tiny_rectilinear.to_tetrahedra(pass_cell_data=True)\n+        if pv._version.version_info >= (0, 43, 0):\n+            raise RuntimeError('Remove this deprecated kwarg')\n+\n+    # Test point data active\n+    tiny_rectilinear.set_active_scalars(\"point_data\")\n+    assert tiny_rectilinear.active_scalars_name == \"point_data\"\n+    tet_grid = tiny_rectilinear.to_tetrahedra(pass_cell_ids=False, pass_data=True)\n+    assert tet_grid.active_scalars_name == \"point_data\"\n", "problem_statement": "to_tetrahedra active scalars\n### Describe the bug, what's wrong, and what you expected.\n\n#4311 passes cell data through the `to_tetrahedra` call. However, after these changes.  The active scalars information is lost.\r\n\r\ncc @akaszynski who implemented these changes in that PR.\n\n### Steps to reproduce the bug.\n\n```py\r\nimport pyvista as pv\r\nimport numpy as np\r\nmesh = pv.UniformGrid(dimensions=(10, 10, 10))\r\nmesh[\"a\"] = np.zeros(mesh.n_cells)\r\nmesh[\"b\"] = np.ones(mesh.n_cells)\r\nprint(mesh.cell_data)\r\ntet = mesh.to_tetrahedra()\r\nprint(tet.cell_data)\r\n```\r\n\r\n```txt\r\npyvista DataSetAttributes\r\nAssociation     : CELL\r\nActive Scalars  : a\r\nActive Vectors  : None\r\nActive Texture  : None\r\nActive Normals  : None\r\nContains arrays :\r\n    a                       float64    (729,)               SCALARS\r\n    b                       float64    (729,)\r\npyvista DataSetAttributes\r\nAssociation     : CELL\r\nActive Scalars  : None\r\nActive Vectors  : None\r\nActive Texture  : None\r\nActive Normals  : None\r\nContains arrays :\r\n    a                       float64    (3645,)\r\n    b                       float64    (3645,)\r\n    vtkOriginalCellIds      int32      (3645,)\r\n```\n\n### System Information\n\n```shell\nPython 3.11.2 (main, Mar 23 2023, 17:12:29) [GCC 10.2.1 20210110]\r\n\r\n           pyvista : 0.39.0\r\n               vtk : 9.2.6\r\n             numpy : 1.24.2\r\n        matplotlib : 3.7.1\r\n            scooby : 0.7.1\r\n             pooch : v1.7.0\r\n           imageio : 2.27.0\r\n           IPython : 8.12.0\r\n--------------------------------------------------------------------------------\n```\n\n\n### Screenshots\n\n_No response_\n", "hints_text": "First, these lines should reset the active_scalars to the last scalars added to the tetrahedral mesh:\r\n\r\nhttps://github.com/pyvista/pyvista/blob/a87cf37d9cea6fc68d8099a56d86ded8f6e78734/pyvista/core/filters/rectilinear_grid.py#L119-L123\r\n\r\nThese subsequent lines pop out the active scalars, which is somehow the blank scalars, and set it as \"vtkOriginalCellIds\".\r\n\r\nhttps://github.com/pyvista/pyvista/blob/a87cf37d9cea6fc68d8099a56d86ded8f6e78734/pyvista/core/filters/rectilinear_grid.py#L125-L129\r\n\r\nEdit: I am wrong the first set of lines, would only set active scalars if there are none present, but the unnamed scalars are active.  We just need to reset the active scalars according to the original mesh I think.\nGood point. Thanks @MatthewFlamm for pointing this out. We'll have this added in the v0.39.1 patch.", "created_at": "2023-05-10T18:54:53Z", "version": "0.40", "FAIL_TO_PASS": ["tests/filters/test_rectilinear_grid.py::test_to_tetrahedral_pass_cell_ids", "tests/filters/test_rectilinear_grid.py::test_to_tetrahedral_pass_cell_data"], "PASS_TO_PASS": ["tests/filters/test_rectilinear_grid.py::test_to_tetrahedral[5]", "tests/filters/test_rectilinear_grid.py::test_to_tetrahedral[6]", "tests/filters/test_rectilinear_grid.py::test_to_tetrahedral[12]", "tests/filters/test_rectilinear_grid.py::test_to_tetrahedral_raise", "tests/filters/test_rectilinear_grid.py::test_to_tetrahedral_mixed", "tests/filters/test_rectilinear_grid.py::test_to_tetrahedral_edge_case"], "environment_setup_commit": "19938bf14e7705ed1e7d4c9aa6558d90df6de9d1"}, {"repo": "pyvista/pyvista", "instance_id": "pyvista__pyvista-4315", "base_commit": "db6ee8dd4a747b8864caae36c5d05883976a3ae5", "patch": "diff --git a/pyvista/core/grid.py b/pyvista/core/grid.py\n--- a/pyvista/core/grid.py\n+++ b/pyvista/core/grid.py\n@@ -135,23 +135,30 @@ def __init__(self, *args, check_duplicates=False, deep=False, **kwargs):\n                     self.shallow_copy(args[0])\n             elif isinstance(args[0], (str, pathlib.Path)):\n                 self._from_file(args[0], **kwargs)\n-            elif isinstance(args[0], np.ndarray):\n-                self._from_arrays(args[0], None, None, check_duplicates)\n+            elif isinstance(args[0], (np.ndarray, Sequence)):\n+                self._from_arrays(np.asanyarray(args[0]), None, None, check_duplicates)\n             else:\n                 raise TypeError(f'Type ({type(args[0])}) not understood by `RectilinearGrid`')\n \n         elif len(args) == 3 or len(args) == 2:\n-            arg0_is_arr = isinstance(args[0], np.ndarray)\n-            arg1_is_arr = isinstance(args[1], np.ndarray)\n+            arg0_is_arr = isinstance(args[0], (np.ndarray, Sequence))\n+            arg1_is_arr = isinstance(args[1], (np.ndarray, Sequence))\n             if len(args) == 3:\n-                arg2_is_arr = isinstance(args[2], np.ndarray)\n+                arg2_is_arr = isinstance(args[2], (np.ndarray, Sequence))\n             else:\n                 arg2_is_arr = False\n \n             if all([arg0_is_arr, arg1_is_arr, arg2_is_arr]):\n-                self._from_arrays(args[0], args[1], args[2], check_duplicates)\n+                self._from_arrays(\n+                    np.asanyarray(args[0]),\n+                    np.asanyarray(args[1]),\n+                    np.asanyarray(args[2]),\n+                    check_duplicates,\n+                )\n             elif all([arg0_is_arr, arg1_is_arr]):\n-                self._from_arrays(args[0], args[1], None, check_duplicates)\n+                self._from_arrays(\n+                    np.asanyarray(args[0]), np.asanyarray(args[1]), None, check_duplicates\n+                )\n             else:\n                 raise TypeError(\"Arguments not understood by `RectilinearGrid`.\")\n \n", "test_patch": "diff --git a/tests/test_grid.py b/tests/test_grid.py\n--- a/tests/test_grid.py\n+++ b/tests/test_grid.py\n@@ -735,6 +735,21 @@ def test_create_rectilinear_grid_from_specs():\n     assert grid.n_cells == 9 * 3 * 19\n     assert grid.n_points == 10 * 4 * 20\n     assert grid.bounds == (-10.0, 8.0, -10.0, 5.0, -10.0, 9.0)\n+\n+    # with Sequence\n+    xrng = [0, 1]\n+    yrng = [0, 1, 2]\n+    zrng = [0, 1, 2, 3]\n+    grid = pyvista.RectilinearGrid(xrng)\n+    assert grid.n_cells == 1\n+    assert grid.n_points == 2\n+    grid = pyvista.RectilinearGrid(xrng, yrng)\n+    assert grid.n_cells == 2\n+    assert grid.n_points == 6\n+    grid = pyvista.RectilinearGrid(xrng, yrng, zrng)\n+    assert grid.n_cells == 6\n+    assert grid.n_points == 24\n+\n     # 2D example\n     cell_spacings = np.array([1.0, 1.0, 2.0, 2.0, 5.0, 10.0])\n     x_coordinates = np.cumsum(cell_spacings)\n", "problem_statement": "Rectilinear grid does not allow Sequences as inputs\n### Describe the bug, what's wrong, and what you expected.\r\n\r\nRectilinear grid gives an error when `Sequence`s are passed in, but `ndarray` are ok.\r\n\r\n### Steps to reproduce the bug.\r\n\r\nThis doesn't work\r\n```python\r\nimport pyvista as pv\r\npv.RectilinearGrid([0, 1], [0, 1], [0, 1])\r\n```\r\n\r\nThis works\r\n```py\r\nimport pyvista as pv\r\nimport numpy as np\r\npv.RectilinearGrid(np.ndarray([0, 1]), np.ndarray([0, 1]), np.ndarray([0, 1]))\r\n```\r\n### System Information\r\n\r\n```shell\r\n--------------------------------------------------------------------------------\r\n  Date: Wed Apr 19 20:15:10 2023 UTC\r\n\r\n                OS : Linux\r\n            CPU(s) : 2\r\n           Machine : x86_64\r\n      Architecture : 64bit\r\n       Environment : IPython\r\n        GPU Vendor : Mesa/X.org\r\n      GPU Renderer : llvmpipe (LLVM 11.0.1, 256 bits)\r\n       GPU Version : 4.5 (Core Profile) Mesa 20.3.5\r\n\r\n  Python 3.11.2 (main, Mar 23 2023, 17:12:29) [GCC 10.2.1 20210110]\r\n\r\n           pyvista : 0.38.5\r\n               vtk : 9.2.6\r\n             numpy : 1.24.2\r\n           imageio : 2.27.0\r\n            scooby : 0.7.1\r\n             pooch : v1.7.0\r\n        matplotlib : 3.7.1\r\n           IPython : 8.12.0\r\n--------------------------------------------------------------------------------\r\n```\r\n\r\n\r\n### Screenshots\r\n\r\n_No response_\n", "hints_text": "", "created_at": "2023-04-21T13:47:31Z", "version": "0.39", "FAIL_TO_PASS": ["tests/test_grid.py::test_create_rectilinear_grid_from_specs"], "PASS_TO_PASS": ["tests/test_grid.py::test_volume", "tests/test_grid.py::test_init_from_polydata", "tests/test_grid.py::test_init_from_structured", "tests/test_grid.py::test_init_from_unstructured", "tests/test_grid.py::test_init_from_numpy_arrays", "tests/test_grid.py::test_init_bad_input", "tests/test_grid.py::test_init_from_arrays[False]", "tests/test_grid.py::test_init_from_arrays[True]", "tests/test_grid.py::test_init_from_dict[False-False]", "tests/test_grid.py::test_init_from_dict[False-True]", "tests/test_grid.py::test_init_from_dict[True-False]", "tests/test_grid.py::test_init_from_dict[True-True]", "tests/test_grid.py::test_init_polyhedron", "tests/test_grid.py::test_cells_dict_hexbeam_file", "tests/test_grid.py::test_cells_dict_variable_length", "tests/test_grid.py::test_cells_dict_empty_grid", "tests/test_grid.py::test_cells_dict_alternating_cells", "tests/test_grid.py::test_destructor", "tests/test_grid.py::test_surface_indices", "tests/test_grid.py::test_extract_feature_edges", "tests/test_grid.py::test_triangulate_inplace", "tests/test_grid.py::test_save[.vtu-True]", "tests/test_grid.py::test_save[.vtu-False]", "tests/test_grid.py::test_save[.vtk-True]", "tests/test_grid.py::test_save[.vtk-False]", "tests/test_grid.py::test_pathlib_read_write", "tests/test_grid.py::test_init_bad_filename", "tests/test_grid.py::test_save_bad_extension", "tests/test_grid.py::test_linear_copy", "tests/test_grid.py::test_linear_copy_surf_elem", "tests/test_grid.py::test_extract_cells[True]", "tests/test_grid.py::test_extract_cells[False]", "tests/test_grid.py::test_merge", "tests/test_grid.py::test_merge_not_main", "tests/test_grid.py::test_merge_list", "tests/test_grid.py::test_merge_invalid", "tests/test_grid.py::test_init_structured_raise", "tests/test_grid.py::test_init_structured", "tests/test_grid.py::test_no_copy_polydata_init", "tests/test_grid.py::test_no_copy_polydata_points_setter", "tests/test_grid.py::test_no_copy_structured_mesh_init", "tests/test_grid.py::test_no_copy_structured_mesh_points_setter", "tests/test_grid.py::test_no_copy_pointset_init", "tests/test_grid.py::test_no_copy_pointset_points_setter", "tests/test_grid.py::test_no_copy_unstructured_grid_points_setter", "tests/test_grid.py::test_no_copy_rectilinear_grid", "tests/test_grid.py::test_grid_repr", "tests/test_grid.py::test_slice_structured", "tests/test_grid.py::test_invalid_init_structured", "tests/test_grid.py::test_save_structured[.vtk-True]", "tests/test_grid.py::test_save_structured[.vtk-False]", "tests/test_grid.py::test_save_structured[.vts-True]", "tests/test_grid.py::test_save_structured[.vts-False]", "tests/test_grid.py::test_load_structured_bad_filename", "tests/test_grid.py::test_instantiate_by_filename", "tests/test_grid.py::test_create_rectilinear_after_init", "tests/test_grid.py::test_create_rectilinear_grid_from_file", "tests/test_grid.py::test_read_rectilinear_grid_from_file", "tests/test_grid.py::test_read_rectilinear_grid_from_pathlib", "tests/test_grid.py::test_raise_rectilinear_grid_non_unique", "tests/test_grid.py::test_cast_rectilinear_grid", "tests/test_grid.py::test_create_uniform_grid_from_specs", "tests/test_grid.py::test_uniform_grid_invald_args", "tests/test_grid.py::test_uniform_setters", "tests/test_grid.py::test_create_uniform_grid_from_file", "tests/test_grid.py::test_read_uniform_grid_from_file", "tests/test_grid.py::test_read_uniform_grid_from_pathlib", "tests/test_grid.py::test_cast_uniform_to_structured", "tests/test_grid.py::test_cast_uniform_to_rectilinear", "tests/test_grid.py::test_uniform_grid_to_tetrahedra", "tests/test_grid.py::test_fft_and_rfft", "tests/test_grid.py::test_fft_low_pass", "tests/test_grid.py::test_fft_high_pass", "tests/test_grid.py::test_save_rectilinear[.vtk-True]", "tests/test_grid.py::test_save_rectilinear[.vtk-False]", "tests/test_grid.py::test_save_rectilinear[.vtr-True]", "tests/test_grid.py::test_save_rectilinear[.vtr-False]", "tests/test_grid.py::test_save_uniform[.vtk-True]", "tests/test_grid.py::test_save_uniform[.vtk-False]", "tests/test_grid.py::test_save_uniform[.vti-True]", "tests/test_grid.py::test_save_uniform[.vti-False]", "tests/test_grid.py::test_grid_points", "tests/test_grid.py::test_grid_extract_selection_points", "tests/test_grid.py::test_gaussian_smooth", "tests/test_grid.py::test_remove_cells[ind0]", "tests/test_grid.py::test_remove_cells[ind1]", "tests/test_grid.py::test_remove_cells[ind2]", "tests/test_grid.py::test_remove_cells_not_inplace[ind0]", "tests/test_grid.py::test_remove_cells_not_inplace[ind1]", "tests/test_grid.py::test_remove_cells_not_inplace[ind2]", "tests/test_grid.py::test_remove_cells_invalid", "tests/test_grid.py::test_hide_cells[ind0]", "tests/test_grid.py::test_hide_cells[ind1]", "tests/test_grid.py::test_hide_cells[ind2]", "tests/test_grid.py::test_hide_points[ind0]", "tests/test_grid.py::test_hide_points[ind1]", "tests/test_grid.py::test_hide_points[ind2]", "tests/test_grid.py::test_set_extent", "tests/test_grid.py::test_UnstructuredGrid_cast_to_explicit_structured_grid", "tests/test_grid.py::test_ExplicitStructuredGrid_init", "tests/test_grid.py::test_ExplicitStructuredGrid_cast_to_unstructured_grid", "tests/test_grid.py::test_ExplicitStructuredGrid_save", "tests/test_grid.py::test_ExplicitStructuredGrid_hide_cells", "tests/test_grid.py::test_ExplicitStructuredGrid_show_cells", "tests/test_grid.py::test_ExplicitStructuredGrid_dimensions", "tests/test_grid.py::test_ExplicitStructuredGrid_visible_bounds", "tests/test_grid.py::test_ExplicitStructuredGrid_cell_id", "tests/test_grid.py::test_ExplicitStructuredGrid_cell_coords", "tests/test_grid.py::test_ExplicitStructuredGrid_neighbors", "tests/test_grid.py::test_ExplicitStructuredGrid_compute_connectivity", "tests/test_grid.py::test_ExplicitStructuredGrid_compute_connections", "tests/test_grid.py::test_ExplicitStructuredGrid_raise_init", "tests/test_grid.py::test_copy_no_copy_wrap_object", "tests/test_grid.py::test_copy_no_copy_wrap_object_vtk9"], "environment_setup_commit": "4c2d1aed10b1600d520271beba8579c71433e808"}, {"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"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-1033", "base_commit": "701c1062bf66de2b29df68fa5540be6009943885", "patch": "diff --git a/pydicom/dataelem.py b/pydicom/dataelem.py\n--- a/pydicom/dataelem.py\n+++ b/pydicom/dataelem.py\n@@ -315,32 +315,21 @@ def to_json_dict(self, bulk_data_element_handler, bulk_data_threshold):\n             via DICOMweb WADO-RS\n         bulk_data_threshold: int\n             Size of base64 encoded data element above which a value will be\n-            provided in form of a \"BulkDataURI\" rather than \"InlineBinary\"\n+            provided in form of a \"BulkDataURI\" rather than \"InlineBinary\".\n+            Ignored if no bulk data handler is given.\n \n         Returns\n         -------\n         dict\n             Mapping representing a JSON encoded data element\n-\n-        Raises\n-        ------\n-        TypeError\n-            When size of encoded data element exceeds `bulk_data_threshold`\n-            but `bulk_data_element_handler` is ``None`` and hence not callable\n-\n         \"\"\"\n         json_element = {'vr': self.VR, }\n         if self.VR in jsonrep.BINARY_VR_VALUES:\n             if not self.is_empty:\n                 binary_value = self.value\n                 encoded_value = base64.b64encode(binary_value).decode('utf-8')\n-                if len(encoded_value) > bulk_data_threshold:\n-                    if bulk_data_element_handler is None:\n-                        raise TypeError(\n-                            'No bulk data element handler provided to '\n-                            'generate URL for value of data element \"{}\".'\n-                            .format(self.name)\n-                        )\n+                if (bulk_data_element_handler is not None and\n+                        len(encoded_value) > bulk_data_threshold):\n                     json_element['BulkDataURI'] = bulk_data_element_handler(\n                         self\n                     )\n@@ -398,7 +387,7 @@ def to_json_dict(self, bulk_data_element_handler, bulk_data_threshold):\n             )\n         return json_element\n \n-    def to_json(self, bulk_data_threshold=1, bulk_data_element_handler=None,\n+    def to_json(self, bulk_data_threshold=1024, bulk_data_element_handler=None,\n                 dump_handler=None):\n         \"\"\"Return a JSON representation of the :class:`DataElement`.\n \n@@ -412,7 +401,8 @@ def to_json(self, bulk_data_threshold=1, bulk_data_element_handler=None,\n             via DICOMweb WADO-RS\n         bulk_data_threshold: int\n             Size of base64 encoded data element above which a value will be\n-            provided in form of a \"BulkDataURI\" rather than \"InlineBinary\"\n+            provided in form of a \"BulkDataURI\" rather than \"InlineBinary\".\n+            Ignored if no bulk data handler is given.\n         dump_handler : callable, optional\n             Callable function that accepts a :class:`dict` and returns the\n             serialized (dumped) JSON string (by default uses\n@@ -423,12 +413,6 @@ def to_json(self, bulk_data_threshold=1, bulk_data_element_handler=None,\n         dict\n             Mapping representing a JSON encoded data element\n \n-        Raises\n-        ------\n-        TypeError\n-            When size of encoded data element exceeds `bulk_data_threshold`\n-            but `bulk_data_element_handler` is ``None`` and hence not callable\n-\n         See also\n         --------\n         Dataset.to_json\ndiff --git a/pydicom/dataset.py b/pydicom/dataset.py\n--- a/pydicom/dataset.py\n+++ b/pydicom/dataset.py\n@@ -2126,11 +2126,11 @@ def from_json(cls, json_dataset, bulk_data_uri_handler=None):\n             dataset.add(data_element)\n         return dataset\n \n-    def to_json_dict(self, bulk_data_threshold=1,\n+    def to_json_dict(self, bulk_data_threshold=1024,\n                      bulk_data_element_handler=None):\n         \"\"\"Return a dictionary representation of the :class:`Dataset`\n         conforming to the DICOM JSON Model as described in the DICOM\n-        Standard, Part 18, :dcm:`Annex F<part18/chaptr_F.html>`.\n+        Standard, Part 18, :dcm:`Annex F<part18/chapter_F.html>`.\n \n         .. versionadded:: 1.4\n \n@@ -2140,7 +2140,7 @@ def to_json_dict(self, bulk_data_threshold=1,\n             Threshold for the length of a base64-encoded binary data element\n             above which the element should be considered bulk data and the\n             value provided as a URI rather than included inline (default:\n-            ``1``).\n+            ``1024``). Ignored if no bulk data handler is given.\n         bulk_data_element_handler : callable, optional\n             Callable function that accepts a bulk data element and returns a\n             JSON representation of the data element (dictionary including the\n@@ -2161,7 +2161,7 @@ def to_json_dict(self, bulk_data_threshold=1,\n             )\n         return json_dataset\n \n-    def to_json(self, bulk_data_threshold=1, bulk_data_element_handler=None,\n+    def to_json(self, bulk_data_threshold=1024, bulk_data_element_handler=None,\n                 dump_handler=None):\n         \"\"\"Return a JSON representation of the :class:`Dataset`.\n \n@@ -2175,7 +2175,7 @@ def to_json(self, bulk_data_threshold=1, bulk_data_element_handler=None,\n             Threshold for the length of a base64-encoded binary data element\n             above which the element should be considered bulk data and the\n             value provided as a URI rather than included inline (default:\n-            ``1``).\n+            ``1024``). Ignored if no bulk data handler is given.\n         bulk_data_element_handler : callable, optional\n             Callable function that accepts a bulk data element and returns a\n             JSON representation of the data element (dictionary including the\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@@ -1,12 +1,11 @@\n # -*- coding: utf-8 -*-\n # Copyright 2008-2019 pydicom authors. See LICENSE file for details.\n import json\n-import sys\n \n import pytest\n \n from pydicom import dcmread, compat\n-from pydicom.data import get_testdata_files\n+from pydicom.data import get_testdata_file\n from pydicom.dataelem import DataElement\n from pydicom.dataset import Dataset\n from pydicom.tag import Tag, BaseTag\n@@ -15,7 +14,7 @@\n \n class TestPersonName(object):\n     def test_json_pn_from_file(self):\n-        with open(get_testdata_files(\"test_PN.json\")[0]) as s:\n+        with open(get_testdata_file(\"test_PN.json\")) as s:\n             ds = Dataset.from_json(s.read())\n         assert isinstance(ds[0x00080090].value,\n                           (PersonNameUnicode, PersonName3))\n@@ -144,7 +143,7 @@ def test_from_json(self):\n         assert 0x000910AF == ds[0x00091001].value\n         assert [0x00100010, 0x00100020, 0x00100030] == ds[0x00091002].value\n \n-    def test_invalid_json(self):\n+    def test_invalid_value_in_json(self):\n         ds_json = ('{\"00091001\": {\"vr\": \"AT\", \"Value\": [\"000910AG\"]}, '\n                    '\"00091002\": {\"vr\": \"AT\", \"Value\": [\"00100010\"]}}')\n         with pytest.warns(UserWarning, match='Invalid value \"000910AG\" for '\n@@ -153,15 +152,24 @@ def test_invalid_json(self):\n             assert ds[0x00091001].value is None\n             assert 0x00100010 == ds[0x00091002].value\n \n+    def test_invalid_tag_in_json(self):\n+        ds_json = ('{\"000910AG\": {\"vr\": \"AT\", \"Value\": [\"00091000\"]}, '\n+                   '\"00091002\": {\"vr\": \"AT\", \"Value\": [\"00100010\"]}}')\n+        with pytest.raises(ValueError, match='Data element \"000910AG\" could '\n+                                             'not be loaded from JSON:'):\n+            ds = Dataset.from_json(ds_json)\n+            assert ds[0x00091001].value is None\n+            assert 0x00100010 == ds[0x00091002].value\n+\n \n class TestDataSetToJson(object):\n     def test_json_from_dicom_file(self):\n-        ds1 = Dataset(dcmread(get_testdata_files(\"CT_small.dcm\")[0]))\n-        ds_json = ds1.to_json(bulk_data_threshold=100000)\n+        ds1 = Dataset(dcmread(get_testdata_file(\"CT_small.dcm\")))\n+        ds_json = ds1.to_json()\n         ds2 = Dataset.from_json(ds_json)\n         assert ds1 == ds2\n \n-        ds_json = ds1.to_json_dict(bulk_data_threshold=100000)\n+        ds_json = ds1.to_json_dict()\n         ds2 = Dataset.from_json(ds_json)\n         assert ds1 == ds2\n \n@@ -205,7 +213,7 @@ def test_roundtrip(self):\n         ds.add_new(0x00091101, 'SH', 'Version2')\n         ds.add_new(0x00091102, 'US', 2)\n \n-        json_string = ds.to_json(bulk_data_threshold=100)\n+        json_string = ds.to_json()\n         json_model = json.loads(json_string)\n \n         assert json_model['00080005']['Value'] == ['ISO_IR 100']\n@@ -223,7 +231,7 @@ def test_roundtrip(self):\n         ds2 = Dataset.from_json(json_model)\n         assert ds == ds2\n \n-        json_model2 = ds.to_json_dict(bulk_data_threshold=100)\n+        json_model2 = ds.to_json_dict()\n         if compat.in_py2:\n             # in Python 2, the encoding of this is slightly different\n             # (single vs double quotation marks)\n@@ -274,7 +282,7 @@ def test_sort_order(self):\n \n class TestSequence(object):\n     def test_nested_sequences(self):\n-        test1_json = get_testdata_files(\"test1.json\")[0]\n+        test1_json = get_testdata_file(\"test1.json\")\n         with open(test1_json) as f:\n             with pytest.warns(UserWarning,\n                               match='no bulk data URI handler provided '):\n@@ -288,7 +296,7 @@ class TestBinary(object):\n     def test_inline_binary(self):\n         ds = Dataset()\n         ds.add_new(0x00091002, 'OB', b'BinaryContent')\n-        ds_json = ds.to_json_dict(bulk_data_threshold=20)\n+        ds_json = ds.to_json_dict()\n         assert \"00091002\" in ds_json\n         assert \"QmluYXJ5Q29udGVudA==\" == ds_json[\"00091002\"][\"InlineBinary\"]\n         ds1 = Dataset.from_json(ds_json)\n", "problem_statement": "to_json does not work with binary data in pixel_array\n**Describe the issue**\r\nLoading a dicom file and then performing a to_json() on it does not work with binary data in pixel_array.\r\n\r\n\r\n\r\n**Expected behavior**\r\nI would have expected that a base64 conversion is first performed on the binary data and then encoded to json. \r\n\r\n**Steps To Reproduce**\r\nHow to reproduce the issue. Please include:\r\n1. A minimum working code sample\r\n\r\nimport pydicom\r\nds = pydicom.dcmread('path_to_file')\r\noutput = ds.to_json()\r\n\r\n\r\n2. The traceback (if one occurred)\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/.virtualenvs/my_env/lib/python3.7/site-packages/pydicom/dataset.py\", line 2003, in to_json\r\n    dump_handler=dump_handler\r\n  File \"/.virtualenvs/my_env/lib/python3.7/site-packages/pydicom/dataset.py\", line 1889, in _data_element_to_json\r\n    binary_value = data_element.value.encode('utf-8')\r\nAttributeError: 'bytes' object has no attribute 'encode'\r\n\r\n\r\n3. Which of the following packages are available and their versions:\r\n  * Numpy\r\nnumpy==1.17.2\r\n  * Pillow\r\nPillow==6.1.0\r\n  * JPEG-LS\r\n  * GDCM\r\n4. The anonymized DICOM dataset (if possible).\r\n\r\n**Your environment**\r\nPlease run the following and paste the output.\r\n```bash\r\n$ python -c \"import platform; print(platform.platform())\"\r\nDarwin-19.2.0-x86_64-i386-64bit\r\n$ python -c \"import sys; print('Python ', sys.version)\"\r\nPython  3.7.6 (default, Dec 30 2019, 19:38:26) \r\n[Clang 11.0.0 (clang-1100.0.33.16)]\r\n$ python -c \"import pydicom; print('pydicom ', pydicom.__version__)\"\r\npydicom  1.3.0\r\n```\r\n\n", "hints_text": "Can you please check with pydicom 1.4? Binary data handling should have been fixed there. \nok works now once I set the bulk_data_threshold value to a higher value. \r\n\r\nThank you!\nOk, that may be an issue with the data size. Currently, the default for `bulk_data_threshold` is 1, if I remember correctly, which may not be the best value - meaning that all binary data larger than that expect a bulk data element handler. Setting the threshold to a large value shall fix this, if the data is encoded directly.\nAh, you already found that, ok!\r\n\nyep. thanks, works now. \n@darcymason - json support is still flagged as alpha - I think we can consider it at least beta now, and add a small section in the documentation.\r\nWe may also rethink the `bulk_data_threshold` parameter - maybe just ignore it if no bulk data handler is set, and set the default value to some sensible value (1kB or something).\n> @darcymason - json support is still flagged as alpha - I think we can consider it at least beta now, and add a small section in the documentation.\r\n> We may also rethink the `bulk_data_threshold` parameter - maybe just ignore it if no bulk data handler is set, and set the default value to some sensible value (1kB or something).\r\n\r\nI agree that updating the documentation is a good idea for this. As its pretty common to have binary image data in dicom files, and its guaranteed to fail with the default value for bulk_data_threshold\r\n\r\nThanks once again though!\nPing @pieper, @hackermd for comment about `bulk_data_threshold`.\n> We may also rethink the bulk_data_threshold parameter - maybe just ignore it if no bulk data handler is set, and set the default value to some sensible value (1kB or something).\r\n\r\n1k threshold makes sense to me.  \ud83d\udc4d ", "created_at": "2020-01-17T20:57:00Z", "version": "1.4", "FAIL_TO_PASS": ["pydicom/tests/test_json.py::TestDataSetToJson::test_json_from_dicom_file", "pydicom/tests/test_json.py::TestDataSetToJson::test_roundtrip", "pydicom/tests/test_json.py::TestBinary::test_inline_binary"], "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_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_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"], "environment_setup_commit": "5098c9147fadcb3e5918487036867931435adeb8"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-816", "base_commit": "3551f5b5a5f8d4de3ed92e5e479ac8c74a8c893a", "patch": "diff --git a/pydicom/charset.py b/pydicom/charset.py\n--- a/pydicom/charset.py\n+++ b/pydicom/charset.py\n@@ -125,15 +125,24 @@ def decode_string(value, encodings, delimiters):\n     \"\"\"\n     # shortcut for the common case - no escape sequences present\n     if ESC not in value:\n+        first_encoding = encodings[0]\n         try:\n-            return value.decode(encodings[0])\n+            return value.decode(first_encoding)\n+        except LookupError:\n+            if config.enforce_valid_values:\n+                raise\n+            warnings.warn(u\"Unknown encoding '{}' - \"\n+                          u\"using default encoding instead\"\n+                          .format(first_encoding))\n+            first_encoding = default_encoding\n+            return value.decode(first_encoding)\n         except UnicodeError:\n             if config.enforce_valid_values:\n                 raise\n-            warnings.warn(u\"Failed to decode byte string with encoding {} - \"\n+            warnings.warn(u\"Failed to decode byte string with encoding '{}' - \"\n                           u\"using replacement characters in decoded \"\n-                          u\"string\".format(encodings[0]))\n-            return value.decode(encodings[0], errors='replace')\n+                          u\"string\".format(first_encoding))\n+            return value.decode(first_encoding, errors='replace')\n \n     # Each part of the value that starts with an escape sequence is decoded\n     # separately. If it starts with an escape sequence, the\n", "test_patch": "diff --git a/pydicom/tests/test_charset.py b/pydicom/tests/test_charset.py\n--- a/pydicom/tests/test_charset.py\n+++ b/pydicom/tests/test_charset.py\n@@ -100,6 +100,26 @@ def test_standard_file(self):\n         ds.decode()\n         assert u'CompressedSamples^CT1' == ds.PatientName\n \n+    def test_invalid_character_set(self):\n+        \"\"\"charset: replace invalid encoding with default encoding\"\"\"\n+        ds = dcmread(get_testdata_files(\"CT_small.dcm\")[0])\n+        ds.read_encoding = None\n+        ds.SpecificCharacterSet = 'Unsupported'\n+        with pytest.warns(UserWarning,\n+                          match=u\"Unknown encoding 'Unsupported' \"\n+                                u\"- using default encoding instead\"):\n+            ds.decode()\n+            assert u'CompressedSamples^CT1' == ds.PatientName\n+\n+    def test_invalid_character_set_enforce_valid(self):\n+        \"\"\"charset: raise on invalid encoding\"\"\"\n+        config.enforce_valid_values = True\n+        ds = dcmread(get_testdata_files(\"CT_small.dcm\")[0])\n+        ds.read_encoding = None\n+        ds.SpecificCharacterSet = 'Unsupported'\n+        with pytest.raises(LookupError, match='unknown encoding: Unsupported'):\n+            ds.decode()\n+\n     def test_decoding_with_specific_tags(self):\n         \"\"\"Decoding is correctly applied even if  Specific Character Set\n         is not in specific tags...\"\"\"\n@@ -126,8 +146,8 @@ def test_bad_encoded_single_encoding(self):\n         elem = DataElement(0x00100010, 'PN',\n                            b'\\xc4\\xe9\\xef\\xed\\xf5\\xf3\\xe9\\xef\\xf2')\n \n-        with pytest.warns(UserWarning, match='Failed to decode byte string '\n-                                             'with encoding UTF8'):\n+        with pytest.warns(UserWarning, match=\"Failed to decode byte string \"\n+                                             \"with encoding 'UTF8'\"):\n             pydicom.charset.decode(elem, ['ISO_IR 192'])\n             assert u'\ufffd\ufffd\ufffd\ufffd\ufffd\ufffd\ufffd\ufffd\ufffd' == elem.value\n \n@@ -235,9 +255,11 @@ def test_patched_charset(self):\n             # make sure no warning is issued for the correct value\n             assert 1 == len(w)\n \n-        # not patched incorrect encoding raises\n+        # not patched incorrect encoding is replaced by default encoding\n         elem = DataElement(0x00100010, 'PN', b'Buc^J\\xc3\\xa9r\\xc3\\xb4me')\n-        with pytest.raises(LookupError):\n+        with pytest.warns(UserWarning,\n+                          match=u\"Unknown encoding 'ISOIR 192' - \"\n+                                u\"using default encoding instead\"):\n             pydicom.charset.decode(elem, ['ISOIR 192'])\n \n         # Python encoding also can be used directly\n", "problem_statement": "LookupError: unknown encoding: Not Supplied\n#### Description\r\nOutput from `ds = pydicom.read_file(dcmFile)` (an RTSTRUCT dicom file, SOP UID 1.2.840.10008.5.1.4.1.1.481.3) results in some tags throwing a LookupError: \"LookupError: unknown encoding: Not Supplied\"\r\nSpecific tags which cannot be decoded are as follows:\r\n['DeviceSerialNumber',\r\n 'Manufacturer',\r\n 'ManufacturerModelName',\r\n 'PatientID',\r\n 'PatientName',\r\n 'RTROIObservationsSequence',\r\n 'ReferringPhysicianName',\r\n 'SeriesDescription',\r\n 'SoftwareVersions',\r\n 'StructureSetLabel',\r\n 'StructureSetName',\r\n 'StructureSetROISequence',\r\n 'StudyDescription',\r\n 'StudyID']\r\n\r\nI suspect that it's due to the fact that `ds.SpecificCharacterSet = 'Not Supplied'`, but when I try to set `ds.SpecificCharacterSet` to something reasonable (ie ISO_IR_100 or 'iso8859'), it doesn't seem to make any difference.\r\n\r\nReading the same file, with NO modifications, in gdcm does not result in any errors and all fields are readable.\r\n\r\n#### Steps/Code to Reproduce\r\n```py\r\nimport pydicom \r\nds = pydicom.read_file(dcmFile)\r\nprint(ds.PatientName)\r\n```\r\n\r\n#### Expected Results\r\nNo error is thrown and the name of the patient is printed.\r\n\r\n#### Actual Results\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"C:\\Users\\Amanda\\AppData\\Local\\Continuum\\anaconda3\\envs\\itk\\lib\\site-packages\\pydicom\\valuerep.py\", line 706, in __str__\r\n    return '='.join(self.components).__str__()\r\n  File \"C:\\Users\\Amanda\\AppData\\Local\\Continuum\\anaconda3\\envs\\itk\\lib\\site-packages\\pydicom\\valuerep.py\", line 641, in components\r\n    self._components = _decode_personname(groups, self.encodings)\r\n  File \"C:\\Users\\Amanda\\AppData\\Local\\Continuum\\anaconda3\\envs\\itk\\lib\\site-packages\\pydicom\\valuerep.py\", line 564, in _decode_personname\r\n    for comp in components]\r\n  File \"C:\\Users\\Amanda\\AppData\\Local\\Continuum\\anaconda3\\envs\\itk\\lib\\site-packages\\pydicom\\valuerep.py\", line 564, in <listcomp>\r\n    for comp in components]\r\n  File \"C:\\Users\\Amanda\\AppData\\Local\\Continuum\\anaconda3\\envs\\itk\\lib\\site-packages\\pydicom\\charset.py\", line 129, in decode_string\r\n    return value.decode(encodings[0])\r\nLookupError: unknown encoding: Not Supplied\r\n\r\n#### Versions\r\nPlatform: Windows-10-10.0.17763-SP0\r\nPython Version: Python 3.6.4 |Anaconda, Inc.| (default, Mar 12 2018, 20:20:50) [MSC v.1900 64 bit (AMD64)]\r\npydicom Version: pydicom 1.2.2\r\n\n", "hints_text": "You said on the pynetdicom issue you can't upload an anonymised file, but can you open the file in a hex editor and post the raw byte output from the first few (non-identifying) elements? From the start of the file to the end of say (0008,0070) should be enough.\r\n\r\nAlternatively you could truncate the file at the end of the (0008,0070) element and upload that.\r\n\r\nIf you need to know how to interpret the encoded data check out [Part 5, Chapter 7](http://dicom.nema.org/medical/dicom/current/output/chtml/part05/chapter_7.html) of the DICOM Standard. And if the file's been saved in the [DICOM File Format](http://dicom.nema.org/medical/dicom/current/output/chtml/part10/chapter_7.html) there may also be a 128 byte header  following by 'DICM' before the start of the dataset (which we don't need).\n> open the file in a hex editor and post the raw byte output from the first few (non-identifying) elements\r\n\r\nAlternatively:\r\n```\r\nimport pydicom.config\r\npydicom.config.debug(True)\r\nds = dcmread(youfilename)\r\n```\r\nAnd as suggested copy the first non-identifying part of the debug output for posting.\nPlease find the truncated dataset attached as requested. I wasn't allowed to upload a *.dcm file so just wrote it as a *.txt file. The file is readable by pydicom but exhibits the same aforementioned problems, where the \"LookupError: unknown encoding: Not Supplied\" happens only for the Manufacturer tag.\r\n\r\n[truncated.txt](https://github.com/pydicom/pydicom/files/2947883/truncated.txt)\r\n\nOkay, so I've tried deleting SpecificCharacterSet and the error still occurs.  I think pydicom is still holding on to the original values, and needs some code to handle the case when SpecificCharacterSet is deleted or set again after reading the file. We can dig into it a little further.\r\n\r\n\nWorkaround:\r\n```python\r\nfrom pydicom import dcmread\r\n\r\nds = dcmread('path/to/file')\r\ndel ds.SpecificCharacterSet\r\nds.read_encoding = []\r\n```\r\n\nBrilliant!  That worked! \r\n\r\nThank you for the quick fix! I've found pydicom is a lot more user-friendly than gdcm so I'm really glad I don't have to resort to that. \ud83d\ude00 \nNo problem, @mrbean-bremen do you want to handle the underlying issue?\nCertainly - as I may have introduced it... Not sure if I'll find the time today though. ", "created_at": "2019-03-10T15:41:44Z", "version": "1.2", "FAIL_TO_PASS": ["pydicom/tests/test_charset.py::TestCharset::test_invalid_character_set", "pydicom/tests/test_charset.py::TestCharset::test_bad_encoded_single_encoding", "pydicom/tests/test_charset.py::TestCharset::test_patched_charset"], "PASS_TO_PASS": ["pydicom/tests/test_charset.py::TestCharset::test_encodings", "pydicom/tests/test_charset.py::TestCharset::test_nested_character_sets", "pydicom/tests/test_charset.py::TestCharset::test_inherited_character_set_in_sequence", "pydicom/tests/test_charset.py::TestCharset::test_standard_file", "pydicom/tests/test_charset.py::TestCharset::test_invalid_character_set_enforce_valid", "pydicom/tests/test_charset.py::TestCharset::test_decoding_with_specific_tags", "pydicom/tests/test_charset.py::TestCharset::test_bad_charset", "pydicom/tests/test_charset.py::TestCharset::test_bad_encoded_single_encoding_enforce_standard", "pydicom/tests/test_charset.py::TestCharset::test_code_extensions_not_allowed", "pydicom/tests/test_charset.py::TestCharset::test_convert_encodings_warnings", "pydicom/tests/test_charset.py::TestCharset::test_convert_python_encodings", "pydicom/tests/test_charset.py::TestCharset::test_bad_decoded_multi_byte_encoding", "pydicom/tests/test_charset.py::TestCharset::test_bad_decoded_multi_byte_encoding_enforce_standard", "pydicom/tests/test_charset.py::TestCharset::test_unknown_escape_sequence", "pydicom/tests/test_charset.py::TestCharset::test_unknown_escape_sequence_enforce_standard", "pydicom/tests/test_charset.py::TestCharset::test_patched_code_extension_charset", "pydicom/tests/test_charset.py::TestCharset::test_multi_charset_default_value", "pydicom/tests/test_charset.py::TestCharset::test_single_byte_multi_charset_personname", "pydicom/tests/test_charset.py::TestCharset::test_single_byte_multi_charset_text", "pydicom/tests/test_charset.py::TestCharset::test_single_byte_code_extensions[ISO", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrArab-\\u0642\\u0628\\u0627\\u0646\\u064a^\\u0644\\u0646\\u0632\\u0627\\u0631]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrFren-Buc^J\\xe9r\\xf4me]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrFrenMulti-Buc^J\\xe9r\\xf4me]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrGerm-\\xc4neas^R\\xfcdiger]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrGreek-\\u0394\\u03b9\\u03bf\\u03bd\\u03c5\\u03c3\\u03b9\\u03bf\\u03c2]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrH31-Yamada^Tarou=\\u5c71\\u7530^\\u592a\\u90ce=\\u3084\\u307e\\u3060^\\u305f\\u308d\\u3046]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrH32-\\uff94\\uff8f\\uff80\\uff9e^\\uff80\\uff9b\\uff73=\\u5c71\\u7530^\\u592a\\u90ce=\\u3084\\u307e\\u3060^\\u305f\\u308d\\u3046]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrHbrw-\\u05e9\\u05e8\\u05d5\\u05df^\\u05d3\\u05d1\\u05d5\\u05e8\\u05d4]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrI2-Hong^Gildong=\\u6d2a^\\u5409\\u6d1e=\\ud64d^\\uae38\\ub3d9]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrJapMulti-\\u3084\\u307e\\u3060^\\u305f\\u308d\\u3046]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrJapMultiExplicitIR6-\\u3084\\u307e\\u3060^\\u305f\\u308d\\u3046]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrKoreanMulti-\\uae40\\ud76c\\uc911]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrRuss-\\u041b\\u044e\\u043ace\\u043c\\u0431yp\\u0433]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrX1-Wang^XiaoDong=\\u738b^\\u5c0f\\u6771]", "pydicom/tests/test_charset.py::TestCharset::test_charset_patient_names[chrX2-Wang^XiaoDong=\\u738b^\\u5c0f\\u4e1c]", "pydicom/tests/test_charset.py::TestCharset::test_changed_character_set"], "environment_setup_commit": "b4b44acbf1ddcaf03df16210aac46cb3a8acd6b9"}, {"repo": "pydicom/pydicom", "instance_id": "pydicom__pydicom-1598", "base_commit": "e9fc645cd8e75d71f7835c0d6e3c0b94b22c2808", "patch": "diff --git a/pydicom/dataset.py b/pydicom/dataset.py\n--- a/pydicom/dataset.py\n+++ b/pydicom/dataset.py\n@@ -393,6 +393,9 @@ def __init__(self, *args: _DatasetType, **kwargs: Any) -> None:\n         self.is_little_endian: Optional[bool] = None\n         self.is_implicit_VR: Optional[bool] = None\n \n+        # True if the dataset is a sequence item with undefined length\n+        self.is_undefined_length_sequence_item = False\n+\n         # the parent data set, if this dataset is a sequence item\n         self.parent: \"Optional[weakref.ReferenceType[Dataset]]\" = None\n \ndiff --git a/pydicom/fileset.py b/pydicom/fileset.py\n--- a/pydicom/fileset.py\n+++ b/pydicom/fileset.py\n@@ -1717,6 +1717,7 @@ def load(\n                     f\"{cast(Path, self.path) / file_id}\"\n                 )\n                 continue\n+\n             # If the instance's existing directory structure doesn't match\n             #   the pydicom semantics then stage for movement\n             if instance.for_moving:\n@@ -2255,6 +2256,10 @@ def _write_dicomdir(\n             offset += 8  # a sequence item's (tag + length)\n             # Copy safe - only modifies RecordNode._offset\n             offset += node._encode_record(force_implicit)\n+            # If the sequence item has undefined length then it uses a\n+            #   sequence item delimiter item\n+            if node._record.is_undefined_length_sequence_item:\n+                offset += 8\n \n         # Step 2: Update the records and add to *Directory Record Sequence*\n         ds.DirectoryRecordSequence = []\n", "test_patch": "diff --git a/pydicom/tests/test_fileset.py b/pydicom/tests/test_fileset.py\n--- a/pydicom/tests/test_fileset.py\n+++ b/pydicom/tests/test_fileset.py\n@@ -2450,6 +2450,21 @@ def test_add_bad_one_level(self, dummy):\n         with pytest.raises(ValueError, match=msg):\n             fs.add(ds)\n \n+    def test_write_undefined_length(self, dicomdir_copy):\n+        \"\"\"Test writing with undefined length items\"\"\"\n+        t, ds = dicomdir_copy\n+        elem = ds[\"DirectoryRecordSequence\"]\n+        ds[\"DirectoryRecordSequence\"].is_undefined_length = True\n+        for item in ds.DirectoryRecordSequence:\n+            item.is_undefined_length_sequence_item = True\n+\n+        fs = FileSet(ds)\n+        fs.write(use_existing=True)\n+\n+        ds = dcmread(Path(t.name) / \"DICOMDIR\")\n+        item = ds.DirectoryRecordSequence[-1]\n+        assert item.ReferencedFileID == ['98892003', 'MR700', '4648']\n+\n \n @pytest.mark.filterwarnings(\"ignore:The 'DicomDir'\")\n class TestFileSet_Copy:\n", "problem_statement": "KeyError when saving a FileSet\n**Describe the bug**\r\nSaving a fileset that was loaded using DICOMDIR returns a Key Error.\r\n\r\n**Expected behavior**\r\nFileset is saved without error\r\n\r\n**Steps To Reproduce**\r\nCode:\r\n```python\r\nfrom pydicom.fileset import FileSet\r\n\r\nfpath=\"DICOMDIR\"\r\ndata=FileSet(fpath)\r\n\r\nprint(data)\r\n\r\ndata.write(use_existing=True)\r\n```\r\n\r\n```\r\nTraceback:\r\nKeyError                                  \r\n\r\nTraceback (most recent call last) \r\n\\<ipython-input-183-effc2d1f6bc9\\> in \\<module\\>\r\n      6 print(data)\r\n      7 \r\n----> 8 data.write(use_existing=True)\r\n\r\n~/anaconda3/lib/python3.7/site-packages/pydicom/fileset.py in write(self, path, use_existing, force_implicit)\r\n   2146                 self._write_dicomdir(f, force_implicit=force_implicit)\r\n   2147 \r\n-> 2148             self.load(p, raise_orphans=True)\r\n   2149 \r\n   2150             return\r\n\r\n~/anaconda3/lib/python3.7/site-packages/pydicom/fileset.py in load(self, ds_or_path, include_orphans, raise_orphans)\r\n   1641             ds = ds_or_path\r\n   1642         else:\r\n-> 1643             ds = dcmread(ds_or_path)\r\n   1644 \r\n   1645         sop_class = ds.file_meta.get(\"MediaStorageSOPClassUID\", None)\r\n\r\n~/anaconda3/lib/python3.7/site-packages/pydicom/filereader.py in dcmread(fp, defer_size, stop_before_pixels, force, specific_tags)\r\n   1032             defer_size=size_in_bytes(defer_size),\r\n   1033             force=force,\r\n-> 1034             specific_tags=specific_tags,\r\n   1035         )\r\n   1036     finally:\r\n\r\n~/anaconda3/lib/python3.7/site-packages/pydicom/filereader.py in read_partial(fileobj, stop_when, defer_size, force, specific_tags)\r\n    885             file_meta_dataset,\r\n    886             is_implicit_VR,\r\n--> 887             is_little_endian,\r\n    888         )\r\n    889     else:\r\n\r\n~/anaconda3/lib/python3.7/site-packages/pydicom/dicomdir.py in __init__(self, filename_or_obj, dataset, preamble, file_meta, is_implicit_VR, is_little_endian)\r\n     94 \r\n     95         self.patient_records: List[Dataset] = []\r\n---> 96         self.parse_records()\r\n     97 \r\n     98     def parse_records(self) -> None:\r\n\r\n~/anaconda3/lib/python3.7/site-packages/pydicom/dicomdir.py in parse_records(self)\r\n    143                 )\r\n    144                 if child_offset:\r\n--> 145                     child = map_offset_to_record[child_offset]\r\n    146                     record.children = get_siblings(child, map_offset_to_record)\r\n    147 \r\n\r\nKeyError: 572\r\n```\r\n\r\n**Your environment**\r\n\r\nmodule       | version\r\n------       | -------\r\nplatform     | Linux-4.15.0-142-generic-x86_64-with-debian-stretch-sid\r\nPython       | 3.7.10 (default, Feb 26 2021, 18:47:35)  [GCC 7.3.0]\r\npydicom      | 2.2.2\r\ngdcm         | _module not found_\r\njpeg_ls      | _module not found_\r\nnumpy        | 1.19.2\r\nPIL          | 8.2.0\r\npylibjpeg    | _module not found_\r\nopenjpeg     | _module not found_\r\nlibjpeg      | _module not found_\r\n\n", "hints_text": "This is going to be difficult to troubleshoot without the original DICOMDIR dataset. Could you create an anonymised version of it using the following and attach it please?\r\n\r\n```python\r\nfrom pydicom import dcmread\r\n\r\nds = dcmread(\"DICOMDIR\")\r\nfor item in ds.DirectoryRecordSequence:\r\n    if item.DirectoryRecordType == \"PATIENT\":\r\n        item.PatientName = \"X\" * len(item.PatientName)\r\n        item.PatientID = \"X\" * len(item.PatientID)\r\n\r\nds.save_as(\"DICOMDIR_anon\", write_like_original=True)\r\n```\r\nIf there are any other identifying elements in the DICOMDIR then just anonymise them using the same method of overwriting with a value of the same length.\nI can't reproduce with:\r\n```python\r\nfrom tempfile import TemporaryDirectory\r\nfrom pathlib import Path\r\nimport shutil\r\n\r\nfrom pydicom.data import get_testdata_file\r\nfrom pydicom.fileset import FileSet\r\n\r\n\r\n# Copy test file set to temporary directory\r\nt = TemporaryDirectory()\r\nsrc = Path(get_testdata_file(\"DICOMDIR\")).parent\r\ndst = Path(t.name)\r\n\r\nshutil.copyfile(src / 'DICOMDIR', dst / 'DICOMDIR')\r\nshutil.copytree(src / \"77654033\", dst / \"77654033\")\r\nshutil.copytree(src / \"98892003\", dst / \"98892003\")\r\nshutil.copytree(src / \"98892001\", dst / \"98892001\")\r\n\r\n# Load\r\nfs = FileSet(dst / \"DICOMDIR\")\r\n# Write without changes\r\nfs.write(use_existing=True)\r\n```\r\nI strongly suspect there's a bad offset being written in your DICOMDIR for some reason, but without seeing the original I can't really do much.", "created_at": "2022-02-11T01:14:16Z", "version": "2.2", "FAIL_TO_PASS": ["pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_undefined_length"], "PASS_TO_PASS": ["pydicom/tests/test_fileset.py::test_is_conformant_file_id", "pydicom/tests/test_fileset.py::test_prefixes", "pydicom/tests/test_fileset.py::TestGenerateFilename::test_numeric", "pydicom/tests/test_fileset.py::TestGenerateFilename::test_numeric_prefix", "pydicom/tests/test_fileset.py::TestGenerateFilename::test_numeric_start", "pydicom/tests/test_fileset.py::TestGenerateFilename::test_alphanumeric", "pydicom/tests/test_fileset.py::TestGenerateFilename::test_alphanumeric_prefix", "pydicom/tests/test_fileset.py::TestGenerateFilename::test_alphanumeric_start", "pydicom/tests/test_fileset.py::TestGenerateFilename::test_long_prefix_raises", "pydicom/tests/test_fileset.py::TestRecordNode::test_root", "pydicom/tests/test_fileset.py::TestRecordNode::test_leaf", "pydicom/tests/test_fileset.py::TestRecordNode::test_add", "pydicom/tests/test_fileset.py::TestRecordNode::test_key", "pydicom/tests/test_fileset.py::TestRecordNode::test_key_raises", "pydicom/tests/test_fileset.py::TestRecordNode::test_bad_record", "pydicom/tests/test_fileset.py::TestRecordNode::test_bad_record_missing_req", "pydicom/tests/test_fileset.py::TestRecordNode::test_encoding", "pydicom/tests/test_fileset.py::TestRecordNode::test_remove_raises", "pydicom/tests/test_fileset.py::TestRecordNode::test_file_id_singleton", "pydicom/tests/test_fileset.py::TestRecordNode::test_file_id_missing", "pydicom/tests/test_fileset.py::TestFileInstance::test_getattr", "pydicom/tests/test_fileset.py::TestFileInstance::test_getattr_order", "pydicom/tests/test_fileset.py::TestFileInstance::test_getitem", "pydicom/tests/test_fileset.py::TestFileInstance::test_getitem_special", "pydicom/tests/test_fileset.py::TestFileInstance::test_getitem_order", "pydicom/tests/test_fileset.py::TestFileInstance::test_contains", "pydicom/tests/test_fileset.py::TestFileInstance::test_is_private", "pydicom/tests/test_fileset.py::TestFileInstance::test_properties", "pydicom/tests/test_fileset.py::TestFileInstance::test_path", "pydicom/tests/test_fileset.py::TestFileInstance::test_path_add", "pydicom/tests/test_fileset.py::TestFileInstance::test_path_move", "pydicom/tests/test_fileset.py::TestFileInstance::test_path_removal", "pydicom/tests/test_fileset.py::TestFileInstance::test_load", "pydicom/tests/test_fileset.py::TestFileInstance::test_load_staged_add", "pydicom/tests/test_fileset.py::TestFileInstance::test_load_staged_move", "pydicom/tests/test_fileset.py::TestFileInstance::test_load_staged_removal", "pydicom/tests/test_fileset.py::TestFileInstance::test_for_moving", "pydicom/tests/test_fileset.py::TestFileInstance::test_fileid", "pydicom/tests/test_fileset.py::TestFileInstance::test_fileid_add", "pydicom/tests/test_fileset.py::TestFileInstance::test_fileid_move", "pydicom/tests/test_fileset.py::TestFileInstance::test_fileid_removal", "pydicom/tests/test_fileset.py::TestFileInstance::test_private", "pydicom/tests/test_fileset.py::TestFileSet::test_empty", "pydicom/tests/test_fileset.py::TestFileSet::test_id", "pydicom/tests/test_fileset.py::TestFileSet::test_uid", "pydicom/tests/test_fileset.py::TestFileSet::test_descriptor", "pydicom/tests/test_fileset.py::TestFileSet::test_descriptor_and_charset_written", "pydicom/tests/test_fileset.py::TestFileSet::test_descriptor_dicomdir", "pydicom/tests/test_fileset.py::TestFileSet::test_descriptor_charset", "pydicom/tests/test_fileset.py::TestFileSet::test_descriptor_charset_dicomdir", "pydicom/tests/test_fileset.py::TestFileSet::test_path", "pydicom/tests/test_fileset.py::TestFileSet::test_empty_write", "pydicom/tests/test_fileset.py::TestFileSet::test_add_dataset", "pydicom/tests/test_fileset.py::TestFileSet::test_add_bad_dataset", "pydicom/tests/test_fileset.py::TestFileSet::test_add_path", "pydicom/tests/test_fileset.py::TestFileSet::test_add_add", "pydicom/tests/test_fileset.py::TestFileSet::test_remove", "pydicom/tests/test_fileset.py::TestFileSet::test_remove_iter", "pydicom/tests/test_fileset.py::TestFileSet::test_remove_remove", "pydicom/tests/test_fileset.py::TestFileSet::test_remove_add", "pydicom/tests/test_fileset.py::TestFileSet::test_add_remove", "pydicom/tests/test_fileset.py::TestFileSet::test_file_ids_unique", "pydicom/tests/test_fileset.py::TestFileSet::test_add_custom", "pydicom/tests/test_fileset.py::TestFileSet::test_add_custom_path", "pydicom/tests/test_fileset.py::TestFileSet::test_add_custom_private", "pydicom/tests/test_fileset.py::TestFileSet::test_add_custom_too_deep", "pydicom/tests/test_fileset.py::TestFileSet::test_add_custom_bad_leaf", "pydicom/tests/test_fileset.py::TestFileSet::test_add_custom_add_add", "pydicom/tests/test_fileset.py::TestFileSet::test_add_custom_remove_add", "pydicom/tests/test_fileset.py::TestFileSet::test_clear", "pydicom/tests/test_fileset.py::TestFileSet::test_str_empty", "pydicom/tests/test_fileset.py::TestFileSet::test_str", "pydicom/tests/test_fileset.py::TestFileSet::test_str_update_structure", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_write_dicomdir", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_write_new_path", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_bad_sop_class_raises", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_bad_filename_raises", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_bad_filename_type_raises", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_find", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_find_load", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_find_values", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_find_values_load", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_empty_file_id", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_bad_file_id", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_load_orphans_raise", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_load_orphans_exclude", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_load_orphans_no_file_id", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_load_orphans_private", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_load_dicomdir_big_endian", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_load_dicomdir_implicit", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_load_dicomdir_reordered", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_load_dicomdir_no_offset", "pydicom/tests/test_fileset.py::TestFileSet_Load::test_load_dicomdir_no_uid", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_dicomdir_fs_changes", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_dicomdir_use_existing", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_dicomdir_use_existing_raises", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_remove_addition_bad_path", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_file_id", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_missing_removal", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_removal_addition_collision", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_implicit", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_use_existing", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_write_use_existing_raises", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_add_instance_missing", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_add_instance_missing_required_value", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_add_rt_dose", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_add_rt_structure_set", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_add_rt_plan", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_remove_list", "pydicom/tests/test_fileset.py::TestFileSet_Modify::test_add_bad_one_level", "pydicom/tests/test_fileset.py::TestFileSet_Copy::test_copy", "pydicom/tests/test_fileset.py::TestFileSet_Copy::test_copy_raises", "pydicom/tests/test_fileset.py::TestFileSet_Copy::test_copy_implicit", "pydicom/tests/test_fileset.py::TestFileSet_Copy::test_file_id", "pydicom/tests/test_fileset.py::TestFileSet_Copy::test_additions", "pydicom/tests/test_fileset.py::TestFileSet_Copy::test_removals", "pydicom/tests/test_fileset.py::TestFileSet_Copy::test_additions_removals", "pydicom/tests/test_fileset.py::test_one_level_record[HANGING", "pydicom/tests/test_fileset.py::test_one_level_record[IMPLANT-1.2.840.10008.5.1.4.43.1]", "pydicom/tests/test_fileset.py::test_one_level_record[IMPLANT", "pydicom/tests/test_fileset.py::test_one_level_record[PALETTE-1.2.840.10008.5.1.4.39.1]", "pydicom/tests/test_fileset.py::test_four_level_record[IMAGE-1.2.840.10008.5.1.4.1.1.2-CT-None]", "pydicom/tests/test_fileset.py::test_four_level_record[RT", "pydicom/tests/test_fileset.py::test_four_level_record[PRESENTATION-1.2.840.10008.5.1.4.1.1.11.1-PR-None]", "pydicom/tests/test_fileset.py::test_four_level_record[WAVEFORM-1.2.840.10008.5.1.4.1.1.9.1.1-ECG-None]", "pydicom/tests/test_fileset.py::test_four_level_record[SR", "pydicom/tests/test_fileset.py::test_four_level_record[KEY", "pydicom/tests/test_fileset.py::test_four_level_record[SPECTROSCOPY-1.2.840.10008.5.1.4.1.1.4.2-MS-None]", "pydicom/tests/test_fileset.py::test_four_level_record[RAW", "pydicom/tests/test_fileset.py::test_four_level_record[REGISTRATION-1.2.840.10008.5.1.4.1.1.66.1-REG-None]", "pydicom/tests/test_fileset.py::test_four_level_record[FIDUCIAL-1.2.840.10008.5.1.4.1.1.66.2-FID-None]", "pydicom/tests/test_fileset.py::test_four_level_record[ENCAP", "pydicom/tests/test_fileset.py::test_four_level_record[VALUE", "pydicom/tests/test_fileset.py::test_four_level_record[STEREOMETRIC-1.2.840.10008.5.1.4.1.1.77.1.5.3-SMR-None]", "pydicom/tests/test_fileset.py::test_four_level_record[PLAN-1.2.840.10008.5.1.4.34.7-PLAN-None]", "pydicom/tests/test_fileset.py::test_four_level_record[MEASUREMENT-1.2.840.10008.5.1.4.1.1.78.1-LEN-None]", "pydicom/tests/test_fileset.py::test_four_level_record[SURFACE-1.2.840.10008.5.1.4.1.1.66.5-LS-None]", "pydicom/tests/test_fileset.py::test_four_level_record[SURFACE", "pydicom/tests/test_fileset.py::test_four_level_record[TRACT-1.2.840.10008.5.1.4.1.1.66.6-NONE-None]", "pydicom/tests/test_fileset.py::test_four_level_record[ASSESSMENT-1.2.840.10008.5.1.4.1.1.90.1-ASMT-None]", "pydicom/tests/test_fileset.py::test_four_level_record[RADIOTHERAPY-1.2.840.10008.5.1.4.1.1.481.13-RTRAD-None]"], "environment_setup_commit": "0fa18d2a2179c92efc22200ed6b3689e66cecf92"}, {"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"}, {"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"}]