Tornado Unit Testing - Tornado应用的单元测试

简介:

之前在测试Django应用时,使用了非常方便的django.test.TestCase。在测试Tornado时,我也包装了一个TestCase类,提供和Django一样便捷的测试方法。最终,测试案例的代码将会是这样:

复制代码
from  testclient  import  TestCase

class  QueryTest(TestCase):
    
def  setUp(self):
        
pass
    
def  test_query(self):
        file 
=  open( ' uploadfile.dat ' ' rb ' )
        response 
=  self.client.post( ' /query ' , {  ' a ' ' 1 ' 'b''2', 'upload ' : file })

        self.failUnlessEqual(response.status_code, 
200 )
        self.failUnlessEqual(response.content, 
' ok ' )
复制代码


testclient.py的代码如下: 

复制代码
代码
# !/usr/bin/env python
#
coding:utf-8
#
#
 Copyright 2009 CoderZh.com.
#
 Licensed under the Apache License, Version 2.0 (the "License");
#
 you may not use this file except in compliance with the License.
#
 You may obtain a copy of the License at
#
#
     http://www.apache.org/licenses/LICENSE-2.0
#
#
 Unless required by applicable law or agreed to in writing, software
#
 distributed under the License is distributed on an "AS IS" BASIS,
#
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#
 See the License for the specific language governing permissions and
#
 limitations under the License.

__author__   =   ' CoderZh '


import  tornado.ioloop
import  unittest
import  mimetypes

import  tornado.httpclient
import  tornado.ioloop

TEST_PORT 
=   8989

def  encode_multipart_formdata(fields, files):
    
"""
    fields is a sequence of (name, value) elements for regular form fields.
    files is a sequence of (name, filename, value) elements for data to be uploaded as files
    Return (content_type, body) ready for httplib.HTTP instance
    
"""
    BOUNDARY 
=   ' ----------ThIs_Is_tHe_bouNdaRY_$ '
    CRLF 
=   ' \r\n '
    L 
=  []
    
for  (key, value)  in  fields:
        L.append(
' -- '   +  BOUNDARY)
        L.append(
' Content-Disposition: form-data; name="%s" '   %  key)
        L.append(
'' )
        L.append(value)
    
for  (key, filename, value)  in  files:
        L.append(
' -- '   +  BOUNDARY)
        L.append(
' Content-Disposition: form-data; name="%s"; filename="%s" '   %  (key, filename))
        L.append(
' Content-Type: %s '   %  get_content_type(filename))
        L.append(
'' )
        L.append(value)
    L.append(
' -- '   +  BOUNDARY  +   ' -- ' )
    L.append(
'' )
    body 
=  CRLF.join(L)
    content_type 
=   ' multipart/form-data; boundary=%s '   %  BOUNDARY
    
return  content_type, body

def  get_content_type(filename):
    
return  mimetypes.guess_type(filename)[0]  or   ' application/octet-stream '


class  Response:
    
def   __init__ (self, status_code, content):
        self.status_code 
=  status_code
        self.content 
=  content

class  Client:
    
    
def  handle_request(self, response):
        self.response 
=  response
        tornado.ioloop.IOLoop.instance().stop()
    
    
def  post(self, url, data = {}):
    url 
=   ' http://127.0.0.1:%s%s '   %  (TEST_PORT, url)
        fields 
=  []
        files 
=  []
        
for  key, value  in  data.items():
            
if  isinstance(value, file):
                files.append([key, value.name, value.read()])
            
else :
                fields.append([key, value])
                
        content_type, body 
=  encode_multipart_formdata(fields, files)
        headers 
=  { ' Content-Type '  : content_type}
        
        request 
=  tornado.httpclient.HTTPRequest(url = url,
                         method
= ' POST ' ,
                         headers
= headers,
                         body
= body)

        client 
=  tornado.httpclient.AsyncHTTPClient()
        client.fetch(request , self.handle_request)    
        tornado.ioloop.IOLoop.instance().start()
        
        
return  Response(self.response.code, self.response.body)
    
class  TestCase(unittest.TestCase):
    
def  _pre_setup(self):
       
pass
    
    
def  _post_teardown(self):
       
pass
    
    
def   __call__ (self, result = None):
        
