{
  "Selected_candidate": {
    "pr_number": 14315,
    "pr_title": "Fixed #32687 -- Restored passing process’ environment to underlying tool in dbshell on PostgreSQL.",
    "pr_body": "[ticket-32687](https://code.djangoproject.com/ticket/32687#ticket)\r\nIntroduced by https://github.com/django/django/commit/bbe6fbb8768e8fb1aecb96d51c049d7ceaf802d3\r\n\r\npostgresql client returns empty dict instead of None for env\r\nas a result os.environ is not used and empty env passed\r\nto subprocess.",
    "issue_id": 32687,
    "issue_title": "database client runshell doesn't respect os.environ values in some cases",
    "issue_body": "postgresql client returns empty dict instead of None for env\nas a result os.environ is not used and empty env passed\nto subprocess.\nBug introduced in\n​\nhttps://github.com/django/django/commit/bbe6fbb8768e8fb1aecb96d51c049d7ceaf802d3#diff-e98866ed4d445fbc94bb60bedffd5d8cf07af55dca6e8ffa4945931486efc3eeR23-R26\nPR\n​\nhttps://github.com/django/django/pull/14315",
    "issue_closed_at": "2021-04-27T05:01:49",
    "base_commit": "187118203197801c6cb72dc8b06b714b23b6dd3d",
    "changes": [
      {
        "file": "django/db/backends/base/client.py",
        "type": "function",
        "name": "settings_to_cmd_args_env",
        "class_name": "BaseDatabaseClient",
        "code": "def settings_to_cmd_args_env(cls, settings_dict, parameters):\n        raise NotImplementedError(\n            'subclasses of BaseDatabaseClient must provide a '\n            'settings_to_cmd_args_env() method or override a runshell().'\n        )"
      },
      {
        "file": "django/db/backends/postgresql/client.py",
        "type": "function",
        "name": "settings_to_cmd_args_env",
        "class_name": "DatabaseClient",
        "code": "def settings_to_cmd_args_env(cls, settings_dict, parameters):\n        args = [cls.executable_name]\n        options = settings_dict.get('OPTIONS', {})\n\n        host = settings_dict.get('HOST')\n        port = settings_dict.get('PORT')\n        dbname = settings_dict.get('NAME')\n        user = settings_dict.get('USER')\n        passwd = settings_dict.get('PASSWORD')\n        passfile = options.get('passfile')\n        service = options.get('service')\n        sslmode = options.get('sslmode')\n        sslrootcert = options.get('sslrootcert')\n        sslcert = options.get('sslcert')\n        sslkey = options.get('sslkey')\n\n        if not dbname and not service:\n            # Connect to the default 'postgres' db.\n            dbname = 'postgres'\n        if user:\n            args += ['-U', user]\n        if host:\n            args += ['-h', host]\n        if port:\n            args += ['-p', str(port)]\n        if dbname:\n            args += [dbname]\n        args.extend(parameters)\n\n        env = {}\n        if passwd:\n            env['PGPASSWORD'] = str(passwd)\n        if service:\n            env['PGSERVICE'] = str(service)\n        if sslmode:\n            env['PGSSLMODE'] = str(sslmode)\n        if sslrootcert:\n            env['PGSSLROOTCERT'] = str(sslrootcert)\n        if sslcert:\n            env['PGSSLCERT'] = str(sslcert)\n        if sslkey:\n            env['PGSSLKEY'] = str(sslkey)\n        if passfile:\n            env['PGPASSFILE'] = str(passfile)\n        return args, env"
      }
    ]
  },
  "Justification": "Candidate C is the most helpful report as it directly pertains to issues with the PostgreSQL database client and addresses a similar concern regarding how command-line arguments are managed in the `dbshell`. Both the CURRENT bug report and Candidate C revolve around handling parameters and environment variables when interacting with the PostgreSQL client. This relevance in handling database commands and the associated fixes can provide significant insights into reordering and correctly passing command-line parameters, informing the debugging process for the CURRENT bug.",
  "instance_id": "django__django-15851",
  "repo": "django/django",
  "created_at": "2022-07-18T01:36:33Z",
  "problem_statement": "dbshell additional parameters should be passed before dbname on PostgreSQL.\nDescription\n\t\npsql expects all options to proceed the database name, if provided. So, if doing something like `./manage.py dbshell -- -c \"select * from some_table;\" one will get this:\n$ ./manage.py dbshell -- -c \"select * from some_table;\"\npsql: warning: extra command-line argument \"-c\" ignored\npsql: warning: extra command-line argument \"select * from some_table;\" ignored\npsql (10.21)\nType \"help\" for help.\nsome_database=>\nIt appears the args list just need to be constructed in the proper order, leaving the database name for the end of the args list.\n",
  "patch": "diff --git a/django/db/backends/postgresql/client.py b/django/db/backends/postgresql/client.py\n--- a/django/db/backends/postgresql/client.py\n+++ b/django/db/backends/postgresql/client.py\n@@ -32,9 +32,9 @@ def settings_to_cmd_args_env(cls, settings_dict, parameters):\n             args += [\"-h\", host]\n         if port:\n             args += [\"-p\", str(port)]\n+        args.extend(parameters)\n         if dbname:\n             args += [dbname]\n-        args.extend(parameters)\n \n         env = {}\n         if passwd:\n"
}