Python测试驱动开发:使用Django、Selenium和JavaScript进行Web编程(第2版)
(英)哈利·J.W.帕西瓦尔更新时间:2020-05-06 16:36:23
最新章节:封面介绍封面
版权信息
O'Reilly Media Inc. 介绍
前言
准备工作和应具备的知识
配套视频
致谢
第一部分 TDD和Django基础
第1章 使用功能测试协助安装Django
1.1 遵从测试山羊的教诲,没有测试什么也别做
1.2 让Django运行起来
1.3 创建Git仓库
第2章 使用unittest模块扩展功能测试
2.1 使用功能测试驱动开发一个最简可用的应用
2.2 Python标准库中的unittest模块
2.3 提交
第3章 使用单元测试测试简单的首页
3.1 第一个Django应用,第一个单元测试
3.2 单元测试及其与功能测试的区别
3.3 Django中的单元测试
3.4 Django中的MVC、URL和视图函数
3.5 终于可以编写一些应用代码了
3.6 urls.py
3.7 为视图编写单元测试
第4章 测试(及重构)的目的
4.1 编程就像从井里打水
4.2 使用Selenium测试用户交互
4.3 遵守“不测试常量”规则,使用模板解决这个问题
4.4 关于重构
4.5 接着修改首页
4.6 总结:TDD流程
第5章 保存用户输入:测试数据库
5.1 编写表单,发送POST请求
5.2 在服务器中处理POST请求
5.3 把Python变量传入模板中渲染
5.4 事不过三,三则重构
5.5 Django ORM和第一个模型
5.6 把POST请求中的数据存入数据库
5.7 处理完POST请求后重定向
5.8 在模板中渲染待办事项
5.9 使用迁移创建生产数据库
5.10 回顾
第6章 改进功能测试:确保隔离,去掉含糊的休眠
6.1 确保功能测试之间相互隔离
6.2 升级Selenium和Geckodriver
6.3 隐式等待、显式等待和含糊的time.sleep
第7章 步步为营
7.1 必要时做少量的设计
7.2 使用TDD实现新设计
7.3 确保出现回归测试
7.4 逐步迭代,实现新设计
7.5 自成一体的第一步:新的URL
7.6 变绿了吗?该重构了
7.7 再迈一小步:一个新模板,用于查看清单
7.8 第三小步:用于添加待办事项的URL
7.9 下定决心,调整模型
7.10 每个列表都应该有自己的URL
7.11 功能测试又检测到回归
7.12 还需要一个视图,把待办事项加入现有清单
7.13 使用URL引入做最后一次重构
第二部分 Web开发要素
第8章 美化网站:布局、样式及其测试方法
8.1 如何在功能测试中测试布局和样式
8.2 使用CSS框架美化网站
8.3 Django模板继承
8.4 集成Bootstrap
8.5 Django中的静态文件
8.6 使用Bootstrap中的组件改进网站外观
8.7 使用自己编写的CSS
8.8 补遗:collectstatic命令和其他静态目录
8.9 没谈到的话题
第9章 使用过渡网站测试部署
9.1 TDD以及部署的危险区域
9.2 一如既往,先写测试
9.3 注册域名
9.4 手动配置托管网站的服务器
9.5 手动部署代码
9.6 手动部署大功告成
第10章 为部署到生产环境做好准备
10.1 换用Gunicorn
10.2 让Nginx伺服静态文件
10.3 换用Unix套接字
10.4 把DEBUG设为False,设置ALLOWED_HOSTS
10.5 使用Systemd确保引导时启动Gunicorn
10.6 考虑自动化
10.7 保存进度
第11章 使用Fabric自动部署
11.1 分析一个Fabric部署脚本
11.2 试用部署脚本
11.3 使用Git标签标注发布状态
11.4 延伸阅读
第12章 输入验证和测试的组织方式
12.1 针对验证的功能测试:避免提交空待办事项
12.2 功能测试新工具:通用显式等待辅助方法
12.3 补完功能测试
12.4 重构单元测试,分拆成多个文件
第13章 数据库层验证
13.1 模型层验证
13.2 在视图中显示模型验证错误
13.3 Django模式:在渲染表单的视图中处理POST请求
13.4 重构:去除硬编码的URL
第14章 简单的表单
14.1 把验证逻辑移到表单中
14.2 在视图中使用这个表单
14.3 在处理POST请求的视图中使用这个表单
14.4 在其他视图中使用这个表单
14.5 值得鼓励
14.6 这难道不是浪费时间吗
14.7 使用表单自带的save方法
第15章 高级表单
15.1 针对重复待办事项的功能测试
15.2 在视图层试验待办事项重复验证
15.3 处理唯一性验证的复杂表单
15.4 在清单视图中使用ExistingListItemForm
15.5 小结:目前所学的Django测试知识
第16章 试探JavaScript
16.1 从功能测试开始
16.2 安装一个基本的JavaScript测试运行程序
16.3 使用jQuery和<div>固件元素
16.4 为想要实现的功能编写JavaScript单元测试
16.5 固件、执行顺序和全局状态:JavaScript 测试的重大挑战
16.6 经验做法:onload样板代码和命名空间
16.7 JavaScript测试在TDD循环中的位置
16.8 一些缺憾
第17章 部署新代码
17.1 部署到过渡服务器
17.2 部署到线上服务器
17.3 如果看到数据库错误该怎么办
17.4 总结:为这次新发布打上Git标签
第三部分 高级话题
第18章 用户身份验证、探究及去掉探究代码
18.1 无密码验证
18.2 探索性编程(又名“探究”)
18.3 去掉探究代码
18.4 一个极简的自定义用户模型
18.5 令牌模型:把电子邮件地址与唯一的ID关联起来
第19章 使用驭件测试外部依赖或减少重复
19.1 开始之前布好基本管道
19.2 自己动手模拟(打猴子补丁)
19.3 Python的模拟库
19.4 去除自定义的身份验证后端中的探究代码
19.5 使用驭件的另一个原因:减少重复
19.6 关键时刻:功能测试能通过吗
19.7 理论上正常,那么实际呢
19.8 完善功能测试,测试退出功能
第20章 测试固件和一个显式等待装饰器
20.1 事先创建好会话,跳过登录过程
20.2 显式等待辅助方法最终版:wait装饰器
第21章 服务器端调试技术
21.1 实践是检验真理的唯一标准:在过渡服务器中捕获最后的问题
21.2 在服务器上通过环境变量设定机密信息
21.3 调整功能测试,以便通过POP3测试真实的电子邮件
21.4 在过渡服务器中管理测试数据库
21.5 集成日志相关的代码
21.6 小结
第22章 完成“My Lists”页面:由外而内的TDD
22.1 对立技术:“由内而外”
22.2 为什么选择使用“由外而内”
22.3 “My Lists”页面的功能测试
22.4 外层:表现层和模板
22.5 下移一层到视图函数(控制器)
22.6 使用由外而内技术,再让一个测试通过
22.7 视图层的下一个需求:新建清单时应该记录属主
22.8 下移到模型层
第23章 测试隔离和“倾听测试的心声”
23.1 重温抉择时刻:视图层依赖于尚未编写的模型代码
23.2 首先尝试使用驭件实现隔离
23.3 倾听测试的心声:丑陋的测试表明需要重构
23.4 以完全隔离的方式重写视图测试
23.5 下移到表单层
23.6 下移到模型层
23.7 关键时刻,以及使用模拟技术的风险
23.8 把层与层之间的交互当作“合约”
23.9 还缺一个测试
23.10 清理:保留哪些整合测试
23.11 总结:什么时候编写隔离测试,什么时候编写整合测试
第24章 持续集成
24.1 安装Jenkins
24.2 配置Jenkins
24.3 设置项目
24.4 第一次构建
24.5 设置虚拟显示器,让功能测试能在无界面的环境中运行
24.6 截图
24.7 如有疑问,增加超时试试
24.8 使用PhantomJS运行QUnit JavaScript测试
24.9 CI服务器能完成的其他操作
第25章 简单的社会化功能、页面模式以及练习
25.1 有多个用户以及使用addCleanup的功能测试
25.2 页面模式
25.3 扩展功能测试测试第二个用户和“My Lists”页面
25.4 留给读者的练习
第26章 测试运行速度的快慢和炽热的岩浆
26.1 正题:单元测试除了运行速度超快之外还有其他优势
26.2 纯粹的单元测试有什么问题
26.3 合题:我们到底想从测试中得到什么
26.4 架构方案
26.5 小结
遵从测试山羊的教诲
测试很难
别忘了给吧台服务员小费
别见外
附录A PythonAnywhere
附录B 基于类的Django视图
附录C 使用Ansible配置服务器
附录D 测试数据库迁移
附录E 行为驱动开发
附录F 构建一个REST API:JSON、Ajax和 JavaScript模拟技术
附录G Django-Rest-Framework
附录H 速查表
附录I 接下来做什么
附录J 示例源码
参考书目
作者简介
封面介绍
更新时间:2020-05-06 16:36:23