{
  "Selected_candidate": {
    "pr_number": 7472,
    "pr_title": "Fixed #27436 -- Display absolute path in makemigrations if a relative path doesn't exist.",
    "pr_body": "For example on Windows it's impossible to obtain a relative path\r\nbetween files located on separate drives (C: and D:, for example).",
    "issue_id": 27436,
    "issue_title": "migrations.test_commands.MakeMigrationsTests fail on Windows when run on a different drive than C:",
    "issue_body": "Some of the test cases in MakeMigrationsTests fail on Windows due to inability to find a relative path between files located on separate drives.\nThe tests create a temporary migrations directory using\ntempfile.mkdtemp\n, which on Windows creates a directory under C:\\Temp (or C:\\Users\\<username>\\AppData\\Local\\Temp).\nIf one clones Django source code to a drive other than C:, then the makemigrations command tests fail with an error like the following (Windows 7, Python 3.5.1):\nERROR: test_makemigrations_non_interactive_not_null_alteration (migrations.test_commands.MakeMigrationsTests)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"D:\\dev\\django\\tests\\migrations\\test_commands.py\", line 834, in test_makemigrations_non_interactive_not_null_alteration\n    call_command(\"makemigrations\", \"migrations\", interactive=False, stdout=out)\n  File \"d:\\dev\\django\\django\\core\\management\\__init__.py\", line 130, in call_command\n    return command.execute(*args, **defaults)\n  File \"d:\\dev\\django\\django\\core\\management\\base.py\", line 330, in execute\n    output = self.handle(*args, **options)\n  File \"d:\\dev\\django\\django\\core\\management\\commands\\makemigrations.py\", line 193, in handle\n    self.write_migration_files(changes)\n  File \"d:\\dev\\django\\django\\core\\management\\commands\\makemigrations.py\", line 211, in write_migration_files\n    migration_string = os.path.relpath(writer.path)\n  File \"D:\\Miniconda3\\lib\\ntpath.py\", line 574, in relpath\n    path_drive, start_drive))\nValueError: path is on mount 'C:', start on mount 'D:'\nSince the value returned from\nrelpath\nis used only for display and not for any I/O, I'd suggest catching this\nValueError\nand using an absolute path in that case.",
    "issue_closed_at": "2016-11-08T17:06:24",
    "base_commit": "dacef9137f43fff88b527d1c02f6fe6a81e975aa",
    "changes": [
      {
        "file": "django/core/management/commands/makemigrations.py",
        "type": "function",
        "name": "write_migration_files",
        "class_name": "Command",
        "code": "def write_migration_files(self, changes):\n        \"\"\"\n        Takes a changes dict and writes them out as migration files.\n        \"\"\"\n        directory_created = {}\n        for app_label, app_migrations in changes.items():\n            if self.verbosity >= 1:\n                self.stdout.write(self.style.MIGRATE_HEADING(\"Migrations for '%s':\" % app_label) + \"\\n\")\n            for migration in app_migrations:\n                # Describe the migration\n                writer = MigrationWriter(migration)\n                if self.verbosity >= 1:\n                    # Display a relative path if it's below the current working\n                    # directory, or an absolute path otherwise.\n                    migration_string = os.path.relpath(writer.path)\n                    if migration_string.startswith('..'):\n                        migration_string = writer.path\n                    self.stdout.write(\"  %s:\\n\" % (self.style.MIGRATE_LABEL(migration_string),))\n                    for operation in migration.operations:\n                        self.stdout.write(\"    - %s\\n\" % operation.describe())\n                if not self.dry_run:\n                    # Write the migrations file to the disk.\n                    migrations_directory = os.path.dirname(writer.path)\n                    if not directory_created.get(app_label):\n                        if not os.path.isdir(migrations_directory):\n                            os.mkdir(migrations_directory)\n                        init_path = os.path.join(migrations_directory, \"__init__.py\")\n                        if not os.path.isfile(init_path):\n                            open(init_path, \"w\").close()\n                        # We just do this once per app\n                        directory_created[app_label] = True\n                    migration_string = writer.as_string()\n                    with io.open(writer.path, \"w\", encoding='utf-8') as fh:\n                        fh.write(migration_string)\n                elif self.verbosity == 3:\n                    # Alternatively, makemigrations --dry-run --verbosity 3\n                    # will output the migrations to stdout rather than saving\n                    # the file to the disk.\n                    self.stdout.write(self.style.MIGRATE_HEADING(\n                        \"Full migrations file '%s':\" % writer.filename) + \"\\n\"\n                    )\n                    self.stdout.write(\"%s\\n\" % writer.as_string())"
      }
    ]
  },
  "Justification": "Candidate A is the most relevant as it discusses issues related to the `makemigrations` command, which is directly related to the CURRENT bug report that involves creating migrations for a model with a dynamically generated file path based on the machine's context. The structural similarity is strong, with both cases involving path resolution and migration generation. Furthermore, since Candidate A proposes a fix for displaying absolute paths when relative paths are not viable—similar to how the CURRENT bug report must address path dependency across different environments—it can provide insights into handling similar migration issues promptly. This makes Candidate A particularly useful for debugging the CURRENT bug.",
  "instance_id": "django__django-10924",
  "repo": "django/django",
  "created_at": "2019-02-03T11:30:12Z",
  "problem_statement": "Allow FilePathField path to accept a callable.\nDescription\n\t\nI have a special case where I want to create a model containing the path to some local files on the server/dev machine. Seeing as the place where these files are stored is different on different machines I have the following:\nimport os\nfrom django.conf import settings\nfrom django.db import models\nclass LocalFiles(models.Model):\n\tname = models.CharField(max_length=255)\n\tfile = models.FilePathField(path=os.path.join(settings.LOCAL_FILE_DIR, 'example_dir'))\nNow when running manage.py makemigrations it will resolve the path based on the machine it is being run on. Eg: /home/<username>/server_files/example_dir\nI had to manually change the migration to include the os.path.join() part to not break this when running the migration on production/other machine.\n",
  "patch": "diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py\n--- a/django/db/models/fields/__init__.py\n+++ b/django/db/models/fields/__init__.py\n@@ -1709,7 +1709,7 @@ def get_prep_value(self, value):\n \n     def formfield(self, **kwargs):\n         return super().formfield(**{\n-            'path': self.path,\n+            'path': self.path() if callable(self.path) else self.path,\n             'match': self.match,\n             'recursive': self.recursive,\n             'form_class': forms.FilePathField,\n"
}