使用 Django 缓存中间件导致 contrib.auth 单元测试失败

2024-03-11

Problem:当我将 UpdateCacheMiddleware 和 FetchFromCacheMiddleware 添加到 Django 项目时,单元测试失败。这与我使用的 CACHE_BACKEND 无关(现在我使用的是 locmem://,但当我使用 file:///path_to_cache 时错误是相同的)

我的中间件:

MIDDLEWARE_CLASSES = (
    'django.middleware.cache.UpdateCacheMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.cache.FetchFromCacheMiddleware',
)

我所有的测试失败都如下所示:“NoneType”对象不可订阅

======================================================================
Error: test_last_login (django.contrib.auth.tests.remote_user.RemoteUserTest)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "C:\Python26\lib\site-packages\django\contrib\auth\tests\remote_user.py",
 line 87, in test_last_login
    self.assertNotEqual(default_login, response.context['user'].last_login)
TypeError: 'NoneType' object is unsubscriptable

当我在网上搜索这个问题时,我一定错过了一些东西(或者做错了什么),但似乎没有人遇到过它。

重现步骤:

  1. 启动一个新的django项目(django-admin.py startproject myproject)并配置settings.py
  2. 将 CACHE_BACKEND 添加到 settings.py 并添加 Django 中的两个缓存中间件
  3. 运行 python manage.py 测试

Notes:使用 dummy:// 缓存时只有一次测试失败,记录在:http://code.djangoproject.com/ticket/11640 http://code.djangoproject.com/ticket/11640


失败测试的解决方案是将 CACHE_MIDDLEWARE_SECONDS 设置为 0(例如,在您的开发环境中将其设置为 0)。这将使 django.contrib 测试全部通过。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用 Django 缓存中间件导致 contrib.auth 单元测试失败 的相关文章

随机推荐