"""
        Wrapper around default __call__ method to perform My test
        set up. This means that user-defined Test Cases aren't required to
        include a call to super().setUp().
        
"""
        self.client 
=  Client()
        
try :
            self._pre_setup()
        
except  (KeyboardInterrupt, SystemExit):
            
raise
        
except  Exception:
            
import  sys
            result.addError(self, sys.exc_info())
            
return
        super(TestCase, self).
__call__ (result)
        
try :
            self._post_teardown()
        
except  (KeyboardInterrupt, SystemExit):
            
raise
        
except  Exception:
            
import  sys
            result.addError(self, sys.exc_info())
            
return
复制代码
 
本文转自CoderZh博客园博客,原文链接:http://www.cnblogs.com/coderzh/archive/2010/01/01/Tornado-Unit-Testing.html,如需转载请自行联系原作者
 
相关文章
|
2月前
|
敏捷开发 测试技术 持续交付
探索自动化测试在敏捷开发中的应用与挑战
本文深入探讨了自动化测试在现代软件开发流程,特别是敏捷开发环境中的重要作用和面临的挑战。通过分析自动化测试的基本原理、实施策略以及在实际项目中的应用案例,揭示了其在提高软件质量和加速产品交付方面的巨大潜力。同时,文章也指出了自动化测试实施过程中可能遇到的技术难题、成本考量及团队协作问题,并提出了相应的解决策略,为软件开发团队提供了有价值的参考和指导。
|
1月前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
2月前
|
编解码 测试技术 开发工具
测试 iPhone 应用在不同屏幕尺寸和分辨率下的响应式效果
【10月更文挑战第23天】测试 iPhone 应用在不同屏幕尺寸和分辨率下的响应式效果是确保应用质量和用户体验的重要环节。通过手动测试、自动化测试、视觉效果评估、性能测试、用户体验测试等多种方法的综合运用,能够全面地发现应用在响应式效果方面存在的问题,并及时进行解决和优化。同时,持续的测试和优化也是不断提升应用质量和用户满意度的关键。
|
2月前
|
jenkins 测试技术 持续交付
探索自动化测试在持续集成中的应用与挑战
本文深入探讨了自动化测试在现代软件开发流程,特别是持续集成(CI)环境中的关键作用。通过分析自动化测试的优势、实施策略以及面临的主要挑战,旨在为开发团队提供实用的指导和建议。文章不仅概述了自动化测试的基本原理和最佳实践,还详细讨论了如何克服实施过程中遇到的技术难题和管理障碍,以实现更高效、更可靠的软件交付。
|
2月前
|
机器学习/深度学习 人工智能 测试技术
探索自动化测试框架在软件开发中的应用与挑战##
本文将深入探讨自动化测试框架在现代软件开发过程中的应用,分析其优势与面临的挑战。通过具体案例分析,揭示如何有效整合自动化测试以提升软件质量和开发效率。 ##
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
69 1
|
2月前
|
敏捷开发 监控 jenkins
探索自动化测试框架在敏捷开发中的应用与优化##
本文深入探讨了自动化测试框架在现代敏捷软件开发流程中的关键作用,分析了其面临的挑战及优化策略。通过对比传统测试方法,阐述了自动化测试如何加速软件迭代周期,提升产品质量,并针对实施过程中的常见问题提出了解决方案。旨在为读者提供一套高效、可扩展的自动化测试实践指南。 ##
51 9
|
2月前
|
监控 安全 测试技术
如何在实际项目中应用Python Web开发的安全测试知识?
如何在实际项目中应用Python Web开发的安全测试知识?
37 4
|
2月前
|
监控 JavaScript 前端开发
如何在实际应用中测试和比较React和Vue的性能?
总之,通过多种方法的综合运用,可以相对客观地比较 React 和 Vue 在实际应用中的性能表现,为项目的选择和优化提供有力的依据。
45 1
|
2月前
|
自然语言处理 安全 测试技术
基于大模型的应用的测试的一些注意事项
大模型应用测试需注意三大冲突:时间敏感性冲突,即模型数据可能随时间变得过时;数据真实性冲突,指训练数据中可能存在虚假信息,影响模型准确性;数据一致性冲突,表现为模型对语义相同但句法不同的输入反应不一。测试时应针对这些问题设计用例,确保模型性能。
80 4