[ 更换 ]
热门城市
北京上海广州深圳成都杭州南京武汉天津西安重庆青岛沈阳长沙大连厦门无锡福州济南宁波昆明苏州郑州长春合肥南昌哈尔滨常州烟台南宁温州石家庄太原珠海南通扬州贵阳东莞徐州大庆佛山威海洛阳淮安呼和浩特镇江潍坊桂林中山临沂咸阳包头嘉兴惠州泉州三亚赣州九江金华泰安榆林许昌新乡舟山慈溪南阳聊城海口东营淄博漳州保定沧州丹东宜兴绍兴唐山湖州揭阳江阴营口衡阳郴州鄂尔多斯泰州义乌汕头宜昌大同鞍山湘潭盐城马鞍山襄樊长治日照常熟安庆吉林乌鲁木齐兰州秦皇岛肇庆西宁介休滨州台州廊坊邢台株洲德阳绵阳双流平顶山龙岩银川芜湖晋江连云港张家港锦州岳阳长沙县济宁邯郸江门齐齐哈尔昆山柳州绍兴县运城齐河衢州太仓张家口湛江眉山常德盘锦枣庄资阳宜宾赤峰余姚清远蚌埠宁德德州宝鸡牡丹江阜阳莆田诸暨黄石吉安延安拉萨海宁通辽黄山长乐安阳增城桐乡上虞辽阳遵义韶关泸州南平滁州温岭南充景德镇抚顺乌海荆门阳江曲靖邵阳宿迁荆州焦作丹阳丽水延吉茂名梅州渭南葫芦岛娄底滕州上饶富阳内江三明淮南孝感溧阳乐山临汾攀枝花阳泉长葛汉中四平六盘水安顺新余晋城自贡三门峡本溪防城港铁岭随州广安广元天水遂宁萍乡西双版纳绥化鹤壁湘西松原阜新酒泉张家界黔西南保山昭通河池来宾玉溪梧州鹰潭钦州云浮佳木斯克拉玛依呼伦贝尔贺州通化朝阳百色毕节贵港丽江安康德宏朔州伊犁文山楚雄嘉峪关凉山雅安西藏四川广东河北山西辽宁黑龙江江苏浙江安徽福建江西山东河南湖北湖南海南贵州云南陕西甘肃青海台湾内蒙古广西宁夏香港澳门
培训资讯网 - 为兴趣爱好者提供专业的职业培训资讯知识

阿里是如何进行单元测试培训的?

培训 培训的 测试培训

一、什么是单元测试?(10 min)

阿里是如何进行单元测试培训的?

单元测试和集成测试的区别

回到测试的本质来看,测试工作就是模拟真实环境,在代码正式上线前进行验证的工作,即使没有任何工具和方法,这项工作也能够通过人工操作来手动完成。但这种方式显然不符合软件从业者的习惯,于是开始出现了各种各样的自动化测试方法,框架和工具。单元测试和集成测试使用的测试框架和工具大部分是相同的,而社区中对集成测试的介绍不尽相同,导致很多看过不同文章的同学对这两种测试的认知存在争议。

首先需要达成一致的是,无论是单元测试还是集成测试,它们都是自动化测试。为了更好地区分,我们可以这样理解:和生产代码以及单元测试代码在同一个代码仓库中,由开发同学自己编写的,对外部环境(数据库、文件系统、外部系统、消息队列等)有真实调用的测试就是集成测试。下表中也从各种角度来对比了单元测试、集成测试和系统级别测试(包括端到端测试、链路测试、自动化回归测试、UI测试等)的区别。

单元测试

集成测试

系统级别测试

编写人员

开发

开发

开发 / 测试

编写场地

生产代码仓库内

生产代码仓库内

生产代码仓库内 / 生产代码仓库外

编写时间

代码发布前

代码发布前

代码发布前 / 代码发布后

编写成本

编写难度

反馈速度

极快,秒级

较慢,分钟级

慢,天级别

覆盖面积

代码行覆盖60-80% 分支覆盖40-60%

功能级别覆盖HappyPath

核心保障链路

环境依赖

代码级别,不依赖环境

依赖日常或本地环境

依赖预发或生产环境

外部依赖模拟

全部模拟

部分模拟

不模拟,完全使用真实环境

小互动(10 min)

上手题 - 用于查看目前大家的单测理解和技能水平

以下是一个简单的服务代码,请认真观看后写下你认为应该写的单元测试。

@Service

public class UserService {

