Проблема: Когда я добавляю UpdateCacheMiddleware и FetchFromCacheMiddleware в мой проект Django, я получаю сбои unittest. Это независимо от того, какой 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
Я, должно быть, что-то упустил (или сделал что-то не так), так как я искал в Интернете эту проблему, но, похоже, никто не сталкивался с ней.
Шаги для воспроизведения:
- Запустите новый проект django (django-admin.py startproject myproject) и настройте settings.py
- Добавьте CACHE_BACKEND в settings.py и добавьте два промежуточных программного обеспечения Cache от Django
- Запустить тест python manage.py
Примечания: При использовании dummy: // cache есть только один сбой теста, который задокументирован по адресу: http://code.djangoproject.com/ticket/11640