gpt4 book ai didi

python - Flask-Login is_authenticated 不一致

转载 作者:太空宇宙 更新时间:2023-11-04 05:43:52 28 4
gpt4 key购买 nike

我正在使用一个测试单元来验证 Flask-Login 的登录。这样做的目的是验证凭据不正确的用户的行为:

    def test_login_user(self):
'''test user login'''
user = User(email='teste@teste.com', pass='teste')
db.session.add(user)
db.session.commit()

response = self.app.post('/login_user', data={'email':
'teste@teste.com', 'pass': 'tste'}, follow_redirects=True)

print(response.get_data(), user.is_authenticated)
assert user.is_authenticated == True
self.assertEqual(response.status, "200 OK")

问题是 assert user.is_authenticated 通过了测试,即使最后一个断言失败了:

Traceback (most recent call last):
File "./test.py", line 58, in test_login_user
self.assertEqual(response.status, "200 OK")
AssertionError: '401 UNAUTHORIZED' != '200 OK'
- 401 UNAUTHORIZED
+ 200 OK

我的登录 View 实现如下:

@app.route('/login_user', methods=['GET', 'POST'])
def login_user():
if request.method == 'POST':
user_requested = User.query.filter_by(email=request.form['email']).first()
if user_requested is not None:
if sha256_crypt.verify(request.form['pass'], user_requested.pass):
return redirect(url_for('student'))
return redirect(url_for('error'))

此外,在 User 类上,我正在扩展 UserMixin。为什么 user.is_authenticated 不返回 False?

最佳答案

您没有在登录 View 中调用 login_user。当您重定向时,login_required 在 protected View 上失败。在重定向之前将您从数据库中获取的用户传递给 login_user

所有用户实例都经过身份验证,即使他们没有登录。只有匿名用户没有经过身份验证。查看上下文中的 current_user 以查看哪个用户已登录。您可以通过使用 with app.test_client() as c block 来保持上下文。

with app.test_client() as c:
r = c.post('/login', data={...})
self.assertEqual(current_user.email, '...')

这是 Flask-Login 设置和测试的最小示例。

import unittest
from flask import Flask, redirect, url_for, request
from flask.ext.login import login_required
from flask_login import LoginManager, UserMixin, login_user, current_user

class TestApp(unittest.TestCase):
def setUp(self):
app.testing = True

def tearDown(self):
app.testing = False

def test_login(self):
with app.test_client() as c:
r = c.post('/login', data={'id': 400617}, follow_redirects=True)
# current_user is only set in context
self.assertEqual(current_user.id, 400617)

# resopnse doesn't depend on context, so can be tested outside block
self.assertEqual(r.status, '200 OK')
# any non-anonymous user is authenticated, even if not logged in
self.assertTrue(User(123).is_authenticated)

app = Flask(__name__)
app.secret_key = 'Stack Overflow'
login = LoginManager(app)
login.login_view = 'login'

class User(UserMixin):
def __init__(self, id):
self.id = id

@login.user_loader
def user_loader(id):
return User(int(id))

@app.route('/')
@login_required
def index():
return 'index'

@app.route('/login', methods=['GET', 'POST'])
def login():
if request.method == 'POST':
user = User(id=request.form.get('id', type=int))
login_user(user)
return redirect(url_for('index'))

return 'login'
$ python -m unittest -v app
test_login (app.TestApp) ... ok

----------------------------------------------------------------------
Ran 1 test in 0.017s

OK

关于python - Flask-Login is_authenticated 不一致,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32926072/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com