Rails测试《九》集成测试integration test

简介:

开场白

今天我们来熟悉一下rails的集成测试integration test。

 

简介

集成测试主要是测试多个controller之间的交互,以及测试应用中比较重要的工作流程,验证这些工作流程是否符合预期的设想。

 

不像单元测试和功能测试,是自动添加的。集成测试是需要我们手动添加的,rails提供了一个命令

rails generate integration_test

通过命令就可以在test/integration文件夹创建集成测试。

 
  1. $ rails generate integration_test user_flows 
  2.       exists  test/integration/ 
  3.       create  test/integration/user_flows_test.rb 

 

我们先来了解一些集成测试中常用的帮助方法。

 

 
  1. https? 

如果session正在模拟https请求,就返回true。

 

 
  1. https! 

允许你模拟https请求。

 

 
  1. host! 

允许你在下一次的请求中设置host name。

 

 
  1. redirect? 

如果上一次请求是一个跳转,就返回true。

 

 
  1. follow_redirect! 

紧跟着一个跳转的响应

 

 
  1. request_via_redirect(http_method, path, [parameters], [headers]) 

向指定的path发送http请求,可选parameters,可选headers,然后跟着一个跳转。

 

 
  1. post_via_redirect(path, [parameters], [headers]) 

向指定的path发送post请求,可选parameters,可选headers,然后跟着一个跳转。

 

 
  1. get_via_redirect(path, [parameters], [headers]) 

向指定的path发送get请求,可选parameters,可选headers,然后跟着一个跳转。

 

 
  1. put_via_redirect(path, [parameters], [headers]) 

向指定的path发送put请求,可选parameters,可选headers,然后跟着一个跳转。

 

 
  1. delete_via_redirect(path, [parameters], [headers]) 

向指定的path发送delete请求,可选parameters,可选headers,然后跟着一个跳转。

 

 
  1. open_session 

开启一个新的session

 

 

示例