    /** 定义依赖对象 */

    /** 用户DAO */

    @Autowired

    private UserDAO userDAO;




    /**

     * 查询用户

     * 

     * @param companyId 公司标识

     * @param startIndex 开始序号

     * @param pageSize 分页大小

     * @return 用户分页数据

     */

    public PageDataVO<UserVO> queryUser(Long companyId, Long startIndex, Integer pageSize) {

        //入参校验

        if(ValidationUtil.validate(companyId)){

            throw new InvalidRequestException(companyId, "Invalid company Id");

        }

      

        // 查询用户数据

        // 查询用户数据: 总共数量

        Long totalSize = userDAO.countByCompany(companyId);

        // 查询接口数据: 数据列表

        List<UserVO> dataList = null;

        if (NumberHelper.isPositive(totalSize)) {

            dataList = userDAO.queryByCompany(companyId, startIndex, pageSize);

        }




        // 返回分页数据

        return new PageDataVO<>(totalSize, dataList);

    }

}

随机问题:

  1. 你觉得针对这段代码,应该需要写几个单元测试?
  2. 你觉得这个单元测试的行覆盖率理论值可以达到多少?我们一般需要达到多少?如果要达到你的目标,投入的工作量是多少?
  3. 单测的代码量和原业务代码量的比值应该是多少比较合适?

答案(仅供参考):

@RunWith(MockitoJUnitRunner.class)

public class UserServiceTest {

    /** 定义静态常量 */

    /** 资源路径 */

    private static final String RESOURCE_PATH = "testUserService/";




    /** 模拟依赖对象 */

    /** 用户DAO */

    @Mock

    private UserDAO userDAO;




    /** 定义测试对象 */

    /** 用户服务 */

    @InjectMocks

    private UserService userService;




    /**

     * 测试: 查询用户-无数据

     */

    @Test

    public void testQueryUser_Succeed_NoData() {

        // 模拟依赖方法

        // 模拟依赖方法: userDAO.countByCompany

        Long companyId = 123L;

        Long startIndex = 90L;

        Integer pageSize = 10;

        Mockito.doReturn(0L).when(userDAO).countByCompany(companyId);




        // 调用测试方法

        String path = RESOURCE_PATH + "testQueryUserWithoutData/";

        PageDataVO<UserVO> pageData = userService.queryUser(companyId, startIndex, pageSize);

        String text = ResourceHelper.getResourceAsString(getClass(), path + "pageData.json");

        Assert.assertEquals("分页数据不一致", text, JSON.toJSONString(pageData));




        // 验证依赖方法

        // 验证依赖方法: userDAO.countByCompany

        Mockito.verify(userDAO).countByCompany(companyId);




        // 验证依赖对象

        Mockito.verifyNoMoreInteractions(userDAO);

    }




    /**

     * 测试: 查询用户-有数据

     */

    @Test

    public void testQueryUser_Succeed_WithData() {

        // 模拟依赖方法

        String path = RESOURCE_PATH + "testQueryUserWithData/";

        // 模拟依赖方法: userDAO.countByCompany

        Long companyId = 123L;

        Mockito.doReturn(91L).when(userDAO).countByCompany(companyId);

        // 模拟依赖方法: userDAO.queryByCompany

        Long startIndex = 90L;

        Integer pageSize = 10;

        String text = ResourceHelper.getResourceAsString(getClass(), path + "dataList.json");

        List<UserVO> dataList = JSON.parseArray(text, UserVO.class);

        Mockito.doReturn(dataList).when(userDAO).queryByCompany(companyId, startIndex, pageSize);




        // 调用测试方法

        PageDataVO<UserVO> pageData = userService.queryUser(companyId, startIndex, pageSize);

        text = ResourceHelper.getResourceAsString(getClass(), path + "pageData.json");

        Assert.assertEquals("分页数据不一致", text, JSON.toJSONString(pageData));




        // 验证依赖方法

        // 验证依赖方法: userDAO.countByCompany

        Mockito.verify(userDAO).countByCompany(companyId);

        // 验证依赖方法: userDAO.queryByCompany

        Mockito.verify(userDAO).queryByCompany(companyId, startIndex, pageSize);




        // 验证依赖对象

        Mockito.verifyNoMoreInteractions(userDAO);

    }

  

    @Test

    public void testQueryUser_Fail_WithBadInput() {}




}抢答题:
  1. 请问这个是单元测试吗?
@RunWith(MockitoJUnitRunner.class)

public class SpringDalTest{

