5

我使用 django-social-auth 作为我的身份验证机制,我需要使用登录用户测试我的应用程序。我正在努力:

from django.test import Client
c = Client()
c.login(username='myfacebook@username.com", password='myfacebookpassword')

尝试登录的用户从浏览器登录成功。该应用程序已被允许访问用户的数据。

使用 django-social-auth 作为身份验证机制时如何从单元测试登录有什么想法吗?

谢谢

4

1 回答 1

2

使用用户实例创建一个夹具

{
    "pk": 15,
    "model": "auth.user",
    "fields": {
        "username": "user",
        "first_name": "user",
        "last_name": "userov",
        "is_active": true,
        "is_superuser": false,
        "is_staff": false,
        "last_login": "2012-07-20 15:37:03",
        "groups": [],
        "user_permissions": [],
        "password": "!",
        "email": "",
        "date_joined": "2012-07-18 13:29:53"
    }
}

像这样使用 SocialAuthUser 实例创建一个夹具

{
    "pk": 7,
    "model": "social_auth.usersocialauth",
    "fields": {
        "uid": "1234567",
        "extra_data": "%some account social data%",
        "user": 15,
        "provider": "linkedin"
    }
}

因此,您将获得与真实用户具有相同行为并拥有您需要的所有社交数据的用户。设置新密码,然后您可以使用身份验证机制登录该用户:

...
user.set_password('password')
user.save()                    
logged_in = self.client.login(username='user', password='password')

然后只需调用需要登录的视图

self.client.get("some/url")

不要忘记,这django.contrib.auth.backends.ModelBackend是必需的,并且django.contrib.sessions应该在您的 INTALLED_APPS 元组中

此外,使用标准身份验证的优点是您不需要发出服务器请求来获取 oauth 令牌等。

于 2012-07-27T15:43:07.280 回答