Rails 5 Test Prescriptions(everday Rspectest作者推荐) 目录 1-3章
RSpec.info/documentation/
如何使用TDD 和 自动化测试来建立一个Rails app。
TDD让你用测试来探索代码的设计。你将学习可利用的工具,并学习用什么工具最好使。Tools comes and tools go, 工具是不断进化的,所以作者希望读者用最少的步骤写出更好的代码。
to help you write great app that do cool things and still catch the train home!
What's in this book?
开始介绍TDD,它为什么起作用,何时用TDD。
然后2章将使用RSpec来为新的Rails app 创建test.
之后几章节将单元测试基础,关于models, 多种方法生成测试数据,使用test doubles(替身) to simulate objects and specify hard-to-reach states.
然后end-to-end tests 集成测试和Capybara.
讨论JavaScript 先学习有JS 代码的end-to-end tests,然后学习JS单元测试。
然后,旅行到其他Rails部分,展示系统支持的工具。
12章还会了解使用Minitest来代替RSpec.
13-14章关于指定的场景测试,包括安全测试,测试第三方services.
15章 Debugging and Troubleshooting failing test.⚠️陌生
16章 关键写快速的代码和快速的写代码
17章 Legacy code 遗产代码,从他人那里继承的代码,等同于bad code.
What You'll Need
最新的Ruby2.5和Rails5.2,RSpec 3.7.1, Minitest 5.11.3
作者说RSpec学习曲线稍微陡峭,但这是业界使用最多的工具。Minitest 学习起来比较容易。
也就是经常说的: sometimes the best practice for learning isn't the best practice for experts.
本书版本的更新:
- 控制器测试被抛弃,集成测试会被结合RSpe讲解
- JS内容是新增的,包括集成和单元测试。Rails Webpacker来开发JS代码
- Capybara 集成现在使用headless Chrome作为Javascript driver。
- 代码样本从写。 factory_bot作为数据创建方法使用在最新的测试中。
下载代码案例
第一章 一个预言故事
不写测试的问题是,重构的时候还要手动测试,而写自动化测试几行不花费额外的时间。
写自动化测试可以防止你忘记测试的步骤。
if you do testing well, your work will go faster。
TDD可以减少bug并且容易改正bug。
TDD步骤:
- 创建测试。每个测试都应当简单,做一件事情。
- 确保测试失败。
- 写最简单的代码来通过当前测试。不要担心完整的代码,不要过于向前,步子要小。
- 测试通过后,重构改进代码。 去除重复。然后再运行测试。
- 重复以上步子
当你不知道程序需要做什么的时候,TDD没有什么用。因为如果你不指定用什么断言/期望,就没法写测试。 比如view-testing:这时需要先写一部分代码然后马上测试,灵活一点,作者称为:test-next mode。
在写测试前,先列出一个测试清单,注明你要测试的内容,以防忘记。
在rails 社区,仍有讨论TDD 破坏代码的问题。
作者认为TDD开发不能取代好的设计天赋,TDD仍可能创造bad code。
第2章Test-driven development Basics
Prescription3:(药方->决策)
Initializing objects is a good starting
place for a TDD process. Another good
approach is to use the test to design
what you want a successful interaction of
the feature to look like.
下面跟着案例章节走。只记录重点。
Install RSpec
git init, #建立版本控制系统。
mkdir gatherer -> cd gatherer
rails new . -> bundle install
rake db:create:all -> rake db:migrate
然后,安装gem 'rspec-rails' ->再次bundle install
rails generate rspec:install #生成初始化文件
⚠️在.rspec, 加上--format documentation
rails spec #测试是否安装成功。
Where to Start?
初始化对象是 TDD驱动测试开发的好的开始。另一个好方法是使用test来设计一个看起来成功的交互的功能。
建立spec/models/project_spec.rb,然后建立一个project的初始状态:
注解:
done?是自定义的方法, be_truthy是内建匹配器,判断actual_value是否是真,不是nil或false。
这是结构:expect(actual_value).to matcher
expect是RSpec定义的方法,接收任意object作为参数并return一个特殊的RSpec对象,这个对象被称为 ExpectationTarget.
然后这ExpectationTarget将作为matcher方法的参数,最后返回结果。
Running the test
使用rspec, 所有目录的文件都会被加载。
每个RSpec文件需要rails_helper文件加载Rails环境,和spec_helper.rb,这里包含非Rails的步骤。
rails_helper.rb会建立固件或预置件。
每个顶级call to RSpec.describe创建一个内部RSpec对象叫做 example group.
example group使用块参数让describe方法被执行。describe方法里面也可以内嵌example groups。
每个descirbe方法内可能包含it方法,每个it方法创造一个独立测试,这个测试叫做example。
在每个example group中先运行before(:all) 在所有案例运行结束后,运行after(:all)
每个案例也有before(:example), after(:example) 钩子方法。
Making the Test Pass
运行rspec会报错, uninitialized constant Project,当然了我没建立这个类。
然后有3个不同的解决办法:
- 最purist way: 写最少的代码让当前错误通过,不考虑更大范围的事情。
- Practical way: 写你需要最终写的代码,忽略太小的没有价值的步骤(不用测试了)
- The teaching way: 介于前两者之间。让TDD既不要陷于细节之中,也不会忽略过多步骤。
作者的态度,偏重purer。作者的经历,有时候因为过于实际了,导致问题没有理解和忽略了本该测试的步骤。
app/models/project.rb
class Project
end
然后再$rspec , ->undefined method `done?' for <Project:0x00007ff65db9b9b8>
定义done?方法,再测试->expected: truthy value got: nil
测试通过!
The Second Test(只记录重点。)
建立了Task.Project and Task都没有继承ActiveRecord。作者的目的是一步步来。
let
使用let重构。 let(:project) {Project.new}
let方法是一个语法糖。定义一个方法,调用这个方法会缓存这个结果。类似:
不调用就不存在。
let! 则是在定义let方法后,就始终存在:project变量
be_comlete匹配器,是自定义的。
如果没有定义方法 complete?,测试会报错:
expected #<Task:0x00007fe3ac637da0 @completed=false> to respond to `complete?`
知识点:
# Enumerable#all? 传递每个元素到块如果每次块返回的是true,则all?方法返回true,否则返回false
Adding Some Math
作者在写测试前会想这个测试需要什么,典型的测试结构
Rails 5 Test Prescriptions(everday Rspectest作者推荐) 目录 1-3章的更多相关文章
- Rails 5 Test Prescriptions 最后一章,如何测试继承下来的代码,legacy code
Set expectations 你不可能把一个老旧的代码野兽只用一晚就转变成优雅的奇迹marvel.你需要如下做法: 让自己有好的状态,用15分钟挥舞拳头诅咒之前的程序员 开始工作,这个codeba ...
- 老李推荐: 第1章1节《MonkeyRunner源码剖析》概述:前言
老李推荐: 第1章1节<MonkeyRunner源码剖析>概述:前言 前言 相信大家做过安卓移动平台UI自动化开发的必然会用过,至少听过MonkeyRunner这个名字.MonkeyR ...
- 老李推荐:第14章9节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-遍历控件树查找控件
老李推荐:第14章9节<MonkeyRunner源码剖析> HierarchyViewer实现原理-遍历控件树查找控件 poptest是国内唯一一家培养测试开发工程师的培训机构,以学员 ...
- 老李推荐:第14章5节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-装备ViewServer-查询ViewServer运行状态
老李推荐:第14章5节<MonkeyRunner源码剖析> HierarchyViewer实现原理-装备ViewServer-查询ViewServer运行状态 poptest是国内唯一 ...
- 老李推荐:第14章6节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-装备ViewServer-启动ViewServer
老李推荐:第14章6节<MonkeyRunner源码剖析> HierarchyViewer实现原理-装备ViewServer-启动ViewServer poptest是国内唯一一家培养 ...
- 老李推荐:第14章3节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-HierarchyViewer实例化
老李推荐:第14章3节<MonkeyRunner源码剖析> HierarchyViewer实现原理-HierarchyViewer实例化 poptest是国内唯一一家培养测试开发工程师的培 ...
- 老李推荐: 第14章2节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-HierarchyViewer架构概述
老李推荐: 第14章2节<MonkeyRunner源码剖析> HierarchyViewer实现原理-HierarchyViewer架构概述 HierarchyViewer库的引入让M ...
- 老李推荐:第14章1节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-面向控件编程VS面向坐标编程
老李推荐:第14章1节<MonkeyRunner源码剖析> HierarchyViewer实现原理-面向控件编程VS面向坐标编程 poptest是国内唯一一家培养测试开发工程师的培训机 ...
- 老李推荐:第8章7节《MonkeyRunner源码剖析》MonkeyRunner启动运行过程-小结
老李推荐:第8章7节<MonkeyRunner源码剖析>MonkeyRunner启动运行过程-小结 poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性 ...
随机推荐
- Mac下通过远程桌面向Windows发送Ctrl+Alt+Delete
今天在Mac中通过远程桌面给Windows安装Git Extensions,在安装程序自动关闭资源管理器时,Windows无响应,桌面显示黑屏.于是,想通过Ctrl+Alt+Delete快捷键调出对话 ...
- CVP沙龙
关于职场: 35岁之后,还去招聘网站投简历? 35岁可能是个分水岭 95后比一些80后还强, 有些80后玻璃心 35岁有的可能已经是VP了 应该深入积累而不是蜻蜓点水 只有第一年成长了,之后是重复劳动 ...
- Python开发【Django】:路由规则
Django路由规则 1.基于正则的URL 在templates目录下创建index.html.detail.html文件 <!DOCTYPE html> <html lang=&q ...
- 优云老王的心路历程(二):下一站Web体验监控产品
在上一篇文章中,和大家聊到了建立Web应用体验监控体系,经过了概念阶段,也完成了技术选型,就进入了把实质性的产品研发阶段.作为产品经理,时刻不敢忘记我们的产品目标:无限感知你的用户,建立完备的体验监控 ...
- django通用视图
通用视图 1. 前言 回想一下,在Django中view层起到的作用是相当于controller的角色,在view中实施的 动作,一般是取得请求参数,再从model中得到数据,再通过数据创建模板,返回 ...
- 洛谷P1373 小a和uim之大逃离 dp
正解:dp 解题报告: 传送门! 同样是看到列表发的题解就想着跟着做下dp的题目趴 然后发现还挺难的,,,反正我只大概想到怎么转移但是初始化什么的都不会TT 所以还是大概说下QAQ 首先可以想到设f[ ...
- (2.12)Mysql之SQL基础——存储过程条件定义与错误处理
转自:博客园桦仔 5.存储过程条件定义与错误处理 -- (1)定义 [1]条件定义:declare condition_name condition for condition_value;[2]错误 ...
- 数据挖掘-聚类分析(Python实现K-Means算法)
概念: 聚类分析(cluster analysis ):是一组将研究对象分为相对同质的群组(clusters)的统计分析技术.聚类分析也叫分类分析,或者数值分类.聚类的输入是一组未被标记的样本,聚类根 ...
- vim多行注释和取消注释 Ubuntu
多行注释: 1. 进入命令行模式,按ctrl + v进入 visual block模式,然后按d 是选择到最后一行,也可以直接光标上下左右,把需要注释的行标记起来 2. 按大写字母I,再插入注释符,例 ...
- python基础学习十 logging模块详细使用【转载】
很多程序都有记录日志的需求,并且日志中包含的信息既有正常的程序访问日志,还可能有错误.警告等信息输出,python的logging模块提供了标准的日志接口,你可以通过它存储各种格式的日志,主要用于输出 ...