    @Resource

    DBClient dbClient;

  

    @Test

    public void testGetDate_success_getFromDB(){

      String result = dbClient.getDate("Request");

      Assert.equals(result,"ExpectedResults");

    }    

}
  1. 请问这个是单元测试吗?
@RunWith(MockitoJUnitRunner.class)

public class DemoControllerTest {

    @Mock

    DemoTairClient tairClient;

    @Mock

    DemoDBMapper dbMapper;

    @InjectMocks

    DemoController demoController;




    @Test

    public void testGetResult_succeed_getFromCache() throws Exception {

        when(tairClient.getCache(anyString())).thenReturn("getCacheResponse");

        when(dbMapper.queryData(anyString())).thenReturn("queryDataResponse");




        String result = demoController.getResult("request");

        Assert.assertEquals("getCacheResponse", result);

    }

}
  1. 请问这个是单元测试吗?
@RunWith(PandoraBootRunner.class)
@DelegateTo(SpringJUnit4ClassRunner.class)
@PropertySource(value = {"classpath:test.properties", "classpath:landlord.properties"})
@SpringBootTest(classes = Application.class)
public class SanityTest{
      @Resource
      InfoService infoService1;
  
      @Mock
      InfoService infoService2;
      
      public void testGetInfo_succeed_giveValidRequest(){
          String result1 = infoService1.getInfo("Request");
          String result2 = infoService2.getInfo("Request");
          Assert.equals(result1,result2);
      }
  
}

二、为什么要写单元测试?(10 min)

反例:现在,领导要响应集团提高代码质量的号召,需要提升单元测试的代码覆盖率。当然,我们不能让领导失望,那就加班加点地补充单元测试用例,努力提高单元测试的代码覆盖率。至于单元测试用例的有效性,我们大抵是不用关心的,因为我们只是面向指标编程。1230 提升到 LV3,331 提升团队成为卓越工程 LV4, FY23 KPI 完成了,岂不是___,___,____?

正例:因为我是一名专业的计算机工程师。

理论上单元测试带来的好处有:

  1. 单测成本低,速度快。
  2. 单测是最佳的、自动化的、可执行的文档。
  3. 测试的要诀是:测试你最担心出错的部分,这样你就能从测试工作中得到最大的利益,100%覆盖率的单测会逐渐消磨开发人员对测试的耐心和好感。
  4. 单测驱动设计,提升代码简洁度,确保安全重构,代码修改后,单测仍然能通过,能够增强开发者的信心。
  5. 快速反馈,更快的发现问题。
  6. 定位缺陷比集成测试更快更准确,降低修复成本。

实际上通过 2 个公司内部的例子来证明:

例子 1

菜鸟 GOC 提供的一个外部 BU 的例子,仅供参考(对照组数据不够严谨,数据还待完善,结论进一步佐证中)

外BU:采销供应链--网络&权限&商家&采购&物流协同(后面简称伍道团队)单测缩短了变更的开发和测试总时长

1、变更开发测试时长领先

从阿里大脑获取到 FY22 5月-10月采购供应链-伍道团队,和供应链BU变更开发测试时长对比趋势的客观数据,如下图所示。对比6个月平均数来看,伍道团队变更开发测试时长平均领先供应链BU 3.1天。

阿里是如何进行单元测试培训的?

2、交付质量高:变更折返修改代码再部署次数更低

采购供应链的有变更发布的全应用和BU内非采购供应链全应用,将变更平均从预发环境折返修改代码重部署次数做对比——5-10月份采购供应链“变更平均从预发环境折返修改代码重部署”次数为X次,同BU其他部门平均次数Y次,相比低40%。

阿里是如何进行单元测试培训的?

从Aone中应用,针对5-10月供应链BU在预发环境有发布成功的变更的核心应用,我们将非采购供应链所有核心应用49个(Aone未观察有UT覆盖率),和采购供应链主版本应用中,单测行覆盖率超60%的7个核心应用做参照对比。说明进行单测并没有使得变更的开发和测试时长变长,反而因为提升了代码内建质量,缩短了变更的开发和测试总时长。

阿里是如何进行单元测试培训的?

例子 2

菜鸟&企业智能:企业智能单测减少了变更从预发环境平均折返修改代码重部署次数

菜鸟整体(单测一般)、企业智能(单测好)、A&B团队(单测差),对比7-10月变更从预发环境平均折返修改代码重部署次数。—— 企业智能返工次数明显低于菜鸟整体,低于菜鸟整体35%,低于单测建设薄弱团队整体45%。

