python – (unittest)测试Flask-Security:无法通过登录页面
|
我正在尝试将测试添加到我的基本应用程序中.访问所有内容需要登录.
这是我的测试用例类: class MyAppTestCase(FlaskTestCaseMixin):
def _create_app(self):
raise NotImplementedError
def _create_fixtures(self):
self.user = EmployeeFactory()
def setUp(self):
super(MyAppTestCase,self).setUp()
self.app = self._create_app()
self.client = self.app.test_client()
self.app_context = self.app.app_context()
self.app_context.push()
db.create_all()
self._create_fixtures()
self._create_csrf_token()
def tearDown(self):
super(MyAppTestCase,self).tearDown()
db.drop_all()
self.app_context.pop()
def _post(self,route,data=None,content_type=None,follow_redirects=True,headers=None):
content_type = content_type or 'application/x-www-form-urlencoded'
return self.client.post(route,data=data,follow_redirects=follow_redirects,content_type=content_type,headers=headers)
def _login(self,email=None,password=None):
email = email or self.user.email
password = password or 'password'
data = {
'email': email,'password': password,'remember': 'y'
}
return self._post('/login',data=data)
class MyFrontendTestCase(MyAppTestCase):
def _create_app(self):
return create_app(settings)
def setUp(self):
super(MyFrontendTestCase,self).setUp()
self._login()
我正在运行我的测试在终端中使用nosetests,如下所示:source my_env / bin / activate&& nosetests –exe 像这样的基本测试失败: class CoolTestCase(MyFrontendTestCase):
def test_logged_in(self):
r = self._login()
self.assertIn('MyAppName',r.data)
def test_authenticated_access(self):
r = self.get('/myroute/')
self.assertIn('MyAppName',r.data)
从输出中,我看到r.data只是登录页面的HTML,没有错误(例如,错误的用户名或密码)或警报(“请登录以访问此页面”). 我在setUp进程中登录,所以test_authenticated_access应该让我访问/ myroute /或者使用闪烁的消息“请登录访问此页面”将我重定向到登录页面.但事实并非如此. 我无法弄清楚出了什么问题.我的测试基于我在Flask文档和this app boilerplate中找到的测试 解决方法
经过一周的自杀之后,我终于明白了…
有几个问题: > Flask-Security和Flask-SSLify之间存在一些冲突.虽然自动https重定向在实际的Web服务器上运行良好,但在测试中它可以防止完全登录.我通过制作假测试路线并尝试POST随机数据来解决这个问题.测试客户端没有POST工作.为了解决这个问题,我不得不将测试配置DEBUG更改为True.请注意,这不是一个很好的解决方法,因为CSS和JS之类的东西不会编译,其他应用程序行为可能会有所不同…… 有问题的代码: session = db.create_scoped_session()
class RoleFactory(SQLAlchemyModelFactory):
FACTORY_FOR = Role
FACTORY_SESSION = session
id = Sequence(int)
name = 'admin'
description = 'Administrator'
class EmployeeFactory(SQLAlchemyModelFactory):
FACTORY_FOR = Employee
FACTORY_SESSION = session
id = Sequence(int)
email = Sequence(lambda n: 'user{0}@app.com'.format(n))
password = LazyAttribute(lambda a: encrypt_password('password'))
username = Sequence(lambda n: 'user{0}'.format(n))
#last_login_at = datetime.utcnow()
#current_login_at = datetime.utcnow()
last_login_ip = '127.0.0.1'
current_login_ip = '127.0.0.1'
login_count = 1
roles = LazyAttribute(lambda _: [RoleFactory()])
active = True
这是我的测试用例: class MyAppTestCase(FlaskTestCaseMixin,MyTestCase):
def _create_app(self):
raise NotImplementedError
def _create_fixtures(self):
#self.user = EmployeeFactory()
populate_data(1)
def setUp(self):
super(MyAppTestCase,password=None):
email = email or 'matt@lp.com' #self.user.email
password = password or 'password'
data = {
'email': email,data=data)
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
