我想伪造单元测试的请求参数。我怎样才能在Flask中实现这一目标?
答案 0 :(得分:51)
您是否阅读过Flask docs about testing?
您可以使用以下内容:
self.app.post('/path-to-request', data=dict(var1='data1', var2='data2', ...))
self.app.get('/path-to-request', query_string=dict(arg1='data1', arg2='data2', ...))
Flask的当前开发版本还包括对testing JSON APIs的支持:
from flask import request, jsonify
@app.route('/jsonapi')
def auth():
json_data = request.get_json()
attribute = json_data['attr']
return jsonify(resp=generate_response(attribute))
with app.test_client() as c:
rv = c.post('/jsonapi', json={
'attr': 'value', 'other': 'data'
})
json_data = rv.get_json()
assert generate_response(email, json_data['resp'])
答案 1 :(得分:29)
POST:
self.app.post('/endpoint', data=params)
GET:
self.app.get('/endpoint', query_string=params)
答案 2 :(得分:2)
如果您更喜欢使用test_request_context
:
import unittest from myapp import extract_query_params testapp = flask.Flask(__name__) class TestFoo(unittest.TestCase): def test_happy(self): with testapp.test_request_context('?limit=1&offset=2'): limit, offset = extract_query_params(['limit', 'offset']) self.assertEquals(limit, 1) self.assertEquals(offset, 2)
答案 3 :(得分:1)
这是单元测试的完整代码示例
testapp = app.test_client()
class Test_test(unittest.TestCase):
def test_user_registration_bad_password_short(self):
response = self.register(name='pat',
email='me@mail.com',
password='Flask',
password2='Flask')
self.assertEqual(response.status_code, 200)
self.assertIn(b'password should be 8 or more characters long',
response.data)
def register(self, name, email, password, password2):
return testapp.post(
'/register',
data=dict(username=name,
email=email,
password=password,
password2=password2),
follow_redirects=True
)
答案 4 :(得分:0)
在测试用于登录的表格数据时,我仍然遇到了这个问题。
def login(self, username, password):
return self.app.post('/', data='Client_id=' + username +'&Password=' + password,
follow_redirects=True,content_type='application/x-www-form-urlencoded')
我发现这是出于这种方式。
铬: 开发者模式 - > Doc - >请求的HTML文档 - >标题标签 - >表格数据 - >查看来源
答案 5 :(得分:0)
我需要一个简单的单元测试请求,这是一个简单的解决方案:
from flask import Request
r = Request({})