9

我的 Django 站点在生产中使用 LDAP 后端进行身份验证,但这不适合测试(不可能从虚拟用户创建请求)。我如何禁用此后端,仅用于测试?

这是相关的 settings.py 部分:

    AUTHENTICATION_BACKENDS = (
#'crowd.backend.CrowdBackend',
# 'django_auth_ldap.backend.LDAPBackend',
'django.contrib.auth.backends.ModelBackend',
    )
   AUTH_LDAP_SERVER_URI = "ldap://ldap.cablelabs.com"
   import ldap
   from django_auth_ldap.config import LDAPSearch

   AUTH_LDAP_BIND_DN = "CN=CableLabs  Internal,OU=cabletest,OU=Teamwork,OU=community,DC=cablelabs,DC=com"
   AUTH_LDAP_BIND_PASSWORD = "UAq,0@ki"
   AUTH_LDAP_USER_SEARCH = LDAPSearch("ou=community,dc=cablelabs,dc=com",ldap.SCOPE_SUBTREE, "(sAMAccountName=%(user)s)")
   AUTH_LDAP_USER_ATTR_MAP = {"first_name": "givenName", "last_name": "sn","username":"sAMAccountName","email":"mail","photo":"thumbnailPhoto"} 
   AUTH_LDAP_CONNECTION_OPTIONS = {
     ldap.OPT_REFERRALS: 0
   }
4

3 回答 3

18

如果您只需要/想要为某些测试禁用后端,您也可以使用override_settings装饰器。您可以在测试用例类上使用此装饰器:

from django.test.utils import override_settings

@override_settings(AUTHENTICATION_BACKENDS=
                   ('django.contrib.auth.backends.ModelBackend',))
class FooTest(TestCase):

    def test_bar(self):
        pass

但是您也可以有选择地在测试方法上使用它:

from django.test.utils import override_settings

class FooTest(TestCase):

    @override_settings(AUTHENTICATION_BACKENDS=
                       ('django.contrib.auth.backends.ModelBackend',))
    def test_bar(self):
        pass
于 2013-10-09T08:31:46.030 回答
14

例如myproj/test_settings.py,创建一个替代设置文件,并在运行单元测试时指定该设置文件。

像这样编写替代设置文件:

from myproj.settings import *

AUTHENTICATION_BACKENDS = (
        #'your.ldap.backend',
        'django.contrib.auth.backends.ModelBackend',
        )

也就是说,这些设置继承了常规设置中的所有内容,但会覆盖AUTHENTICATION_BACKENDS定义,并将您的 LDAP 后端注释掉。

然后,像这样运行您的测试:

python manage.py test --settings=myproj.test_settings
于 2013-07-05T21:51:28.273 回答
0

为了将来参考,另一个测试选项是is_authenticated将对象的属性更改User为 lambda。例如:

user = User(...)
user.is_authenticated = lambda: True
于 2014-10-04T05:43:50.717 回答