python – 测试Flask登录和身份验证?

前端之家收集整理的这篇文章主要介绍了python – 测试Flask登录和身份验证?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在开发一个Flask应用程序,并使用Flask-security进行用户身份验证(其又使用Flask-login在下面).

我有一个需要身份验证的路由,/ user.我正在尝试编写一个单元测试,测试一下,对于经过身份验证的用户,这将返回相应的响应.

在我的单元测试中,我正在创建一个用户,并以该用户身份登录

from unittest import TestCase
from app import app,db
from models import User
from flask_security.utils import login_user

class UserTest(TestCase):
   def setUp(self):
       self.app = app
       self.client = self.app.test_client()
       self._ctx = self.app.test_request_context()
       self._ctx.push()

       db.create_all()

   def tearDown(self):
       if self._ctx is not None:
           self._ctx.pop()

       db.session.remove()
       db.drop_all()

   def test_user_authentication():
       # (the test case is within a test request context)
       user = User(active=True)
       db.session.add(user)
       db.session.commit()
       login_user(user)

       # current_user here is the user
       print(current_user)

       # current_user within this request is an anonymous user
       r = test_client.get('/user')

在测试中,current_user返回正确的用户.但是,请求的视图总是返回一个AnonymousUser作为current_user.

/用户路由定义为:

class CurrentUser(Resource):
    def get(self):
        return current_user  # returns an AnonymousUser

我相当确定我只是不完全了解如何测试Flask请求上下文.我读过这个Flask Request Context documentation一堆,但是我仍然不了解如何处理这个特定的单元测试.

解决方法

问题是test_client.get()调用会导致一个新的请求上下文被推送,所以你在你的测试用例的setUp()方法中推送的内容不是/ user handler看到的.

我认为在文档的Logging In and OutTest Adding Messages部分显示方法是测试登录的最佳方法.这个想法是通过应用程序发送登录请求,就像普通客户端一样.这将在测试客户端的用户会话中注意登录用户.

原文链接:https://www.f2er.com/python/186237.html

猜你在找的Python相关文章