refactor upload files with requests-toolbelt:

1, Simplify usage syntax;
2, support upload multiple fields.
This commit is contained in:
debugtalk
2019-04-11 12:25:20 +08:00
parent 4d09ddd688
commit e58e87befe
6 changed files with 59 additions and 20 deletions

View File

@@ -11,6 +11,7 @@ har2case = "*"
colorama = "*"
colorlog = "*"
requests-toolbelt = "*"
filetype = "*"
[dev-packages]
Flask = "<1.0.0"

View File

@@ -1,7 +1,7 @@
__title__ = 'HttpRunner'
__description__ = 'One-stop solution for HTTP(S) testing.'
__url__ = 'https://github.com/HttpRunner/HttpRunner'
__version__ = '2.1.0'
__version__ = '2.1.1'
__author__ = 'debugtalk'
__author_email__ = 'mail@debugtalk.com'
__license__ = 'Apache-2.0'

View File

@@ -12,10 +12,13 @@ import re
import string
import time
import filetype
from httprunner.compat import basestring, builtin_str, integer_types, str
from httprunner.exceptions import ParamsError
from requests_toolbelt import MultipartEncoder
PWD = os.getcwd()
""" built-in functions
"""
@@ -38,17 +41,54 @@ def get_current_date(fmt="%Y-%m-%d"):
"""
return datetime.datetime.now().strftime(fmt)
def multipart_encoder(field_name, file_path, file_type=None, file_headers=None):
if not os.path.isabs(file_path):
file_path = os.path.join(os.getcwd(), file_path)
filename = os.path.basename(file_path)
with open(file_path, 'rb') as f:
fields = {
field_name: (filename, f.read(), file_type)
}
def multipart_encoder(**kwargs):
""" upload files with requests-toolbelt
- test:
name: upload file
variables:
file_path: "data/test.env"
multipart_encoder: ${multipart_encoder(file=$file_path)}
request:
url: /post
method: POST
headers:
Content-Type: ${multipart_content_type($multipart_encoder)}
data: $multipart_encoder
validate:
- eq: ["status_code", 200]
- startswith: ["content.files.file", "UserName=test"]
"""
def get_filetype(file_path):
file_type = filetype.guess(file_path)
if file_type:
return file_type.mime
else:
return "text/html"
fields_dict = {}
for key, value in kwargs.items():
if os.path.isabs(value):
_file_path = value
is_file = True
else:
global PWD
_file_path = os.path.join(PWD, value)
is_file = os.path.isfile(_file_path)
if is_file:
filename = os.path.basename(_file_path)
with open(_file_path, 'rb') as f:
mime_type = get_filetype(_file_path)
fields_dict[key] = (filename, f.read(), mime_type)
else:
fields_dict[key] = value
return MultipartEncoder(fields=fields_dict)
return MultipartEncoder(fields)
def multipart_content_type(multipart_encoder):
return multipart_encoder.content_type

View File

@@ -8,8 +8,7 @@ import os
import sys
import yaml
from httprunner import exceptions, logger, parser, utils, validator
from httprunner import built_in, exceptions, logger, parser, utils, validator
###############################################################################
## file loader
@@ -263,7 +262,6 @@ def load_module_functions(module):
def load_builtin_functions():
""" load built_in module functions
"""
from httprunner import built_in
return load_module_functions(built_in)
@@ -703,6 +701,7 @@ def load_project_tests(test_path, dot_env_path=None):
# locate PWD and load debugtalk.py functions
project_mapping["PWD"] = project_working_directory
built_in.PWD = project_working_directory
project_mapping["functions"] = debugtalk_functions
# load api

View File

@@ -21,7 +21,8 @@ install_requires = [
"har2case",
"colorama",
"colorlog",
"requests_toolbelt"
"requests_toolbelt",
"filetype"
]
class UploadCommand(Command):

View File

@@ -5,17 +5,15 @@
- test:
name: upload file
variables:
field_name: "file"
file_path: "LICENSE"
file_type: "text/html"
multipart_encoder: ${multipart_encoder($field_name, $file_path, $file_type)}
file_path: "data/test.env"
multipart_encoder: ${multipart_encoder(file=$file_path)}
request:
url: /post
method: POST
headers:
Content-Type: ${multipart_content_type($multipart_encoder)}
data: $multipart_encoder
validators:
validate:
- eq: ["status_code", 200]
- startswith: ["content.files.file", "MIT License"]
- startswith: ["content.files.file", "UserName=test"]