{
  "Selected_candidate": {
    "pr_number": 4660,
    "pr_title": "Fixed #24791 -- Added fallback when 'postgres' database isn't available",
    "pr_body": "",
    "issue_id": 24791,
    "issue_title": "Cannot run tests without access to postgres database",
    "issue_body": "The change for ticket\n#16969\nprevents Django from being able to run tests on Heroku,\nhere you are not allowed to connect to the \"postgres\" database, at least with the free tier.\nWould it be an option to use an explicitly configured\nDATABASES['default']['TEST']['NAME']\nsetting, instead of 'postgres' here?\nOr could there be a new setting, like\nDATABASES['default']['TEST']['CONNECT_NAME']\n?\nThe traceback, for reference (Django 1.8.1):\n.heroku/python/lib/python2.7/site-packages/pytest_django/fixtures.py:53: \n>           db_cfg = setup_databases(verbosity=0, interactive=False)\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n.heroku/python/lib/python2.7/site-packages/django/test/runner.py:370: in setup_databases\n    serialize=connection.settings_dict.get(\"TEST\", {}).get(\"SERIALIZE\", True),\n.heroku/python/lib/python2.7/site-packages/django/db/backends/base/creation.py:354: in create_test_db\n    self._create_test_db(verbosity, autoclobber, keepdb)\n.heroku/python/lib/python2.7/site-packages/django/db/backends/base/creation.py:447: in _create_test_db\n    with self._nodb_connection.cursor() as cursor:\n.heroku/python/lib/python2.7/site-packages/django/db/backends/base/base.py:164: in cursor\n    cursor = self.make_cursor(self._cursor())\n.heroku/python/lib/python2.7/site-packages/django/db/backends/base/base.py:135: in _cursor\n    self.ensure_connection()\n.heroku/python/lib/python2.7/site-packages/django/db/backends/base/base.py:130: in ensure_connection\n    self.connect()\n.heroku/python/lib/python2.7/site-packages/django/db/utils.py:97: in __exit__\n    six.reraise(dj_exc_type, dj_exc_value, traceback)\n.heroku/python/lib/python2.7/site-packages/django/db/backends/base/base.py:130: in ensure_connection\n    self.connect()\n.heroku/python/lib/python2.7/site-packages/django/db/backends/base/base.py:119: in connect\n    self.connection = self.get_new_connection(conn_params)\n.heroku/python/lib/python2.7/site-packages/django/db/backends/postgresql_psycopg2/base.py:172: in get_new_connection\n    connection = Database.connect(**conn_params)\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \n\n    ...\n\n        if dsn is None:\n            if not items:\n                raise TypeError('missing dsn and no parameters')\n            else:\n                dsn = \" \".join([\"%s=%s\" % (k, _param_escape(str(v)))\n                    for (k, v) in items])\n\n>       conn = _connect(dsn, connection_factory=connection_factory, async=async)\nE       OperationalError: FATAL:  permission denied for database \"postgres\"\nE       DETAIL:  User does not have CONNECT privilege.\n\n.heroku/python/lib/python2.7/site-packages/psycopg2/__init__.py:164: OperationalError",
    "issue_closed_at": "2015-05-15T11:43:40",
    "base_commit": "2dee853ed4def42b7ef1b3b472b395055543cc00",
    "changes": [
      {
        "file": "django/db/backends/base/creation.py",
        "type": "function",
        "name": "_destroy_test_db",
        "class_name": "BaseDatabaseCreation",
        "code": "def _destroy_test_db(self, test_database_name, verbosity):\n        \"\"\"\n        Internal implementation - remove the test db tables.\n        \"\"\"\n        # Remove the test database to clean up after\n        # ourselves. Connect to the previous database (not the test database)\n        # to do so, because it's not allowed to delete a database while being\n        # connected to it.\n        with self._nodb_connection.cursor() as cursor:\n            # Wait to avoid \"database is being accessed by other users\" errors.\n            time.sleep(1)\n            cursor.execute(\"DROP DATABASE %s\"\n                           % self.connection.ops.quote_name(test_database_name))"
      },
      {
        "file": "django/db/backends/postgresql_psycopg2/base.py",
        "type": "line",
        "name": "line 4",
        "code": "Requires psycopg 2: http://initd.org/projects/psycopg2\n\"\"\"\n\nfrom django.conf import settings\nfrom django.core.exceptions import ImproperlyConfigured\nfrom django.db.backends.base.base import BaseDatabaseWrapper\nfrom django.db.backends.base.validation import BaseDatabaseValidation\nfrom django.utils.encoding import force_str\nfrom django.utils.functional import cached_property\nfrom django.utils.safestring import SafeBytes, SafeText"
      },
      {
        "file": "django/db/backends/postgresql_psycopg2/base.py",
        "type": "function",
        "name": "is_usable",
        "class_name": "DatabaseWrapper",
        "code": "def is_usable(self):\n        try:\n            # Use a psycopg cursor directly, bypassing Django's utilities.\n            self.connection.cursor().execute(\"SELECT 1\")\n        except Database.Error:\n            return False\n        else:\n            return True"
      }
    ]
  },
  "Justification": "Candidate C is the most helpful as it relates to database creation issues in Django, which are likely tied to the slugify functionality that relies on input sanitation and database interactions. While it doesn't directly relate to text manipulation, the debugging context around handling conditions in database settings and tests can provide insights into ensuring that the slugify function appropriately manages its outputs. The impact of error handling during database operations may parallel the challenges presented by incorrect slug handling in different environments.",
  "instance_id": "django__django-12983",
  "repo": "django/django",
  "created_at": "2020-05-26T22:02:40Z",
  "problem_statement": "Make django.utils.text.slugify() strip dashes and underscores\nDescription\n\t \n\t\t(last modified by Elinaldo do Nascimento Monteiro)\n\t \nBug generation slug\nExample:\nfrom django.utils import text\ntext.slugify(\"___This is a test ---\")\noutput: ___this-is-a-test-\nImprovement after correction\nfrom django.utils import text\ntext.slugify(\"___This is a test ---\")\noutput: this-is-a-test\n​PR\n",
  "patch": "diff --git a/django/utils/text.py b/django/utils/text.py\n--- a/django/utils/text.py\n+++ b/django/utils/text.py\n@@ -393,17 +393,18 @@ def unescape_string_literal(s):\n @keep_lazy_text\n def slugify(value, allow_unicode=False):\n     \"\"\"\n-    Convert to ASCII if 'allow_unicode' is False. Convert spaces to hyphens.\n-    Remove characters that aren't alphanumerics, underscores, or hyphens.\n-    Convert to lowercase. Also strip leading and trailing whitespace.\n+    Convert to ASCII if 'allow_unicode' is False. Convert spaces or repeated\n+    dashes to single dashes. Remove characters that aren't alphanumerics,\n+    underscores, or hyphens. Convert to lowercase. Also strip leading and\n+    trailing whitespace, dashes, and underscores.\n     \"\"\"\n     value = str(value)\n     if allow_unicode:\n         value = unicodedata.normalize('NFKC', value)\n     else:\n         value = unicodedata.normalize('NFKD', value).encode('ascii', 'ignore').decode('ascii')\n-    value = re.sub(r'[^\\w\\s-]', '', value.lower()).strip()\n-    return re.sub(r'[-\\s]+', '-', value)\n+    value = re.sub(r'[^\\w\\s-]', '', value.lower())\n+    return re.sub(r'[-\\s]+', '-', value).strip('-_')\n \n \n def camel_case_to_spaces(value):\n"
}