阿里是如何进行单元测试培训的?

阿里是如何进行单元测试培训的?

7-10月,企业智能5个BU核心应用平均全量行覆盖≥60% 以及 菜鸟其他团队 5个 无单测建设的BU核心应用对比变更从预发环境平均折返修改代码重部署次数。——变更平均从预发环境折返修改代码重部署次数为X,低于5个无单测应用对照组的Y,说明经过充分的单测的变更的内建质量更好,因而在预发环境折返修改代码重部署次数比对照组低52%

阿里是如何进行单元测试培训的?

三、怎么写单元测试?(50 min)

阿里是如何进行单元测试培训的?

上一篇:如何选择一家靠谱的自动化测试培训机构?#软件测试

下一篇:转行测试选择自学还是培训?看完这篇少走弯路

相关内容

怎么学?如何干?西藏7市(地)委书记在西藏日报发表文章

启航新征程 开创新局面为全面建设社会主义现代化新拉萨努力奋斗自治区党委常委、拉萨市委书记 普布顿珠党的二十大大笔擘画坚持以中国式现代化全面推进中华民族伟大复兴的宏伟蓝图,区党委十届三次全会全面铺开建设美丽幸福西藏、共圆伟大复兴梦想的壮阔实践···

2023年全区智慧旅游专业人才培训班圆满结业

6月2日,自治区旅游发展厅主办的全区智慧旅游专业人才培训班在拉萨圆满结业。培训共历时三天,累计完成全区旅游行政管理部门工作人员及涉旅企业专业技术人员培训100人。本次培训是区旅发厅深入推进学习贯彻习近平新时代中国特色社会主义思想主题教育重要···

徐汇萨迦共同举办大美西藏首届口腔学习班

随着现代医学的发展,口腔健康越来越受到人们的关注,为提高西藏地区口腔技术水平和服务质量,近日,徐汇区牙病防治所和萨迦县中心医院远程连线共同举办首届口腔学习班开班仪式。徐汇区卫生健康委副主任胡强,上海援藏干部、萨迦县委常务副书记、常务副县长沈···

自觉抵制“一对一”“一对多”等学科类培训!哈尔滨中小学生暑期预警来了

17日,记者从哈尔滨市各区教育局获悉,2023年暑假将至,南岗区、道里区、香坊区教育局向家长发出预警,自觉抵制违规培训,各区义务教育阶段学科类培训机构已经全部注销,暑假期间以任何形式开展的学科类培训均属于违规培训。家长要自觉抵制任何机构或个···

哈尔滨市道里区企投局举办“招商大讲堂”专题培训

黑龙江网讯(记者 王惠婷)10月24日,哈尔滨市道里区企投局组织开展“招商大讲堂”专题培训班,全区各招商专班负责同志及业务骨干参加培训。本次培训从实际需求出发,紧紧围绕当前招商工作中的热点、难点,对“什么是招商引资”“道里区的产业结构和主导···

团黑龙江省委举办全省青年文明号青年岗位能手学习宣传贯彻党的二十大精神培训交流会

中国青年报客户端讯(李海涛)为深入学习贯彻党的二十大精神,充分发挥青年文明号、青年岗位能手示范引领作用,在全省职业青年中掀起学习党的二十大精神热潮,11月22日,团黑龙江省委举办全省青年文明号青年岗位能手学习宣传贯彻党的二十大精神培训交流会···

辽宁葫芦岛举办外贸政策培训会推动外贸保稳增量

辽宁省葫芦岛市外贸政策培训会4月3日举办。 辽宁省贸促会供图中新网葫芦岛4月3日电 (李晛)辽宁省葫芦岛市外贸政策培训会4月3日举办。本次活动由辽宁省贸促会支持、葫芦岛市商务局主办,葫芦岛市贸促会、葫芦岛海关、中国出口信用保险辽宁分公司和辽···

山西运城:严查无证校外培训机构 查封9家警告2家

新华社太原8月5日电(记者王飞航)记者从山西省运城市政府了解到,运城市教育局近日联合市公安局等多家单位,对中心城区无证校外培训机构进行了一次突击检查,共检查了13家校外培训机构,查封9家,警告2家,发放整改通知书4份。今年7月,运城市教育局···

山西开展培训筑牢森林“防火墙”