让我们在创建好的集成测试文件test/integration/user_flows_test.rb中添加一些代码。

 

 
  1. require 'test_helper' 
  2.  
  3. class UserFlowsTest < ActionDispatch::IntegrationTest 
  4.   include FactoryGirl::Syntax::Methods 
  5.  
  6.   def test_admin_login_and_browse_posts 
  7.     user = FactoryGirl.create(:user_valid
  8.  
  9.     get "/signin" 
  10.     assert_response(200) 
  11.  
  12.     post_via_redirect("sessions", {:user=>{:email=> user.email, :password => user.password}}) 
  13.     assert_equal "/", path 
  14.     assert_equal "sign in successfully", flash[:notice
  15.  
  16.     get "admin/posts" 
  17.     assert_response(200) 
  18.     assert assigns(:posts
  19.    
  20.   end 
  21.  
  22. end 

上面的代码中,我们先是在users表中添加了一条记录。然后访问signin,然后断言是否返回200.

然后向sessions提交刚才添加的用户邮箱和密码,sessionscontroller是负责验证用户信息的controller。然后断言是否跳转到了根目录,是否出现了正确的flash提示信息。

最后访问admin/posts,断言是否返回200,并且返回posts变量。

 

上面的测试涉及了多个controller,测试覆盖从数据库到controller的调度分配。

 

我们可以同时模拟多个session,并且用extend扩展这些session,创建一些强大的测试用的DSL(Domain-Specific Language 领域描述语言)。

我们把上面的测试改成下面的样子。

 
  1. require 'test_helper' 
  2.  
  3. class UserFlowsTest < ActionDispatch::IntegrationTest 
  4.   include FactoryGirl::Syntax::Methods 
  5.  
  6.   def test_admin_login_and_browse_posts 
  7.     user = FactoryGirl.create(:user_valid
  8.     guest = FactoryGirl.create(:user_valid_too
  9.   
  10.     user_session = signin(user) 
  11.     guest_session = signin(guest) 
  12.  
  13.     assert_equal("sign in successfully", user_session.flash[:notice]) 
  14.     assert_equal("sign in successfully", guest_session.flash[:notice]) 
  15.  
  16.     user_session.browse_site 
  17.     guest_session.browse_site 
  18.    
  19.   end 
  20.  
  21.   private 
  22.  
  23.   module CustomDSL 
  24.     def browse_site 
  25.       get "admin/posts" 
  26.       assert_response(200) 
  27.       assert assigns(:posts
  28.     end 
  29.   end 
  30.  
  31.   def signin(user) 
  32.     open_session do |sess| 
  33.       sess.extend(CustomDSL) 
  34.       sess.post_via_redirect("sessions", {:user => {:email => user.email, :password => user.password}}) 
  35.        
  36.     end 
  37.   end 
  38.  
  39. end 

 

什么是DSL(领域描述语言)呢?

我理解就是业务描述语言。我们的应用一般是面向一个行业,或者说面向一个领域的,业务的语言就是领域描述语言。

 

如果能用这个领域的业务语言描述测试过程,那么这个测试就更加贴近业务,具有了很强的沟通能力。也就是说这个测试可以拿来和业务进行沟通,看看是不是他们想要的业务过程。

 

 




本文转自 virusswb 51CTO博客,原文链接:http://blog.51cto.com/virusswb/1079120,如需转载请自行联系原作者

目录
相关文章
|
1天前
|
机器学习/深度学习 敏捷开发 监控
深入探索软件测试中的持续集成与持续部署(CI/CD)实践
【5月更文挑战第10天】 在现代软件开发周期中,"持续集成"(CI)与"持续部署"(CD)是提升效率、确保质量的重要环节。本文将详细探讨CI/CD在软件测试中的应用,包括其基本概念、实施策略、工具应用及面临的挑战。不同于一般性概述,本文将重点分析如何优化测试流程以适应CI/CD环境,并提出针对性的改进措施。通过实际案例分析,揭示成功实施CI/CD的最佳实践,并讨论如何在不断变化的技术环境中保持测试策略的前瞻性和灵活性。
|
5天前
|
敏捷开发 监控 jenkins
探索自动化测试在持续集成环境中的关键作用
【5月更文挑战第6天】 在快速迭代的软件开发周期中,持续集成(CI)已经成为确保代码质量和加速交付的重要实践。本文将深入探讨自动化测试作为持续集成不可或缺的组成部分,它如何通过减少人为错误、提高测试覆盖率和加快反馈周期来强化软件开发流程。通过对现代自动化测试工具的评估以及真实案例的分析,我们揭示了自动化测试在提升软件可靠性和效率方面的核心价值,并提出了实现高效自动化测试策略的最佳实践。
|
5天前
|
敏捷开发 数据管理 测试技术
探索自动化测试在持续集成环境中的优化策略
【5月更文挑战第6天】 本文旨在深入剖析自动化测试在持续集成(CI)环境中所面临的挑战,并提出一系列创新的优化策略。通过对现代软件开发过程中自动化测试角色的分析,我们揭示了在快速迭代和部署的背景下,如何通过改进测试框架、选择合适的测试工具、以及实施数据驱动测试等手段来提高测试效率和准确性。文章不仅聚焦于技术层面的解决方案,还探讨了团队协作和流程管理对提升自动化测试效能的重要性。
|
8天前
|
敏捷开发 监控 测试技术
探索自动化测试在持续集成中的关键作用
【5月更文挑战第3天】 随着敏捷开发和持续集成(CI)实践的普及,自动化测试已成为确保软件质量和加速交付过程的核心环节。本文旨在深入探讨自动化测试在持续集成环境中的作用,重点分析其在提高测试效率、降低人力成本及维护软件质量保障体系中的重要性。通过实际案例研究,本文揭示了有效实施自动化测试策略的关键因素,并提出了一系列优化建议,以帮助软件开发团队充分利用自动化测试工具,实现持续交付的高效运作。
31 6
|
11天前
|
敏捷开发 监控 测试技术
探索自动化测试工具Selenium Grid的高效集成策略
【4月更文挑战第30天】在现代Web应用的快速迭代和持续部署中,测试自动化已成为确保产品质量的关键。Selenium Grid作为一款支持多种浏览器和操作系统的测试工具,提供了并行执行测试用例的能力,极大地提升了测试效率。本文将深入探讨如何高效地将Selenium Grid集成到现有的测试框架中,以及实施过程中的最佳实践,帮助团队最大化测试覆盖率,同时降低资源消耗。
|
11天前
|
中间件 测试技术 API
探索自动化测试工具的新边界:Selenium与Appium的集成实践
【4月更文挑战第30天】 随着移动应用和Web应用的不断融合,传统的自动化测试工具需要适应新的测试环境。本文将详细分析Selenium和Appium这两款流行的自动化测试工具的集成实践,探讨如何构建一个能够同时支持Web和移动端应用的自动化测试框架。通过对比两者的技术架构、功能特性以及在实际项目中的集成过程,我们旨在为读者提供一个清晰的指导,帮助他们在复杂的应用环境中实现高效、稳定的自动化测试流程。
|
11天前
|
监控 JavaScript 前端开发
【TypeScript技术专栏】TypeScript的单元测试与集成测试
【4月更文挑战第30天】本文讨论了在TypeScript项目中实施单元测试和集成测试的重要性。单元测试专注于验证单个函数、类或模块的行为,而集成测试关注不同组件的协作。选用合适的测试框架(如Jest、Mocha),配置测试环境,编写测试用例,并利用模拟和存根进行隔离是关键。集成测试则涉及组件间的交互,需定义测试范围,设置测试数据并解决可能出现的集成问题。将这些测试整合到CI/CD流程中,能确保代码质量和快速响应变化。
|
12天前
|
敏捷开发 监控 jenkins
探索自动化测试在持续集成中的关键角色
【4月更文挑战第29天】 随着敏捷开发和持续集成(CI)实践的不断演进,自动化测试已成为确保软件质量和加快交付速度的核心要素。本文深入探讨了自动化测试在持续集成流程中的作用,分析了其提升效率、降低风险及促进团队协作的多重价值,并提出了有效整合自动化测试与CI的策略。通过案例分析,我们进一步验证了自动化测试在现代软件开发生态中不可替代的地位,同时指出了实施过程中可能遇到的挑战以及相应的解决方案。
|
12天前
|
敏捷开发 监控 Devops
探索自动化测试在持续集成中的关键作用
【4月更文挑战第29天】 在现代软件开发的快节奏环境中,持续集成(CI)已成为确保代码质量和加快交付速度的重要实践。本文将深入探讨自动化测试作为持续集成不可或缺的组成部分,分析其在提高软件交付效率、降低风险和确保质量方面的核心价值。通过实际案例和最佳实践的分享,揭示如何有效地整合自动化测试与持续集成流程,并讨论面临的挑战及应对策略,为软件开发团队提供实用的参考和指导。
7 1
|
14天前
|
敏捷开发 Kubernetes 测试技术
深入理解软件测试中的持续集成与持续部署
【4月更文挑战第27天】 随着敏捷开发实践的普及,持续集成(CI)和持续部署(CD)成为软件开发周期中不可或缺的组成部分。本文旨在探讨CI/CD在软件测试中的应用及其对提高产品质量和加快上市速度的影响。通过对自动化测试、环境管理、版本控制等方面的分析,我们揭示了实施CI/CD的最佳实践,并讨论了如何克服常见挑战。文章的目的是为测试人员提供一个清晰的指南,帮助他们理解和实现一个高效的CI/CD流程。

热门文章

最新文章