一个电商项目的Web服务化改造6:单元测试4步走,构造数据、执行操作、断言、回滚
单元测试,在很早之前的文章已经介绍过。
可以在这里看到相关的几篇文章:http://blog.csdn.net/FansUnion/article/category/1333595/2
在这次Web服务化改造中,理论上有4层需要测试。
1. Mybatis的mapper层,mapper.java和,mapper.xml,
2. 负责数据组装的Dao层,Dao.java。
3.负责业务逻辑的Service层,Service.java。
4.经过Dubbo包装之后的WebService层,WebService.java。
考虑到实际情况,mapper层没有写相关的单元测试,只写了另外3层的。
同时需要注意到的是,Service层和WebService层,内部代码可以说是完全一样,唯一不同的是,Service调用的是本地代码,而WebService调用的是远程的代码。
Dao层的单元测试:初始化数据,然后就是“单元测试标准4步”,构造数据-执行操作-断言-回滚。
初始化:Spring和JUnit结合提供了注解支持,配置dataSource.xml就可以了。
构造数据:手动构造brand对象
执行操作:我们自己写的add、get等方法
断言:增加add之后,数据库中的数据和我们插入的数据,是否完全一样
回滚:执行操作之后,数据库回滚。也就是说,单元测试,不会“污染”数据库。
Service层的单元测试
Service层和Dao层流程基本一致,初始化+标准4步。
不同点:service初始化,需要配置spring上下文,上下文文件中,再引入dataSource.xml。
spring-context-nodubbo.xml
Dubbo的WebService的单元测试
总体流程,和Service一模一样。
需要注意的地方:
1.引入的context不一样,里面有dubbo配置。
这个地方的单元测试,注入的bean,是dubbo包装的。
而service层,是本地的bean。
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
- xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsd
- http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd
- ">
- <dubbo:application name="ws-demo" />
- <dubbo:registry address="N/A" />
- <dubbo:reference id="brandService" interface="cn.fansunion.webservice.service.front.BrandService" version="1.0.0"
- url="webservice://127.0.0.1:9000/cn.fansunion.webservice.service.front.BrandService"/>
- <dubbo:reference id="redmanService" interface="cn.fansunion.webservice.service.front.RedmanService" version="1.0.0"
- url="webservice://127.0.0.1:9000/cn.fansunion.webservice.service.front.RedmanService"/>
- </beans>
2.调用dubbo服务时,“事务”不再自己本地的控制范围内,因此,执行操作之后,数据无法回滚。
单元测试结束,数据库中多了“脏数据” ,需要手动清除。
因此,我觉得dubbo服务方,应该使用单元测试专门配置的库。
//设置自动回滚
3.有相关人士认为,dubbo的WebService没有提供服务,因为service经过测试了,dubbo就是简单的包装了下,只有1个是对的,其它的就没啥问题。
我本人认为这纯粹是“过于自信” 、“侥幸”的心理,单元测试本身的目的之一,就是让程序自动化地发现问题,至少要在预期之内。
当程序有所改动,重新执行一遍测试,就可能发现新的问题。
或者说,这是个概率问题。service层是对的,dubbo包装的WebService很可能不会有问题,但我认为它不可能做到“100%” 。
建言:多写点单元测试,真是提高开发质量的好方法。怎么测试自己写的代码,保障代码质量,有规律可循。
个人观察:人类世界,就没有几件事是一定会发生的。一定发生的事,通常带有附加条件。
一个电商项目的Web服务化改造6:单元测试4步走,构造数据、执行操作、断言、回滚的更多相关文章
- 一个电商项目的Web服务化改造
一个电商项目的Web服务化改造 项目,早期是随便瞎做的,没啥架构,连基本的设计也没. 有需求,实现需求,再反复修改. 大致就是这么做的. 最近,项目要重新架构,和某boss协商的结果是,采用阿里开源的 ...
- 一个电商项目的Web服务化改造3:改进方案の规范和约定、单表、单一职责
最近一直在做一个电商项目,需要把原有单系统架构的项目,改造成基于服务的架构,SOA. 有点挑战,做完了,会有很大进步. 上一篇,我们描述了原有项目中的问题. 或者说是,本篇的基本 ...
- 一个电商项目的Web服务化改造5:面向服务的分层架构设计(有图有真相)
最近一直在做一个电商项目,需要把原有单系统架构的项目,改造成基于服务的架构,SOA. 有点挑战,做完了,会有很大进步. 本篇,以我亲自画的3个图,阐述一下架构设计. 一.分层架构-总体图 ...
- 一个电商项目的Web服务化改造4:方案和架构,通用接口的定义和实现
最近一直在做一个电商项目,需要把原有单系统架构的项目,改造成基于服务的架构,SOA. 有点挑战,做完了,会有很大进步. 上一篇,我们明确了我们的"规范和约定". 从 ...
- 一个电商项目的Web服务化改造2:现有项目的5个问题
最近一直在做一个电商项目,需要把原有单系统架构的项目,改造成基于服务的架构,SOA. 有点挑战,做完了,会有很大进步, 1.现有项目的问题 1.1代码风格不统一 不同的 ...
- 一个电商项目的Web服务化改造7:Dubbo服务的调用,4个项目
使用dubbo服务的过程,很简单,和之前学习的WebService完全一样,和本地接口调用也基本一致. dubbo和WebService的区别:我认为dubbo就是封装了WebService,然后提供 ...
- 如何一步一步用DDD设计一个电商网站(六)—— 给购物车加点料,集成售价上下文
阅读目录 前言 如何在一个项目中实现多个上下文的业务 售价上下文与购买上下文的集成 结语 一.前言 前几篇已经实现了一个最简单的购买过程,这次开始往这个过程中增加一些东西.比如促销.会员价等,在我们的 ...
- 如何一步一步用DDD设计一个电商网站(十)—— 一个完整的购物车
阅读目录 前言 回顾 梳理 实现 结语 一.前言 之前的文章中已经涉及到了购买商品加入购物车,购物车内购物项的金额计算等功能.本篇准备把剩下的购物车的基本概念一次处理完. 二.回顾 在动手之前我对之 ...
- 如何一步一步用DDD设计一个电商网站(七)—— 实现售价上下文
阅读目录 前言 明确业务细节 建模 实现 结语 一.前言 上一篇我们已经确立的购买上下文和销售上下文的交互方式,传送门在此:http://www.cnblogs.com/Zachary-Fan/p/D ...
随机推荐
- HDU2564 词组缩写
2019-06-03 15:00:38 感觉有有种被坑了的感觉,这道题不难,就是一再的W,
- BZOJ 4310 二分+SA+RMQ
思路: 首先求出后缀数组和height数组,这样能得到本质不同的子串数目 这里利用:本质不同的子串=∑(Len−SA[i]−height[i])=∑(Len−SA[i]−height[i])利用SA[ ...
- 15年用canvas画的
请恕我当年的工作太轻松,用canvas手打了一个图,技术含量并没有什么,现在看看,甚是怀念_(¦3」∠)_ <!DOCTYPE html> <html> <head&g ...
- layer实现在前台删除前确认弹出框,并回调后台删除事件
最近遇到一些问题,用layer提示消息框,比如删除时,提示消息确定后 return false时,则不管用了,因为layer不支持阻塞,下面就解决一下这个问题:(本文使用Xcode,如要学习,请复下面 ...
- [ SCOI 2007 ] Perm
\(\\\) \(Description\) 给出只包括多个\(0\text~ 9\)的数字集,求有多少个本质不同的全排列,使得组成的数字能够整除\(M\). \(|S|\in [1,10]\),\( ...
- Less文件的建立
1.打开DreamWeaver 2.选择 新建 Less 文件名为.less,保存于Less文件夹中 3.声明文档头:@charset "utf-8"; 4.将Less ...
- Android 8.0 启动后台service 出错 IllegalStateException: Not allowed to start service Intent
错误原因: Android 8.0 不再允许后台service直接通过startService方式去启动, 具体行为变更如下: 如果针对 Android 8.0 的应用尝试在不允许其创建后台服务的情况 ...
- PHP中单例模式与工厂模式
单例模式概念 单例模式是指整个应用中类只有一个对象实例的设计模式. 单例模式的特点 一个类在整个应用中只有一个实例 类必须自行创建这个实例 必须自行向整个系统提供这个实例 php中使用单例模式的原因 ...
- 【MySQL】RPM包安装
操作系统:Red Hat Enterprise Linux Server release 6.5 Mysql安装包:MySQL-5.6.35-1.linux_glibc2.5.x86_64.rpm-b ...
- js获取某年某月一共多少天
const getDaysInMonth = (year, month) => { let date = new Date(year, month, 1); return new Date(da ...