山西新闻网3月30日讯(记者 卢奕如)今日,记者从山西省应急管理厅获悉,全省举办森林草原防灭火业务培训,邀请专家以视频会议形式,围绕森林扑火指挥实操、森林草原火灾防控经验做法、火灾现场各级各类指挥员具体操作中遇到的问题等内容进行授课。培训内···

校外培训机构治理工作取得进展 山西停办近1300所

资料图:小学生排队等待进入校园。中新社记者 刘文华 摄中新网5月11日电 据教育部网站消息,按照校外培训机构专项治理工作整体安排,教育部、民政部、国家市场监管总局启动了校外培训机构治理专项督查工作。5月9日至10日,督查组率先在北京市开展华···

山西综改区举办省技术创新中心申报培训

  8月18日,山西综改区科技金融部举办2023年度省技术创新中心申报培训会,来自区内企业、科研院所及有关单位代表160余人参加了培训。  山西省技术创新中心是以产业前沿引领技术和关键共性技术研发为核心的产业技术创新平台,承担着为区域和产业···

山西汾阳医院开展健康教育与控烟知识培训

来源:【吕梁日报-吕梁新闻网】本报讯 (记者 刘少伟) 5月18日,在“世界无烟日”到来之际,山西汾阳医院组织开展健康教育与控烟知识培训。近年来,山西汾阳医院全面落实健康中国战略,根据国家卫健委《关于2011年起全国医疗卫生系统全面禁烟的决···

山西省文物局年度田野考古技术培训班开班

10月10日,山西省文物局在运城闻喜上郭城址、邱家庄墓群举办2023年度田野考古技术培训班开班仪式。该次培训为期三个月,通过理论和实践两部分教学,旨在推进山西考古工作高质量发展,提升考古业务人员专业技术水平。本次培训由山西省考古研究院和山西···

最低每课时9元!全省学科类校外培训课时长和收费标准出台

近日,山西省发改委、省教育厅下发《关于中小学学科类校外培训收费标准及有关事项的通知》,明确全省中小学学科类校外培训收费标准,从12月17日起执行。《通知》对全省线上线下学科类校外培训基准收费标准和浮动幅度制定了科学标准。其中,义务教育阶段线···

山西天镇 阳光职业培训学校培养乡村“新农人”乡村振兴添动能

(记者 贺文生) 山西天镇县阳光职业培训学校紧紧围绕乡村振兴战略,按照“政府引导、农民自愿、立足产业、突出重点”的原则,创新高素质农民技能培训方式方法,采取以“授人以渔”的方式,让人才振兴成为助推农业农村现代化的内生动力,以高素质农民引领现···

山西:建立全过程 全链条 无缝隙安全培训制度

黄河新闻网讯(记者杨江涛)日前,山西省应急管理厅下发了《山西省安全培训管理暂行办法》(以下简称《办法》)。我省将进一步抓好安全生产这个基本盘、基本面,推动全省安全培训工作制度化、规范化、科学化,促进安全培训工作高质量发展。山西省应急管理厅厅···

山西:艺考培训机构纳入全国监管平台管理

央广网太原10月6日消息(记者郎麒) 日前,山西省教育厅、省发改委、省公安厅等部门联合制定《加强面向高中阶段学生艺考培训规范管理工作方案》,针对艺考培训的突出特点和实际情况,全面规范艺考培训行为,将艺考培训机构统一纳入全国校外教育培训监管与···

太平财险阳泉中支开展消防安全教育和有限空间作业培训

为强化员工安全意识,进一步提升员工消防和有限空间突发事件应急处理能力,9月14日,太平财险阳泉中支邀请北京市卫民安消防教育咨询中心山西分中心讲师向全体员工开展了一次消防安全教育和有限空间作业课程培训。按照防消结合、预防为主的原则,本次讲座通···

山西省数字化转型贯标试点工作宣贯培训会在太原举行

  10月20日消息,山西省数字化转型贯标试点工作宣贯培训会在太原举行。省工信厅介绍,作为国家数字化转型贯标试点省份,试点启动后将引导企业加快数字化转型,助力制造业高端化、智能化、绿色化发展。  今年,工信部启动数字化转型贯标试点工作,我省···

山西马兰花创业培训讲师大赛收官 太原市获多个奖项

山西新闻网8月31日讯(记者 冯耿姝)8月29日,山西省第四届马兰花创业培训讲师大赛圆满收官,太原市代表队在比赛中分获多个二、三等奖和优秀奖。本届大赛以“启迪创新思维·激发创业梦想”为主题,全省共有56名教师晋级复赛,其中,太原市有7名选手···