{
  "instance_id": "django__django-15347",
  "repo": "django/django",
  "created_at": "2022-01-22T01:56:48Z",
  "problem_statement": "Messages framework incorrectly serializes/deserializes extra_tags when it's an empty string\nDescription\n\t\nWhen a message is serialised and then deserialised with any of the built in storage backends, then extra_tags==\"\" is converted to extra_tags==None. This is because MessageEncoder checks for the truthyness of extra_tags rather than checking it is not None.\nTo replicate this bug\n>>> from django.conf import settings\n>>> settings.configure() # Just to allow the following import\n>>> from django.contrib.messages.storage.base import Message\n>>> from django.contrib.messages.storage.cookie import MessageEncoder, MessageDecoder\n>>> original_message = Message(10, \"Here is a message\", extra_tags=\"\")\n>>> encoded_message = MessageEncoder().encode(original_message)\n>>> decoded_message = MessageDecoder().decode(encoded_message)\n>>> original_message.extra_tags == \"\"\nTrue\n>>> decoded_message.extra_tags is None\nTrue\nEffect of the bug in application behaviour\nThis error occurred in the wild with a template tag similar to the following:\n{% if x not in message.extra_tags %}\nWhen the message was displayed as part of a redirect, it had been serialised and deserialized which meant that extra_tags was None instead of the empty string. This caused an error.\nIt's important to note that this bug affects all of the standard API (messages.debug, messages.info etc. all have a default value of extra_tags equal to \"\").\n",
  "patch": "diff --git a/django/contrib/messages/storage/cookie.py b/django/contrib/messages/storage/cookie.py\n--- a/django/contrib/messages/storage/cookie.py\n+++ b/django/contrib/messages/storage/cookie.py\n@@ -19,7 +19,7 @@ def default(self, obj):\n             # Using 0/1 here instead of False/True to produce more compact json\n             is_safedata = 1 if isinstance(obj.message, SafeData) else 0\n             message = [self.message_key, is_safedata, obj.level, obj.message]\n-            if obj.extra_tags:\n+            if obj.extra_tags is not None:\n                 message.append(obj.extra_tags)\n             return message\n         return super().default(obj)\n",
  "similar_bug_items": [
    {
      "pr_number": 6540,
      "pr_title": "Fixed #26341 (again) -- Addressed multiple occurrences per line use case",
      "pr_body": "",
      "issue_id": 26341,
      "issue_title": "Weird comments in PO files (.html.py filenames)",
      "issue_body": "I just upgraded Django to 1.9.4 from 1.8.10, and sometimes, the filenames in PO files comments contain \".html.py\" extensions.\nThis is visible on django's main repository :\n​\nhttps://github.com/django/django/blob/ae4d932b1ac12651a7c57d89742c25483ee8c9f9/django/contrib/admin/locale/en/LC_MESSAGES/django.po#L282\n​\nhttps://github.com/django/django/blob/4323676ea5ab6994feb1385522665069d84f397b/django/contrib/admin/locale/en/LC_MESSAGES/django.po#L302\nIn this example, the \"contrib/admin/templates/admin/base_site.html\" file is now named \"contrib/admin/templates/admin/base_site.html.py\" (with a trailing \".py\") in the po file.\nThis seems to appear only on lines with a python file before the template html file.\nclaudep found that this could be the faulty commit :\n​\nhttps://github.com/django/django/commit/e75882332c",
      "issue_closed_at": "2016-04-30T05:07:43",
      "base_commit": "4e2ee8662753ca6a2619039b903f11c60709f398",
      "changes": [
        {
          "file": "django/core/management/commands/makemessages.py",
          "type": "function",
          "name": "postprocess_messages",
          "class_name": "BuildFile",
          "code": "def postprocess_messages(self, msgs):\n        \"\"\"\n        Postprocess messages generated by xgettext GNU gettext utility.\n\n        Transform paths as if these messages were generated from original\n        translatable files rather than from preprocessed versions.\n        \"\"\"\n        if not self.is_templatized:\n            return msgs\n\n        # Remove '.py' suffix\n        if os.name == 'nt':\n            # Preserve '.\\' prefix on Windows to respect gettext behavior\n            old_path = self.work_path\n            new_path = self.path\n        else:\n            old_path = self.work_path[2:]\n            new_path = self.path[2:]\n\n        return re.sub(\n            r'^(#: .*)(' + re.escape(old_path) + r')',\n            r'\\1' + new_path,\n            msgs,\n            flags=re.MULTILINE\n        )"
        }
      ]
    },
    {
      "pr_number": 12263,
      "pr_title": "Fixed #31166 -- Used \"raise from\" when raising ImproperlyConfigured exceptions in django.urls.resolvers.",
      "pr_body": "This will make it have a text of \"this exception is the direct result of\" instead of \"During handling of the above exception, another exception occurred\" \r\n\r\nThis is more accurate for the case of this exception.",
      "issue_id": 31166,
      "issue_title": "Provide context for ImproperlyConfigured exceptions in URL resolver.",
      "issue_body": "The patch is ready here:\n​\nhttps://github.com/django/django/pull/12263\nThis will make it have a text of \"this exception is the direct result of\" instead of \"During handling of the above exception, another exception occurred\"\nThis is more accurate for the case of this exception.\nIf this change will be merged, there are a couple more place in this module where it can be added.\nWhen it happened to me a few weeks ago, it was due to a circular import, which I then fixed. Now of course, when I tried to reproduce the circular import to show you, I couldn't. But I could achieve the same thing by renaming\nurlpatterns\nto\nxurlpatterns\n, so it wouldn't be available. This is the error I get:\nException in thread django-main-thread:\nTraceback (most recent call last):\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\urls\\resolvers.py\", line 590, in url_patterns\n    iter(patterns)\nTypeError: 'module' object is not iterable\n\nDuring handling of the above exception, another exception occurred:\n\nTraceback (most recent call last):\n  File \"C:\\Program Files\\Python38\\lib\\threading.py\", line 932, in _bootstrap_inner\n    self.run()\n  File \"C:\\Program Files\\Python38\\lib\\threading.py\", line 870, in run\n    self._target(*self._args, **self._kwargs)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\utils\\autoreload.py\", line 53, in wrapper\n    fn(*args, **kwargs)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\management\\commands\\runserver.py\", line 117, in inner_run\n    self.check(display_num_errors=True)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\management\\base.py\", line 392, in check\n    all_issues = self._run_checks(\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\management\\base.py\", line 382, in _run_checks\n    return checks.run_checks(**kwargs)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\checks\\registry.py\", line 72, in run_checks\n    new_errors = check(app_configs=app_configs)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\checks\\urls.py\", line 13, in check_url_config\n    return check_resolver(resolver)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\checks\\urls.py\", line 23, in check_resolver\n    return check_method()\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\urls\\resolvers.py\", line 408, in check\n    messages.extend(check_resolver(pattern))\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\checks\\urls.py\", line 23, in check_resolver\n    return check_method()\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\urls\\resolvers.py\", line 407, in check\n    for pattern in self.url_patterns:\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\utils\\functional.py\", line 48, in __get__\n    res = instance.__dict__[self.name] = self.func(instance)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\urls\\resolvers.py\", line 597, in url_patterns\n    raise ImproperlyConfigured(msg.format(name=self.urlconf_name))\ndjango.core.exceptions.ImproperlyConfigured: The included URLconf '<module 'barb.urls' from 'C:\\\\Users\\\\Administrator\\\\Desktop\\\\foof\\\\barb\\\\urls.py'>' does not appear to have any patterns in it. If you see valid patterns in the file then the issue is probably caused by a circular import.\nThe bad part is\nDuring handling of the above exception, another exception occurred\n.\nAfter my fix, it looks like this:\nException in thread django-main-thread:\nTraceback (most recent call last):\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\urls\\resolvers.py\", line 590, in url_patterns\n    iter(patterns)\nTypeError: 'module' object is not iterable\n\nThe above exception was the direct cause of the following exception:\n\nTraceback (most recent call last):\n  File \"C:\\Program Files\\Python38\\lib\\threading.py\", line 932, in _bootstrap_inner\n    self.run()\n  File \"C:\\Program Files\\Python38\\lib\\threading.py\", line 870, in run\n    self._target(*self._args, **self._kwargs)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\utils\\autoreload.py\", line 53, in wrapper\n    fn(*args, **kwargs)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\management\\commands\\runserver.py\", line 117, in inner_run\n    self.check(display_num_errors=True)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\management\\base.py\", line 392, in check\n    all_issues = self._run_checks(\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\management\\base.py\", line 382, in _run_checks\n    return checks.run_checks(**kwargs)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\checks\\registry.py\", line 72, in run_checks\n    new_errors = check(app_configs=app_configs)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\checks\\urls.py\", line 13, in check_url_config\n    return check_resolver(resolver)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\checks\\urls.py\", line 23, in check_resolver\n    return check_method()\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\urls\\resolvers.py\", line 408, in check\n    messages.extend(check_resolver(pattern))\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\core\\checks\\urls.py\", line 23, in check_resolver\n    return check_method()\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\urls\\resolvers.py\", line 407, in check\n    for pattern in self.url_patterns:\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\utils\\functional.py\", line 48, in __get__\n    res = instance.__dict__[self.name] = self.func(instance)\n  File \"C:\\Program Files\\Python38\\lib\\site-packages\\django\\urls\\resolvers.py\", line 597, in url_patterns\n    raise ImproperlyConfigured(msg.format(name=self.urlconf_name)) from type_error # Ram hack, remove\ndjango.core.exceptions.ImproperlyConfigured: The included URLconf '<module 'barb.urls' from 'C:\\\\Users\\\\Administrator\\\\Desktop\\\\foof\\\\barb\\\\urls.py'>' does not appear to have any patterns in it. If you see valid patterns in the file then the issue is probably caused by a circular import.\nNow the text is corrected to\nThe above exception was the direct cause of the following exception",
      "issue_closed_at": "2020-01-17T05:21:04",
      "base_commit": "73563183c2ea92e9ef1d3a1f790a503acc14ade2",
      "changes": [
        {
          "file": "django/urls/resolvers.py",
          "type": "function",
          "name": "_compile",
          "class_name": "RoutePattern",
          "code": "def _compile(self, route):\n        return re.compile(_route_to_regex(route, self._is_endpoint)[0])"
        },
        {
          "file": "django/urls/resolvers.py",
          "type": "function",
          "name": "_route_to_regex",
          "class_name": null,
          "code": "def _route_to_regex(route, is_endpoint=False):\n    \"\"\"\n    Convert a path pattern into a regular expression. Return the regular\n    expression and a dictionary mapping the capture names to the converters.\n    For example, 'foo/<int:pk>' returns '^foo\\\\/(?P<pk>[0-9]+)'\n    and {'pk': <django.urls.converters.IntConverter>}.\n    \"\"\"\n    if not set(route).isdisjoint(string.whitespace):\n        raise ImproperlyConfigured(\"URL route '%s' cannot contain whitespace.\" % route)\n    original_route = route\n    parts = ['^']\n    converters = {}\n    while True:\n        match = _PATH_PARAMETER_COMPONENT_RE.search(route)\n        if not match:\n            parts.append(re.escape(route))\n            break\n        parts.append(re.escape(route[:match.start()]))\n        route = route[match.end():]\n        parameter = match.group('parameter')\n        if not parameter.isidentifier():\n            raise ImproperlyConfigured(\n                \"URL route '%s' uses parameter name %r which isn't a valid \"\n                \"Python identifier.\" % (original_route, parameter)\n            )\n        raw_converter = match.group('converter')\n        if raw_converter is None:\n            # If a converter isn't specified, the default is `str`.\n            raw_converter = 'str'\n        try:\n            converter = get_converter(raw_converter)\n        except KeyError as e:\n            raise ImproperlyConfigured(\n                \"URL route '%s' uses invalid converter %s.\" % (original_route, e)\n            )\n        converters[parameter] = converter\n        parts.append('(?P<' + parameter + '>' + converter.regex + ')')\n    if is_endpoint:\n        parts.append('$')\n    return ''.join(parts), converters"
        },
        {
          "file": "django/urls/resolvers.py",
          "type": "function",
          "name": "url_patterns",
          "class_name": "URLResolver",
          "code": "def url_patterns(self):\n        # urlconf_module might be a valid set of patterns, so we default to it\n        patterns = getattr(self.urlconf_module, \"urlpatterns\", self.urlconf_module)\n        try:\n            iter(patterns)\n        except TypeError:\n            msg = (\n                \"The included URLconf '{name}' does not appear to have any \"\n                \"patterns in it. If you see valid patterns in the file then \"\n                \"the issue is probably caused by a circular import.\"\n            )\n            raise ImproperlyConfigured(msg.format(name=self.urlconf_name))\n        return patterns"
        }
      ]
    },
    {
      "pr_number": 9112,
      "pr_title": "Fixed #27846 -- clear all cached reverse relationships on refresh_from_db()",
      "pr_body": "https://code.djangoproject.com/ticket/27846",
      "issue_id": 27846,
      "issue_title": "refresh_from_db() doesn't clear reverse OneToOneFields",
      "issue_body": "Sorry for the poor summary, it is difficult to explain in words. I have a project to demo this bug attached to this ticket, but I will try to explain the bug anyway in steps and the setup.\nSetup:\n2 models (A and B)\nB has a OneToOne to A\nBoth A and B have a field (ie TextField)\nSetup either a signal or override save() for A to update B's TextField to equal that of A's on save() or post_save for signals\nSteps:\nCreate instance of A\nGet another copy of the instance of A via A.objects.get()\nCreate instance of B using the copy of the instance of A\nDo refresh_from_db() on original instance of A\nTry to access B from A\nThe project I have provided is a slim version of this problem that demonstrates it with signals, overriden save(), and basic set and save inside the test. The basic set and save works, but the other two fail when using the above steps. Run the test suite to see.",
      "issue_closed_at": "2017-10-12T16:25:22",
      "base_commit": "df0aebc893973c78d7d2cda712ba4133dbe29b6e",
      "changes": [
        {
          "file": "django/db/models/base.py",
          "type": "function",
          "name": "refresh_from_db",
          "class_name": "Model",
          "code": "def refresh_from_db(self, using=None, fields=None):\n        \"\"\"\n        Reload field values from the database.\n\n        By default, the reloading happens from the database this instance was\n        loaded from, or by the read router if this instance wasn't loaded from\n        any database. The using parameter will override the default.\n\n        Fields can be used to specify which fields to reload. The fields\n        should be an iterable of field attnames. If fields is None, then\n        all non-deferred fields are reloaded.\n\n        When accessing deferred fields of an instance, the deferred loading\n        of the field will call this method.\n        \"\"\"\n        if fields is not None:\n            if len(fields) == 0:\n                return\n            if any(LOOKUP_SEP in f for f in fields):\n                raise ValueError(\n                    'Found \"%s\" in fields argument. Relations and transforms '\n                    'are not allowed in fields.' % LOOKUP_SEP)\n\n        db = using if using is not None else self._state.db\n        db_instance_qs = self.__class__._default_manager.using(db).filter(pk=self.pk)\n\n        # Use provided fields, if not set then reload all non-deferred fields.\n        deferred_fields = self.get_deferred_fields()\n        if fields is not None:\n            fields = list(fields)\n            db_instance_qs = db_instance_qs.only(*fields)\n        elif deferred_fields:\n            fields = [f.attname for f in self._meta.concrete_fields\n                      if f.attname not in deferred_fields]\n            db_instance_qs = db_instance_qs.only(*fields)\n\n        db_instance = db_instance_qs.get()\n        non_loaded_fields = db_instance.get_deferred_fields()\n        for field in self._meta.concrete_fields:\n            if field.attname in non_loaded_fields:\n                # This field wasn't refreshed - skip ahead.\n                continue\n            setattr(self, field.attname, getattr(db_instance, field.attname))\n            # Throw away stale foreign key references.\n            if field.is_relation and field.is_cached(self):\n                rel_instance = field.get_cached_value(self)\n                local_val = getattr(db_instance, field.attname)\n                related_val = None if rel_instance is None else getattr(rel_instance, field.target_field.attname)\n                if local_val != related_val or (local_val is None and related_val is None):\n                    field.delete_cached_value(self)\n        self._state.db = db_instance._state.db"
        }
      ]
    },
    {
      "pr_number": 13800,
      "pr_title": "Fixed #32191 -- Made CookieStorage use RFC 6265 compliant format.",
      "pr_body": "Continues work by Florian Apolloner in this [PR](https://github.com/django/django/pull/13793).\r\nThe aim is to make messages, when stored in cookies, compliant with RFC6265 which defines allowed characters for cookies. It does this by base64 encoding them, and then to reduce their size, it compresses them using zlib.\r\nThis fix is achieved by introducing `sign_object` and `unsign_object` into the base signer class.",
      "issue_id": 32191,
      "issue_title": "Not RFC 6265 compliant cookies in contrib.messages.",
      "issue_body": "Hi\nA Customer of mine is using a WAF which is handling Cookies as it is described tin the RFC:\n​\nhttps://tools.ietf.org/html/rfc6265\nThe issue now is that Django is trying to use an escape-character in cookie-Values which is not supported in the RFC\nan example of such a cookie:\nmessages=\\\"123\\\\\\\"NOTRECEIVED\\\"\"\nPlease consider to get this fixed so there can be a protection of this system.\nRegards,\nNico",
      "issue_closed_at": "2021-01-07T06:20:56",
      "base_commit": "3eb98743dcaa0b7abd2d5832cba8cc9cb586a964",
      "changes": [
        {
          "file": "django/contrib/messages/storage/cookie.py",
          "type": "class",
          "name": "MessageEncoder",
          "code": "class MessageEncoder(json.JSONEncoder):\n    \"\"\"\n    Compactly serialize instances of the ``Message`` class as JSON.\n    \"\"\"\n    message_key = '__json_message'\n\n    def __init__(self, *args, **kwargs):\n        kwargs.setdefault('separators', (',', ':'))\n        super().__init__(*args, **kwargs)\n\n    def default(self, obj):\n        if isinstance(obj, Message):\n            # Using 0/1 here instead of False/True to produce more compact json\n            is_safedata = 1 if isinstance(obj.message, SafeData) else 0\n            message = [self.message_key, is_safedata, obj.level, obj.message]\n            if obj.extra_tags:\n                message.append(obj.extra_tags)\n            return message\n        return super().default(obj)"
        },
        {
          "file": "django/contrib/messages/storage/cookie.py",
          "type": "function",
          "name": "decode",
          "class_name": "MessageDecoder",
          "code": "def decode(self, s, **kwargs):\n        decoded = super().decode(s, **kwargs)\n        return self.process_messages(decoded)"
        },
        {
          "file": "django/contrib/messages/storage/cookie.py",
          "type": "function",
          "name": "_encode",
          "class_name": "CookieStorage",
          "code": "def _encode(self, messages, encode_empty=False):\n        \"\"\"\n        Return an encoded version of the messages list which can be stored as\n        plain text.\n\n        Since the data will be retrieved from the client-side, the encoded data\n        also contains a hash to ensure that the data was not tampered with.\n        \"\"\"\n        if messages or encode_empty:\n            encoder = MessageEncoder()\n            value = encoder.encode(messages)\n            return self.signer.sign(value)"
        },
        {
          "file": "django/contrib/messages/storage/cookie.py",
          "type": "function",
          "name": "_decode",
          "class_name": "CookieStorage",
          "code": "def _decode(self, data):\n        \"\"\"\n        Safely decode an encoded text stream back into a list of messages.\n\n        If the encoded text stream contained an invalid hash or was in an\n        invalid format, return None.\n        \"\"\"\n        if not data:\n            return None\n        try:\n            decoded = self.signer.unsign(data)\n        except signing.BadSignature:\n            # RemovedInDjango40Warning: when the deprecation ends, replace\n            # with:\n            #   decoded = None.\n            decoded = self._legacy_decode(data)\n        if decoded:\n            try:\n                return json.loads(decoded, cls=MessageDecoder)\n            except json.JSONDecodeError:\n                pass\n        # Mark the data as used (so it gets removed) since something was wrong\n        # with the data.\n        self.used = True\n        return None"
        }
      ]
    },
    {
      "pr_number": 9512,
      "pr_title": "Fixed #28918 -- Fixed Model.refresh_from_db() for instances hidden by the default manager.",
      "pr_body": "https://code.djangoproject.com/ticket/28918",
      "issue_id": 28918,
      "issue_title": "Model.refresh_from_db() should use _base_manager instead of the default_manager",
      "issue_body": "When using\nrefresh_from_db\n, currently the\n_default_manager\nis used.\nBased upon the documentation at\n​\nhttps://docs.djangoproject.com/en/2.0/topics/db/managers/#default-managers\n, it seems that there's a requirement for\n_base_manager\nto not filter out results, while for\n_default_manager\nthere's just a preference for this to be the case.\nI think the stronger \"guarantee\" provided by\n_base_manager\nis more appropriate in this case.\nThe following patch both adds a test and fixes the issue.\ndiff --git a/django/db/models/base.py b/django/db/models/base.py\nindex 27ca63fd22..0813bedcb0 100644\n--- a/django/db/models/base.py\n+++ b/django/db/models/base.py\n@@ -591,7 +591,7 @@ class Model(metaclass=ModelBase):\n                     'are not allowed in fields.' % LOOKUP_SEP)\n\n         db = using if using is not None else self._state.db\n-        db_instance_qs = self.__class__._default_manager.using(db).filter(pk=self.pk)\n+        db_instance_qs = self.__class__._base_manager.using(db).filter(pk=self.pk)\n\n         # Use provided fields, if not set then reload all non-deferred fields.\n         deferred_fields = self.get_deferred_fields()\ndiff --git a/tests/custom_managers/tests.py b/tests/custom_managers/tests.py\nindex ee2ac1d552..61b1a07933 100644\n--- a/tests/custom_managers/tests.py\n+++ b/tests/custom_managers/tests.py\n@@ -643,3 +643,13 @@ class CustomManagersRegressTestCase(TestCase):\n         qs_custom = Person.custom_init_queryset_manager.all()\n         qs_default = Person.objects.all()\n         self.assertQuerysetEqual(qs_custom, qs_default)\n+\n+    def test_refresh_from_db_when_default_manager_filters(self):\n+        \"\"\"\n+        obj.refresh_from_db() should also fetch object if default manager\n+        hides it.\n+        \"\"\"\n+        book = Book._base_manager.create(is_published=False)\n+        Book._base_manager.filter(pk=book.pk).update(title='Hi')\n+        book.refresh_from_db()\n+        self.assertEqual(book.title, 'Hi')",
      "issue_closed_at": "2017-12-30T17:01:08",
      "base_commit": "dcdd219ee1e062dc6189f382e0298e0adf5d5ddf",
      "changes": [
        {
          "file": "django/db/models/base.py",
          "type": "function",
          "name": "refresh_from_db",
          "class_name": "Model",
          "code": "def refresh_from_db(self, using=None, fields=None):\n        \"\"\"\n        Reload field values from the database.\n\n        By default, the reloading happens from the database this instance was\n        loaded from, or by the read router if this instance wasn't loaded from\n        any database. The using parameter will override the default.\n\n        Fields can be used to specify which fields to reload. The fields\n        should be an iterable of field attnames. If fields is None, then\n        all non-deferred fields are reloaded.\n\n        When accessing deferred fields of an instance, the deferred loading\n        of the field will call this method.\n        \"\"\"\n        if fields is not None:\n            if not fields:\n                return\n            if any(LOOKUP_SEP in f for f in fields):\n                raise ValueError(\n                    'Found \"%s\" in fields argument. Relations and transforms '\n                    'are not allowed in fields.' % LOOKUP_SEP)\n\n        db = using if using is not None else self._state.db\n        db_instance_qs = self.__class__._default_manager.using(db).filter(pk=self.pk)\n\n        # Use provided fields, if not set then reload all non-deferred fields.\n        deferred_fields = self.get_deferred_fields()\n        if fields is not None:\n            fields = list(fields)\n            db_instance_qs = db_instance_qs.only(*fields)\n        elif deferred_fields:\n            fields = [f.attname for f in self._meta.concrete_fields\n                      if f.attname not in deferred_fields]\n            db_instance_qs = db_instance_qs.only(*fields)\n\n        db_instance = db_instance_qs.get()\n        non_loaded_fields = db_instance.get_deferred_fields()\n        for field in self._meta.concrete_fields:\n            if field.attname in non_loaded_fields:\n                # This field wasn't refreshed - skip ahead.\n                continue\n            setattr(self, field.attname, getattr(db_instance, field.attname))\n            # Throw away stale foreign key references.\n            if field.is_relation and field.is_cached(self):\n                rel_instance = field.get_cached_value(self)\n                local_val = getattr(db_instance, field.attname)\n                related_val = None if rel_instance is None else getattr(rel_instance, field.target_field.attname)\n                if local_val != related_val or (local_val is None and related_val is None):\n                    field.delete_cached_value(self)\n\n        # Clear cached relations.\n        for field in self._meta.related_objects:\n            if field.is_cached(self):\n                field.delete_cached_value(self)\n\n        self._state.db = db_instance._state.db"
        }
      ]
    }
  ]
}